

.shop-main {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    margin: 0 auto;
    max-width: 1568px;
    overflow: hidden;
    width: 100%;
    color: #1d1d1f;
}

    .shop-main a {
        color: var(--ow-text-light-grey);
    }

/*        .shop-main a:hover {
            text-decoration: underline;
        }*/

/*@media screen and (min-width:1025px) {*/
@media screen and (min-width:768px) {
    .shop-main {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -ms-flex-direction: row;
        flex-direction: row
    }
}


.shop-main .map-with-panel__canvas {
    height: 205px;
    -webkit-box-ordinal-group: 0;
    -webkit-order: -1;
    -ms-flex-order: -1;
    order: -1;
    width: 100%
}

@media screen and (min-width:700px) and (max-width:1024px) {
    .shop-main .map-with-panel__canvas {
        height: 497px
    }
}

@media screen and (min-width:1025px) {
    .shop-main .map-with-panel__canvas {
        height: 100%;
        min-height: 644px;
        -webkit-box-ordinal-group: 2;
        -webkit-order: 1;
        -ms-flex-order: 1;
        order: 1
    }
}

.shop-main .map-with-panel {
/*    -webkit-box-shadow: 0 -5px 30px 0 rgba(0,0,0,.15);
    box-shadow: 0 -5px 30px 0 rgba(0,0,0,.15);*/
    z-index: 1
}

@media screen and (min-width:1025px) {
    .shop-main .map-with-panel {
        -webkit-box-shadow: none;
        box-shadow: none;
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 440px;
        -ms-flex: 1 0 440px;
        flex: 1 0 440px
    }
}

.shop-main .map-with-panel .single-store__heading-banner {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    background: var(--ow-bg-light-grey);
}

.shop-main .map-with-panel .single-store__heading-banner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    padding: 26px 10%;
}


/*@media (max-width: 767px) {
    .shop-main .map-with-panel .single-store__heading-banner {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
    }
}*/

.shop-main .map-with-panel .single-store__heading-banner h1 {
    -webkit-flex-shrink: 1;
    -ms-flex-negative: 1;
    flex-shrink: 1;
    margin: 0;
    padding: 0
}

    .shop-main .map-with-panel .single-store__heading-banner .view-all-stores {
        -webkit-flex-shrink: 0;
        -ms-flex-negative: 0;
        flex-shrink: 0;
        text-underline-offset: 5px;
    }

        .shop-main .map-with-panel .single-store__heading-banner .view-all-stores a {
            text-decoration-line: underline;
            text-underline-offset: 5px;
        }

@media screen and (min-width:1025px) {
    .shop-main .map-with-panel .single-store__heading-banner {
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }

        .shop-main .map-with-panel .single-store__heading-banner h1 {
            -webkit-flex-basis: 100%;
            -ms-flex-preferred-size: 100%;
            flex-basis: 100%
        }
}

.shop-main .single-store__store-location {
    padding-bottom: 20px;
    padding-left: 25px;
    padding-right: 25px;
    padding-top: 20px
}

@media screen and (min-width:700px) {
    .shop-main .single-store__store-location {
        padding: 40px
    }
}

.shop-main .single-store__info-space {
    margin-left: 35px
}

@media screen and (min-width:700px) and (max-width:1024px) {
/*    .shop-main .single-store__info {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex
    }*/

        .shop-main .single-store__info > div {
            -webkit-box-flex: 1;
            -webkit-flex: 1;
            -ms-flex: 1;
            flex: 1
        }

/*            .shop-main .single-store__info > div:first-of-type {
                margin-right: 20px
            }

            .shop-main .single-store__info > div:last-of-type {
                margin-left: 20px
            }*/

        .shop-main .single-store__info .hr {
            display: none
        }
}

.shop-main .single-store__info-address {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 18px;
    font-stretch: 100%;
    font-weight: 400;
/*    letter-spacing: .6px;*/
    line-height: 1.5384615385;
    text-transform: none
}

.shop-main .single-store__info-directions {
    padding-bottom: 20px
}

.shop-main .single-store__info-store-hours {
    padding-bottom: 30px
}

.shop-main .store-hour__list-container {
    margin-right: -10px;
    max-width: 300px;
    padding-left: 0px;
}

@media screen and (min-width:700px) and (max-width:1024px) {
    .shop-main .store-hour__list-container {
        margin-right: -25px
    }
}

.shop-main .store-hours__row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

    .shop-main .store-hours__row span:first-child:not(.store-hours__col--date) {
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -ms-flex: 1;
        flex: 1;
        padding-right: 10px
    }

    .shop-main .store-hours__row span:last-child {
        -webkit-box-flex: 1;
        -webkit-flex: 1 0 1px;
        -ms-flex: 1 0 1px;
        flex: 1 0 1px
    }

.shop-main .single-store__hours-disclaimer {
    padding-top: 20px
}


.shop-location-list a,
.shop-brand-list a {
    color: var(--ow-text-light-grey);
}

.shop-location-list p,
.shop-brand-list p {
    height: auto;
    margin-top: 0px;
    font-size: 1.3rem;
    text-transform: uppercase;
}

.shop-brand-list h2 {
    position: relative;
    text-align: center;
    font-size: 26px;
    color: var(--ow-text-light-grey);
    font-weight: 700;
    margin: 40px auto;
    max-width: 980px;
    text-align: left;
}


.shop-location-list h2 {
    position: relative;
    text-align: center;
    font-size: 26px;
    color: var(--ow-text-light-grey);
    font-weight: 700;
    margin: 40px 0;
/*    max-width: 980px;*/
    text-align: left;
}

    .shop-brand-list h2:lang(en),
    .shop-location-list h2:lang(en) {
        font-weight: 300;
    }

    .shop-location-list h2:after, .shop-brand-list h2:after {
        content: '';
        position: absolute;
        left: 0;
        bottom: -10px;
        width: 100%;
        height: 8px;
        /*    background: #f2f0ec;*/
        border-bottom: 1px solid #ccc;
    }



@media only screen and (max-width: 767px) {
    .map-with-panel, .mapFrameClass {
        width: 100%;
        float: left;
        display: block;
    }

    .shop-main {
        flex-direction: column-reverse
    }

    .mapFrameClass {
        height: 50vh;
    }
}




.infoWindow {
    max-width: 240px;
}

    .infoWindow img {
        display: block;
        width: 100%;
        height: auto;
        margin-bottom: 5px;
        aspect-ratio: 16 / 9;
        object-fit: cover;
    }

    .infoWindow h5 {
        margin: 10px 0;
        color: #fff;
        font-weight: 600;
    }


    .infoWindow a.button {
        display: inline-block;
        text-align: center;
        padding: 0.25em 0.75em;
        color: #c09434;
        font-size: 14px;
        font-weight: 600;
        background: transparent;
        border: 2px solid #c09434;
        transition: all 0.3s;
        cursor: pointer;
        width: fit-content;
    }

    .infoWindow a:hover {
        color: #f8bb4d;
    }

.store-card-content {
    border-bottom: 1px solid #dadada;
    cursor: pointer;
    padding: 28px;
    aspect-ratio: 16 / 7;
    display: flex;
    justify-content: center;
    flex-direction: column;
    transition: all .3s ease-out;
}

    .store-card-content:hover {
    background: var(--ow-bg-light-grey);
}

    .store-card-content h3 {
        font-size: 16px;
        font-weight: bold;
        margin-left: 25px;
        margin-bottom: 0;
    }

    .store-card-content h3:lang(en) {
        font-weight: 400;
    }



    .store-locator-all {
        display: flex;
        justify-content: center;
        align-items: center;
        color: #616161;
        text-decoration: underline;
        cursor: pointer;
        text-underline-offset: 5px;
    }


div.flat-page-list ul {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
    list-style: none;
}

    div.flat-page-list ul li {
        font-size: 1.5em;
        font-weight: 600;
        padding: 0;
/*        margin: 0 10px 0 0;*/
    }


        div.flat-page-list ul li a {
            color: var(--ow-text-light-grey);
            display: block;
            transition: all 0.3s;
            font-size: 18px;
            margin-bottom: 10px;
            cursor: pointer;
            padding: 0 15px;
            font-weight: 600;
            height: 32px;
            display: flex;
            justify-content: center;
            line-height: 32px;
            border-radius: 2px;
            transition: all 0.3s;
            margin: 2px;
        }
            div.flat-page-list ul li a.selected,
            div.flat-page-list ul li a:hover {
                background: #e6e6e6;
                color: var(--ow-text-light-grey);
            }

@media (max-width: 375px) {
    div.flat-page-list ul {
        display:block;
    }
}


    @media (max-width: 767px) {
        div.flat-page-list ul li {
            margin: 0;
        }

            div.flat-page-list ul li a {
                font-size: 17px;
            }
    }

    /*            remove close icon from the google map info window*/
    button.gm-ui-hover-effect {
        display: none !important;
    }

    .gm-style .gm-style-iw-c {
        background: #111;
        color: white;
        padding: 12px !important;
        max-height: 400px !important;
        width: 240px;
    }

    .gm-style .gm-style-iw-tc:after {
        background: #111;
        color: white;
    }

    .gm-style .gm-style-iw-d {
        overflow: hidden !important;
        max-height: 400px !important;
    }


        .gm-style .gm-style-iw-d p {
            margin: 18px 0;
        }


    .gm-style .gm-style-iw-tc {
        -webkit-filter: drop-shadow(0 4px 2px rgba(178,178,178,.4));
        filter: drop-shadow(0 4px 2px rgba(178,178,178,.4));
        height: 12px;
        left: 0;
        position: absolute;
        top: 0;
        -webkit-transform: translateX(-50%);
        -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        -o-transform: translateX(-50%);
        transform: translateX(-50%);
        width: 25px;
    }

.gm-style-iw-chr {
    display: none;
}

.tdt-infowindow-content,
#allmap .infoBox {
    background: #111;
    color: white;
    padding: 12px !important;
    width: 240px;
    border-radius: 8px;
}

.tdt-infowindow-content-wrapper {
    background: none !important;
    color: unset !important;
    box-shadow: none !important;
}

.tdt-infowindow-tip-container,
.tdt-infowindow-close-button {
    display: none;
}

.store-searchfield-input {
    margin-inline-start: -45px;
    margin-inline-end: -32px;
    padding-inline-start: 42px;
    padding-inline-end: 38px;
    font-size: 14px;
    font-weight: 600;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    background-color: white;
    border: none;
    border-radius: 0;
    outline: 0;
    border-radius: 8px;
    padding-top: 10px;
    padding-bottom: 10px;
}
