/*--------------------------------------------------------------
# Wrapper
--------------------------------------------------------------*/

.wrapper {
    background-size: cover;
    display: block;
    position: relative;
}

.wrapper:not(.static) {
    position: relative;
    z-index: 75;
}

.wrapper.overflow {
    overflow: hidden;
}


/*--------------------------------------------------------------
# Wrapper - size variations
--------------------------------------------------------------*/

.wrapper.medium {
    padding: 100px 0 100px;
}

.wrapper.medium.first {
    padding: 200px 0 100px;
}

body.sticky-header .wrapper.medium.first {
    padding-top: 75px;
}


/*--------------------------------------------------------------
# Wrapper - utility classes
--------------------------------------------------------------*/

.wrapper.no-top {
    padding-top: 0;
    margin-top: 0;
}

.wrapper.pulled-bottom {
    z-index: unset;
}

.wrapper.top {
    margin-top: 2rem;
}


/*--------------------------------------------------------------
# Wrapper - spacings
--------------------------------------------------------------*/

.wrapper.spacing-top {
    margin-top: 75px;
}

.wrapper.spacing-bottom {
    margin-bottom: 75px;
}

.wrapper.offset-bottom {
    margin-bottom: 150px;
}
.wrapper.under-header.spacing {
    padding: 5rem 0 2rem;
}

.wrapper.under-header:after {
    content: '';
}


/*--------------------------------------------------------------
# Wrapper - logo wrapper
--------------------------------------------------------------*/

.logo-wrap {
    display: block;
    position: relative;
}

.logo-wrap>.logo {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
}




/*--------------------------------------------------------------
# Wrapper - floating wrapper ( banner )
--------------------------------------------------------------*/

.wrapper .wrap-center.floating {
    position: absolute;
    top: 50%;
    transform: translateY(-30%);
}

/*--------------------------------------------------------------
# Wrapper - offers-wrapper ( home )
--------------------------------------------------------------*/

body.ready .wrapper.offers-wrapper .offers-card-background,
body.ready .wrapper.offers-wrapper .offers-card::before,
body.ready .wrapper.offers-wrapper .offers-card::after,
body.ready .wrapper.offers-wrapper .offers-card {
    transition: 0.25s;
}

.wrapper.offers-wrapper:before {
    content: '';
    display: block;
    position: absolute;
    background: var(--beige-sand);
    border-bottom-left-radius: var(--rounded);
    border-top-left-radius: var(--rounded);
    transform: translateY(-50%);
    top: 50%;
    height: 50%;
    width: 100vw;
    left: 15%;
}

.wrapper.offers-wrapper.has-gradient:before {
    background: linear-gradient(90deg, rgba(240,232,221,0) 0%, rgba(240,232,221,1) 100%);
    transform: none;
    top: auto;
    bottom: 95px;
    height: 75%;
}

.wrapper.offers-wrapper .offers-card {
    min-height: 30rem;
    display: flex;
    overflow: hidden;
    flex-direction: column;
    justify-content: end;
    background-color: var(--white);
    color: var(--white);
    text-align: center;
    position: relative;
    background-position: center center;
    padding: 15px 30px;
}

.wrapper.offers-wrapper .offers-card:before,
.wrapper.offers-wrapper .offers-card:after {
    content: '';
    display: block;
    position: absolute;
    inset: 0;
    z-index: 6;
}

.wrapper.offers-wrapper .offers-card.rounded:before,
.wrapper.offers-wrapper .offers-card.rounded:after {
    border-radius: var(--rounded);
}

.wrapper.offers-wrapper .offers-card:before {
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.5));
    z-index: 7;
}

.wrapper.offers-wrapper .offers-card-title h3 {
    font-weight: 600;
    margin-bottom: 15px;
    font-size: var(--font-size-title-h4);
}

.wrapper.offers-wrapper .offers-card-content {
    position: relative;
    line-height: 1.35em;
    font-weight: 500;
    z-index: 20;
    text-shadow: 0 0 5px rgba(0, 0, 0, 0.25);
    font-size: var(--font-size-theme);
    letter-spacing: var(--letter-spacing);
}

.wrapper.offers-wrapper .offers-card-background {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

@media all and (max-width: 991px) {

    .wrapper.offers-wrapper .offers-card {
        padding: 10px 20px;
    }

}

@media all and (max-width: 575px) {


    .wrapper.offers-wrapper .offers-card-content p,
    .wrapper.offers-wrapper .offers-card-title h3 {
        margin-bottom: 10px;
    }

}






/*--------------------------------------------------------------
# Wrapper - offers-wrapper ( home )
--------------------------------------------------------------*/


.wrapper.offers-wrapper .offers-card.shadow,
.wrapper.offers-wrapper .offers-card.shadow .offers-card-background {
    box-shadow: inset 0 0 10px 5px rgba(0, 0, 0, 0.05);
}

.wrapper.offers-wrapper.has-gradient .offers-card:after {
    background: linear-gradient(0deg, rgba(14, 60, 94, 1) 0%, rgba(14, 60, 94, 0) 100%);
    top: auto;
    height: 85%;
    opacity: 0.8;
    z-index: 2;
}
.wrapper.offers-wrapper.has-gradient .offers-card:before {
    opacity: 0.125;
}

.wrapper.offers-wrapper.has-gradient .offers-card.no-image:before {
    background: var(--beige);
}

.wrapper.offers-wrapper.has-gradient .offers-card.no-image:after {
    opacity: 0;
}




.wrapper.offers-wrapper .offers-card[data-hover-parent] {
    outline: 2px solid rgba(0,0,0,0);
}

.wrapper.offers-wrapper .offers-card[data-hover-parent]:hover {
    outline: 2px solid var(--theme-navy);
    outline-offset: 3px;
}

.wrapper.offers-wrapper .offers-card .offers-card-background {
    inset: -10px;
}

.wrapper.offers-wrapper.hover .offers-card:hover .offers-card-background {
    inset: 0;
}

.wrapper.offers-wrapper.hover .offers-card:not(:hover) .offers-card-background {
    filter: blur( 5px );
    opacity: 0.35;
}

.wrapper.offers-wrapper.hover .offers-card:not(:hover)::before {
    opacity: 0;
}

.wrapper.offers-wrapper.hover .offers-card:not(:hover)::after {
    opacity: 0.35;
}







/* GRID */


.wrapper.offers-wrapper.has-grid {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.wrapper.offers-wrapper.has-grid.max-width {
    width: 1100px;
}

.wrapper.offers-wrapper.has-grid .offers-card {
    min-height: 0;
    aspect-ratio: 1.5;
}


@media all and (min-width: 1200px) {

    .wrapper.offers-wrapper.has-grid > .row {
        margin: 100px -60px 0;
    }

    .wrapper.offers-wrapper.has-grid > .row > div {
        padding: 0 60px 40px;
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n) {
        padding-bottom: 80px;
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+1) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="0"] {
        transform: translateY( 0px ) translateX( 0px );
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+2) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="1"] {
        transform: translateY(-100px) translateX(-80px);
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+3) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="2"] {
        transform: translateY( 0px ) translateX( 80px );
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+4) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="3"] {
        transform: translateY( -100px ) translateX( 0px );
    }

}


@media all and (min-width: 992px) and (max-width: 1199px) {

    .wrapper.offers-wrapper.has-grid > .row {
        margin: 100px -40px 0;
    }

    .wrapper.offers-wrapper.has-grid > .row > div {
        padding: 0 40px 30px;
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n) {
        padding-bottom: 60px;
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+1) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="0"] {
        transform: translateY( 0px ) translateX( 0px );
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+2) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="1"] {
        transform: translateY(-80px) translateX(-50px);
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+3) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="2"] {
        transform: translateY( 0px ) translateX( 50px );
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+4) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="3"] {
        transform: translateY( -80px ) translateX( 0px );
    }

}


@media all and (min-width: 768px) and (max-width: 991px) {

    .wrapper.offers-wrapper.has-grid > .row {
        margin: 100px -30px 0;
    }

    .wrapper.offers-wrapper.has-grid > .row > div {
        padding: 0 30px 20px;
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n) {
        padding-bottom: 80px;
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+1) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="0"] {
        transform: translateY( 0px ) translateX( 0px );
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+2) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="1"] {
        transform: translateY(-50px) translateX(-40px);
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+3) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="2"] {
        transform: translateY( 0px ) translateX( 40px );
    }

    .wrapper.offers-wrapper.has-grid .row > div:nth-child(4n+4) .offers-card,
    .wrapper.offers-wrapper.has-grid .offers-card[data-index="3"] {
        transform: translateY( -50px ) translateX( 0px );
    }


}



.wrapper.offers-wrapper.has-grid .row > div:last-child {
    padding-bottom: 0 !important;
}



/*--------------------------------------------------------------
# Wrapper - background wrapper
--------------------------------------------------------------*/

.background-wrapper {
    display: block;
    overflow: hidden;
    min-height: 700px;
    z-index: 65;
}

.background-wrapper:not(.static) {
    z-index: 65 !important;
}

.background-wrapper:not(.overflow) {
    overflow: hidden;
}

.background-wrapper .background-video {
    display: block;
    position: absolute;
    overflow: hidden;
    top: 0; left: 0; right: 0; bottom: 0;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    z-index: 69;
}
.background-wrapper,
.background-wrapper .background-slider,
.background-wrapper .background-video {
    background-color: var(--theme-baltic-sea);
}
.background-wrapper .background-video.opacity .video-wrap {
    opacity: 0.35;
}
.background-wrapper .background-slider.opacity .slider {
    opacity: 0.35;
}
.background-wrapper .background-video.fixed {
    position: fixed;
}



.background-wrapper .background-article {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 80px;
}

.background-wrapper .background-article:not(.centered) {
    align-items: end;
}

@media all and (min-width: 992px) {

    .background-wrapper .background-article {
        padding-top: 130px;
    }

}

.background-wrapper .background-article > .wrapper {
    flex: 1 1;
}





/* Background wrapper - sizes */

.background-wrapper.fullscreen {
    height: 100vh;
}
.background-wrapper.min-fullscreen,
.background-wrapper.min-fullscreen .background-article {
    min-height: 100svh;
}





/* Background wrapper - dark overlay  */
.background-wrapper,
.background-wrapper:after {
    background-size: cover;
    background-position: center;
}

.background-wrapper:after {
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    z-index: 24;
    background-image: linear-gradient(to right, rgba(78, 67, 62, 0.5), rgba(0, 0, 0, 0.3));
}

.background-wrapper.has-gradient::after {
    opacity: 0.75;
}

.background-wrapper.has-gradient::before {
    content: ' ';
    position: absolute;
    inset: 0;
    right: auto;
    width: 100%;
    z-index: 72;
    opacity: 0.75;
    background: linear-gradient(rgba(78,67,62,1), rgba(23,40,52,0) 100%);
}



/* Background wrapper - article slogan */

.background-wrapper .article-wrap .article.slogan h1 {
    font-size: var(--title-banner);
    letter-spacing: var(--letter-spacing-sm);
    font-weight: 600;
    line-height: 1.1em;
}

.background-wrapper .article-wrap .article.slogan {
    font-weight: 500;
    font-size: var(--font-size-theme);
    letter-spacing: var(--letter-spacing);
    color: var(--white);
}

.background-wrapper .article-wrap .article.slogan h1,
.background-wrapper .article-wrap .article.slogan p {
    color: var(--white);
}

.background-wrapper .article-wrap .article.slogan .btn {
    font-size: 1rem;
}

.background-wrapper .article-wrap .article.slogan p em strong,
.background-wrapper .article-wrap .article.slogan p strong em {
    display: inline-block;
    color: currentColor;
    font-style: normal;
    font-weight: 600;
    line-height: 1.35em;
    font-size: var(--font-size-subtitle-h2);
    letter-spacing: var(--letter-spacing-title);
}





/* Background wrapper - expand wrapper */

.wrapper.background-wrapper>.wrapper.expand,
.wrapper.fullscreen.floating>.wrapper.expand {
    display: block;
    position: absolute;
    padding: 150px 0 50px;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 25;
}

.menu-wrapper .menu-wrap .container,
.video-wrap.fullscreen>.container,
.wrapper.background-wrapper>.wrapper.expand>.container-expand,
.wrapper.fullscreen.floating>.wrapper.expand>.container-expand {
    height: 100%;
}













/*--------------------------------------------------------------
# Wrapper - Images
--------------------------------------------------------------*/

.image-wrap {
    z-index: 24;
}

.image-wrap .image {
    width: 100%;
    height: 100%;
}

/* Combined styles */
.image-wrap,
.image-wrap .image {
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}


/*--------------------------------------------------------------
# Wrapper - Images size variations
--------------------------------------------------------------*/

.image-wrap.extra-small {
    height: 10rem;
}

.image-wrap.small {
    height: 20rem;
}

.image-wrap.medium {
    height: 35rem;
}
.image-wrap.large {
    height: 45rem;
}

.image-wrap.banner {
    min-height: 200px;
    max-width: 100%;
    aspect-ratio: 2;
}

.image-wrap.treatment-detail {
    min-height: 150px;
    max-width: 100%;
    aspect-ratio: 2;
}


/*--------------------------------------------------------------
# Wrapper - Images utility classes
--------------------------------------------------------------*/

.image-wrap.top {
    margin-top: 2rem;
}

.image-wrap.spacing-top {
    margin-top: 4rem;
}

.image-wrap.has-border,
.image.has-border {
    border: 1px solid var(--border-main);
}

.image-wrap.contain picture {
    background-size: contain;
}


/*--------------------------------------------------------------
# Wrapper - Our location
--------------------------------------------------------------*/


.wrapper.our-location .article-wrap {
    padding: 0 2rem;
}


/* Our location image wrap */
.wrapper.our-location .image-wrap {
    display: block;
}
.wrapper.our-location .image-wrap .image {
    height: 100%;
    width: 100%;
}


/*--------------------------------------------------------------
# Wrapper - treatment categories wrapper
--------------------------------------------------------------*/

.wrapper.treatment-categories-wrapper {
    display: inline-block;
}

.wrapper.treatment-categories-wrapper ul {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.wrapper.treatment-categories-wrapper ul li {
    transition: color 200ms, background 200ms;
}

.wrapper.treatment-categories-wrapper li.show-mobile {
    margin: 0 auto;
}

.wrapper.treatment-categories-wrapper li select {
    border: 1px solid var(--beige);
    padding: 10px 15px 8px;
    min-width: 12rem;
    text-align: left;
    -webkit-appearance: none;
    background-image: url('/images/chevron-down.png');
    background-repeat: no-repeat;
    background-position: right 15px center;
    background-size: 14px;
    color: var(--beige);
}

.wrapper.treatment-categories-wrapper li select {

}


/* Active treatment category button */
.wrapper.treatment-categories-wrapper li.active {
    background: var(--beige);
    color: var(--white);
}


/*--------------------------------------------------------------
# Wrapper - overview wrapper
--------------------------------------------------------------*/

.wrapper.overview-wrapper .row {
    row-gap: 30px;
}


/*--------------------------------------------------------------
# Wrapper - treatment detail cards wrapper
--------------------------------------------------------------*/

.page-cards-wrapper-outer {
    position: sticky;
    /*top: 13.5rem;*/
    /*top: 160px;*/
    top: calc( 130px + 30px );
}

body.has-actionbar .page-cards-wrapper-outer {
    top: calc( 130px + 30px + 50px );
}



/* Treatments card wrapper outer - quick menu  */

.page-cards-wrapper-outer .article h3 {
    font-size: 1.35rem;
    font-weight: 500;
    margin-bottom: 10px;
}

.page-cards-wrapper-outer .card-block p {
    margin-bottom: 10px;
}





/*margin: 10px 0;*/

.page-cards-wrapper-outer {
    font-size: var(--font-size-theme);
    letter-spacing: var(--letter-spacing);
}

.page-cards-wrapper-outer .menu li a {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    line-height: 1.25em;
    color: var(--text-brown-dark);
    /*font-size: var(--font-size-theme);*/
}

.page-cards-wrapper-outer .menu li a:hover {
    text-shadow: 0 0 0 var(--text-brown-dark);
    /*text-decoration: underline;*/
}

.page-cards-wrapper-outer .menu li a svg {
    width: 0.75rem;
    height: 0.75rem;
    margin-top: -2px;
}






/*--------------------------------------------------------------
# Wrapper - under header
--------------------------------------------------------------*/

.wrapper.under-header {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 140px;
    color: var(--beige);
    padding: 2rem 0;
}

.wrapper.under-header h1 {
    margin-bottom: 0;
}
.wrapper.under-header.title-gap h1 {
    margin-bottom: 0.5rem;
}

body.sticky-header .wrapper.under-header {
    padding: 50px 0 100px;
    margin-top: 0;
}




/*--------------------------------------------------------------
# Wrapper - treatments detail banner
--------------------------------------------------------------*/

/* Back to treatment overview link */
.wrapper.treatment-detail-banner .back-to-treatments-link {
    position: relative;
    letter-spacing: var(--letter-spacing);
    z-index: 35;
}

.wrapper.treatment-detail-banner .back-to-treatments-link svg {
    width: 1.25rem;
    height: 1.25rem;
    top: 4px;
    position: relative;
    margin-right: 10px;
}


/*--------------------------------------------------------------
# Wrapper - locations card wrapper (waiting times page)
--------------------------------------------------------------*/

.locations-cards-wrap {
    margin-top: 1.5rem;
}


/*--------------------------------------------------------------
# Wrapper - map (contact)
--------------------------------------------------------------*/

.maps-wrapper,
.maps-wrapper.contact {
    min-height: 450px;
}

.maps-wrapper.contact {
    height: 35vw;
    z-index: 74;
}

@media all and (min-width: 992px) {

    .maps-wrapper.contact {
        min-height: 800px;
    }
}


.maps-wrap {
    display: block;
    position: relative;
    overflow: hidden;
    height: 100%;
}

.maps-wrap>.maps,
.maps-wrap>.maps>iframe {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 25;
    outline: none;
    border: none;
    width: 100%;
    height: 100%;
}


/*--------------------------------------------------------------
# Wrapper - banner detail page
--------------------------------------------------------------*/

.wrapper.banner {
    padding-top: 135px;
}


/*--------------------------------------------------------------
# Wrapper - home cta image
--------------------------------------------------------------*/

/*.page-home .image-wrap.large {*/
/*    width: 95%;*/
/*    border-top-right-radius: var(--rounded);*/
/*    border-bottom-right-radius: var(--rounded);*/
/*}*/


/*--------------------------------------------------------------
# Wrapper - btn switch wrapper (make appointment)
--------------------------------------------------------------*/

.wrapper .btn-switch-wrapper {
    border: 1px solid rgba(158, 136, 125, 0.2);
    display: flex;
    gap: 1rem;
    padding: 5px;
    position: absolute;
    bottom: 0;
}
/*.wrapper .btn-switch-wrapper .btn:focus:before {*/
/*    width: 100%;*/
/*    height: 100%;*/
/*}*/
.wrapper .btn-switch-wrapper .btn:hover span {
    color: var(--white);
}
.wrapper .btn-switch-wrapper .btn:not(.active, :hover):before {
    background: transparent;
}
.wrapper .btn-switch-wrapper .btn:not(.active) {
    color: var(--text-brown-dark);
}


/*--------------------------------------------------------------
# Wrapper - reviews filters wrapper
--------------------------------------------------------------*/

.reviews-filter-wrapper:not(.no-margin) {
    margin: 2rem;
}
.reviews-filter-wrapper .form-wrap .fields {
    display: flex;
}
.reviews-filter-wrapper .form-wrap .fields .field:nth-child(odd) {
    padding-right: 0;
}

.reviews-filter-wrapper .form-wrap .fields .field.select {
    width: 100%;
}


/*--------------------------------------------------------------
# Media querys
--------------------------------------------------------------*/

@media all and (max-width: 1200px) {

    /* Wrapper - our location (home)  */
    .wrapper.our-location .article-wrap {
        padding: 0 2rem;
    }


    .wrapper.under-header.spacing {
        padding-left: 0;
        padding-right: 0;
        padding-top: 0;
    }



    /* Wrapper - contact page map */
    .maps-wrapper,
    .maps-wrapper.contact {
        height: 65vh;
    }

}

@media all and (max-width: 992px) {



    /* Wrapper - offers wrapper card  */

    .wrapper.offers-wrapper.has-grid .offers-card {
        aspect-ratio: 1.5;
    }
    .wrapper.offers-wrapper:not(.has-grid) .offers-card {
        margin-bottom: 15px;
    }



    /* Wrapper floating (banner) */
    .wrapper .wrap-center.floating {
        left: 30px;
        right: 30px;
    }



    /* Wrapper - utility classes  */
    .wrapper.spacing-top {
        margin-top: 35px;
    }


    /* Wrapper - treatment wrapper */
    .wrapper.home-treatments-wrapper .row,
    .wrapper.related-treatments-wrapper .row {
        row-gap: 30px;
    }



    /* Image wrap - utility classes  */
    .image-wrap.top-medium {
        margin-top: 3rem;
    }



    /* First wrapper ( top of page ) */
    .wrapper.medium.first {
        padding: 150px 0 100px;
    }

    body.sticky-header .wrapper.medium.first {
        padding-top: 50px;
    }



    /* Wrapper - overview */
    .wrapper.overview-wrapper .row {
        row-gap: 1rem;
    }



    /* Wrapper - treatment categories  */
    .wrapper.treatment-categories-wrapper {
        display: block;
    }

    .wrapper.treatment-categories-wrapper li.show-desktop {
        display: none;
    }



    /*  Wrapper - treatment detail cards */
    .treatments-cards-wrapper-outer {
        margin: 2rem 0;
    }

    .treatments-cards-wrapper-outer .card.quick-links {
        display: none;
    }



    /* Wrapper - treatment download file */
    .treatment-download-file-wrap {
        width: 50%;
    }



    /*  Wrapper - page cards wrapper */
    .page-cards-wrapper-outer {
        margin-top: 2rem;
    }

    .page-cards-wrapper-outer .card.quick-links {
        display: none;
    }


    /* Wrapper - banner detail  */
    .wrapper.banner-detail {
        margin-top: 0;
        padding-top: 150px;
    }


    /* Specialist detail - image */
    .wrapper.wrapper.specialist-detail .image-wrap {
        height: 25rem;
        width: 25rem;
        margin: 1.5rem auto;
    }



    /* Wrapper - btn switch wrapper */
    .wrapper .btn-switch-wrapper {
        margin-bottom: 2rem;
        position: relative;
        display: flex;
    }



    /* Page Home - image wrap */
    .page-home .image-wrap.large {
        width: 100%;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }



    /* Wrapper - under header */
    .wrapper.under-header {
        margin-top: 80px;
    }
    body.sticky-header .wrapper.under-header {
        margin-top: 0;
    }


}

@media all and (max-width: 768px) {

    .wrapper.our-location .container {
        padding: 0;
    }





    /* Wrapper - offers wrapper card  */
    .wrapper.offers-wrapper.has-grid .offers-card {
        margin-bottom: 15px;
    }
    .wrapper.offers-wrapper.has-grid .offers-card {
        min-height: 165px;
        width: calc( 100% - 10% );
        padding: 10px 20px;
    }
    .wrapper.offers-wrapper.has-grid .offers-card.odd {
        margin-left: auto;
        margin-right: 5px;
    }
    .wrapper.offers-wrapper.has-grid .offers-card.even {
        margin-right: auto;
        margin-left: 5px;
    }




    /* Wrapper -  treatments wrapper */
    .wrapper.home-treatments-wrapper .row,
    .wrapper.related-treatments-wrapper .row {
        row-gap: 0.75rem;
    }


    /* Wrapper - treatment detail banner  */
    .wrapper.treatment-detail-banner h1 {
        font-size: 2rem;
    }


    /* Page Home - image wrap */
    .image-wrap.large {
        height: 30rem;
    }


}

@media all and (max-width: 575px) {




    /*  Wrapper medium  */
    .wrapper.medium {
        padding: 50px 0;
    }


    /* Wrapper floating (banner) */
    .wrapper .wrap-center.floating {
        left: 20px;
        right: 20px;
    }


    /* Banner article */
    .article-wrap.banner {
        width: auto;
    }


    /* Image wrapper - utility classes */
    .image-wrap.top {
        margin-top: 2rem;
    }

    .image-wrap.bottom {
        margin-bottom: 5rem;
    }



    /* Wrapper - our location (home)  */
    .wrapper.our-location .article {
        color: var(--black);
    }

    .wrapper.our-location .article-wrap {
        padding: 0 15px;
    }



    /* Wrapper - spacings  */
    .wrapper.offset-bottom {
        margin-bottom: 100px;
    }


    /* Wrapper - treatment detail banner  */
    .wrapper.treatment-detail-banner h1 {
        font-size: 1.95rem;
    }



    /* Wrapper - treatment download file */
    .treatment-download-file-wrap {
        width: auto;
    }



    /* Wrapper - contact page map */
    .maps-wrapper,
    .maps-wrapper.contact {
        height: 50vh;
    }



    /* Wrapper - our location images (homepage) */
    .wrapper.our-location .image-wrap .image {
        border-radius: 0;
    }



    /* Specialist detail - image */
    .wrapper.wrapper.specialist-detail .image-wrap {
        height: 17rem;
        width: 17rem;
    }

    .wrapper.banner-detail {
        padding-top: 50px;
    }



    /* Wrapper - btn switch wrapper */
    .wrapper .btn-switch-wrapper {
        position: relative;
        border: 0;
        display: flex;
        flex-direction: column;
    }


}


@media all and (min-width: 400px) {




    /* Wrapper - offers wrapper card  */
    .wrapper.offers-wrapper.has-grid .offers-card {
        width: calc( 100% - 20px );
    }



}







.specialists-wrap {
    display: block;
    position: relative;
    color: #fff;
    background-color: var(--theme-navy);
    border-radius: var(--rounded-md);
    overflow: hidden;
    padding: 50px;
}

@media all and (min-width: 992px) {

    .specialists-wrap:not(.no-min-height) .specialists-article .article-wrap {
        min-height: 400px;
    }

}

@media all and (max-width: 991px) {

    .specialists-wrap:not(.no-min-height) {
        min-height: 400px;
    }

}

.specialists-wrap .specialists-flex {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

@media all and (min-width: 1200px) {

    .specialists-wrap .specialists-article .article-wrap {
        padding-left: 30px;
    }

}

.specialists-wrapper .container {
    position: relative;
    z-index: 36;
}

.specialists-wrapper .specialists-background {
    position: relative;
    z-index: 25;
    overflow: hidden;
    border-radius: var(--rounded-md);
    width: calc( 100vw - (( 100vw - var(--container-size) ) * 0.25 ));
    margin: 0 auto -250px 0;
    aspect-ratio: 2;
}

.specialists-wrapper .specialists-background picture {
    height: 100%;
}

.specialists-wrapper .specialists-background:after {
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    z-index: 24;
    background-image: linear-gradient(to right, rgba(14, 59, 94, 0.5), rgba(0, 0, 0, 0.3));
}

.specialists-wrapper .specialists-background.has-gradient::after {
    opacity: 0.35;
}

.specialists-wrapper .specialists-background.has-gradient::before {
    content: ' ';
    position: absolute;
    inset: 0;
    right: auto;
    width: 100%;
    z-index: 72;
    opacity: 0.75;
    /*background: linear-gradient(90deg, rgba(14,60,94,1) 0%, rgba(14,60,94,0) 100%);*/
    background: linear-gradient(90deg, rgba(23,40,52,1) 0%, rgba(23,40,52,0) 100%);
}

@media all and (min-width: 1200px) {

    .specialists-wrapper .specialists-background.has-gradient::before {
        width: 75%;
    }

}

@media all and (max-width: 991px) {

    .specialists-wrapper .specialists-background {
        display: none;
    }

    .specialists-wrap {
        padding: 30px;
    }

    .specialists-wrap .specialists-article {
        margin-bottom: 30px;
    }



}



@media all and (max-width: 575px) {


    .specialists-slider:not(.is-full) .slider-wrap {
        width: auto;
    }

    .specialists-slider:not(.is-full) .card.specialist-card .image-wrap {
        max-width: calc( 100% - 20px );
        aspect-ratio: 1;
        height: auto;
    }

    .specialists-slider:not(.is-full) .slider-wrap .slider .slick-arrow {
        transform: none !important;
        top: auto !important;
        bottom: 0 !important;
    }

    .specialists-slider:not(.is-full) .slider-wrap .slider .slick-prev {
        left: -5px !important;
    }

    .specialists-slider:not(.is-full) .slider-wrap .slider .slick-next {
        right: -5px !important;
    }



}


