/*--------------------------------------------------------------
# Card
--------------------------------------------------------------*/

.card {
    padding: 1.35rem;
    transition: transform 200ms, background 200ms, color 200ms;
}
.card.zero {
    padding: 0 !important;
}


/*--------------------------------------------------------------
# Card - size variations
--------------------------------------------------------------*/

.card-sm {
    padding: 1rem;
}


/*--------------------------------------------------------------
# Card - utility classes
--------------------------------------------------------------*/

.card.pulled-top {
    margin-top: -20rem;
    z-index: 25;
}
.card.pulled-bottom {
    margin-bottom: -10rem;
    z-index: 76;
    position: relative;
}

.pulled-bottom-extra,
.card.pulled-bottom-extra {
    margin-bottom: -12.5rem;
}

.card.full-height {
    height: 100%;
}

.card.top {
    margin-top: 4rem;
}

.card.visible {
   transform: scale(1);
}
.card.hidden {
    transform: scale(0);
}


/*--------------------------------------------------------------
# Card - spacings
--------------------------------------------------------------*/

.card.spacing-inner {
    padding: 3rem;
}

.card.spacing-inner-sm {
    /*padding: 2.25rem 2rem;*/
    padding: 30px;
}

.card.bottom {
    margin-bottom: 2rem;
}

.card.bottom-sm {
    margin-bottom: 1rem;
}


/*--------------------------------------------------------------
# Card - background variations
--------------------------------------------------------------*/

.card.bg-white {
    background: var(--white);
}

.card.bg-grey {
    background: var(--grey-bg);
}

.card.bg-light {
    background: var(--grey-light);
}

.card.bg-white .card-icon.bg-blue-light svg path {
    fill: var(--text-blue);
}

.card.bg-brown {
    background: var(--brown);
    color: var(--white);
}

.card.bg-blue {
    background: var(--blue);
}
.card.bg-blue h2 {
    color: var(--text-blue);
}

.card.bg-beige-sand {
    background: var(--beige-sand);
}

.card.bg-orange {
    background: var(--orange);
    color: #fff;
}






/*--------------------------------------------------------------
# Card - hover variations
--------------------------------------------------------------*/

.card.bg-white.hover:hover {
    transform: translateY(-8px);
    background: var(--text-blue);
    color: var(--white);
}


.card.bg-white.hover:hover .card-title h2,
.card.bg-white.hover:hover .card-title h3,
.card.bg-white.hover:hover .card-read-more-link,
.card.bg-white.hover:hover .card-read-more-link svg {
    color: var(--white);
    fill: var(--white);
}

.card.bg-white.hover:hover .card-read-more-link svg {
    transform: rotate(-45deg);
}


/*--------------------------------------------------------------
# Card - colour variations
--------------------------------------------------------------*/

.card.text-brown {
    color: var(--beige);
}


/*--------------------------------------------------------------
# Card - variations
--------------------------------------------------------------*/

.card.shadow {
    box-shadow: 0 0 15px 3px rgba(0, 0, 0, 0.05);
}

.card.shadow-inset {
    box-shadow: inset 0 0 15px 3px rgba(0, 0, 0, 0.05);
}






/*--------------------------------------------------------------
# Card - content
--------------------------------------------------------------*/

.card-content {
    position: relative;
    height: 100%;
}


/*--------------------------------------------------------------
# Card - titles
--------------------------------------------------------------*/

.card-title .title,
.card-title h2,
.card-title h3,
.card-title h4 {
    color: var(--text-brown-dark);
    margin: 1.25rem 0;
    font-weight: 600;
    letter-spacing: var(--letter-spacing);
    transition: color 200ms;
    line-height: 1.5rem;
}

.card-title .title,
.card-title h2 {
    /*font-size: 1.25rem;*/
    font-size: var(--font-size-title-h4);
}

.card.title-medium h2 {
    font-weight: 400;
}



/*--------------------------------------------------------------
# Card - description
--------------------------------------------------------------*/

.card-description {
    font-size: var(--font-size-theme);
    letter-spacing: var(--letter-spacing);
    padding-bottom: 1.5rem;
}

.card-description .article:not(.no-bottom) {
    margin-bottom: 1rem;
}


/*--------------------------------------------------------------
# Card - icon
--------------------------------------------------------------*/

.card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.65rem;
}


/*--------------------------------------------------------------
# Card - (creation) date
--------------------------------------------------------------*/

.card-date {
    font-size: var(--font-size-sm);
}


/*--------------------------------------------------------------
# Card - icon size variations
--------------------------------------------------------------*/

.card-icon svg {
    width: 100%;
    height: 100%;
}

.card-icon.normal {
    width: 3rem;
    height: 3rem;
}

.card-icon.sm {
    width: 1rem;
    height: 1rem;
}

.card-icon.xl {
    width: 5rem;
    height: 5rem;
}


/* Card icon incline (card title besides icon) */
.card-icon.inline.normal {
    width: 100%;
    justify-content: start;
    padding: 0;
}

.card-icon.inline.normal svg {
    width: 1.5rem;
    height: 1.5rem;
    margin-right: 1rem;
    margin-top: -15px;
}


/*--------------------------------------------------------------
# Card - image
--------------------------------------------------------------*/

.card-image picture {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-repeat: no-repeat;
}

.card-image {
    padding: -10px;
}


/*--------------------------------------------------------------
# Card - image size variations
--------------------------------------------------------------*/

.card-image.regular {
    width: 100%;
    height: 13rem;
}


/*--------------------------------------------------------------
# Card - block (grouping)
--------------------------------------------------------------*/

.card-block.bottom-sm {
    margin-bottom: 1.5rem;
}


/*--------------------------------------------------------------
# Card - read more link
--------------------------------------------------------------*/

.card-read-more-link {
    color: var(--grey-2);
    font-size: var(--font-size-xsl);
    font-weight: 400;
    display: block;
    text-align: right;
    letter-spacing: var(--letter-spacing);
}

.card-read-more-link svg {
    width: 1rem;
    height: 1rem;
    vertical-align: middle;
    margin-left: 0.5rem;
    color: var(--text-brown-dark);
    transition: 300ms;
}


/* Place the link at the bottom at full height cards */
.card.full-height .card-read-more-link {
    position: absolute;
    bottom: 0;
    right: 0;
}


/*--------------------------------------------------------------
# Card - actions wrapper
--------------------------------------------------------------*/

.card-actions-wrapper.spacing-top {
    margin-top: 2.5rem;
}

.card-actions-wrapper.center {
    text-align: center;
}


/*--------------------------------------------------------------
# Card - cta/contact card (detailpages)
--------------------------------------------------------------*/

.card.cta-card .link-phone {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 0.85rem;
}

.card.cta-card .link-phone svg {
    width: 1rem;
    height: 1rem;
    color: var(--beige);
    margin-top: -3px;
}

.card.cta-card .link-phone span {
    color: var(--beige);
    font-weight: 600;
}

.card.cta-card .link-phone.text-brown span {
    color: var(--text-brown-dark);
}




/*--------------------------------------------------------------
# Card - contact page
--------------------------------------------------------------*/

.card.contact-card {
    position: relative;
}

/*.card.contact-card.top {*/
/*    top: 5rem;*/
/*}*/

/*.card.contact-card .article h3 {*/
/*    font-size: 1.7rem;*/
/*    font-weight: 500;*/
/*    margin-bottom: 0;*/
/*}*/

/*.card.contact-card .article p {*/
/*    color: var(--text-brown-dark);*/
/*    font-weight: 400;*/
/*}*/


/*--------------------------------------------------------------
# Card - related doctors card
--------------------------------------------------------------*/

.card.related-doctors-card {
    padding: 3rem;
}

.card.related-doctors-card .article h3 {
    margin-bottom: 0.5rem;
}


/*--------------------------------------------------------------
# Card - doctors card (home)
--------------------------------------------------------------*/

.card.doctors-card .article h3 {
    color: var(--text-blue);
}


/*--------------------------------------------------------------
# Card - affairs card
--------------------------------------------------------------*/


/* Affair card - image */
.card.affair-card .card-image {
    padding: 0.85rem;
}

/* Affair card - content */
.card.affair-card .card-content {
    height: auto;
    padding: 0 1.65rem 1.35rem 1.65rem;
}

.card.affair-card .card-content .card-title h2 {
    margin-top: 0.5rem;
}

.card.affair-card .card-description {
    padding-bottom: 0;
}

.card.affair-card .card-read-more-link {
    position: relative;
}


/*--------------------------------------------------------------
# Card - no spacing card
--------------------------------------------------------------*/

.card.no-spacing {
    padding: 0;
}
.card.no-spacing .card-image {
    padding: 0.85rem;
}
.card.no-spacing .card-image picture {
    border: 1px solid var(--border-main);
}

.card.no-spacing .card-content {
    height: auto;
    padding: 0 1.65rem 1.35rem 1.65rem;
}

.card.no-spacing .card-content .card-title h2 {
    margin-top: 0.5rem;
}

.card.no-spacing .card-read-more-link {
    position: relative;
}


/*--------------------------------------------------------------
# Card - location card
--------------------------------------------------------------*/

.card.location-card h3 {
    font-size: 1rem;
    margin-bottom: 0;
}

.card.location-card br {
    display: none;
}

.card.location-card p {
    margin-bottom: 0;
    font-weight: 500;
    letter-spacing: var(--letter-spacing);
}

.card.location-card p em {
    font-style: normal;
    font-size: 1.4rem;
    margin-top: 10px;
    display: block;
}


/*--------------------------------------------------------------
# Card - our location card (part)
--------------------------------------------------------------*/

.card.our-location-card {
    top: -10rem;
    margin-bottom: -10rem;
    position: relative;
}

.card.our-location-card h3,
.card.our-location-card h4 {
    color: var(--text-brown-dark);
}

.card.our-location-card .location-block h4 {
    font-size: 1.1rem;
}

.card.our-location-card .location-block p {
    margin-bottom: 0;
    color: var(--text-brown-dark);
}

.card.our-location-card .image-wrap {
    margin-top: -2.35rem;
    margin-right: -3.75rem;
}

.card.our-location-card .slider-wrap {
    margin-bottom: 50px;
}




/*--------------------------------------------------------------
# Card - specialist car
--------------------------------------------------------------*/

.card.specialist-card {
    text-align: center;
}

.card.specialist-card .image-wrap {
    top: 1rem;
    height: 12rem;
}

.card.specialist-card .image-wrap,
.card.specialist-card .image-size {
    position: relative;
    width: 12rem;
    margin: 0 auto;
}

.card.specialist-card .image-wrap picture {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    border-radius: 999px;
    z-index: 5;
}
.card.specialist-card .image-wrap:before,
.card.specialist-card .image-wrap:after {
    content: '';
    display: block;
    position: absolute;
    inset: 0;
    z-index: 10;
    border: 1px solid var(--grey-border);
    border-radius: 999px;
}
.card.specialist-card .image-wrap:after {
    inset: -10px;
    background-color: white;
    z-index: 1;
}

.card.specialist-card .card-title {
    margin: 3rem 0;
}
.card.specialist-card h2 {
    margin: 0;
}

.card.specialist-card .subtitle,
.card.specialist-card h3 {
    font-weight: 300;
    font-size: 1rem;
    margin: 0.5rem;
}




/*--------------------------------------------------------------
# Card - review card (specialist detail)
--------------------------------------------------------------*/

.card.specialist-review-card span {
    font-size: 2.5rem;
    letter-spacing: var(--letter-spacing-md);
    font-weight: 600;
}

.card.review-card {
    position: relative;
}
.card.review-card .rating {
    background: var(--text-blue);
    position: absolute;
    top: 1rem;
    right: 1rem;
    padding: 0.35rem 1.5rem;
    color: var(--white);
    border-radius: var(--rounded-xs);
    font-size: 1.15rem;
    font-weight: 400;
}


/*--------------------------------------------------------------
# Card - write review card
--------------------------------------------------------------*/

.card.write-review-card .article-wrap.review-card {
    padding: 1rem 3rem;
}


/*--------------------------------------------------------------
# Card - specializations card (specialist detail)
--------------------------------------------------------------*/

.card.specializations-card .article a,
.card.specializations-card .article span {
    color: var(--black);
}

.card.specializations-card .btn:not(:last-child) {
    margin-bottom: 1.25rem;
}


/*--------------------------------------------------------------
# Card - faq card
--------------------------------------------------------------*/

body.ready .card.faq-card .faq-question-item,
body.ready .card.faq-card .faq-question-item .accordion {
    transition: 200ms;
}

/* FAQ Accordion item */
.card.faq-card .faq-question-item {
    cursor: pointer;
    transition: background 200ms;
    border-radius: 5px;
    position: relative;
}
.card.faq-card .faq-question-item:hover h3 {
    color: var(--black);
}

/* FAQ Accordion item - hover effect */
.card.faq-card .faq-question-item:hover {
    background: var(--blue);
}

.card.faq-card .faq-question-item .accordion {
    /*padding: 1.5rem;*/
    padding: 20px;
    transition: background 200ms, padding 200ms;
    border-radius: 5px;
    overflow: hidden;
}
.card.faq-card .faq-question-item:not(:last-of-type) p {
    margin-bottom: 0;
}

.card.faq-card .faq-question-item .article.story {
    transition: all 300ms;
}


/* FAQ Accordion item - arrow */
.card.faq-card .faq-question-item .arrow-down {
    position: absolute;
    display: block;
    width: 1rem;
    height: 1rem;
    top: 1.25rem;
    right: 1.25rem;
    transition: transform 200ms;
}
.card.faq-card .faq-question-item .arrow-down.rotate {
    transform: rotate(90deg);
}


/* FAQ Accordion item - not active */

.card.faq-card .faq-question-item .accordion {
    color: var(--text-brown-dark);
    font-size: var(--font-size-xsl);
    border: 2px solid #ebebeb;
    /*border: 1px solid transparent;*/

}
.card.faq-card .faq-question-item .accordion h3,
.card.faq-card .faq-question-item .accordion .title {
    margin-bottom: -2px;
    font-weight: 600;
    line-height: 1.25em;
    padding-right: 30px;
    font-size: var(--font-size-subtitle-faq);
}



/* FAQ Accordion item - active */
.card.faq-card .faq-question-item:hover .accordion {
    background: var(--blue);
    border-color: var(--text-blue);
}
.card.faq-card .faq-question-item.open .accordion {
    background: var(--blue);
    border-color: var(--text-blue);
    /*border: 1px solid var(--text-blue);*/
    color: var(--black);
}

.card.faq-card .faq-question-item.open:not(:last-of-type),
.card.faq-card .faq-question-item:not(:last-of-type) {
    margin-bottom: 1.5rem;
}

.card.faq-card .faq-question-item.open .accordion .article.story {
    opacity: 1;
    visibility: visible;
    margin-top: 1rem;
}




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

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

    /* Card - our locations card  */
    .card.our-location-card {
        top: -5rem;
        margin-bottom: -5rem;
    }

    .card.our-location-card .image-wrap {
        margin-top: 1.5rem;
        margin-bottom: calc(1.5rem - 25px);
        margin-right: 0;
    }


    /* Card - FAQ cards */
    /*.card.faq-card .faq-question-item.open .accordion .article.story {*/
    /*    overflow: scroll;*/
    /*}*/

    /*.card.faq-card .faq-question-item .accordion {*/
    /*    padding: 1rem 3rem 1rem 1rem;*/
    /*}*/
    /*.card.faq-card .faq-question-item.open .accordion {*/
    /*    padding: 1rem 3rem 1rem 1rem;*/
    /*}*/


}

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

    /* Card - actions wrapper */
    .card-actions-wrapper.spacing-top {
        margin-top: 2rem;
    }



    /* Card - spacings */
    .card.spacing-inner {
        padding: 2rem;
    }



    /* Card - treatment download file */
    .card.download-file-card {
        width: 50%;
    }

}

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



    /* Card - spacings */
    .card.spacing-inner {
        padding: 20px;
    }



    /* Card - actions wrapper */
    .card-actions-wrapper.spacing-top {
        margin-top: 1.75rem;
    }


    /*  Card - utility classes  */
    .card.pulled-top {
        margin-top: 0;
    }



    /* Card - spacings */
    .card.spacing-inner:not(.spacing-mobile) {
        padding: 0;
    }
    .card.spacing-inner.spacing-mobile-sm {
        padding: 1.5rem 1rem;
    }



    /*  Card - doctors card (home)  */
    .card.doctors-card {
        padding-left: 0;
        padding-right: 0;
    }

    .card.doctors-card .article {
        color: var(--black);
    }



    /*  Card - doctors card (treatment detail)  */
    .card.related-doctors-card {
        padding: 1.5rem;
    }



    /* Card - our locations card  */
    .card.our-location-card {
        top: -5rem;
        margin-bottom: -5rem;
    }



    /* FAQ Card */
    .card.faq-card {
        padding: 20px 15px 16px;
    }
    .card.faq-card .article.has-title h2 {
        font-size: 1.5rem;
    }



    .card.faq-card .faq-question-item .accordion {
        padding: 14px 16px;
    }
    .card.faq-card .faq-question-item .accordion h3,
    .card.faq-card .faq-question-item .accordion .title {
        padding-right: 24px;
        line-height: 1.2em;
    }
    .card.faq-card .faq-question-item .arrow-down {
        top: 15px;
        right: 15px;
    }


    /*.card.faq-card .faq-question-item .accordion {*/
    /*    font-size: 0.75rem;*/
    /*}*/
    /*.card.faq-card .faq-question-item .article.story p {*/
    /*    font-size: var(--font-size-xs);*/
    /*}*/


    /* FAQ Card - accordion item */
    /*.card.faq-card .faq-question-item .accordion {*/
    /*    padding: 0.5rem 0.75rem;*/
    /*}*/
    /*.card.faq-card .faq-question-item.open .accordion {*/
    /*    padding: 1rem 0.75rem;*/
    /*}*/
    /*.card.faq-card .faq-question-item .accordion h3 {*/
    /*    padding-right: 3rem;*/
    /*}*/



    /* Card - specializations card */
    .card.specializations-card .btn.has-icon span {
        justify-content: space-between;
        display: flex;
        align-items: start;
        flex-direction: column;
    }

    .card.specializations-card .btn.has-icon .icon {
        margin-left: 0;
        margin-top: 1rem;
    }

}




/*--------------------------------------------------------------
# Card - album card
--------------------------------------------------------------*/

.card.album-card {

}

.card.album-card .card-description {
    padding: 10px 0 0;
}

.card.album-card .card-description p {
    font-weight: 300;
    font-size: var(--font-size-xs);
    line-height: 1.5em;
}

.album-row > .album-column:not(:last-child) {
    padding-bottom: 15px;
}

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


    .card.album-card .picture-wrap {
        /*max-height: 165px;*/
        /*max-width: max-content;*/
    }

    .card.album-card .picture-wrap .picture {
        max-height: 200px;

    }

    .card.album-card .card-description {
        max-width: 100%;
        width: 360px;
    }

    .card.album-card .picture-wrap.rounded-xs:not(.forced) {
        border-radius: var(--rounded);
    }


    .album-row > .album-column:last-child {
        padding-bottom: 0 !important;
    }

}








/* Card New */

.card.is-flex.full-height {
    display: flex;
    flex-direction: column;
}

.card.is-flex.full-height .card-content {
    height: auto;
}

.card.is-flex.full-height .card-content {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex: 1 1;
}

.card.is-flex.full-height .card-content-inner {
    display: flex;
    flex-direction: column;

}





/* Card Alert */

.card-alert {
    padding: 20px 25px;
    max-width: 100%;
}

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

    .card-alert {
        padding: 15px 20px;
    }

}

.card-alert.max-width {
    width: 500px;
}

.card-alert .alert-title {
    display: flex;
    align-items: center;
    justify-content: start;
    margin-bottom: 12px;
    gap: 0 15px;
}

.card-alert .alert-title i.icon {
    width: 1.5rem;
    height: 1.5rem;
}

.card-alert .alert-title .title {
    display: inline-flex;
    font-weight: 500;
    margin-bottom: -2px;
    flex: 1 1;
}

.card-alert .alert-article > *:not(:last-child) {
    margin-bottom: 12px;
}

.card-alert .alert-article > *:last-child {
    margin-bottom: 0 !important;
}

.card-alert .alert-article {
    font-weight: 400;
    font-size: var(--font-size-sm);
    letter-spacing: var(--letter-spacing);
}





