/* ============================================================
   Gozalyan Doctors — Dental Clinic
   Design system + responsive landing page
   ============================================================ */

:root{
  /* Brand navy scale (from logo / poster) */
  --navy-900:#081a33;
  --navy-800:#0a1f3c;   /* primary deep brand */
  --navy-700:#102a4c;
  --navy-600:#16365f;
  --navy-500:#1d4474;

  /* Accent blue (tweakable) */
  --accent:#2f6fb5;
  --accent-600:#285f9d;
  --accent-300:#7db0e6;

  /* Neutrals — subtly cool */
  --ink:#0c1c33;
  --slate:#56657c;
  --slate-light:#7d8aa0;
  --line:#e4eaf2;
  --line-soft:#eef2f8;
  --paper:#ffffff;
  --mist:#f5f8fc;
  --mist-2:#eef3fa;

  /* Type */
  --serif:'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Form */
  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 1px 2px rgba(10,31,60,.06), 0 4px 14px rgba(10,31,60,.05);
  --shadow-md:0 10px 30px -10px rgba(10,31,60,.18), 0 4px 12px rgba(10,31,60,.06);
  --shadow-lg:0 30px 60px -22px rgba(8,26,51,.45);
  --maxw:1200px;
  --gut:clamp(20px,5vw,64px);
}

/* Heading serif alternates (tweakable) */
:root[data-serif="cormorant"]{ --serif:'Cormorant Garamond', Georgia, serif; }
:root[data-serif="caslon"]{ --serif:'Libre Caslon Text', Georgia, serif; }

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:88px; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3{ margin:0; line-height:1.08; font-weight:600; letter-spacing:-.01em; }
p{ margin:0; }
.serif{ font-family:var(--serif); }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }

.eyebrow{
  font-size:13px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--accent); display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:26px; height:1.5px; background:var(--accent); display:inline-block; }
.eyebrow.center::after{ content:""; width:26px; height:1.5px; background:var(--accent); display:inline-block; }
.eyebrow.center{ justify-content:center; }

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 28px; border-radius:999px; font-size:15.5px; font-weight:700;
  letter-spacing:.01em; border:1.5px solid transparent; white-space:nowrap;
  transition:transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s, background .25s, color .25s, border-color .25s;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--accent); color:#fff; box-shadow:0 12px 26px -12px var(--accent); }
.btn-primary:hover{ background:var(--accent-600); transform:translateY(-2px); box-shadow:0 18px 34px -12px var(--accent); }
.btn-navy{ background:var(--navy-800); color:#fff; }
.btn-navy:hover{ background:var(--navy-700); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--navy-800); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--accent); color:var(--accent); transform:translateY(-2px); }
.btn-light{ background:#fff; color:var(--navy-800); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-outline-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.4); }
.btn-outline-light:hover{ border-color:#fff; background:rgba(255,255,255,.08); transform:translateY(-2px); }
.btn-lg{ padding:18px 34px; font-size:16.5px; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s, background .3s;
}
.site-header.scrolled{ border-color:var(--line); box-shadow:0 6px 24px -16px rgba(10,31,60,.4); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; height:78px; }
.brand{ display:flex; align-items:center; gap:13px; }
.brand img{ height:46px; width:auto; }
.brand-text{ display:flex; flex-direction:column; line-height:1.05; min-width:0; }
.brand-text b{ font-family:var(--serif); font-size:18px; font-weight:600; color:var(--navy-800); letter-spacing:.01em; white-space:nowrap; }
.brand-text > span{ font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--slate-light); margin-top:5px; white-space:nowrap; }

.nav{ display:flex; align-items:center; gap:34px; }
.nav a{ font-size:15px; font-weight:600; color:var(--navy-700); position:relative; padding:6px 0; }
.nav a::after{ content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--accent); transition:width .28s; }
.nav a:hover{ color:var(--accent); }
.nav a:hover::after{ width:100%; }

.header-cta{ display:flex; align-items:center; gap:16px; }
.header-phone{ display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--navy-800); font-size:15px; white-space:nowrap; }
.header-phone svg{ width:17px; height:17px; color:var(--accent); }

.menu-btn{ display:none; background:none; border:none; padding:8px; color:var(--navy-800); }
.menu-btn svg{ width:26px; height:26px; }

/* mobile drawer */
.drawer{ position:fixed; inset:0; z-index:60; visibility:hidden; pointer-events:none; }
.drawer-scrim{ position:absolute; inset:0; background:rgba(8,26,51,.45); opacity:0; transition:opacity .3s; }
.drawer-panel{
  position:absolute; top:0; right:0; height:100%; width:min(82vw,340px);
  background:#fff; padding:28px 26px; display:flex; flex-direction:column; gap:6px;
  transform:translateX(100%); transition:transform .34s cubic-bezier(.2,.7,.3,1); box-shadow:var(--shadow-lg);
}
.drawer.open{ visibility:visible; pointer-events:auto; }
.drawer.open .drawer-scrim{ opacity:1; }
.drawer.open .drawer-panel{ transform:translateX(0); }
.drawer-panel .drawer-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.drawer-panel a:not(.btn){ padding:14px 4px; font-size:18px; font-weight:600; color:var(--navy-800); border-bottom:1px solid var(--line-soft); }
.drawer-panel .btn{ margin-top:20px; }
.drawer-close{ background:none; border:none; color:var(--navy-800); padding:6px; }
.drawer-close svg{ width:26px; height:26px; }

/* ============================================================
   HERO  (3 tweakable treatments via [data-hero])
   ============================================================ */
.hero{ position:relative; overflow:hidden; }
.hero-bg{ display:none; }
.hero-inner{
  display:grid; grid-template-columns:1.04fr .96fr; align-items:center;
  gap:clamp(32px,5vw,72px);
  max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut);
}
.hero-copy{ padding:clamp(48px,7vw,96px) 0; max-width:600px; }
.hero-copy .eyebrow{ margin-bottom:22px; }
.hero h1{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(44px,6.2vw,82px); line-height:1.02; letter-spacing:-.02em;
  color:var(--navy-800);
}
.hero h1 .accentword{ font-weight:700; font-style:italic; color:var(--accent); }
.hero .tagline{ font-size:clamp(18px,2.1vw,23px); color:var(--slate); margin-top:24px; max-width:30ch; line-height:1.5; }
.hero .slogan{
  display:inline-flex; align-items:center; gap:14px; margin-top:26px;
  font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--navy-700);
}
.hero .slogan span{ display:inline-flex; align-items:center; gap:14px; }
.hero .slogan i{ width:5px; height:5px; border-radius:50%; background:var(--accent); display:inline-block; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; }
.hero-meta{ display:flex; align-items:center; gap:14px; margin-top:34px; color:var(--slate); font-size:14.5px; }
.hero-meta .stars{ color:#e8b53d; letter-spacing:2px; font-size:16px; }
.hero-meta b{ color:var(--navy-800); }

.hero-media{ position:relative; align-self:stretch; background:var(--navy-800); }
.hero-media img{ width:100%; height:100%; object-fit:contain; object-position:center top; }

/* --- Treatment: SPLIT (default) — light copy left, photo panel right --- */
:root[data-hero="split"] .hero{ background:linear-gradient(180deg,#fff 0%, var(--mist) 100%); }
:root[data-hero="split"] .hero{ background:linear-gradient(180deg,#fff 0%, var(--mist) 100%); min-height:calc(100svh - 78px); }
:root[data-hero="split"] .hero-media{
  border-radius:0; overflow:hidden; min-height:0;
  background:var(--navy-800);
  -webkit-mask:none;
}
:root[data-hero="split"] .hero-media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(110deg, var(--mist) 0%, rgba(245,248,252,0) 22%),
    linear-gradient(to bottom, rgba(8,26,51,0) 58%, var(--navy-800) 90%);
  pointer-events:none;
}
:root[data-hero="split"] .hero-inner{ gap:0; grid-template-columns:42% 58%; min-height:calc(100svh - 78px); align-items:stretch; }
:root[data-hero="split"] .hero-copy{ align-self:center; padding-right:clamp(24px,4vw,64px); }

/* --- Treatment: FRAMED — navy bg, photo in floating rounded card --- */
:root[data-hero="framed"] .hero{ background:radial-gradient(120% 120% at 80% 0%, var(--navy-700) 0%, var(--navy-900) 70%); }
:root[data-hero="framed"] .hero h1{ color:#fff; }
:root[data-hero="framed"] .hero .tagline{ color:#c3d2e6; }
:root[data-hero="framed"] .hero .slogan{ color:#9fb6d2; }
:root[data-hero="framed"] .hero .eyebrow{ color:var(--accent-300); }
:root[data-hero="framed"] .hero .eyebrow::before{ background:var(--accent-300); }
:root[data-hero="framed"] .hero-meta{ color:#a9bcd6; }
:root[data-hero="framed"] .hero-meta b{ color:#fff; }
:root[data-hero="framed"] .hero-copy{ padding-block:clamp(56px,8vw,108px); }
:root[data-hero="framed"] .hero-media{
  min-height:0; margin:clamp(40px,6vw,80px) 0; border-radius:24px; overflow:hidden;
  align-self:center; aspect-ratio:1086 / 858;
  box-shadow:var(--shadow-lg); border:1px solid rgba(255,255,255,.12);
  outline:8px solid rgba(255,255,255,.04); outline-offset:0;
}
:root[data-hero="framed"] .hero-media::before{
  content:""; position:absolute; inset:0; z-index:2; border-radius:24px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}

/* --- Treatment: BLEED — full photo background, white copy --- */
/* --- Treatment: BLEED — full-screen photo, copy anchored at the bottom --- */
:root[data-hero="bleed"] .hero{ background:var(--navy-900); min-height:calc(100svh - 78px); }
:root[data-hero="bleed"] .hero-bg{
  display:block; position:absolute; inset:0;
  background:url('assets/hero-doctors.png') center top/cover no-repeat;
}
:root[data-hero="bleed"] .hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(8,26,51,.42) 0%, rgba(8,26,51,0) 22%, rgba(8,26,51,0) 44%, rgba(8,26,51,.74) 82%, var(--navy-900) 100%),
    linear-gradient(90deg, rgba(8,26,51,.6) 0%, rgba(8,26,51,.12) 46%, rgba(8,26,51,0) 72%);
}
:root[data-hero="bleed"] .hero-inner{ grid-template-columns:none; display:flex; align-items:flex-end; min-height:calc(100svh - 78px); position:relative; z-index:2; }
:root[data-hero="bleed"] .hero-media{ display:none; }
:root[data-hero="bleed"] .hero-copy{ width:100%; max-width:640px; padding-block:0 clamp(44px,8vh,96px); }
:root[data-hero="bleed"] .hero h1{ color:#fff; }
:root[data-hero="bleed"] .hero .tagline{ color:#cddaec; }
:root[data-hero="bleed"] .hero .slogan{ color:#aebfda; }
:root[data-hero="bleed"] .hero .eyebrow{ color:var(--accent-300); }
:root[data-hero="bleed"] .hero .eyebrow::before{ background:var(--accent-300); }
:root[data-hero="bleed"] .hero-meta{ color:#bdcde3; }
:root[data-hero="bleed"] .hero-meta b{ color:#fff; }
/* On the dark photo/navy hero treatments, make the ghost "Call Us" button legible */
:root[data-hero="bleed"] .hero-actions .btn-ghost,
:root[data-hero="framed"] .hero-actions .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.45); }
:root[data-hero="bleed"] .hero-actions .btn-ghost:hover,
:root[data-hero="framed"] .hero-actions .btn-ghost:hover{ color:#fff; border-color:#fff; background:rgba(255,255,255,.1); }
:root[data-hero="stage"] .hero-actions .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.45); }
:root[data-hero="stage"] .hero-actions .btn-ghost:hover{ color:#fff; border-color:#fff; background:rgba(255,255,255,.1); }

/* --- Treatment: STAGE (default) — photo banner on top (faces always fully
       visible at a capped, width-based height), copy flows in the navy zone just
       below and overlaps onto the dark scrubs so it reads as "on the picture,
       under the faces." Height is driven by width only — stable on any viewport. --- */
:root[data-hero="stage"] .hero{ background:var(--navy-900); }
:root[data-hero="stage"] .hero-bg{ display:none !important; }
:root[data-hero="stage"] .hero-inner{
  position:relative;
  display:flex; flex-direction:column; align-items:center; justify-content:flex-start; gap:0;
  grid-template-columns:none; max-width:none; margin:0; padding-inline:0;
  min-height:0;
}
:root[data-hero="stage"] .hero-media{
  order:-1; position:relative; z-index:0;
  align-self:stretch; width:100%; margin:0;
  height:clamp(560px, 72vw, 1040px); min-height:0;
  border:none; outline:none; box-shadow:none; border-radius:0;
  background:var(--navy-900); display:block;
}
:root[data-hero="stage"] .hero-media::before{ content:none !important; display:none !important; }
/* fade only the very bottom of the photo into navy — keep chest & hands visible */
:root[data-hero="stage"] .hero-media::after{
  content:"" !important; display:block !important;
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg,
    rgba(8,26,51,0) 62%,
    rgba(8,26,51,.35) 82%,
    rgba(8,26,51,.88) 96%,
    var(--navy-900) 100%);
}
:root[data-hero="stage"] .hero-media img{
  width:100% !important; height:100% !important;
  object-fit:cover !important; object-position:center top !important;
}
:root[data-hero="stage"] .hero-copy{
  position:relative; z-index:2;
  order:0; align-self:center; width:100%; max-width:900px; text-align:center;
  margin-top:clamp(-16px, 0.5vw, 28px);
  padding:0 var(--gut) clamp(48px,6vw,86px);
}
:root[data-hero="stage"] .hero h1{ color:#fff; }
:root[data-hero="stage"] .hero .tagline{ color:#d4e0ef; margin-inline:auto; max-width:54ch; }
:root[data-hero="stage"] .hero .eyebrow{ color:var(--accent-300); }
:root[data-hero="stage"] .hero .eyebrow::before{ background:var(--accent-300); }
:root[data-hero="stage"] .hero .slogan{ color:#bccde4; }
:root[data-hero="stage"] .hero-meta{ color:#c4d4e9; }
:root[data-hero="stage"] .hero-meta b{ color:#fff; }
:root[data-hero="stage"] .hero-copy .eyebrow{ justify-content:center; }
:root[data-hero="stage"] .hero-copy .eyebrow::after{ content:""; width:26px; height:1.5px; background:var(--accent-300); display:inline-block; }
:root[data-hero="stage"] .hero .slogan,
:root[data-hero="stage"] .hero-actions,
:root[data-hero="stage"] .hero-meta{ justify-content:center; }

/* ============================================================
   TRUST BADGES
   ============================================================ */
.trust{ background:var(--navy-800); color:#fff; }
.trust .wrap{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,4vw,56px); padding-block:clamp(40px,5vw,60px); }
.trust-item{ display:flex; gap:18px; align-items:flex-start; }
.trust-item .ti-icon{
  flex:none; width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  background:linear-gradient(160deg, rgba(255,255,255,.14), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.14);
}
.trust-item .ti-icon svg{ width:26px; height:26px; color:var(--accent-300); }
.trust-item h3{ font-size:17px; font-weight:700; letter-spacing:.01em; }
.trust-item p{ color:#a9bcd6; font-size:14.5px; margin-top:5px; line-height:1.45; }
.trust-sep{ position:relative; }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
section.block{ padding-block:clamp(72px,9vw,128px); }
.sec-head{ max-width:640px; }
.sec-head.center{ margin:0 auto; text-align:center; }
.sec-head h2{
  font-family:var(--serif); font-weight:500; color:var(--navy-800);
  font-size:clamp(32px,4.4vw,52px); line-height:1.06; letter-spacing:-.018em; margin-top:18px;
}
.sec-head p{ color:var(--slate); font-size:18px; margin-top:18px; line-height:1.55; }

/* ============================================================
   SERVICES
   ============================================================ */
.services{ background:var(--mist); }
.services-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:32px; flex-wrap:wrap; }
.svc-grid{
  margin-top:clamp(40px,5vw,60px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
}
.svc-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:30px 26px 28px; display:flex; flex-direction:column; gap:14px;
  box-shadow:var(--shadow-sm); transition:transform .3s cubic-bezier(.2,.7,.3,1), box-shadow .3s, border-color .3s;
  position:relative; overflow:hidden;
}
.svc-card::before{
  content:""; position:absolute; left:0; top:0; height:3px; width:0; background:var(--accent); transition:width .35s;
}
.svc-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.svc-card:hover::before{ width:100%; }
.svc-ico{
  width:56px; height:56px; border-radius:15px; display:grid; place-items:center;
  background:var(--mist-2); color:var(--accent); transition:background .3s, color .3s;
}
.svc-ico svg{ width:28px; height:28px; }
.svc-card:hover .svc-ico{ background:var(--accent); color:#fff; }
.svc-card h3{ font-size:19px; font-weight:700; color:var(--navy-800); font-family:var(--serif); letter-spacing:0; }
.svc-card p{ color:var(--slate); font-size:14.5px; line-height:1.5; }
.svc-card .svc-link{ margin-top:auto; padding-top:8px; font-size:13.5px; font-weight:700; color:var(--accent); display:inline-flex; align-items:center; gap:7px; letter-spacing:.02em; }
.svc-card .svc-link svg{ width:15px; height:15px; transition:transform .3s; }
.svc-card:hover .svc-link svg{ transform:translateX(4px); }
/* highlighted CTA card */
.svc-card.cta{
  background:linear-gradient(155deg, var(--navy-700), var(--navy-900));
  border-color:transparent; color:#fff; justify-content:center; gap:18px;
}
.svc-card.cta::before{ display:none; }
.svc-card.cta h3{ color:#fff; }
.svc-card.cta p{ color:#b6c6dd; }
.svc-card.cta .btn{ align-self:flex-start; margin-top:6px; }

/* ============================================================
   DOCTORS
   ============================================================ */
.doctors-grid{ margin-top:clamp(44px,5vw,64px); display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.doc-card{
  display:grid; grid-template-columns:200px 1fr; gap:0; background:#fff;
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm);
  transition:transform .3s, box-shadow .3s;
}
.doc-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.doc-photo{ position:relative; background:var(--navy-800); overflow:hidden; min-height:280px; }
.doc-photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:top center; }
.doc-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,26,51,0) 55%, rgba(8,26,51,.55)); }
.doc-body{ padding:30px 28px; display:flex; flex-direction:column; }
.doc-body .doc-spec{ font-size:12.5px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); }
.doc-body h3{ font-family:var(--serif); font-size:27px; font-weight:600; color:var(--navy-800); margin-top:10px; }
.doc-body .doc-desc{ color:var(--slate); font-size:15px; margin-top:14px; line-height:1.55; }
.doc-exp{ display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:22px; }
.doc-exp .num{ font-family:var(--serif); font-size:34px; font-weight:600; color:var(--navy-800); line-height:1; }
.doc-exp .lbl{ font-size:13px; color:var(--slate); line-height:1.3; }

/* ============================================================
   STATS BAND
   ============================================================ */
.stats{ background:linear-gradient(120deg, var(--navy-800), var(--navy-900)); color:#fff; position:relative; overflow:hidden; }
.stats::before{
  content:""; position:absolute; right:-10%; top:-40%; width:60%; height:180%;
  background:radial-gradient(closest-side, rgba(47,111,181,.28), transparent 70%);
}
.stats .wrap{ position:relative; }
.stats-head{ text-align:center; max-width:680px; margin:0 auto 14px; }
.stats-head h2{ font-family:var(--serif); font-weight:500; font-size:clamp(30px,4vw,46px); }
.stats-head p{ color:#b6c6dd; margin-top:16px; font-size:17.5px; }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:clamp(40px,5vw,60px); }
.stat{ text-align:center; padding:14px; }
.stat .snum{ font-family:var(--serif); font-weight:600; font-size:clamp(40px,5vw,62px); line-height:1; letter-spacing:-.02em; }
.stat .snum em{ font-style:normal; color:var(--accent-300); }
.stat .slbl{ margin-top:14px; font-size:14.5px; color:#aebfda; letter-spacing:.04em; }
.stats-grid .stat + .stat{ border-left:1px solid rgba(255,255,255,.1); }

/* ============================================================
   REVIEWS
   ============================================================ */
.rev-grid{ margin-top:clamp(44px,5vw,64px); display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.rev-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 30px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:18px; position:relative;
}
.rev-card .quotemark{ font-family:var(--serif); font-size:64px; line-height:.6; color:var(--mist-2); position:absolute; top:24px; right:26px; }
.rev-stars{ color:#e8b53d; letter-spacing:3px; font-size:17px; }
.rev-text{ color:var(--ink); font-size:16px; line-height:1.6; }
.rev-who{ display:flex; align-items:center; gap:14px; margin-top:auto; padding-top:6px; }
.rev-ava{ width:48px; height:48px; border-radius:50%; display:grid; place-items:center; font-family:var(--serif); font-weight:600; color:#fff; font-size:19px; background:var(--accent); flex:none; }
.rev-who b{ color:var(--navy-800); font-size:15.5px; font-weight:700; display:block; }
.rev-who span{ color:var(--slate-light); font-size:13.5px; }

/* ============================================================
   BOOKING
   ============================================================ */
.booking{ background:var(--navy-900); color:#fff; position:relative; overflow:hidden; }
.booking::before{ content:""; position:absolute; left:-12%; bottom:-50%; width:55%; height:170%; background:radial-gradient(closest-side, rgba(47,111,181,.26), transparent 70%); }
.booking .wrap{ position:relative; display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(40px,6vw,84px); align-items:center; }
.booking-copy .eyebrow{ color:var(--accent-300); }
.booking-copy .eyebrow::before{ background:var(--accent-300); }
.booking-copy h2{ font-family:var(--serif); font-weight:500; font-size:clamp(32px,4.4vw,52px); margin-top:18px; line-height:1.06; }
.booking-copy p{ color:#bccbe2; font-size:18px; margin-top:20px; line-height:1.6; max-width:42ch; }
.booking-call{
  display:inline-flex; align-items:center; gap:18px; margin-top:34px; padding:20px 26px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:18px;
}
.booking-call .bc-ico{ width:48px; height:48px; border-radius:12px; background:var(--accent); display:grid; place-items:center; flex:none; }
.booking-call .bc-ico svg{ width:23px; height:23px; color:#fff; }
.booking-call .bc-lbl{ font-size:13px; color:#9fb6d2; letter-spacing:.04em; }
.booking-call .bc-num{ font-family:var(--serif); font-size:25px; font-weight:600; color:#fff; letter-spacing:.01em; white-space:nowrap; }
.booking-call:hover .bc-num{ color:var(--accent-300); }

.book-form{
  background:#fff; color:var(--ink); border-radius:24px; padding:clamp(28px,3.4vw,42px);
  box-shadow:var(--shadow-lg);
}
.book-form h3{ font-family:var(--serif); font-weight:600; font-size:24px; color:var(--navy-800); }
.book-form .ff-sub{ color:var(--slate); font-size:14.5px; margin-top:8px; margin-bottom:24px; }
.field{ margin-bottom:16px; }
.field.row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:16px; }
.field.row .field{ margin-bottom:0; }
label.flbl{ display:block; font-size:13px; font-weight:700; color:var(--navy-700); margin-bottom:7px; letter-spacing:.02em; }
.field input, .field select, .field textarea{
  width:100%; font-family:inherit; font-size:15px; color:var(--ink);
  padding:13px 15px; border:1.5px solid var(--line); border-radius:12px; background:var(--mist);
  transition:border-color .2s, background .2s, box-shadow .2s; outline:none;
}
.field textarea{ resize:vertical; min-height:92px; }
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:var(--accent); background:#fff; box-shadow:0 0 0 4px rgba(47,111,181,.12);
}
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2356657c' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; padding-right:40px; }
.book-form .btn{ width:100%; margin-top:8px; }
.book-form .form-fine{ text-align:center; font-size:12.5px; color:var(--slate-light); margin-top:16px; }
.book-form .form-fine svg{ width:13px; height:13px; vertical-align:-2px; margin-right:5px; color:var(--accent); }
/* success state */
.form-success{ display:none; text-align:center; padding:24px 6px; }
.book-form.done .form-grid{ display:none; }
.book-form.done .form-success{ display:block; }
.form-success .fs-ico{ width:70px; height:70px; border-radius:50%; background:rgba(47,111,181,.12); display:grid; place-items:center; margin:6px auto 20px; }
.form-success .fs-ico svg{ width:34px; height:34px; color:var(--accent); }
.form-success h3{ margin-bottom:10px; }
.form-success p{ color:var(--slate); font-size:15px; }

/* ============================================================
   CONTACT + FOOTER
   ============================================================ */
.contact{ background:#fff; }
.contact .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:start; }
.contact-list{ display:flex; flex-direction:column; gap:4px; margin-top:clamp(32px,4vw,44px); }
.ci{ display:flex; gap:18px; padding:20px 0; border-bottom:1px solid var(--line-soft); }
.ci:last-child{ border-bottom:none; }
.ci .ci-ico{ width:46px; height:46px; border-radius:12px; flex:none; background:var(--mist); color:var(--accent); display:grid; place-items:center; }
.ci .ci-ico svg{ width:21px; height:21px; }
.ci .ci-lbl{ font-size:12.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--slate-light); }
.ci .ci-val{ font-size:17px; color:var(--navy-800); font-weight:600; margin-top:3px; }
.ci .ci-val a:hover{ color:var(--accent); }
.map-card{
  margin-top:clamp(32px,4vw,44px); border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--shadow-sm); position:relative; min-height:380px; background:var(--mist-2);
}
.map-ph{
  position:absolute; inset:0;
  background-image:
    linear-gradient(135deg, rgba(47,111,181,.06) 25%, transparent 25%, transparent 50%, rgba(47,111,181,.06) 50%, rgba(47,111,181,.06) 75%, transparent 75%);
  background-size:22px 22px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; text-align:center; padding:24px;
}
.map-ph .pin{ width:52px; height:52px; border-radius:50%; background:var(--accent); display:grid; place-items:center; box-shadow:0 12px 26px -8px var(--accent); }
.map-ph .pin svg{ width:26px; height:26px; color:#fff; }
.map-ph .map-addr{ font-family:var(--serif); font-size:20px; color:var(--navy-800); font-weight:600; }
.map-ph .map-note{ font-family:ui-monospace, 'SF Mono', Menlo, monospace; font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--slate-light); }

.site-footer{ background:var(--navy-900); color:#fff; padding-top:clamp(56px,7vw,84px); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
.footer-brand .fb-logo{ display:flex; align-items:center; gap:12px; }
.footer-brand .fb-logo .fb-badge{ width:48px; height:48px; border-radius:12px; background:#fff; display:grid; place-items:center; padding:6px; }
.footer-brand .fb-logo .fb-badge img{ width:100%; height:100%; object-fit:contain; }
.footer-brand .fb-logo b{ font-family:var(--serif); font-size:19px; font-weight:600; }
.footer-brand .fb-logo span{ font-size:10px; letter-spacing:.26em; text-transform:uppercase; color:#8aa0bf; display:block; margin-top:3px; }
.footer-brand p{ color:#9fb2cd; font-size:14.5px; line-height:1.6; margin-top:20px; max-width:34ch; }
.footer-soc{ display:flex; gap:12px; margin-top:24px; }
.footer-soc a{ width:42px; height:42px; border-radius:11px; border:1px solid rgba(255,255,255,.14); display:grid; place-items:center; color:#cddaec; transition:background .25s, color .25s, border-color .25s, transform .25s; }
.footer-soc a:hover{ background:var(--accent); color:#fff; border-color:var(--accent); transform:translateY(-3px); }
.footer-soc a svg{ width:19px; height:19px; }
.footer-col h4{ font-size:13px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#fff; margin:0 0 18px; }
.footer-col a:not(.btn), .footer-col p{ display:block; color:#9fb2cd; font-size:14.5px; padding:6px 0; transition:color .2s; }
.footer-col a:not(.btn):hover{ color:#fff; }
.footer-hours span{ display:flex; justify-content:space-between; gap:18px; color:#9fb2cd; font-size:14px; padding:6px 0; }
.footer-hours span b{ color:#dce7f5; font-weight:600; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:clamp(40px,5vw,60px); padding:26px 0; display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap; }
.footer-bottom p{ color:#7f95b4; font-size:13.5px; }
.footer-bottom .fb-links{ display:flex; gap:24px; }
.footer-bottom .fb-links a{ color:#9fb2cd; font-size:13.5px; }
.footer-bottom .fb-links a:hover{ color:#fff; }

/* reveal-on-scroll */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.3,1), transform .7s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }
/* never trap content hidden: no-JS and reveal-off both force visible */
html:not(.js) .reveal,
:root[data-reveal="off"] .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1 !important; transform:none !important; transition:none !important; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav{ gap:24px; }
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .stats-grid{ grid-template-columns:repeat(2,1fr); }
  .stats-grid .stat:nth-child(3){ border-left:none; }
  .rev-grid{ grid-template-columns:1fr; max-width:560px; }
  .doctors-grid{ grid-template-columns:1fr; max-width:620px; }
}
@media (max-width:880px){
  html{ scroll-padding-top:72px; }
  .header-inner{ height:68px; }
  .nav, .header-phone{ display:none; }
  .menu-btn{ display:inline-flex; }
  /* Mobile: solid header bar (no translucent wash over the photo) + declutter the CTA (booking lives in the menu + hero) */
  .site-header{ background:#fff !important; backdrop-filter:none !important; -webkit-backdrop-filter:none !important; border-bottom:1px solid var(--line) !important; box-shadow:0 2px 14px -8px rgba(10,31,60,.3); }
  .header-cta .btn{ display:none !important; }
  :root[data-hero="bleed"] .hero, :root[data-hero="bleed"] .hero-inner,
  :root[data-hero="split"] .hero, :root[data-hero="split"] .hero-inner{ min-height:0 !important; align-items:stretch !important; }
  .hero-inner{ grid-template-columns:1fr !important; display:flex !important; flex-direction:column; position:relative; z-index:2; }
  /* Mobile/narrow: full UNCROPPED photo stacked on top, copy below — faces always fully visible, never overlapped */
  .hero{ background:var(--navy-900) !important; }
  .hero-bg{ display:none !important; }
  .hero-media{ display:block !important; order:-1; align-self:auto !important; min-height:0 !important; aspect-ratio:auto !important; margin:0 !important; border:none !important; outline:none !important; box-shadow:none !important; border-radius:0 !important; background:var(--navy-900) !important; }
  :root[data-hero="bleed"] .hero-media{ display:block !important; }
  .hero-media::before{ display:none !important; }
  .hero-media::after{ content:"" !important; display:block !important; position:absolute; left:0; right:0; bottom:-1px; height:80px; background:linear-gradient(to bottom, rgba(8,26,51,0), var(--navy-900)) !important; }
  .hero-media img{ width:100% !important; height:auto !important; object-fit:contain !important; }
  .hero-copy{ max-width:none !important; padding-block:clamp(26px,6vw,42px) clamp(40px,9vw,60px) !important; padding-right:0 !important; }
  .hero h1{ color:#fff !important; }
  .hero .tagline{ color:#cddaec !important; }
  .hero .slogan{ color:#aebfda !important; }
  .hero .eyebrow{ color:var(--accent-300) !important; }
  .hero .eyebrow::before{ background:var(--accent-300) !important; }
  .hero-meta{ color:#bdcde3 !important; }
  .hero-meta b{ color:#fff !important; }
  .hero-actions .btn{ flex:1 1 auto; }

  .trust .wrap{ grid-template-columns:1fr; gap:22px; }
  .booking .wrap{ grid-template-columns:1fr; }
  .contact .wrap{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .footer-brand{ grid-column:1 / -1; }
}
/* Stage hero on mobile: full-width photo on top, dark copy centered on mist below.
   Also repositions the legacy split overlay so it can never wash over the faces. */
@media (max-width:880px){
  :root[data-hero="stage"] .hero{ background:var(--mist) !important; }
  :root[data-hero="stage"] .hero-inner{ justify-content:flex-start !important; min-height:0 !important; }
  :root[data-hero="stage"] .hero-media{ position:static !important; order:-1 !important; height:auto !important; min-height:0 !important; background:var(--navy-900) !important; }
  :root[data-hero="stage"] .hero-media img{ height:auto !important; object-fit:contain !important; }
  :root[data-hero="stage"] .hero-media::before,
  :root[data-hero="stage"] .hero-media::after{ display:none !important; content:none !important; }
  :root[data-hero="stage"] .hero-copy{ text-align:center !important; max-width:none !important; padding-block:clamp(28px,6vw,46px) clamp(40px,9vw,60px) !important; padding-inline:var(--gut) !important; }
  :root[data-hero="stage"] .hero h1{ color:var(--navy-800) !important; }
  :root[data-hero="stage"] .hero .tagline{ color:var(--slate) !important; }
  :root[data-hero="stage"] .hero .slogan{ color:var(--navy-700) !important; justify-content:center !important; }
  :root[data-hero="stage"] .hero-actions{ justify-content:center !important; }
  :root[data-hero="stage"] .hero-actions .btn-ghost{ color:var(--navy-800) !important; border-color:var(--line) !important; }
  :root[data-hero="stage"] .hero-actions .btn-ghost:hover{ color:var(--accent) !important; border-color:var(--accent) !important; background:rgba(47,111,181,.05) !important; }
  :root[data-hero="stage"] .hero .eyebrow{ color:var(--accent) !important; justify-content:center !important; }
  :root[data-hero="stage"] .hero .eyebrow::before,
  :root[data-hero="stage"] .hero .eyebrow::after{ background:var(--accent) !important; }
  :root[data-hero="stage"] .hero-meta{ color:var(--slate) !important; justify-content:center !important; }
  :root[data-hero="stage"] .hero-meta b{ color:var(--navy-800) !important; }
  /* legacy split overlay: confine to a thin bottom fade, never the top */
  :root[data-hero="split"] .hero-media::after{
    top:auto !important; height:80px !important;
    background:linear-gradient(to bottom, rgba(8,26,51,0), var(--navy-900)) !important;
  }
}
@media (max-width:560px){
  :root{ --gut:20px; }
  body{ font-size:16px; }
  .svc-grid{ grid-template-columns:1fr; }
  .stats-grid{ grid-template-columns:1fr 1fr; }
  .field.row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .doc-card{ grid-template-columns:1fr; }
  .doc-photo{ min-height:320px; }
  .hero-actions{ flex-direction:column; }
  .hero-actions .btn{ width:100%; }
  .header-cta .btn span.bk-full{ display:none; }
}
