/* RHVA V87 FINAL popup + preview fit */

/* Preview images: whole image visible in card previews */
.service-card > img:first-child,
.specialization-card > img:first-child,
.rhva-card > img:first-child,
.rhva-service-card > img:first-child,
.rhva-specialization-card > img:first-child,
.rhv-v39-card-image img,
.rhv-v39-card > img:first-child,
.service-grid > * > img:first-child,
.specialization-grid > * > img:first-child,
.services-grid > * > img:first-child,
.specializations-grid > * > img:first-child,
.gallery-grid > * > img:first-child,
.cards-grid > * > img:first-child,
.card-grid > * > img:first-child {
    width: 100% !important;
    height: 210px !important;
    min-height: 210px !important;
    max-height: 210px !important;
    object-fit: contain !important;
    object-position: center center !important;
    display: block !important;
    padding: 8px !important;
    background:
        radial-gradient(circle at 24% 16%, rgba(22,190,225,.13), transparent 36%),
        linear-gradient(135deg, #f5fbfd 0%, #eaf7fa 100%) !important;
    border-radius: 22px 22px 0 0 !important;
    filter: none !important;
    transform: none !important;
}

.rhv-v39-card-image,
.service-card .card-image,
.specialization-card .card-image,
.service-card .card-media,
.specialization-card .card-media,
.gallery-card figure,
.media-card figure {
    height: 210px !important;
    min-height: 210px !important;
    max-height: 210px !important;
    padding: 8px !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background:
        radial-gradient(circle at 24% 16%, rgba(22,190,225,.13), transparent 36%),
        linear-gradient(135deg, #f5fbfd 0%, #eaf7fa 100%) !important;
}

.rhv-v39-card-image img,
.service-card .card-image img,
.specialization-card .card-image img,
.service-card .card-media img,
.specialization-card .card-media img,
.gallery-card figure img,
.media-card figure img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    display: block !important;
    background: transparent !important;
    filter: none !important;
    transform: none !important;
}

.service-card [style*="background-image"],
.specialization-card [style*="background-image"],
.rhv-v39-card [style*="background-image"],
.gallery-card [style*="background-image"],
.media-card [style*="background-image"] {
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
}

/* Hide old popup systems when new V87 opens */
body.rhva-v87-lock .rhv-v39-modal,
body.rhva-v87-lock .rhva-v85-modal,
body.rhva-v87-lock .rhva-v83-modal,
body.rhva-v87-lock .rhva-v81-modal,
body.rhva-v87-lock #rhvaV85Modal,
body.rhva-v87-lock #rhvaV83Modal,
body.rhva-v87-lock #rhvaV81Modal,
body.rhva-v87-lock #rhvV39Modal,
body.rhva-v87-lock #rhvaCardPopup,
body.rhva-v87-lock #cardPopup,
body.rhva-v87-lock #reviewPopup {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* V87 requested popup design */
.rhva-v87-modal {
    position: fixed !important;
    inset: 0 !important;
    z-index: 2147483640 !important;
    display: none;
    align-items: center !important;
    justify-content: center !important;
    padding: 18px !important;
    background: rgba(2, 15, 24, .76) !important;
    backdrop-filter: blur(9px) !important;
}

.rhva-v87-modal.is-open {
    display: flex !important;
}

body.rhva-v87-lock {
    overflow: hidden !important;
}

.rhva-v87-dialog {
    position: relative !important;
    width: min(96vw, 1280px) !important;
    max-height: 92vh !important;
    display: grid !important;
    grid-template-columns: minmax(520px, 1.05fr) minmax(430px, .95fr) !important;
    align-items: start !important;
    overflow: hidden !important;
    background: #ffffff !important;
    border-radius: 0 !important;
    box-shadow: 0 34px 110px rgba(0,0,0,.48) !important;
    border: 1px solid rgba(255,255,255,.25) !important;
}

.rhva-v87-close {
    position: absolute !important;
    top: 18px !important;
    right: 18px !important;
    z-index: 10 !important;
    width: 54px !important;
    height: 54px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: #071f2e !important;
    color: #ffffff !important;
    font-size: 34px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 18px 40px rgba(0,0,0,.28) !important;
}

.rhva-v87-media {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: 92vh !important;
    align-self: start !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
    overflow: hidden !important;
    background: #eaf2f5 !important;
}

.rhva-v87-media img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 88vh !important;
    object-fit: contain !important;
    object-position: center center !important;
    display: block !important;
    margin: 0 auto !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #eaf2f5 !important;
    box-shadow: none !important;
}

.rhva-v87-no-image {
    width: 100% !important;
    min-height: 520px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 40px !important;
    background: linear-gradient(135deg,#062f42,#0aaed0) !important;
    color: #fff !important;
    font-size: 38px !important;
    font-weight: 900 !important;
}

.rhva-v87-body {
    max-height: 92vh !important;
    overflow-y: auto !important;
    padding: clamp(38px, 4.5vw, 62px) !important;
    background: #ffffff !important;
    color: #172033 !important;
    align-self: stretch !important;
}

.rhva-v87-pill {
    display: inline-flex !important;
    width: fit-content !important;
    align-items: center !important;
    margin: 0 0 16px !important;
    padding: 8px 14px !important;
    border-radius: 999px !important;
    background: #eefbff !important;
    color: #1759d8 !important;
    border: 1px solid rgba(22,190,225,.35) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.rhva-v87-title {
    margin: 0 0 20px !important;
    color: #111827 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: clamp(34px, 3.2vw, 52px) !important;
    line-height: 1.05 !important;
    letter-spacing: -.045em !important;
    font-weight: 900 !important;
}

.rhva-v87-desc {
    color: #334155 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 17px !important;
    line-height: 1.72 !important;
    font-weight: 500 !important;
}

.rhva-v87-desc p {
    margin: 0 0 18px !important;
}

.rhva-v87-desc .intro {
    color: #334155 !important;
    font-size: 17px !important;
    line-height: 1.78 !important;
    margin-bottom: 26px !important;
}

.rhva-v87-desc .section-head {
    display: block !important;
    margin: 26px 0 12px !important;
    color: #111827 !important;
    font-size: 18px !important;
    line-height: 1.25 !important;
    font-weight: 900 !important;
}

.rhva-v87-desc ul {
    margin: 0 0 22px !important;
    padding: 0 !important;
    list-style: none !important;
}

.rhva-v87-desc li {
    position: relative !important;
    margin: 0 0 14px !important;
    padding-left: 24px !important;
    color: #42566b !important;
    font-size: 16px !important;
    line-height: 1.68 !important;
}

.rhva-v87-desc li::before {
    content: "•" !important;
    position: absolute !important;
    left: 3px !important;
    top: 0 !important;
    color: #4b5563 !important;
    font-size: 20px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
}

.rhva-v87-body::-webkit-scrollbar {
    width: 10px !important;
}

.rhva-v87-body::-webkit-scrollbar-thumb {
    background: #c9d8de !important;
    border-radius: 999px !important;
}

.rhva-v87-body::-webkit-scrollbar-track {
    background: #f5fafc !important;
}

@media(max-width:1020px) {
    .rhva-v87-dialog {
        width: min(94vw, 780px) !important;
        max-height: 92vh !important;
        grid-template-columns: 1fr !important;
    }
    .rhva-v87-media img {
        max-height: 42vh !important;
    }
    .rhva-v87-body {
        max-height: 50vh !important;
        padding: 28px !important;
    }
    .rhva-v87-title {
        font-size: 34px !important;
    }
}

@media(max-width:768px) {
    .service-card > img:first-child,
    .specialization-card > img:first-child,
    .rhva-card > img:first-child,
    .rhv-v39-card-image,
    .rhv-v39-card-image img {
        height: 185px !important;
        min-height: 185px !important;
        max-height: 185px !important;
    }
}