:root{
 --bg:#f6f8fc; --bg-soft:#eaeff8; --paper:#ffffff;
 --ink:#0b1428; --ink-2:#2a3654; --muted:#6b7493; --line:rgba(15,27,61,.10);
 --teal:#1e3a6e; --teal-2:#0f1b3d; --teal-soft:#e8edf6;
 --gold:#c9a84c; --gold-2:#8a6f1f; --gold-soft:#f5edd0;
 --shadow-s:0 2px 10px rgba(15,27,61,.08);
 --shadow-m:0 18px 50px -20px rgba(15,27,61,.30);
 --shadow-l:0 40px 90px -30px rgba(15,27,61,.40);
 --r:14px; --r-lg:22px;
 --serif:'Fraunces',Georgia,serif; --sans:'Inter',system-ui,sans-serif;
 --container:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--teal);color:#fff}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:-.02em;line-height:1.1;color:var(--teal-2)}
h1{font-size:clamp(40px,6.4vw,84px);font-weight:400}
h2{font-size:clamp(30px,4vw,52px);font-weight:400}
h3{font-size:clamp(20px,2vw,26px)}
.container{max-width:var(--container);margin:0 auto;padding:0 28px}
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.section{padding:120px 0;position:relative}
.section.tight{padding:90px 0}
.lead{color:var(--ink-2);font-size:18px;max-width:62ch}
.muted{color:var(--muted)}
em{font-style:italic;font-family:var(--serif);color:var(--gold-2)}

/* Reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* Splash — light, premium, animated */
 #splash{position:fixed;inset:0;z-index:9999;background:#f0dcbe;color:#0a1733;display:flex;align-items:center;justify-content:center;transition:opacity 1.1s cubic-bezier(.65,0,.35,1),visibility 1.1s cubic-bezier(.65,0,.35,1);overflow:hidden;will-change:opacity}
  #splash::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 38%,#fbeed6 0%,#f0dcbe 50%,#e3cba8 100%);z-index:0;transition:opacity 1.1s cubic-bezier(.65,0,.35,1)}
  #splash::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(10,23,51,.04) 1px,transparent 1px);background-size:3px 3px;opacity:.6;z-index:0;pointer-events:none;transition:opacity 1.1s ease}
  #splash.hide{opacity:0;visibility:hidden;pointer-events:none}
  #splash.hide::before,#splash.hide::after{opacity:0}
  #splash.hide .splash-inner{transform:scale(1.04);opacity:0}
  .splash-inner{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:24px;padding:24px;z-index:2;transition:transform 1.1s cubic-bezier(.65,0,.35,1),opacity .9s cubic-bezier(.65,0,.35,1);will-change:transform,opacity}
 .splash-glow{position:absolute;width:min(82vw,560px);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.7) 0%,rgba(255,255,255,.25) 35%,rgba(232,135,77,.12) 60%,rgba(240,220,190,0) 75%);filter:blur(10px);opacity:0;animation:splashGlowIn 1.6s cubic-bezier(.22,.61,.36,1) .05s forwards;z-index:1;top:50%;left:50%;transform:translate(-50%,-58%) scale(.9);transform-origin:center}
 .splash-wordmark,.splash-sub{display:none}
 .splash-logo{width:min(72vw,560px);height:auto;display:block;position:relative;z-index:2;opacity:0;transform:translateY(14px) scale(.94);image-rendering:-webkit-optimize-contrast;-webkit-backface-visibility:hidden;backface-visibility:hidden;filter:drop-shadow(0 14px 32px rgba(10,23,51,.18));animation:splashLogoIn 1.2s cubic-bezier(.22,.61,.36,1) .15s forwards}
 .splash-rule{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:14px;opacity:0;animation:splashFadeIn .9s cubic-bezier(.22,.61,.36,1) .8s forwards}
 .splash-rule i{display:block;width:0;height:1px;background:linear-gradient(90deg,transparent,rgba(10,23,51,.4),transparent);animation:splashRuleGrow 1s cubic-bezier(.22,.61,.36,1) .85s forwards}
 .splash-rule s{width:5px;height:5px;border-radius:50%;background:#c25a2a;text-decoration:none;flex:none;box-shadow:0 0 10px rgba(194,90,42,.4)}
 .splash-name{position:relative;z-index:2;font-family:'Playfair Display','Cormorant Garamond',Georgia,serif;font-weight:500;font-size:clamp(26px,5vw,42px);letter-spacing:.02em;color:#0a0a0a;opacity:0;transform:translateY(10px);animation:splashTextIn 1s cubic-bezier(.22,.61,.36,1) 1s forwards;text-align:center;line-height:1.1}
 .splash-name b{font-weight:700;color:#0a0a0a;letter-spacing:.01em}
 .splash-tag{position:relative;z-index:2;font-family:Inter,system-ui,sans-serif;font-size:11px;font-weight:600;letter-spacing:.36em;text-transform:uppercase;color:rgba(10,23,51,.55);opacity:0;animation:splashFadeIn .9s cubic-bezier(.22,.61,.36,1) 1.3s forwards;margin-top:2px}
 @keyframes splashGlowIn{to{opacity:1;transform:translate(-50%,-58%) scale(1)}}
 @keyframes splashLogoIn{to{opacity:1;transform:translateY(0) scale(1)}}
 @keyframes splashTextIn{to{opacity:1;transform:translateY(0)}}
 @keyframes splashFadeIn{to{opacity:1}}
 @keyframes splashRuleGrow{to{width:min(48vw,260px)}}
 @media (prefers-reduced-motion:reduce){.splash-logo,.splash-name,.splash-glow,.splash-rule,.splash-rule i,.splash-tag{animation:none;opacity:1}.splash-rule i{width:min(42vw,220px)}.splash-logo,.splash-name{transform:none}.splash-glow{transform:translate(-50%,-58%)}}

/* Top utility bar */
.utility{background:#082826;color:#cfd9d7;font-size:12.5px;border-bottom:1px solid rgba(255,255,255,.06)}
.utility .inner{display:flex;justify-content:space-between;align-items:center;padding:10px 28px;max-width:var(--container);margin:0 auto;gap:20px;flex-wrap:wrap}
.utility a{color:#e8d6a9;transition:color .2s}
.utility a:hover{color:#fff}
.utility .left{display:flex;gap:22px;flex-wrap:wrap}
.utility .right{display:flex;gap:18px;align-items:center}
.utility i{margin-right:6px;color:var(--gold)}

/* Nav */
nav.site{position:sticky;top:0;z-index:90;background:rgba(250,248,244,.86);backdrop-filter:saturate(140%) blur(18px);-webkit-backdrop-filter:saturate(140%) blur(18px);border-bottom:1px solid var(--line);transition:padding .3s,box-shadow .3s}
nav.site.scrolled{padding-bottom:0;box-shadow:0 10px 30px -20px rgba(10,66,61,.25)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 28px;max-width:var(--container);margin:0 auto}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:58px;height:58px;border-radius:15px;background:linear-gradient(140deg,var(--teal),var(--teal-2));color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:var(--shadow-s),inset 0 0 0 1px rgba(255,255,255,.08)}
.brand-text{font-family:var(--serif);font-size:21px;color:var(--teal-2);font-weight:500;line-height:1.05}
.brand-text small{display:block;font-family:var(--sans);font-size:10px;letter-spacing:.28em;color:var(--gold-2);text-transform:uppercase;font-weight:600;margin-top:4px}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:14px;color:var(--ink-2);font-weight:500;position:relative;padding:6px 0;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .35s}
.nav-links a:hover{color:var(--teal-2)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:999px;font-weight:600;font-size:14px;border:none;transition:transform .25s,box-shadow .25s,background .25s,color .25s;letter-spacing:.01em}
.btn-primary{background:linear-gradient(135deg,var(--teal),var(--teal-2));color:#fff;box-shadow:var(--shadow-s)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-m)}
.btn-gold{background:linear-gradient(135deg,#d8a24a,var(--gold-2));color:#fff;box-shadow:var(--shadow-s)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:var(--shadow-m)}
.btn-ghost{background:transparent;color:var(--teal-2);border:1.5px solid rgba(10,66,61,.25)}
.btn-ghost:hover{background:var(--teal-2);color:#fff;border-color:var(--teal-2)}
.btn-light{background:#fff;color:var(--teal-2);box-shadow:var(--shadow-s)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-m)}
.hamburger{display:none;width:44px;height:44px;border-radius:12px;background:#fff;border:1px solid var(--line);align-items:center;justify-content:center;font-size:18px;color:var(--teal-2)}

/* Hero — bold dark editorial */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;overflow:hidden;isolation:isolate;background:#161616}
.hero-slides{position:absolute;inset:0;z-index:-2}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.08);transition:opacity 1.8s ease,transform 9s ease}
.hero-slide.active{opacity:1;transform:scale(1)}
.hero-veil{position:absolute;inset:0;z-index:-1;background:
  linear-gradient(95deg, rgba(10,18,42,.96) 0%, rgba(11,20,46,.90) 18%, rgba(12,22,50,.72) 34%, rgba(14,24,54,.42) 48%, rgba(16,28,60,.18) 60%, rgba(18,30,64,.05) 72%, rgba(20,32,68,0) 85%),
  radial-gradient(120% 90% at -10% 55%, rgba(8,14,36,.55), transparent 60%),
  linear-gradient(180deg, rgba(10,18,42,.20) 0%, transparent 30%, transparent 70%, rgba(8,14,36,.35) 100%)}
.hero-textwash{position:absolute;left:0;top:0;bottom:0;width:56%;z-index:-1;pointer-events:none;backdrop-filter:blur(6px) saturate(115%);-webkit-backdrop-filter:blur(6px) saturate(115%);-webkit-mask-image:linear-gradient(90deg,#000 0%,#000 35%,rgba(0,0,0,.6) 55%,rgba(0,0,0,.15) 75%,transparent 100%);mask-image:linear-gradient(90deg,#000 0%,#000 35%,rgba(0,0,0,.6) 55%,rgba(0,0,0,.15) 75%,transparent 100%)}
.hero-top{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:38px 44px;z-index:3;font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.65)}
.hero-top .badge-live{display:inline-flex;align-items:center;gap:10px;color:#fff}
.hero-top .badge-live span.dot{width:8px;height:8px;border-radius:50%;background:#5ee0a8;box-shadow:0 0 0 4px rgba(94,224,168,.18);animation:pulse 1.8s ease-in-out infinite}
.hero-inner{max-width:var(--container);margin:0 auto;padding:130px 28px 50px;width:100%;position:relative;z-index:2;display:grid;grid-template-columns:1.45fr .95fr;gap:60px;align-items:end}
.hero-inner .left{min-width:0}
.hero .kicker{display:inline-flex;align-items:center;gap:14px;font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;color:#e7c98a;font-weight:600;margin-bottom:30px}
.hero .kicker::before{content:"";width:42px;height:1px;background:#e7c98a}
.hero h1{color:#fff;font-size:clamp(40px,5.6vw,82px);line-height:1;letter-spacing:-.025em;font-weight:400;max-width:14ch}
.hero h1 em{color:#e7c98a;font-style:italic;font-weight:400;display:inline-block}
.hero h1 .line{display:block}
.hero .sub{margin-top:28px;max-width:52ch;color:rgba(255,255,255,.82);font-size:17px;line-height:1.55}
.hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;align-items:center}
.hero-cta .meta-rating{display:inline-flex;align-items:center;gap:10px;color:rgba(255,255,255,.85);font-size:13px;margin-left:4px}
.hero-cta .meta-rating .stars{color:#f5c769;letter-spacing:2px;font-size:14px}
.hero-cta .meta-rating b{color:#fff;font-weight:600}
/* Glass info card (right) */
.hero-card{display:flex;flex-direction:column;gap:18px;padding:28px;border-radius:var(--r-lg);background:rgba(20,20,22,.45);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border:1px solid rgba(255,255,255,.14);box-shadow:0 30px 80px -30px rgba(0,0,0,.6)}
.hero-card .rating{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.10)}
.hero-card .rating .stars{color:#f5c769;letter-spacing:2px;font-size:18px}
.hero-card .rating b{display:block;color:#fff;font-weight:600;font-size:15px}
.hero-card .rating small{color:rgba(255,255,255,.65);font-size:12.5px}
.hero-card .m{display:flex;gap:14px;align-items:flex-start}
.hero-card .m i{font-size:18px;color:#e7c98a;margin-top:3px;width:22px;text-align:center}
.hero-card .m b{display:block;color:#fff;font-weight:600;font-size:13px;letter-spacing:.08em}
.hero-card .m span{color:rgba(255,255,255,.72);font-size:13px}
/* Stat ribbon integrated at bottom of hero */
.hero-ribbon{position:relative;z-index:2;margin-top:80px;border-top:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.05))}
.hero-ribbon .row{max-width:var(--container);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(4,1fr)}
.hero-ribbon .cell{padding:30px 26px;border-right:1px solid rgba(255,255,255,.10);display:flex;flex-direction:column;gap:6px}
.hero-ribbon .cell:last-child{border-right:none}
.hero-ribbon .v{font-family:var(--serif);font-size:38px;color:#fff;font-weight:500;display:flex;align-items:baseline;gap:6px;line-height:1}
.hero-ribbon .v span{color:#e7c98a;font-size:22px}
.hero-ribbon .l{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.65)}
.hero-dots{position:absolute;top:50%;right:32px;transform:translateY(-50%);display:flex;flex-direction:column;gap:12px;z-index:3}
.hero-dots button{width:3px;height:28px;border-radius:2px;border:none;background:rgba(255,255,255,.25);cursor:pointer;transition:background .3s,height .3s}
.hero-dots button.active{background:#e7c98a;height:48px}
.hero-scroll{position:absolute;bottom:140px;right:36px;color:rgba(255,255,255,.55);font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;writing-mode:vertical-rl;transform:rotate(180deg);z-index:2}
.hero-rule{position:absolute;left:44px;bottom:140px;display:flex;flex-direction:column;gap:8px;z-index:2;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.hero-rule b{color:#e7c98a;font-weight:600;letter-spacing:.28em}

/* About */
.about{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);gap:56px;align-items:center}
.about-media{position:relative}
.about-media .img-main{position:relative;z-index:2;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-l);aspect-ratio:4/3;background-size:cover;background-position:center;width:100%;min-height:520px}
.about-body h2{margin:14px 0 22px}
.about-body p{color:var(--ink-2);margin-bottom:18px;font-size:16.5px}
.about-pillars{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:32px}

/* Doctor portrait — editorial split frame */
.doctor-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:80px;align-items:center}
.doc-portrait{position:relative;padding:24px 0 24px 24px}
.doc-portrait::before{content:"";position:absolute;left:0;top:0;bottom:60px;width:78%;background:linear-gradient(160deg,var(--teal-soft) 0%,#e6d3a8 100%);border-radius:var(--r-lg);z-index:0}
.doc-portrait .frame{position:relative;z-index:2;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;background-size:cover;background-position:center top;box-shadow:var(--shadow-l);margin-top:48px;margin-right:36px}
.doc-portrait .doc-tag{position:absolute;right:-12px;bottom:24px;z-index:3;background:#0a423d;color:#fff;padding:18px 24px;border-radius:14px;box-shadow:var(--shadow-m);min-width:220px}
.doc-portrait .doc-tag b{display:block;font-family:var(--serif);font-size:19px;color:#fff;margin-bottom:4px}
.doc-portrait .doc-tag span{display:block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#e7c98a;font-weight:600}

.pillar{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px;display:flex;gap:14px;align-items:flex-start;transition:transform .3s,box-shadow .3s}
.pillar:hover{transform:translateY(-3px);box-shadow:var(--shadow-m)}
.pillar i{font-size:20px;color:var(--teal);background:var(--teal-soft);width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pillar b{display:block;font-family:var(--serif);color:var(--teal-2);font-size:17px;margin-bottom:2px}
.pillar p{font-size:13.5px;color:var(--muted);margin:0}

/* Doctor */
.doctor{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%);overflow:hidden}

.doc-body h2{margin:14px 0 6px}
.doc-body .role{color:var(--gold-2);font-size:15px;font-weight:600;letter-spacing:.05em;margin-bottom:22px;text-transform:uppercase}
.doc-body p{color:var(--ink-2);margin-bottom:16px;font-size:16px}
.creds{margin-top:28px;display:flex;flex-direction:column;gap:14px}
.cred{display:flex;gap:16px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line)}
.cred:last-child{border-bottom:none}
.cred .yr{font-family:var(--serif);color:var(--gold-2);font-size:18px;width:70px;flex-shrink:0;font-weight:600}
.cred b{display:block;color:var(--teal-2);font-family:var(--serif);font-size:16px}
.cred span{color:var(--muted);font-size:13.5px}

/* Services */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:60px;flex-wrap:wrap}
.section-head h2{max-width:18ch;margin-top:12px}
.section-head .right{max-width:42ch}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.svc{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow-l)}
.svc .img{aspect-ratio:16/10;background:var(--teal-2);background-size:cover;background-position:center;position:relative;overflow:hidden}
.svc .img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(10,66,61,.65));}
.svc .img i{position:absolute;left:18px;bottom:18px;color:#fff;font-size:22px;width:46px;height:46px;background:rgba(255,255,255,.18);backdrop-filter:blur(8px);border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:1;border:1px solid rgba(255,255,255,.25)}
.svc .body{padding:22px 22px 24px;flex:1;display:flex;flex-direction:column}
.svc h3{font-size:18.5px;color:var(--teal-2);margin-bottom:8px;font-weight:500}
.svc p{color:var(--ink-2);font-size:14.5px;flex:1}
.svc .more{margin-top:16px;font-size:13px;color:var(--gold-2);font-weight:600;letter-spacing:.04em;display:inline-flex;align-items:center;gap:8px;transition:gap .25s}
.svc:hover .more{gap:14px}

/* Why */
.why{background:var(--teal-2);color:#fff}
.why h2{color:#fff}
.why .lead{color:rgba(255,255,255,.8)}
.why .eyebrow{color:#e7c98a}
.why .eyebrow::before{background:#e7c98a}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
.why-card{padding:32px 28px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);transition:transform .3s,background .3s}
.why-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.07)}
.why-card .icon{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,#e2b766,var(--gold-2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;margin-bottom:22px}
.why-card h3{color:#fff;font-size:20px;margin-bottom:10px}
.why-card p{color:rgba(255,255,255,.75);font-size:14.5px}

/* Facilities */
.fac-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.fac-list{display:grid;gap:20px}
.fac-row{display:flex;gap:18px;align-items:flex-start;padding:20px 22px;background:#fff;border:1px solid var(--line);border-radius:var(--r);transition:transform .3s,box-shadow .3s}
.fac-row:hover{transform:translateX(4px);box-shadow:var(--shadow-m)}
.fac-row i{font-size:20px;color:var(--teal);background:var(--teal-soft);width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fac-row b{display:block;font-family:var(--serif);color:var(--teal-2);font-size:18px;margin-bottom:4px}
.fac-row p{color:var(--ink-2);font-size:14px;margin:0}
.fac-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;background-size:cover;background-position:center;box-shadow:var(--shadow-l)}

/* Insurance */
.insurance{background:var(--bg-soft)}
.ins-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-top:40px}
.ins-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 16px;text-align:center;font-weight:500;color:var(--teal-2);font-size:14px;transition:transform .25s,box-shadow .25s}
.ins-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-s)}
.ins-card i{color:var(--gold-2);margin-right:8px}

/* Testimonials */
.t-track{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:60px}
.t-card{background:#fff;padding:32px 30px;border-radius:var(--r-lg);border:1px solid var(--line);position:relative;transition:transform .3s,box-shadow .3s}
.t-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.t-card .quote{position:absolute;top:-16px;left:24px;width:42px;height:42px;background:linear-gradient(135deg,#d8a24a,var(--gold-2));color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px}
.t-card .stars{color:#f5c769;letter-spacing:3px;margin-bottom:12px}
.t-card p{color:var(--ink-2);font-size:15.5px;line-height:1.7;margin-bottom:22px;font-style:italic}
.t-meta{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--line)}
.t-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-2));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:17px;font-weight:600}
.t-meta b{display:block;color:var(--teal-2);font-size:14.5px}
.t-meta span{color:var(--muted);font-size:12.5px}
.t-google{display:inline-flex;align-items:center;gap:10px;margin-top:50px;padding:14px 22px;background:#fff;border:1px solid var(--line);border-radius:999px;font-size:13.5px;color:var(--ink-2)}
.t-google b{color:var(--teal-2)}
.t-google .stars{color:#f5c769}

/* FAQ */
.faq{background:var(--bg-soft)}
.faq-list{margin-top:50px;max-width:880px;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:box-shadow .3s}
.faq-item.open{box-shadow:var(--shadow-m)}
.faq-q{padding:22px 26px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:var(--serif);color:var(--teal-2);font-size:18px;gap:20px}
.faq-q i{color:var(--gold-2);transition:transform .3s}
.faq-item.open .faq-q i{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease;padding:0 26px;color:var(--ink-2);font-size:15px}
.faq-item.open .faq-a{max-height:300px;padding:0 26px 24px}

/* Visit */
.visit-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:stretch}
.visit-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:42px;display:flex;flex-direction:column;gap:24px;box-shadow:var(--shadow-s)}
.visit-block{display:flex;gap:18px;align-items:flex-start;padding-bottom:20px;border-bottom:1px solid var(--line)}
.visit-block:last-of-type{border-bottom:none;padding-bottom:0}
.visit-block i{font-size:18px;color:#fff;background:linear-gradient(135deg,var(--teal),var(--teal-2));width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.visit-block b{display:block;font-family:var(--serif);color:var(--teal-2);font-size:18px;margin-bottom:6px}
.visit-block p,.visit-block a{color:var(--ink-2);font-size:14.5px;margin:0;line-height:1.6}
.visit-block a:hover{color:var(--teal-2)}
.visit-hours{display:grid;grid-template-columns:1fr auto;gap:6px 24px;font-size:14px;color:var(--ink-2)}
.visit-hours b{font-weight:600;color:var(--teal-2)}
.map{border-radius:var(--r-lg);overflow:hidden;min-height:500px;box-shadow:var(--shadow-m);position:relative}
.map iframe{width:100%;height:100%;border:0;display:block;min-height:500px}
.visit-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

/* CTA banner */
.cta-banner{position:relative;padding:0;margin:0}
.cta-inner{background:linear-gradient(135deg,var(--teal),var(--teal-2));border-radius:var(--r-lg);padding:60px 64px;display:flex;justify-content:space-between;align-items:center;gap:40px;color:#fff;flex-wrap:wrap;box-shadow:var(--shadow-l);position:relative;overflow:hidden}
.cta-inner::before{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(231,201,138,.25),transparent 70%)}
.cta-inner h2{color:#fff;max-width:18ch;position:relative}
.cta-inner h2 em{color:#e7c98a}
.cta-inner p{color:rgba(255,255,255,.8);margin-top:10px;max-width:46ch;position:relative}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap;position:relative}

/* Footer */
footer{background:#06102b;color:rgba(255,255,255,.7);padding:80px 0 0;margin-top:0}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:50px;padding-bottom:50px}
.f-brand{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.f-brand .brand-text{color:#fff}
.f-brand .brand-text small{color:#e7c98a}
footer h4{color:#fff;font-family:var(--serif);font-size:16px;margin-bottom:18px;font-weight:500;letter-spacing:.02em}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
footer ul a{font-size:14px;color:rgba(255,255,255,.65);transition:color .2s}
footer ul a:hover{color:#e7c98a}
.f-contact{display:flex;flex-direction:column;gap:14px;font-size:14px}
.f-contact div{display:flex;gap:12px;align-items:flex-start}
.f-contact i{color:#e7c98a;font-size:15px;margin-top:3px}
.f-bottom{border-top:1px solid rgba(255,255,255,.08);padding:24px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:12.5px;color:rgba(255,255,255,.5)}
.f-bottom a{color:#e7c98a}

/* Sticky actions */
.sticky-fab{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;flex-direction:column;gap:12px}
.fab{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;box-shadow:var(--shadow-m);transition:transform .25s}
.fab:hover{transform:scale(1.08)}
.fab.wa{background:#25d366}
.fab.call{background:linear-gradient(135deg,var(--teal),var(--teal-2))}

/* Mobile menu */
.m-menu{position:fixed;inset:0;background:rgba(6,30,28,.96);z-index:95;display:none;flex-direction:column;padding:90px 32px 40px;backdrop-filter:blur(20px)}
.m-menu.open{display:flex}
.m-menu a{color:#fff;font-family:var(--serif);font-size:30px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.m-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center}

@media (max-width:980px){
 h1{font-size:clamp(38px,8vw,56px)}
 .section{padding:80px 0}
[data-bg]{background-color:#eef2f6;background-size:cover;background-position:center}
#services,#facilities,#reviews,#visit{content-visibility:auto;contain-intrinsic-size:1px 900px}
 .nav-links,.utility .left{display:none}
 .hamburger{display:flex}
 .hero{min-height:auto}
 .hero-inner{padding:140px 24px 50px;grid-template-columns:1fr;gap:40px}
 .hero-card{padding:22px}
 .hero h1{font-size:clamp(44px,11vw,72px)}
 .hero-top{padding:24px 22px}
 .hero-top .right{display:none}
 .hero-ribbon .row{grid-template-columns:1fr 1fr}
 .hero-ribbon .cell{border-bottom:1px solid rgba(255,255,255,.10)}
 .hero-ribbon .cell:nth-child(2n){border-right:none}
 .hero-dots{flex-direction:row;top:auto;bottom:20px;right:50%;transform:translateX(50%)}
 .hero-dots button{width:28px;height:3px}
 .hero-dots button.active{width:46px;height:3px}
 .hero-rule,.hero-scroll{display:none}
 .about,.doctor-grid,.fac-grid,.visit-grid{grid-template-columns:1fr;gap:50px}
 .about-media .img-acc{display:none}
 .about-media .img-main{aspect-ratio:4/3}
 .about-media .badge{left:auto;right:20px;top:20px}
 .services-grid{grid-template-columns:1fr 1fr}
 .why-grid{grid-template-columns:1fr 1fr;margin-top:40px}
 .t-track{grid-template-columns:1fr}
 .cta-inner{padding:44px 32px}
 .f-grid{grid-template-columns:1fr 1fr;gap:36px}
 .visit-card{padding:30px}
}
@media (max-width:600px){
 .services-grid,.why-grid,.about-pillars{grid-template-columns:1fr}
 .hero-cta{width:100%}
 .hero-cta .btn{flex:1;justify-content:center}
 .hero-cta .meta-rating{margin-left:0;width:100%;justify-content:center;margin-top:8px}
 .f-grid{grid-template-columns:1fr}
}

.hero-slide{background-position:center 50%}
@media (max-width:780px){
  .hero-slide{background-position:center 38%!important;background-size:cover!important;transform:none!important}
  .hero{min-height:76svh}
  .hero-veil{background:
    linear-gradient(180deg,rgba(6,16,43,.36) 0%,rgba(6,16,43,.24) 30%,rgba(6,16,43,.68) 68%,rgba(6,16,43,.96) 100%)!important}
}



.brand-mark{background:#fff !important;padding:5px}
.brand-mark img{width:100%;height:100%;object-fit:contain;display:block}
.f-brand .brand-mark{background:rgba(255,255,255,.95) !important}

/* Mobile navbar fixes */
@media (max-width:980px){
 nav.site .nav-inner{padding:12px 16px;gap:10px;flex-wrap:nowrap}
 .brand{gap:10px;min-width:0;flex:1 1 auto;max-width:calc(100% - 110px)}
 .brand-mark{width:52px;height:52px;border-radius:12px;flex-shrink:0}
 .brand-mark img{width:44px;height:44px}
 .brand-text{font-size:15px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
 .brand-text small{font-size:8.5px;letter-spacing:.2em;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
 nav.site .btn,nav.site a.btn,nav.site .btn-gold,nav.site .btn-primary{display:none!important}
 .hamburger{display:flex;width:44px;height:44px;flex-shrink:0;margin-left:auto}
 .utility{padding:8px 16px;font-size:11px}
 .utility .right{gap:12px}
}
@media (max-width:480px){
 .brand-text{font-size:14px}
 .brand-text small{font-size:7px}
 .nav-inner{padding:8px 12px;gap:8px}
}




/* ===== Mobile responsive v12 ===== */
*{box-sizing:border-box}
html,body{overflow-x:hidden;max-width:100vw}
img,svg{max-width:100%;height:auto}
h1,h2,h3,p,a,span,b,li,div{overflow-wrap:break-word;word-wrap:break-word;min-width:0}

@media (max-width:780px){
  .container{padding:0 18px;max-width:100%}
  .section{padding:60px 0}
  .section-head{flex-direction:column;align-items:flex-start;gap:14px}
  .section-head .right{max-width:100%}

  /* Splash — smaller on mobile */
   .splash-logo{width:min(38vw,160px) !important;max-width:min(38vw,160px) !important;will-change:opacity,transform}
   .splash-name{font-size:clamp(24px,5.5vw,36px) !important}
   .splash-tag{font-size:9px !important;letter-spacing:.28em !important}
   .splash-rule i{max-width:90px}
   .splash-inner{padding:0 16px;width:100%;gap:14px}


  /* Universal heading caps - beats inline clamp */
  section h1, .hero h1{font-size:clamp(26px,7.4vw,38px) !important;line-height:1.18 !important;max-width:100% !important;letter-spacing:-.015em}
  section h2, .section h2{font-size:clamp(24px,6.4vw,32px) !important;line-height:1.2 !important;max-width:100% !important}
  h3{font-size:clamp(17px,4.6vw,21px) !important}
  .lead, p.lead{font-size:15px !important;max-width:100% !important}
}
/* Lead text on dark sections (apply at all viewports) */
[style*="color:#fff"] .lead, [style*="color: #fff"] .lead{color:rgba(255,255,255,.82) !important}
[style*="color:#fff"] p, [style*="color: #fff"] p{color:rgba(255,255,255,.82)}
@media (max-width:780px){

  /* Hero */
  .hero-inner{padding:120px 18px 40px;gap:32px}
  .hero .sub{font-size:15px;max-width:100%}
  .hero-card{padding:20px}
  .hero-card .m b{font-size:12px}
  .hero-card .m span{font-size:12.5px}
  .eyebrow{font-size:11px;letter-spacing:.22em}

  /* Hero CTA - stack, more compact */
  .hero-cta{flex-direction:column;align-items:stretch;gap:10px;width:100%;margin-top:26px}
  .hero-cta .btn{width:100%;justify-content:center;font-size:13.5px;padding:11px 16px;border-radius:999px;letter-spacing:.01em;font-weight:600}
  .hero-cta .btn i{font-size:13px}
  .hero-cta .meta-rating{margin-left:0;width:100%;justify-content:center;margin-top:4px;font-size:12.5px}

  /* Hero ribbon - 2x2 compact */
  .hero-ribbon{margin-top:48px}
  .hero-ribbon .row{padding:0;grid-template-columns:1fr 1fr}
  .hero-ribbon .cell{padding:18px 14px;border-right:1px solid rgba(255,255,255,.10)}
  .hero-ribbon .cell:nth-child(2n){border-right:none}
  .hero-ribbon .v{font-size:24px}
  .hero-ribbon .v span{font-size:14px}
  .hero-ribbon .l{font-size:9.5px;letter-spacing:.16em}

  /* Generic grids stack */
  .about,.doctor-grid,.fac-grid,.visit-grid,.f-grid,.services-grid,.why-grid,.t-track{grid-template-columns:1fr !important;gap:28px}
  .about-pillars{grid-template-columns:1fr 1fr !important;gap:8px !important;margin-top:14px !important}
  .doc-portrait::before{display:none}
  .doc-meta{position:static !important;margin-top:18px;right:auto !important;bottom:auto !important;min-width:0 !important}
  .about-media .badge{position:static !important;margin-bottom:16px;display:inline-flex !important;left:auto !important;top:auto !important}
  .about-media .img-acc{display:none !important}
  .about-media{margin:0;width:100%;max-width:none}
  .about-media .img-main{width:100%;aspect-ratio:4/3 !important;max-height:none !important;min-height:320px;border-radius:14px}
  .fac-img{aspect-ratio:16/10 !important;max-height:240px;border-radius:14px;margin:6px 0 10px}

  /* Doctor section - compact mobile */
  #doctor.section{padding:30px 0}
  .doctor-grid{gap:18px}
  .doc-portrait .frame{aspect-ratio:4/3;border-radius:14px;background-position:center 22%}
  .doc-portrait > div:not(.frame){display:none}
  .doc-body h2{font-size:24px;line-height:1.15;margin:4px 0 6px}
  .doc-body .role{font-size:12px;letter-spacing:.14em;margin-bottom:12px}
  .doc-body p{font-size:13.5px;line-height:1.55;margin:6px 0}
  .doc-body .btn{padding:11px 18px;font-size:13px}
  /* Mobile reorder handled via JS (insert portrait before .role) */
  .creds{margin-top:18px;gap:0}
  .cred{display:grid;grid-template-columns:60px 1fr;align-items:start;gap:10px;padding:10px 0;border-bottom:1px solid rgba(176,138,62,.18)}
  .cred:last-child{border-bottom:none}
  .cred .yr{font-size:13px;width:auto}
  .cred b{font-size:13.5px}
  .cred span{font-size:12px}

  /* About section - compact mobile */
  #about.section{padding:30px 0}
  .about{gap:18px}
  .about-media .img-main{aspect-ratio:4/3 !important;max-height:none !important;min-height:320px}
  .about-media .badge{padding:12px 16px;border-radius:12px}
  .about-media .badge i{font-size:18px}
  .about-media .badge b{font-size:18px}
  .about-media .badge span{font-size:11px}
  .about-body h2{font-size:24px;line-height:1.2;margin:8px 0 12px}
  .about-body p{font-size:13.5px;line-height:1.55;margin:8px 0}
  .about-pillars{gap:8px;margin-top:14px}
  .pillar{padding:10px 10px;gap:6px;flex-direction:column;align-items:flex-start;border-radius:12px}
  .pillar i{font-size:14px;width:28px;height:28px;border-radius:8px;margin-bottom:2px}
  .pillar b{font-size:12.5px;line-height:1.2;margin-bottom:2px}
  .pillar p{font-size:11px;line-height:1.35}

  /* Doctor section - compact mobile */
  #doctor.section{padding:30px 0}
  .doctor-grid{gap:18px}
  .doc-portrait .frame{aspect-ratio:4/3;border-radius:14px;background-position:center 22%}
  .doc-portrait > div:not(.frame){display:none}
  .doc-body h2{font-size:24px;line-height:1.15;margin:4px 0 6px}
  .doc-body .role{font-size:12px;letter-spacing:.14em;margin-bottom:12px}
  .doc-body p{font-size:13.5px;line-height:1.55;margin:6px 0}
  .doc-body .btn{padding:11px 18px;font-size:13px}
  .creds{margin-top:18px;gap:0}
  .cred{display:grid;grid-template-columns:60px 1fr;align-items:start;gap:10px;padding:10px 0;border-bottom:1px solid rgba(176,138,62,.18)}
  .cred:last-child{border-bottom:none}
  .cred .yr{font-size:13px;width:auto}
  .cred b{font-size:13.5px}
  .cred span{font-size:12px}

  /* About section - compact mobile */
  #about.section{padding:30px 0}
  .about{gap:18px}
  .about-media .img-main{aspect-ratio:4/3 !important;max-height:none !important;min-height:320px}
  .about-media .badge{padding:12px 16px;border-radius:12px}
  .about-media .badge i{font-size:18px}
  .about-media .badge b{font-size:18px}
  .about-media .badge span{font-size:11px}
  .about-body h2{font-size:24px;line-height:1.2;margin:8px 0 12px}
  .about-body p{font-size:13.5px;line-height:1.55;margin:8px 0}
  .about-pillars{gap:8px;margin-top:14px}
  .pillar{padding:10px 10px;gap:6px;flex-direction:column;align-items:flex-start;border-radius:12px}
  .pillar i{font-size:14px;width:28px;height:28px;border-radius:8px;margin-bottom:2px}
  .pillar b{font-size:12.5px;line-height:1.2;margin-bottom:2px}
  .pillar p{font-size:11px;line-height:1.35}

  /* CTA section */
  .cta-inner{padding:36px 22px}
  .cta-inner h2{font-size:clamp(24px,7vw,34px) !important;max-width:100% !important}
  .cta-inner p{font-size:14.5px;max-width:100%}

  /* Footer */
  .footer{padding:48px 0 28px}
  .f-grid{gap:32px}
  .f-bottom{flex-direction:column;gap:12px;text-align:center}

  /* Cards generic */
  .card,.service-card,.fac-card,.why-card,.t-card,.review-card,.visit-card{padding:20px}

  /* Mobile menu items */
  .m-menu a{font-size:24px;padding:12px 0}
}

@media (max-width:420px){
  .container{padding:0 14px}
  .hero-inner{padding:108px 14px 32px}
  section h1, .hero h1{font-size:28px !important}
  .hero-card{padding:16px}
  .hero-ribbon .v{font-size:21px}
  .hero-ribbon .v span{font-size:13px}
  .hero-ribbon .l{font-size:8.5px}
  .cta-inner{padding:30px 18px}

  /* Doctor + About - extra compact on small screens */
  .doc-portrait .frame{aspect-ratio:1/1 !important}
  .doc-body h2{font-size:22px}
  .about-media .img-main{aspect-ratio:4/3 !important;max-height:none !important;min-height:300px}
  .about-body h2{font-size:22px}
  .about-pillars{gap:6px}
  .pillar{padding:9px 9px}
  .pillar i{width:26px;height:26px;font-size:13px}
  .pillar b{font-size:12px}
  .pillar p{font-size:10.5px}
}

/* ===== Reference-exact hero override (desktop) ===== */
@media (min-width:781px){
  .hero{min-height:100vh;justify-content:space-between}
  .hero-top,.hero-rule,.hero-scroll,.hero-dots,.hero-card{display:none !important}
  .hero-inner{grid-template-columns:1fr;gap:24px;padding:110px 44px 30px;align-items:start}
  .hero-veil{background:
    linear-gradient(180deg,rgba(8,14,30,.10) 0%,rgba(8,14,30,.18) 35%,rgba(8,14,30,.55) 80%,rgba(8,14,30,.80) 100%),
    linear-gradient(90deg,rgba(8,14,30,.55) 0%,rgba(8,14,30,.20) 55%,rgba(8,14,30,0) 100%) !important}
  .hero-chip{display:inline-flex;align-items:center;gap:10px;background:rgba(20,25,40,.55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.14);color:#fff;padding:9px 18px;border-radius:999px;font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:26px;font-weight:500}
  .hero-chip::before{content:"";width:8px;height:8px;border-radius:50%;background:#5ee0a8;box-shadow:0 0 0 4px rgba(94,224,168,.18);animation:pulse 1.8s ease-in-out infinite}
  .hero .kicker{color:#e7c98a;margin-bottom:24px}
  .hero h1{max-width:16ch;font-size:clamp(48px,5.4vw,80px)}
  .hero .sub{max-width:46ch;color:rgba(255,255,255,.86)}
  .hero-cta{flex-direction:row;gap:14px;margin-top:32px}
  .hero-cta .btn{padding:16px 30px;font-size:14.5px;border-radius:14px;font-weight:600}
  .hero-cta .btn-gold{background:linear-gradient(135deg,#d8a24a,#b8862a);box-shadow:0 12px 30px -10px rgba(184,134,42,.55)}
  .hero-cta .btn-light{background:#fff;color:#1e3a6e}
  /* Premium glassmorphism stats ribbon */
  .hero-ribbon{margin:0 28px 28px;background:
      radial-gradient(120% 140% at 50% 0%, rgba(20,32,62,.62) 0%, rgba(10,18,40,.46) 55%, rgba(8,16,38,.22) 100%);
    backdrop-filter:blur(18px) saturate(130%);-webkit-backdrop-filter:blur(18px) saturate(130%);
    border:1px solid rgba(176,138,62,.22);border-top-color:rgba(212,170,90,.38);border-bottom-color:rgba(176,138,62,.10);
    border-radius:18px;box-shadow:0 30px 80px -40px rgba(0,0,0,.6), 0 0 60px -22px rgba(212,170,90,.22), inset 0 1px 0 rgba(255,255,255,.05);
    position:relative;z-index:3;overflow:hidden}
  .hero-ribbon::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(212,170,90,.10) 50%,transparent 100%);height:1px;top:0}
  .hero-ribbon .row{padding:18px 24px;grid-template-columns:repeat(4,1fr);gap:0;max-width:none;margin:0}
  .hero-ribbon .cell{padding:6px 22px;border-right:1px solid rgba(212,170,90,.16);display:flex;flex-direction:row;align-items:center;gap:14px;background:transparent}
  .hero-ribbon .cell:last-child{border-right:none}
  .hero-ribbon .cell-ico{width:38px;height:38px;border-radius:50%;background:rgba(212,170,90,.10);color:#e7c98a;border:1px solid rgba(212,170,90,.28);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
  .hero-ribbon .cell-text{display:flex;flex-direction:column;gap:3px}
  .hero-ribbon .v{font-family:var(--serif);font-size:26px;color:#fff;font-weight:500;line-height:1;letter-spacing:.005em}
  .hero-ribbon .v span{color:#e7c98a;font-size:15px;margin-left:3px;font-weight:400}
  .hero-ribbon .l{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.62);font-family:var(--sans);font-weight:500;line-height:1.3}
  /* Nav cream look + gold book btn */
  nav.site{background:rgba(250,245,233,.92)}
  nav.site .btn-primary{background:linear-gradient(135deg,#d8a24a,#b8862a);color:#fff}
  nav.site .nav-links a.active{color:#b8862a}
  nav.site .nav-links a.active::after{transform:scaleX(1);background:#b8862a}
}
/* Mobile hide chip-extras gracefully */
@media (max-width:780px){
  .hero-chip{display:inline-flex;align-items:center;gap:8px;background:rgba(20,25,40,.55);border:1px solid rgba(255,255,255,.14);color:#fff;padding:7px 14px;border-radius:999px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;font-weight:500}
  .hero-chip::before{content:"";width:7px;height:7px;border-radius:50%;background:#5ee0a8}
}

/* =================== v51 — Reference-match landing hero =================== */
.hero-v2{position:relative;min-height:100vh;display:block;color:#fff;overflow:hidden;isolation:isolate;background:#161616;padding-bottom:140px;font-family:'Plus Jakarta Sans','Inter',system-ui,sans-serif}
.hero-v2 h1,.hero-v2 h1 em{font-family:'Cormorant Garamond',Georgia,serif}
.hero-v2 .hero-bg{position:absolute;inset:0;z-index:-2;display:block;overflow:hidden}
.hero-v2 .hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center right;display:block}
.hero-v2 .hero-veil{position:absolute;inset:0;z-index:-1;pointer-events:none;background:
  linear-gradient(96deg, rgba(8,16,38,.94) 0%, rgba(10,18,42,.88) 14%, rgba(11,20,46,.72) 30%, rgba(13,22,50,.46) 44%, rgba(15,26,56,.22) 58%, rgba(18,30,62,.06) 72%, rgba(20,32,68,0) 88%),
  radial-gradient(140% 95% at -8% 55%, rgba(6,12,30,.55), transparent 62%),
  linear-gradient(180deg, rgba(8,14,34,.18) 0%, transparent 26%, transparent 74%, rgba(6,12,28,.38) 100%)}
.hero-v2 .hero-textwash{position:absolute;left:0;top:0;bottom:0;width:55%;z-index:-1;pointer-events:none;backdrop-filter:blur(5px) saturate(118%);-webkit-backdrop-filter:blur(5px) saturate(118%);-webkit-mask-image:linear-gradient(95deg,#000 0%,#000 32%,rgba(0,0,0,.55) 55%,rgba(0,0,0,.15) 78%,transparent 100%);mask-image:linear-gradient(95deg,#000 0%,#000 32%,rgba(0,0,0,.55) 55%,rgba(0,0,0,.15) 78%,transparent 100%)}
.hero-v2 .hero-inner{max-width:var(--container);margin:0 auto;padding:110px 44px 60px;width:100%;position:relative;z-index:2;display:block}
.hero-v2 .left{max-width:640px}
.hero-v2 .hero-chip{display:inline-flex;align-items:center;gap:10px;background:rgba(20,25,40,.55);border:1px solid rgba(255,255,255,.16);color:#fff;padding:9px 18px;border-radius:999px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:26px;font-weight:500}
.hero-v2 .hero-chip .dot{width:8px;height:8px;border-radius:50%;background:#5ee0a8;box-shadow:0 0 0 4px rgba(94,224,168,.18);animation:pulse 1.8s ease-in-out infinite}
.hero-v2 .kicker{display:inline-flex;align-items:center;gap:14px;font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:#ffd98a;font-weight:700;margin-bottom:24px;text-shadow:0 2px 14px rgba(0,0,0,.55),0 1px 2px rgba(0,0,0,.6)}
.hero-v2 .kicker::before{content:"";width:42px;height:1.5px;background:#ffd98a;box-shadow:0 0 8px rgba(0,0,0,.4)}
 .hero-v2 h1{color:#fff;font-family:var(--serif);font-size:clamp(40px,5.2vw,72px);line-height:1.02;letter-spacing:-.015em;font-weight:400;max-width:15ch}
 .hero-v2 h1 .line{display:block}
 .hero-v2 h1 em{color:#e7c98a;font-style:italic;font-weight:500;position:relative}
 .hero-v2 h1 em::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:linear-gradient(90deg,transparent,#e7c98a 30%,#e7c98a 70%,transparent)}
 .hero-v2 .sub{margin-top:24px;color:rgba(255,255,255,.78);font-size:15px;line-height:1.6;max-width:46ch;font-weight:300;letter-spacing:.005em}
 .hero-v2 .creds{display:flex;gap:22px;flex-wrap:wrap;margin-top:22px;color:rgba(255,255,255,.6);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
 .hero-v2 .creds span{display:inline-flex;align-items:center;gap:8px}
 .hero-v2 .creds span i{color:#e7c98a;font-size:11px}
 .hero-v2 .hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
 .hero-v2 .hero-cta .btn{padding:14px 28px;font-size:13px;border-radius:999px;font-weight:600;display:inline-flex;align-items:center;gap:10px;letter-spacing:.04em;text-transform:uppercase}
.hero-v2 .hero-cta .btn-gold{background:linear-gradient(180deg,#d99a4a,#b7782c);color:#fff;border:none;box-shadow:0 12px 30px -10px rgba(183,120,44,.55)}
.hero-v2 .hero-cta .btn-light{background:#fff;color:#0f1b3d;border:none}
.hero-v2 .hero-ribbon{position:absolute;left:44px;right:44px;bottom:30px;z-index:3;background:#f3ede1;border:none;border-radius:18px;box-shadow:0 30px 80px -20px rgba(0,0,0,.45);margin:0;max-width:none}
.hero-v2 .hero-ribbon .row{max-width:none;margin:0;padding:26px 30px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.hero-v2 .hero-ribbon .cell{padding:6px 18px;border-right:1px solid rgba(15,27,61,.08);display:flex;flex-direction:row;align-items:center;gap:18px;flex-direction:row}
.hero-v2 .hero-ribbon .cell:last-child{border-right:none}
.hero-v2 .hero-ribbon .cell-ico{width:58px;height:58px;border-radius:50%;background:#ece0c6;color:#1e3a6e;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.hero-v2 .hero-ribbon .cell-text{display:flex;flex-direction:column;gap:4px}
.hero-v2 .hero-ribbon .v{font-family:var(--serif);font-size:32px;color:#0f1b3d;font-weight:600;line-height:1;display:flex;align-items:baseline;gap:4px}
.hero-v2 .hero-ribbon .v span{color:#0f1b3d;font-size:20px}
.hero-v2 .hero-ribbon .l{font-size:13.5px;letter-spacing:0;text-transform:none;color:#6b7493;font-family:var(--sans);font-weight:400;line-height:1.3}
@media (max-width:900px){
 .hero-v2{min-height:auto;padding-bottom:0}
  .hero-v2 .hero-bg img{object-position:72% 38%}
 .hero-v2 .hero-veil{background:linear-gradient(180deg,rgba(10,18,32,.5) 0%,rgba(10,18,32,.55) 45%,rgba(10,18,32,.92) 90%)}
 .hero-v2 .hero-inner{padding:110px 20px 30px}
 .hero-v2 h1{font-size:clamp(32px,8.4vw,46px);max-width:none}
 .hero-v2 .sub{font-size:13.5px;line-height:1.55;max-width:none}
 .hero-v2 .sub br{display:none}
 .hero-v2 .creds{gap:14px;font-size:9.5px;letter-spacing:.18em;margin-top:18px}
 .hero-v2 .hero-cta .btn{font-size:12px;padding:13px 20px}
 .hero-v2 .hero-cta{flex-direction:column;gap:10px}
 .hero-v2 .hero-cta .btn{width:100%;justify-content:center}
 .hero-v2 .hero-ribbon{position:relative;left:auto;right:auto;bottom:auto;margin:24px 16px;border-radius:14px}
 .hero-v2 .hero-ribbon .row{grid-template-columns:1fr 1fr;padding:16px;gap:10px}
 .hero-v2 .hero-ribbon .cell{padding:10px;gap:12px;border-right:1px solid rgba(15,27,61,.08)}
 .hero-v2 .hero-ribbon .cell:nth-child(2n){border-right:none}
 .hero-v2 .hero-ribbon .cell-ico{width:44px;height:44px;font-size:17px}
 .hero-v2 .hero-ribbon .v{font-size:22px}
 .hero-v2 .hero-ribbon .v span{font-size:14px}
 .hero-v2 .hero-ribbon .l{font-size:11.5px}
}

/* ===== v128 mobile fixes ===== */
@media (max-width:780px){
  .doc-portrait{padding:0 !important}
  .doc-portrait .frame{margin:0 !important;aspect-ratio:4/5 !important;max-height:none !important;width:100% !important;border-radius:16px;background-position:center top}
  .doctor-grid{gap:14px !important}
  #pharmacy .fac-img,#facility-corridor .fac-img,#ricu .fac-img{aspect-ratio:4/5 !important;max-height:none !important;width:100%;border-radius:16px;min-height:0 !important;margin:0 0 6px !important}
  .svc-bento{grid-template-columns:1fr !important;gap:14px !important}
  .svc-bento .sb{min-height:220px !important;padding:22px !important}
  .svc-bento .sb-title{font-size:22px !important}
  .svc-bento .sb-tag{font-size:10.5px !important}
}
@media (max-width:520px){
  .svc-bento{grid-template-columns:1fr !important}
  .svc-bento .sb{min-height:200px !important}
}
