/**
 * ClinicIVF — new-classes.css
 * Only classes NOT in original style.css
 * Logo + Mobile responsive fixes + SEO card fixes
 */

/* ═══════════════════════════════════════════
   LOGO
═══════════════════════════════════════════ */
.logo-with-image {
    display: flex;
    align-items: center;
    gap: 0;
    text-decoration: none;
}
.logo-img {
    height: 56px;
    width: auto;
    object-fit: contain;
    display: block;
    /* Slightly darken on cream header for contrast */
    filter: brightness(0.92) saturate(1.1);
    transition: opacity 0.2s;
}
.logo-with-image:hover .logo-img { opacity: 0.85; }

.logo-fallback {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

/* Mobile menu logo */
.mobile-menu-header .logo-img {
    height: 44px;
    filter: none;
}

/* Footer logo — white version on dark bg */
.footer .logo-img,
.footer-logo-img {
    height: 48px;
    filter: brightness(0) invert(1);
    opacity: 0.92;
}
.footer .logo-fallback .logo-text { color: var(--cream); }

/* ═══════════════════════════════════════════
   ACCESSIBILITY
═══════════════════════════════════════════ */
.skip-link {
    position: absolute; top: -100%; left: 1rem;
    background: var(--teal); color: var(--cream);
    padding: .5rem 1rem;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    font-weight: 600; z-index: 10000; transition: top .2s;
}
.skip-link:focus { top: 0; }
.sr-only { position: absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ═══════════════════════════════════════════
   HEADER RESPONSIVE
═══════════════════════════════════════════ */
.header .container {
    height: 76px;
}
/* Scrolled state */
.header.scrolled {
    box-shadow: 0 2px 20px rgba(0,0,0,.1);
}
@media (max-width: 992px) {
    .header .container { height: 64px; }
    .logo-img { height: 44px; }
}
@media (max-width: 480px) {
    .header .container { height: 58px; }
    .logo-img { height: 38px; }
}

/* ═══════════════════════════════════════════
   MOBILE MENU — full screen drawer
═══════════════════════════════════════════ */
.mobile-menu-overlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 1099;
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
}
.mobile-menu-overlay.active { display: block; }

.mobile-menu {
    position: fixed;
    top: 0; right: 0;
    width: min(340px, 88vw);
    height: 100vh;
    height: 100dvh; /* dynamic viewport on mobile */
    background: var(--cream);
    z-index: 1100;
    display: flex;
    flex-direction: column;
    padding: 0;
    transform: translateX(100%);
    transition: transform 0.32s cubic-bezier(0.4,0,0.2,1);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    box-shadow: -8px 0 32px rgba(0,0,0,.15);
}
.mobile-menu.active { transform: translateX(0); }

.mobile-menu-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--sand);
    position: sticky; top: 0;
    background: var(--cream);
    z-index: 1;
}

.mobile-nav {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 0.5rem 0;
}
.mobile-nav a {
    display: block;
    padding: 0.875rem 1.5rem;
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--ink);
    border-bottom: 1px solid rgba(237,232,224,.7);
    transition: background 0.15s, color 0.15s;
}
.mobile-nav a:hover,
.mobile-nav a:active {
    background: var(--sand);
    color: var(--teal);
}
.mobile-nav a.mobile-sub {
    padding-left: 2.25rem;
    font-size: 0.9rem;
    opacity: 0.75;
    border-bottom-color: transparent;
}
.mobile-nav a.mobile-sub:hover { opacity: 1; }

.mobile-menu-ctas {
    padding: 1.25rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    border-top: 1px solid var(--sand);
    background: var(--cream);
    position: sticky; bottom: 0;
}

/* ═══════════════════════════════════════════
   WHATSAPP BUTTON
═══════════════════════════════════════════ */
.btn-whatsapp {
    background: #25D366; color: #fff;
    border-radius: var(--radius-full);
    display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
    padding: .75rem 1.5rem;
    font-weight: 600; border: none; cursor: pointer;
    transition: var(--transition); text-decoration: none;
    font-size: 1rem;
    font-family: inherit;
}
.btn-whatsapp:hover { background: #1da851; color: #fff; transform: translateY(-2px); }
.btn-whatsapp.btn-lg   { padding: 1rem 2rem; font-size: 1.125rem; }
.btn-whatsapp.btn-block { width: 100%; text-align: center; }
.btn-sm { padding: .45rem 1rem; font-size: .85rem; }

/* ═══════════════════════════════════════════
   CTA SECTION LAYOUT
═══════════════════════════════════════════ */
.cta-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    flex-wrap: wrap;
    padding: 4rem 0;
}
.cta-buttons { display: flex; gap: 1rem; flex-wrap: wrap; flex-shrink: 0; }

/* ═══════════════════════════════════════════
   PAGE HEADER EXTRAS
═══════════════════════════════════════════ */
.page-header .breadcrumb a { color: rgba(245,240,232,.75); opacity: 1; }
.page-header .breadcrumb .current { color: var(--gold); }
.page-header-meta {
    display: flex; flex-wrap: wrap; gap: 1.5rem;
    margin-top: 1rem; font-size: .9rem; opacity: .85;
}
.page-header-meta strong { color: var(--gold); }

/* ═══════════════════════════════════════════
   DARK CARD TEXT FIX (CSS specificity override)
   .card p { color:var(--ink) } in original gets
   overridden here when card has teal background
═══════════════════════════════════════════ */
.card[style*="background: var(--teal)"] p,
.card[style*="background:var(--teal)"] p,
.card[style*="background: var(--teal-dark)"] p,
.card[style*="background:var(--teal-dark)"] p { color: var(--cream); }
.card[style*="background: var(--teal)"] h2,
.card[style*="background:var(--teal)"] h2,
.card[style*="background: var(--teal)"] h3,
.card[style*="background:var(--teal)"] h3 { color: var(--cream); }
.card-dark { background: var(--teal); color: var(--cream); }
.card-dark p, .card-dark h2, .card-dark h3,
.card-dark h4, .card-dark span, .card-dark li { color: var(--cream); }
.card-dark p { opacity: .85; }

/* Category tag */
.category-tag {
    display: inline-block; background: var(--teal); color: var(--cream);
    padding: .25rem 1rem; border-radius: 999px;
    font-size: .8rem; font-weight: 600; margin-bottom: .75rem; text-decoration: none;
}

/* Share buttons */
.share-box { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--sand); font-size: .875rem; opacity: .75; }
.share-btns { display: flex; gap: .5rem; }
.share-btn { width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;border:none;cursor:pointer;transition:var(--transition);color:#fff;text-decoration:none; }
.share-btn.facebook    { background:#1877f2; }
.share-btn.twitter     { background:#1da1f2; }
.share-btn.whatsapp-share { background:#25d366; }
.share-btn.copy-btn    { background:var(--ink); }
.share-btn:hover       { transform:scale(1.12); }

/* FAQ footer */
.faq-footer { display:flex;align-items:center;gap:1rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--sand);font-size:.85rem;flex-wrap:wrap; }
.faq-cat-label { background:var(--teal);color:var(--cream);padding:.15rem .6rem;border-radius:999px;font-size:.75rem; }
.faq-detail-link { color:var(--teal); }

/* ═══════════════════════════════════════════
   BLOG POST LAYOUT
═══════════════════════════════════════════ */
.blog-post-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 3rem; align-items: start; padding: 2.5rem 0;
}
.blog-post-sidebar { position: sticky; top: 90px; }
.blog-post-meta { display:flex;flex-wrap:wrap;gap:1.25rem;font-size:.875rem;opacity:.6;margin-bottom:1.5rem; }
.blog-post-hero { border-radius:var(--radius-xl);overflow:hidden;margin-bottom:2.5rem;aspect-ratio:16/9; }
.author-box { display:flex;gap:1.5rem;align-items:flex-start;padding:2rem;background:var(--sand);border-radius:var(--radius-xl);margin-top:2.5rem; }
.author-avatar { width:70px;height:70px;min-width:70px;background:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.5rem;color:var(--cream); }
.author-info h3 { font-family:var(--font-display);font-size:1.1rem;margin-bottom:.4rem; }
.author-info p  { font-size:.875rem;opacity:.7;margin-bottom:.75rem; }
.author-info a  { color:var(--teal);font-size:.875rem; }
.sidebar-cta { border:2px solid var(--gold); }

/* ═══════════════════════════════════════════
   TREATMENT DETAIL LAYOUT
═══════════════════════════════════════════ */
.treatment-layout { display:grid;grid-template-columns:1fr 320px;gap:3rem;align-items:start; }
.treatment-sidebar { position:sticky;top:90px; }

/* ═══════════════════════════════════════════
   FAQ DETAIL LAYOUT
═══════════════════════════════════════════ */
.faq-detail-layout { display:grid;grid-template-columns:1fr 300px;gap:3rem;align-items:start;padding:2.5rem 0; }
.faq-detail-sidebar { position:sticky;top:90px; }
.faq-answer-full { background:var(--white);border-radius:var(--radius-xl);padding:2rem;border:1px solid var(--sand);margin-bottom:1.5rem;box-shadow:var(--shadow-sm); }
.answer-header { display:flex;align-items:center;justify-content:space-between;padding-bottom:1.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--sand);flex-wrap:wrap;gap:.75rem; }
.answer-author { display:flex;align-items:center;gap:1rem; }
.answer-avatar { width:44px;height:44px;background:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);color:var(--cream);font-size:.9rem;flex-shrink:0; }
.answer-author strong { display:block;font-weight:600; }
.answer-author span   { font-size:.8rem;opacity:.6; }
.answer-views         { font-size:.8rem;opacity:.5; }
.answer-body          { line-height:1.85;font-size:1.025rem; }
.helpful-box { margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--sand); }
.helpful-box p { font-size:.875rem;margin-bottom:.75rem;opacity:.7; }
.helpful-btns { display:flex;gap:.75rem; }

/* ═══════════════════════════════════════════
   CONTACT LAYOUT
═══════════════════════════════════════════ */
.contact-layout { display:grid;grid-template-columns:1fr 340px;gap:3rem;align-items:start; }
.contact-sidebar { position:sticky;top:90px; }
.contact-detail-list { list-style:none;display:flex;flex-direction:column;gap:1rem; }
.contact-detail-list li { display:flex;gap:1rem;align-items:flex-start; }
.cd-icon { width:38px;height:38px;min-width:38px;background:var(--teal);color:var(--cream);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;flex-shrink:0; }
.cd-icon--whatsapp { background:#25d366; }
.contact-detail-list strong { display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;opacity:.5;margin-bottom:.15rem; }
.contact-detail-list a { color:var(--teal); }
.form-privacy { font-size:.78rem;text-align:center;opacity:.55;margin-top:.75rem; }
.form-privacy a { color:var(--teal); }
.form-success { text-align:center;padding:2rem 0; }
.form-success i { font-size:3.5rem;color:var(--teal);margin-bottom:1rem;display:block; }
.form-success h3 { font-family:var(--font-display);font-size:1.5rem;margin-bottom:.5rem; }
.form-success p { opacity:.7;margin-bottom:1.5rem; }

/* ═══════════════════════════════════════════
   COSTS PAGE
═══════════════════════════════════════════ */
.table-wrap { overflow-x:auto;margin-bottom:1.5rem;-webkit-overflow-scrolling:touch; }
.comparison-table { width:100%;min-width:560px;border-collapse:collapse; }
.comparison-table th { text-align:left;padding:.9rem 1rem;font-family:var(--font-display);font-size:1rem;border-bottom:2px solid var(--sand); }
.comparison-table td { padding:.9rem 1rem;border-bottom:1px solid var(--sand); }
.comparison-table .turkey-row td { background:rgba(26,92,94,.06); }
.mono { font-family:monospace; }
.flag { font-size:1.4rem;margin-right:.5rem; }
.saving-badge { background:rgba(26,92,94,.1);color:var(--teal);padding:.2rem .75rem;border-radius:999px;font-size:.8rem;font-weight:700; }
.info-box { display:flex;gap:.75rem;padding:1rem 1.25rem;background:rgba(201,162,39,.12);border-radius:.75rem; }
.info-box i { color:var(--gold);margin-top:.15rem;flex-shrink:0; }
.info-box p { font-size:.875rem;opacity:.85;margin:0; }
.packages-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem; }
.package-card { background:var(--white);border:1.5px solid var(--sand);border-radius:var(--radius-xl);padding:2rem;position:relative;display:flex;flex-direction:column;box-shadow:var(--shadow-sm); }
.package-card--featured { background:var(--teal);color:var(--cream);border-color:var(--gold);box-shadow:0 8px 32px rgba(26,92,94,.25); }
.package-badge { display:inline-block;background:var(--gold);color:var(--ink);padding:.2rem .9rem;border-radius:999px;font-size:.75rem;font-weight:700;margin-bottom:1rem; }
.package-card h3 { font-family:var(--font-display);font-size:1.3rem;margin-bottom:.35rem; }
.package-card>p { font-size:.875rem;opacity:.7;margin-bottom:1.25rem; }
.pkg-heading { font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.55;margin-bottom:.6rem; }
.package-includes ul,.package-excludes ul { display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;list-style:none; }
.package-includes li,.package-excludes li { display:flex;gap:.5rem;font-size:.875rem;align-items:flex-start; }
.package-includes i { color:var(--teal);flex-shrink:0;margin-top:.15rem; }
.package-card--featured .package-includes i { color:var(--gold); }
.package-excludes li { opacity:.5; }
.package-excludes i { flex-shrink:0;margin-top:.15rem; }
.extras-list { display:flex;flex-direction:column;gap:.9rem;margin-bottom:2rem; }
.extra-item { display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.9rem 1.25rem;background:var(--sand);border-radius:.75rem; }
.extra-note { display:block;font-size:.8rem;opacity:.55; }
.extra-est  { font-family:monospace;font-size:.85rem;white-space:nowrap;opacity:.75; }
.promise-box { display:flex;gap:1rem;padding:1.5rem;background:rgba(26,92,94,.06);border-radius:var(--radius-lg);border:1px solid rgba(26,92,94,.15); }
.promise-box i  { font-size:1.5rem;color:var(--teal);flex-shrink:0; }
.promise-box h4 { margin-bottom:.4rem;font-weight:700; }
.promise-box p  { font-size:.875rem;opacity:.75;margin:0; }

/* ═══════════════════════════════════════════
   JOURNEY CONTENT
═══════════════════════════════════════════ */
.journey-content { background:var(--white);border-radius:var(--radius-xl);padding:1.75rem;border:1px solid rgba(26,92,94,.08);box-shadow:var(--shadow-sm); }
.journey-content h3 { font-family:var(--font-display);font-size:1.3rem;margin-bottom:.5rem; }
.journey-content>p { opacity:.65;margin-bottom:1rem;line-height:1.6; }
.journey-details { list-style:none;display:flex;flex-direction:column;gap:.5rem; }
.journey-details li { display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem;line-height:1.4; }
.journey-details i { color:var(--teal);margin-top:.15rem;flex-shrink:0;font-size:.8rem; }
.tool-form { margin-bottom:1.5rem; }

/* ═══════════════════════════════════════════
   ABOUT PAGE
═══════════════════════════════════════════ */
.reasons-grid { display:grid;grid-template-columns:1fr 1fr;gap:1.25rem; }
.reason-item { display:flex;gap:1rem;align-items:flex-start; }
.reason-icon { width:40px;height:40px;min-width:40px;background:var(--teal);color:var(--cream);border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1rem; }
.reason-item strong { display:block;margin-bottom:.25rem; }
.reason-item p { font-size:.875rem;opacity:.7;margin:0; }
.doctor-card { text-align:center; }
.doctor-photo { width:150px;height:150px;background:var(--sand);border-radius:50%;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--teal); }
.credential-list { list-style:none;margin-top:1.5rem;text-align:left; }
.credential-list li { display:flex;gap:.75rem;align-items:flex-start;padding:.65rem 0;border-bottom:1px solid var(--sand); }
.credential-list li:last-child { border:none; }
.credential-list i  { color:var(--teal);margin-top:.15rem;flex-shrink:0;width:16px; }
.cred-label { display:block;font-size:.75rem;opacity:.5;text-transform:uppercase;letter-spacing:.04em; }
.cred-value { display:block;font-size:.875rem; }

/* ═══════════════════════════════════════════
   LAZY LOAD FADE
═══════════════════════════════════════════ */
img[loading="lazy"] { opacity:0;transition:opacity .4s; }
img[loading="lazy"].img-loaded { opacity:1; }

/* ═══════════════════════════════════════════
   MOBILE RESPONSIVE — ALL BREAKPOINTS
═══════════════════════════════════════════ */

/* ── Tablet (≤ 1024px) ── */
@media (max-width: 1024px) {
    /* Sidebar layouts → single column */
    .treatment-layout,
    .faq-detail-layout,
    .blog-post-layout,
    .contact-layout { grid-template-columns: 1fr; }

    .treatment-sidebar,
    .faq-detail-sidebar,
    .blog-post-sidebar,
    .contact-sidebar { position: static; }

    .blog-post-layout { padding: 1.5rem 0; }
    .faq-detail-layout { padding: 1.5rem 0; }

    /* Packages → single column */
    .packages-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }

    /* CTA sections → stacked */
    .cta-inner { flex-direction: column; text-align: center; padding: 3rem 0; }
    .cta-buttons { justify-content: center; }

    /* About page inline grid */
    .reasons-grid { grid-template-columns: 1fr; }
}

/* ── Mobile (≤ 768px) ── */
@media (max-width: 768px) {
    /* INLINE GRIDS in PHP files — override with class on container */
    .mobile-single-col,
    .mobile-single-col > div { display: block !important; }

    /* Author box */
    .author-box { flex-direction: column; }

    /* Blog post */
    .blog-post-meta { gap: .75rem; }

    /* Packages */
    .packages-grid { grid-template-columns: 1fr; }

    /* Share */
    .share-box { flex-direction: column; align-items: flex-start; }
    .answer-header { flex-direction: column; align-items: flex-start; }

    /* Page header */
    .page-header { padding: 6rem 0 2.5rem; }
    .page-header h1 { font-size: clamp(1.6rem, 5vw, 2.5rem); }
    .page-header-meta { gap: 1rem; }

    /* CTA */
    .cta-inner { padding: 2.5rem 0; gap: 1.5rem; }
    .cta-buttons { flex-direction: column; width: 100%; }
    .cta-buttons .btn, .cta-buttons a { width: 100%; text-align: center; justify-content: center; }

    /* Hero trust bar */
    .hero-trust { gap: 1rem; font-size: .8rem; }

    /* Section spacing */
    section { padding: 3rem 0; }

    /* Stats */
    .stats-grid { grid-template-columns: repeat(2,1fr); gap: 1.5rem; }

    /* Card grid → 2 col */
    .card-grid { grid-template-columns: repeat(2,1fr); gap: 1.25rem; }

    /* Comparison table */
    .comparison-table { font-size: .85rem; }
    .comparison-table th,
    .comparison-table td { padding: .65rem .75rem; }
}

/* ── Small mobile (≤ 480px) ── */
@media (max-width: 480px) {
    /* Single column everything */
    .card-grid { grid-template-columns: 1fr; }
    .stats-grid { grid-template-columns: repeat(2,1fr); gap: 1rem; }
    .stat-number { font-size: 2.2rem; }

    /* Hero */
    .hero { padding: 7rem 0 3rem; min-height: auto; }
    .hero h1 { font-size: 2.2rem; }
    .hero-buttons { flex-direction: column; }
    .hero-buttons .btn { width: 100%; justify-content: center; }

    /* Modal */
    .modal-content { padding: 1.75rem 1.25rem; margin: .5rem; }
    .form-row { grid-template-columns: 1fr; }

    /* Contact layout */
    .contact-layout { gap: 1.5rem; }

    /* Footer grid */
    .footer-grid { grid-template-columns: 1fr; }
    .footer-bottom { flex-direction: column; text-align: center; gap: .5rem; }
    .footer-links { flex-wrap: wrap; justify-content: center; gap: 1rem; }

    /* Tools */
    .tool-tabs { grid-template-columns: repeat(2,1fr); }

    /* Blog */
    .blog-grid { grid-template-columns: 1fr; }

    /* Journey */
    .journey-step { padding-left: 3.5rem; }
    .journey-icon { width: 36px; height: 36px; font-size: .9rem; }
    .journey-line { left: 17px; }

    /* About inline grid */
    .page-header-meta { flex-direction: column; gap: .5rem; }
}

/* ═══════════════════════════════════════════
   INLINE GRID RESPONSIVE OVERRIDES
   For PHP pages that use style="display:grid"
   We use a wrapper class approach
═══════════════════════════════════════════ */
@media (max-width: 992px) {
    /* about.php doctor grid */
    .about-grid { display: block !important; }
    .about-grid > div { margin-bottom: 2rem; }

    /* treatment-detail.php main grid */
    .treatment-main-grid { display: block !important; }
    .treatment-main-grid > div { margin-bottom: 2rem; }

    /* contact.php form grid */
    .contact-main-grid { display: block !important; }
    .contact-main-grid > div { margin-bottom: 2rem; }

    /* faq-detail.php grid */
    .faq-detail-grid { display: block !important; }
    .faq-detail-grid > div { margin-bottom: 2rem; }
}

/* ═══════════════════════════════════════════
   TOUCH TARGETS (min 44px for mobile)
═══════════════════════════════════════════ */
@media (max-width: 768px) {
    .btn { min-height: 44px; }
    .btn-icon { min-width: 44px; min-height: 44px; }
    .faq-question { min-height: 52px; padding: 1rem 1.25rem; }
    .mobile-nav a { min-height: 48px; display: flex; align-items: center; }
    .pagination a, .pagination span { width: 44px; height: 44px; }
}

/* ═══════════════════════════════════════════
   VISUAL FIXES — identified from screenshot
═══════════════════════════════════════════ */

/* ── Fix: 5-card treatment grid — center last row ── */
/* When 5 items in a 3-col grid, last row has 2 items left-aligned
   This makes the last row look centered */
.card-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    /* Center orphan cards in last row */
    justify-items: stretch;
}

/* Treatment cards: ensure equal height */
.treatment-card {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* ── Logo sizing — header ── */
.header .logo-with-image {
    display: flex;
    align-items: center;
}
.header .logo-img {
    height: 52px;
    width: auto;
    max-width: 160px;
    object-fit: contain;
}

/* ── Header height match logo ── */
.header .container {
    height: auto;
    min-height: 72px;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

/* ── Mobile menu — ensure it slides from RIGHT, 
   not overlay hero from left ── */
.mobile-menu {
    left: auto;
    right: 0;
}

/* ── Hero section — prevent mobile menu overlap ── */
.mobile-menu.active + * {
    position: relative;
    z-index: 0;
}

/* ── Nav links — tighten spacing for longer labels ── */
.nav {
    gap: 1.25rem;
}
.nav-link {
    font-size: 0.9rem;
    white-space: nowrap;
}

/* ── Treatment card grid — 5 items: 3+2 layout ── */
/* Make last orphan row centered when 5 cards */
.card-grid:has(.card:nth-child(5):last-child) {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}
/* Fallback for browsers without :has() */
.treatments-grid-5 {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    justify-content: center;
}
.treatments-grid-5 > * {
    flex: 1 1 calc(33.333% - 2rem);
    max-width: calc(33.333% - 1.5rem);
    min-width: 240px;
}

/* ── Footer logo — cleaner white treatment ── */
.footer .logo-with-image {
    margin-bottom: 0.5rem;
}
.footer .logo-img,
.footer-logo-img {
    height: 50px;
    width: auto;
    max-width: 180px;
    filter: brightness(0) invert(1);
    opacity: 0.92;
    display: block;
}

/* ── Footer fallback logo (text version) ── */
.footer .logo-fallback {
    display: none;
}
.footer .logo-fallback .logo-icon {
    background: rgba(255,255,255,0.2);
    color: var(--cream);
}
.footer .logo-fallback .logo-text {
    color: var(--cream);
}

/* ── Stats section on dark background ── */
.stats .stat-label {
    color: var(--cream);
    opacity: 0.8;
}
.stats .stat-number {
    color: var(--gold);
}

/* ── CTA section on dark teal background ── */
section[style*="background: var(--teal)"] .section-title,
section[style*="background: var(--teal)"] h2 {
    color: var(--cream);
}
section[style*="background: var(--teal)"] p {
    color: var(--cream);
}

/* ── Mobile menu improvements ── */
@media (max-width: 992px) {
    /* Header compact */
    .header .logo-img { height: 40px; }
    .header .container { min-height: 60px; }

    /* Nav gap */
    .nav { gap: 1rem; }
}

@media (max-width: 768px) {
    /* Treatment grid → 2 col on tablet */
    .card-grid { grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
    
    /* Logo */
    .header .logo-img { height: 36px; }
}

@media (max-width: 480px) {
    /* Single col */
    .card-grid { grid-template-columns: 1fr; }
    
    /* Logo */
    .header .logo-img { height: 32px; }
    .header .container { min-height: 54px; }
}

/* ── Treatment flex grid responsive ── */
@media (max-width: 768px) {
    /* Treatment flex items → 2 col */
    a.card.treatment-card[style*="flex:1 1 calc(33.333%"],
    a.treatment-card[style*="flex:1 1 calc(33.333%"] {
        flex: 1 1 calc(50% - 1rem) !important;
        max-width: calc(50% - 1rem) !important;
        min-width: 220px !important;
    }
}
@media (max-width: 480px) {
    a.card.treatment-card[style*="flex:1 1 calc(33.333%"],
    a.treatment-card[style*="flex:1 1 calc(33.333%"] {
        flex: 1 1 100% !important;
        max-width: 100% !important;
    }
}

/* ── FAQ accordion — fix for long answers from DB ── */
/* Original max-height:500px is too small for 100+ word answers */
.faq-item.active .faq-answer {
    max-height: 2000px !important;
    transition: max-height 0.5s ease !important;
}
.faq-answer {
    transition: max-height 0.4s ease !important;
}
