/* ============================================================
   Mr Amit Kumar, styles.css
   Surgical navy / steel / red system. Tokens locked in CLAUDE.md.
   Type: Newsreader (display) + Libre Franklin (body/UI).
   ============================================================ */

/* ── 1. Tokens ───────────────────────────────────────────── */
:root{
  /* Navy base ramp */
  --ink:#0B1622;
  --ink-2:#0F1E2E;
  --ink-3:#16293B;

  /* Surgical steel (PRIMARY accent, used freely) */
  --steel:#3DA8B8;
  --steel-bright:#52C4D4;
  --steel-deep:#2A7F8C;

  /* Brick red (HIGH-CONTRAST accent, rationed) */
  --red:#A8322F;
  --red-bright:#C24340;
  --red-deep:#85211F;

  /* Cool light surfaces */
  --paper:#F4F6F7;
  --paper-2:#E8EDEF;

  /* Text */
  --txt-on-dark:#E8EEF1;
  --txt-on-dark-mute:#9DB0BC;
  --txt-on-light:#12222E;
  --txt-on-light-mute:#52656F;

  --line-on-dark:rgba(255,255,255,.12);
  --line-on-light:rgba(11,22,34,.12);

  /* Steel washes (reused for tags / borders) */
  --steel-wash:rgba(61,168,184,.12);
  --steel-line:rgba(61,168,184,.32);

  /* Type */
  --serif:'Newsreader', Georgia, 'Times New Roman', serif;
  --sans:'Libre Franklin', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Layout */
  --maxw:1180px;
  --pad:clamp(20px,5vw,72px);

  /* Shadows */
  --shadow-card:0 24px 50px -28px rgba(11,22,34,.45), 0 4px 12px -6px rgba(11,22,34,.22);
  --shadow-soft:0 18px 40px -26px rgba(11,22,34,.4);

  --radius:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ── 2. Reset & base ─────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);
  color:var(--txt-on-light);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
::selection{background:var(--steel);color:var(--ink)}

/* ── 3. Shared primitives ────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--steel-deep);
}
.on-dark .eyebrow,.eyebrow.on-dark{color:var(--steel-bright)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-.012em;line-height:1.08}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.35rem,2.4vw,1.85rem)}
em.accent{font-style:italic;color:var(--steel-deep)}
.on-dark em.accent{color:var(--steel-bright)}
em.accent-red{font-style:italic;color:var(--red-deep)}
.on-dark em.accent-red{color:var(--red-bright)}

/* Typography measure (standing default): headings wrap only when they run out of
   horizontal space, never from an artificially narrow max-width. Body copy uses a
   readable 60 to 66 character measure. Do not add narrow heading max-widths. */
h1,h2,h3,h4{max-width:none}
p{max-width:66ch}

/* Buttons: red is the rationed primary, steel/ghost for the rest */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:.95rem;
  padding:15px 30px;border-radius:8px;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(3px)}

.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-bright)}

.btn-steel{background:var(--steel);color:var(--ink)}
.btn-steel:hover{background:var(--steel-bright)}

.btn-ghost{background:transparent;color:var(--steel-deep);border:1px solid var(--line-on-light)}
.btn-ghost:hover{border-color:var(--steel-deep);color:var(--steel-deep)}
.on-dark .btn-ghost,.btn-ghost.on-dark{color:var(--steel-bright);border-color:var(--steel-line)}
.on-dark .btn-ghost:hover,.btn-ghost.on-dark:hover{border-color:var(--steel-bright)}

/* Steel text link with arrow */
.link-steel{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:600;font-size:.95rem;
  color:var(--steel-deep);
}
.on-dark .link-steel{color:var(--steel-bright)}
.link-steel .arrow{transition:transform .25s var(--ease)}
.link-steel:hover .arrow{transform:translateX(4px)}

/* Tags / pills (steel) */
.tag{
  display:inline-block;
  font-family:var(--sans);font-size:.7rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--steel-deep);
  background:var(--steel-wash);
  border:1px solid var(--steel-line);
  padding:5px 13px;border-radius:100px;
}
.on-dark .tag{color:var(--steel-bright)}

/* Section eyebrow + heading group */
.section-head{max-width:none;margin-bottom:clamp(34px,5vw,58px)}
.section-head .eyebrow{display:block;margin-bottom:16px}
.section-head .sub{margin-top:18px;color:var(--txt-on-light-mute);font-size:1.05rem;max-width:64ch}
.on-dark .section-head .sub{color:var(--txt-on-dark-mute)}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}

section{position:relative}
.band{padding:clamp(64px,9vw,120px) 0}
.band-dark{background:var(--ink);color:var(--txt-on-dark)}
.band-dark-2{background:var(--ink-2);color:var(--txt-on-dark)}
.band-paper{background:var(--paper);color:var(--txt-on-light)}
.band-paper-2{background:var(--paper-2);color:var(--txt-on-light)}
.band-dark .section-head h2,.band-dark-2 .section-head h2{color:#fff}

/* ── 4. Top nav ──────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(11,22,34,.82);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line-on-dark);
  color:var(--txt-on-dark);
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;
  padding:0 var(--pad);
  height:72px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:baseline;gap:10px;font-family:var(--serif);font-size:1.18rem;color:#fff;letter-spacing:-.01em}
.brand .brand-mark{
  font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--steel-bright);
}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{
  font-family:var(--sans);font-size:.92rem;font-weight:400;
  color:var(--txt-on-dark-mute);
  padding:6px 0;position:relative;
  transition:color .2s var(--ease);
}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:#fff}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--red);border-radius:2px;
}
.nav-links a.soon{opacity:.62;cursor:default}
.nav-links a.soon:hover{color:var(--txt-on-dark-mute)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .btn{padding:11px 20px;font-size:.88rem}
.nav-tel{font-family:var(--sans);font-size:.9rem;color:var(--txt-on-dark-mute);white-space:nowrap}
.nav-tel:hover{color:var(--steel-bright)}

.nav-burger{display:none;width:42px;height:42px;border-radius:8px;border:1px solid var(--line-on-dark);align-items:center;justify-content:center}
.nav-burger span,.nav-burger span::before,.nav-burger span::after{
  content:"";display:block;width:18px;height:1.5px;background:var(--txt-on-dark);position:relative;transition:transform .25s var(--ease),opacity .2s}
.nav-burger span::before{position:absolute;top:-6px}
.nav-burger span::after{position:absolute;top:6px}

/* mobile overlay */
.nav-overlay{
  position:fixed;inset:0;z-index:80;
  background:var(--ink);
  display:flex;flex-direction:column;
  padding:24px var(--pad) 40px;
  transform:translateX(100%);transition:transform .35s var(--ease);
  visibility:hidden;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.nav-overlay.open{transform:none;visibility:visible}
.nav-overlay-top{display:flex;align-items:center;justify-content:space-between;height:72px;margin:0 calc(-1 * var(--pad)) 16px;padding:0 var(--pad);border-bottom:1px solid var(--line-on-dark)}
.nav-overlay-close{width:42px;height:42px;border-radius:8px;border:1px solid var(--line-on-dark);color:var(--txt-on-dark);font-size:1.4rem;display:flex;align-items:center;justify-content:center}
.nav-overlay nav{display:flex;flex-direction:column;gap:2px;margin-top:8px}
.nav-overlay nav a{
  font-family:var(--serif);font-size:1.7rem;color:var(--txt-on-dark);
  padding:14px 0;border-bottom:1px solid var(--line-on-dark);
}
.nav-overlay nav a.active{color:var(--steel-bright)}
.nav-overlay nav a.soon{color:var(--txt-on-dark-mute)}
.nav-overlay .overlay-cta{margin-top:auto;display:flex;flex-direction:column;gap:14px;padding-top:28px}
.nav-overlay .overlay-cta .btn{justify-content:center}

/* ── 5. Hero (home / interior) ───────────────────────────── */
.hero{
  background:
    radial-gradient(120% 95% at 82% 8%, var(--ink-3) 0%, var(--ink-2) 40%, var(--ink) 100%);
  color:var(--txt-on-dark);
  position:relative;overflow:hidden;
}
.hero::before{ /* faint steel grid suggestion, surgical, very subtle */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(var(--line-on-dark) 1px,transparent 1px) 0 0/100% 56px,
    linear-gradient(90deg,var(--line-on-dark) 1px,transparent 1px) 0 0/56px 100%;
  opacity:.35;
  -webkit-mask-image:radial-gradient(80% 70% at 70% 20%,#000,transparent 80%);
  mask-image:radial-gradient(80% 70% at 70% 20%,#000,transparent 80%);
}
.hero-inner{
  max-width:var(--maxw);margin:0 auto;padding:clamp(56px,8vw,104px) var(--pad) clamp(48px,7vw,88px);
  display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(24px,5vw,72px);align-items:center;
  position:relative;z-index:2;
}
.hero-copy .eyebrow{display:inline-block;margin-bottom:24px}
.hero h1{
  color:#fff;
  font-size:clamp(2.5rem,5.4vw,4.4rem);
  line-height:1.04;margin-bottom:26px;
}
.hero .standfirst{
  font-size:clamp(1.05rem,1.5vw,1.24rem);
  color:var(--txt-on-dark-mute);max-width:52ch;margin-bottom:36px;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}

.hero-portrait{
  position:relative;align-self:end;justify-self:center;
  width:100%;max-width:440px;aspect-ratio:4/5;
  border-radius:18px;overflow:hidden;
  border:1px solid var(--line-on-dark);
  background:linear-gradient(160deg,var(--ink-3),var(--ink));
}
.hero-portrait img{width:100%;height:100%;object-fit:cover}
/* Real photo treatment: no frame, edges dissolve into the navy hero.
   Left edge fades toward the headline; bottom feathers into the band. */
.hero-portrait.is-photo{border:0;border-radius:0;background:transparent;box-shadow:none;max-width:520px;align-self:end}
.hero-portrait.is-photo img{
  object-position:center 14%;
  /* Feather all four edges into the navy, generous distance so no hard corner */
  -webkit-mask-image:
    linear-gradient(to right,  transparent 0%, #000 18%, #000 89%, transparent 100%),
    linear-gradient(to bottom, transparent 0%, #000 11%, #000 80%, transparent 100%);
  -webkit-mask-composite:source-in;
  mask-image:
    linear-gradient(to right,  transparent 0%, #000 18%, #000 89%, transparent 100%),
    linear-gradient(to bottom, transparent 0%, #000 11%, #000 80%, transparent 100%);
  mask-composite:intersect;
}
@media(max-width:880px){.hero-portrait.is-photo{max-width:360px;align-self:center}}

/* generic interior page hero (no portrait) */
.page-hero{background:var(--ink);color:var(--txt-on-dark);overflow:hidden;position:relative}
.page-hero .hero-inner{display:block;padding-bottom:clamp(40px,6vw,70px)}
.page-hero .breadcrumb{font-size:.82rem;color:var(--txt-on-dark-mute);margin-bottom:22px;display:flex;gap:8px;flex-wrap:wrap}
.page-hero .breadcrumb a:hover{color:var(--steel-bright)}
.page-hero .breadcrumb .sep{opacity:.5}
.page-hero h1{color:#fff;font-size:clamp(2.3rem,4.6vw,3.7rem);line-height:1.05;max-width:none;margin-bottom:22px}
.page-hero .standfirst{font-size:clamp(1.05rem,1.4vw,1.22rem);color:var(--txt-on-dark-mute);max-width:62ch}

/* ── 6. Stat ribbon ──────────────────────────────────────── */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(18px,3vw,40px);
}
.stat{position:relative;padding-left:18px;display:flex;flex-direction:column}
.stat::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:2px;background:var(--steel-line);border-radius:2px}
.stat.is-red::before{background:var(--red)}
.stat .num{font-family:var(--serif);font-size:clamp(1.9rem,3.6vw,2.8rem);line-height:1;color:var(--steel-bright)}
.stat.is-red .num{color:var(--red-bright)}
.stat.on-light .num{color:var(--steel-deep)}
.stat.on-light.is-red .num{color:var(--red-deep)}
.stat .label{margin-top:10px;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--txt-on-dark-mute)}
.stat.on-light .label{color:var(--txt-on-light-mute)}

/* ── 7. Cards ────────────────────────────────────────────── */
.grid{display:grid;gap:clamp(18px,2.4vw,28px)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.card{
  background:#fff;border:1px solid var(--line-on-light);border-radius:var(--radius);
  padding:26px;display:flex;flex-direction:column;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--steel-line)}
.card.on-dark{background:var(--ink-3);border-color:var(--line-on-dark)}
.card .card-media{
  aspect-ratio:4/3;border-radius:10px;overflow:hidden;margin-bottom:20px;
  background:linear-gradient(150deg,var(--paper-2),#dfe6e9);
  display:flex;align-items:center;justify-content:center;
}
.card.on-dark .card-media{background:linear-gradient(150deg,var(--ink-2),var(--ink))}
.card .card-media img{width:100%;height:100%;object-fit:cover}
.card .tag{margin-bottom:14px;align-self:flex-start}
.card h3{font-size:1.3rem;margin-bottom:10px}
.card.on-dark h3{color:#fff}
.card p{color:var(--txt-on-light-mute);font-size:.96rem;margin-bottom:20px;flex:1}
.card.on-dark p{color:var(--txt-on-dark-mute)}
.card .link-steel{margin-top:auto}
a.card{text-decoration:none}

/* feature row: media + copy, alternating */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.feature + .feature{margin-top:clamp(48px,7vw,96px)}
.feature.flip .feature-media{order:2}
.feature-copy h2,.feature-copy h3{margin-bottom:18px}
.feature-copy .eyebrow{display:block;margin-bottom:16px}
.feature-copy p{color:var(--txt-on-light-mute);margin-bottom:18px}
.band-dark .feature-copy p,.band-dark-2 .feature-copy p{color:var(--txt-on-dark-mute)}

/* ── 8. Video facade (section 6 spec) ────────────────────── */
.video-frame{
  position:relative;width:100%;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(160deg,var(--ink-3),var(--ink));
  border:1px solid var(--line-on-dark);
  box-shadow:var(--shadow-soft);
}
.video-frame.ratio-16-9{aspect-ratio:16/9}
.video-frame.ratio-9-16{aspect-ratio:9/16;max-width:340px;margin-inline:auto}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-facade{
  position:absolute;inset:0;width:100%;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  color:var(--txt-on-dark-mute);
  background:radial-gradient(120% 120% at 50% 35%, rgba(61,168,184,.08), transparent 70%);
  transition:background .3s var(--ease);
}
.video-facade:hover{background:radial-gradient(120% 120% at 50% 35%, rgba(61,168,184,.16), transparent 70%)}
.video-facade .play{
  width:72px;height:72px;border-radius:50%;
  border:1.5px solid var(--steel-line);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(2px);
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease);
}
.video-facade:hover .play{transform:scale(1.07);border-color:var(--steel-bright);background:rgba(82,196,212,.14)}
.video-facade .play::before{
  content:"";border-style:solid;border-width:11px 0 11px 18px;
  border-color:transparent transparent transparent var(--steel-bright);
  margin-left:5px;
}
.video-facade small{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}

/* ── 9. Pull quote / testimonial ─────────────────────────── */
.pull{
  border-left:2px solid var(--steel);
  padding:6px 0 6px 24px;
  font-family:var(--serif);font-style:italic;
  font-size:clamp(1.15rem,1.7vw,1.45rem);line-height:1.4;
  color:var(--txt-on-light);max-width:46ch;
}
.band-dark .pull,.band-dark-2 .pull{color:#fff;border-color:var(--steel-bright)}
.pull cite{display:block;margin-top:16px;font-style:normal;font-family:var(--sans);font-size:.82rem;letter-spacing:.06em;color:var(--txt-on-light-mute)}
.band-dark .pull cite{color:var(--txt-on-dark-mute)}

.review{
  background:#fff;border:1px solid var(--line-on-light);border-radius:var(--radius);
  padding:28px;display:flex;flex-direction:column;height:100%;
}
.review .stars{color:var(--steel);letter-spacing:.12em;margin-bottom:16px;font-size:.95rem}
.review p{font-family:var(--serif);font-style:italic;font-size:1.08rem;line-height:1.5;color:var(--txt-on-light);margin-bottom:20px;flex:1}
.review cite{font-style:normal;font-family:var(--sans);font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;color:var(--txt-on-light-mute)}

/* ── 10. CTA band ────────────────────────────────────────── */
.cta-band{background:var(--ink-2);color:var(--txt-on-dark);text-align:center}
.cta-band h2{color:#fff;max-width:none;margin:0 auto 20px}
.cta-band p{color:var(--txt-on-dark-mute);max-width:60ch;margin:0 auto 30px}
.cta-band .hero-actions{justify-content:center}

/* ── 11. Footer ──────────────────────────────────────────── */
.footer{background:var(--ink);color:var(--txt-on-dark-mute);padding:clamp(54px,7vw,84px) 0 34px;border-top:1px solid var(--line-on-dark)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
.footer h4{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--steel-bright);margin-bottom:18px}
.footer .brand{margin-bottom:16px}
.footer p{font-size:.92rem;line-height:1.7;max-width:34ch}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer ul a{font-size:.92rem;color:var(--txt-on-dark-mute);transition:color .2s}
.footer ul a:hover{color:#fff}
.footer ul a.soon{opacity:.6}
.footer .contact-line{display:flex;align-items:center;gap:10px;font-size:.92rem;margin-bottom:11px}
.footer .contact-line a:hover{color:var(--steel-bright)}
.footer-social{display:flex;gap:16px;margin-top:18px}
.footer-social a{font-size:.82rem;color:var(--txt-on-dark-mute)}
.footer-social a:hover{color:var(--steel-bright)}
.footer-legal{margin-top:clamp(38px,5vw,56px);padding-top:26px;border-top:1px solid var(--line-on-dark);font-size:.78rem;line-height:1.7;color:var(--txt-on-dark-mute);max-width:90ch}
.footer-legal .copy{margin-bottom:8px;color:var(--txt-on-dark)}

/* ── 12. Misc content blocks ─────────────────────────────── */
.lede{font-size:clamp(1.15rem,1.7vw,1.5rem);font-family:var(--serif);line-height:1.45;color:var(--txt-on-light);max-width:62ch}
.prose p{margin-bottom:18px;color:var(--txt-on-light-mute)}
.prose p:last-child{margin-bottom:0}
.checklist{list-style:none;display:flex;flex-direction:column;gap:13px}
.checklist li{position:relative;padding-left:30px;color:var(--txt-on-light-mute)}
.checklist li::before{content:"";position:absolute;left:0;top:.5em;width:14px;height:8px;border-left:2px solid var(--steel-deep);border-bottom:2px solid var(--steel-deep);transform:rotate(-45deg)}
.band-dark .checklist li{color:var(--txt-on-dark-mute)}
.band-dark .checklist li::before{border-color:var(--steel-bright)}

/* timeline (recovery) */
.timeline{list-style:none;display:flex;flex-direction:column;gap:0;counter-reset:tl}
.timeline li{position:relative;padding:0 0 26px 34px;border-left:1px solid var(--line-on-light)}
.timeline li:last-child{padding-bottom:0;border-left-color:transparent}
.timeline li::before{content:"";position:absolute;left:-6px;top:3px;width:11px;height:11px;border-radius:50%;background:var(--steel);border:2px solid var(--paper)}
.timeline .when{font-family:var(--sans);font-weight:600;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--steel-deep);display:block;margin-bottom:5px}
.timeline .what{color:var(--txt-on-light-mute);font-size:.98rem}

/* warning / note callout */
.callout{border-left:3px solid var(--red);background:#fff;border-radius:0 10px 10px 0;padding:22px 26px;box-shadow:var(--shadow-soft)}
.callout h4{font-family:var(--serif);font-size:1.1rem;color:var(--txt-on-light);margin-bottom:12px}

/* anchored section offset under sticky nav */
[id]{scroll-margin-top:88px}

/* ── 13. Reveal motion ───────────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.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}

/* ── 16. Deep condition template: figures, cost, FAQ ─────── */
/* Recovery stat callouts (figures, one red per spec) */
.figures{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,26px)}
.figure{position:relative;background:#fff;border:1px solid var(--line-on-light);border-radius:var(--radius);padding:26px 24px;overflow:hidden}
.figure::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--steel)}
.figure.is-red::before{background:var(--red)}
.figure .fig-num{font-family:var(--serif);font-size:clamp(2rem,4vw,2.9rem);line-height:1;color:var(--steel-deep)}
.figure.is-red .fig-num{color:var(--red-deep)}
.figure .fig-label{margin-top:12px;font-size:.86rem;line-height:1.45;color:var(--txt-on-light-mute)}

/* Cost / self-pay card */
.cost-card{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(24px,4vw,52px);align-items:center;
  background:#fff;border:1px solid var(--line-on-light);border-radius:var(--radius);
  padding:clamp(26px,3.5vw,42px);box-shadow:var(--shadow-soft)}
.cost-card .cost-figure{font-family:var(--serif);font-size:clamp(2.1rem,4.4vw,3rem);line-height:1.04;color:var(--steel-deep)}
.cost-card .cost-sub{margin-top:12px;color:var(--txt-on-light-mute);font-size:.92rem;max-width:30ch}
.cost-card .cost-incl h4{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-deep);margin-bottom:16px}

/* FAQ accordion (native <details>, no JS, reduced-motion safe) */
.faq{max-width:840px}
.faq-item{border-bottom:1px solid var(--line-on-light)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:22px 2px;font-family:var(--serif);font-size:clamp(1.1rem,1.7vw,1.32rem);line-height:1.3;color:var(--txt-on-light);
  transition:color .2s var(--ease)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--steel-deep)}
.faq-item .chev{position:relative;flex:0 0 auto;width:22px;height:22px}
.faq-item .chev::before,.faq-item .chev::after{content:"";position:absolute;top:50%;left:50%;width:13px;height:2px;border-radius:2px;background:var(--steel-deep);transition:transform .25s var(--ease)}
.faq-item .chev::before{transform:translate(-50%,-50%)}
.faq-item .chev::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item[open] .chev::after{transform:translate(-50%,-50%) rotate(0)}
.faq-item .faq-a{padding:0 2px 24px;max-width:72ch;color:var(--txt-on-light-mute)}
.faq-item .faq-a p{margin-bottom:12px}
.faq-item .faq-a p:last-child{margin-bottom:0}
.faq-item .faq-a a{color:var(--steel-deep);font-weight:600}

@media(max-width:680px){
  .figures{grid-template-columns:1fr}
  .cost-card{grid-template-columns:1fr;gap:26px}
}

/* ── 17. Blog article: data table, key takeaway, post nav ── */
.article{max-width:820px;margin:0 auto}
.article > h2{margin:clamp(38px,5vw,54px) 0 18px}
.article .prose{margin-bottom:8px}
.article-meta{display:flex;gap:16px;align-items:center;flex-wrap:wrap;color:var(--txt-on-dark-mute);font-size:.86rem;margin-bottom:22px}
.article-meta .cat{color:var(--steel-bright);font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.72rem}

.data-table{width:100%;border-collapse:collapse;border:1px solid var(--line-on-light);border-radius:var(--radius);overflow:hidden;background:#fff;font-size:.96rem}
.data-table thead th{background:var(--ink);color:#fff;font-family:var(--sans);font-weight:600;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;text-align:left;padding:14px 18px}
.data-table td{padding:14px 18px;border-top:1px solid var(--line-on-light);color:var(--txt-on-light-mute);vertical-align:top}
.data-table td:first-child{font-weight:600;color:var(--txt-on-light);width:34%}
.data-table tbody tr:nth-child(even){background:var(--paper)}

.takeaway{background:var(--ink);color:var(--txt-on-dark);border-radius:var(--radius);padding:clamp(26px,3.5vw,40px);border-left:3px solid var(--steel)}
.takeaway .eyebrow{display:block;margin-bottom:14px;color:var(--steel-bright)}
.takeaway p{color:#fff;font-family:var(--serif);font-size:clamp(1.15rem,1.8vw,1.42rem);line-height:1.42;max-width:60ch}

.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.post-nav a{display:block;background:#fff;border:1px solid var(--line-on-light);border-radius:var(--radius);padding:20px 22px;transition:border-color .25s var(--ease),transform .25s var(--ease)}
.post-nav a:hover{border-color:var(--steel-line);transform:translateY(-2px)}
.post-nav a.disabled{opacity:.5;pointer-events:none}
.post-nav .dir{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel-deep);font-weight:600;margin-bottom:8px}
.post-nav .ptitle{font-family:var(--serif);font-size:1.08rem;color:var(--txt-on-light);line-height:1.2}
.post-nav a.next{text-align:right}
@media(max-width:560px){
  .data-table{font-size:.88rem}.data-table th,.data-table td{padding:11px 12px}
  .post-nav{grid-template-columns:1fr}.post-nav a.next{text-align:left}
}

/* ── 20. Anatomy render (16:9, object-fit cover) ─────────── */
.render{aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-on-light);box-shadow:var(--shadow-soft);background:var(--paper-2)}
.render img{width:100%;height:100%;object-fit:cover;display:block}
.render.on-dark{border-color:var(--line-on-dark);background:var(--ink-2)}

/* ── 21. Phase-1 revisions: util bar, card hierarchy, locations ── */
/* Utility bar above the main nav */
.util-bar{background:var(--ink);border-bottom:1px solid var(--line-on-dark);color:var(--txt-on-dark-mute);font-family:var(--sans);font-size:.82rem}
.util-bar-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);min-height:40px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.util-bar a{color:var(--txt-on-dark-mute);transition:color .2s var(--ease)}
.util-bar a:hover{color:var(--steel-bright)}
.util-left{display:flex;align-items:center;gap:24px}
.util-item{display:inline-flex;align-items:center;gap:8px}
.util-item svg{flex:0 0 auto}
.util-right{display:flex;align-items:center;gap:18px}
.util-right a{display:inline-flex;align-items:center}
@media(max-width:680px){
  .util-bar-inner{padding-top:8px;padding-bottom:8px;gap:10px}
  .util-left{gap:16px}
  .util-email .util-label{display:none}
}
@media(max-width:420px){.util-left{flex-wrap:wrap}}

/* Card hierarchy: media, then TITLE, then small pill UNDER it */
.card .card-media{order:0}
.card h3{order:1;margin-bottom:8px}
/* heading-plus-list cards: keep the list directly under its heading */
.card .checklist{order:1}
.card .tag,.card .pills{order:2}
.card > p{order:3}
.card .link-steel,.card .loc-actions{order:4}
.card .pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.card .pills .tag{margin-bottom:0}
/* second pill shade for quick scanning */
.tag.alt{background:rgba(11,22,34,.05);border-color:var(--line-on-light);color:var(--txt-on-light-mute)}
.on-dark .tag.alt,.card.on-dark .tag.alt{background:rgba(255,255,255,.06);border-color:var(--line-on-dark);color:var(--txt-on-dark-mute)}

/* Three-up stat strip, evenly spaced */
.stats.three{grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:560px){.stats.three{grid-template-columns:1fr;gap:22px}}

/* Differentiate hip vs knee card media so they don't read identical */
.card-media.media-hip{box-shadow:inset 0 0 0 1px rgba(61,168,184,.45)}
.card-media.media-knee{box-shadow:inset 0 0 0 1px rgba(40,127,140,.5)}

/* Location tiles */
.loc-actions{display:flex;align-items:center;gap:18px;margin-top:18px;flex-wrap:wrap}
.loc-actions .btn{padding:10px 18px;font-size:.85rem}
.maps-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--steel-deep)}
.maps-link:hover{color:var(--steel-bright)}
.maps-link .arrow{transition:transform .25s var(--ease)}
.maps-link:hover .arrow{transform:translateX(3px)}

/* Keep the main nav on one line; collapse to the mobile menu before 7 items would wrap */
@media(max-width:1100px){.nav-links{gap:20px}}
@media(max-width:1024px){.nav-links,.nav-cta .btn,.nav-tel{display:none}.nav-burger{display:flex}}

/* ── 18. Nav dropdown (Treatments) ───────────────────────── */
.nav-links li.has-menu{position:relative}
.nav-links .menu-trigger{display:inline-flex;align-items:center;gap:7px}
.nav-links .caret{width:7px;height:7px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);position:relative;top:-2px;transition:transform .2s var(--ease),top .2s var(--ease)}
.nav-links li.has-menu:hover .caret,.nav-links li.has-menu:focus-within .caret{transform:rotate(-135deg);top:1px}
.submenu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);min-width:320px;
  background:var(--ink-2);border:1px solid var(--line-on-dark);border-radius:12px;padding:20px;
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  opacity:0;visibility:hidden;transition:opacity .2s var(--ease),transform .2s var(--ease);
  box-shadow:var(--shadow-card);z-index:70}
.submenu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.nav-links li.has-menu:hover .submenu,.nav-links li.has-menu:focus-within .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.submenu-label{display:block;font-family:var(--sans);font-size:.64rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-bright);margin-bottom:10px}
.submenu-group a{display:block;padding:7px 0;font-size:.9rem;color:var(--txt-on-dark-mute);white-space:nowrap}
.submenu-group a:hover{color:#fff}
/* mobile overlay sub-links */
.nav-overlay nav a.sub{font-family:var(--sans);font-size:1.02rem;font-weight:400;padding:11px 0 11px 18px;color:var(--txt-on-dark-mute);border-bottom:1px solid var(--line-on-dark)}
.nav-overlay nav a.sub:hover{color:#fff}

/* ── 19. Trust strip (reusable, add badges to .trust-row) ── */
.trust{background:var(--ink-2);border-top:1px solid var(--line-on-dark)}
.trust .trust-label{text-align:center;font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--steel-bright);margin-bottom:28px}
.trust-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(30px,6vw,76px)}
.trust-row img{height:clamp(68px,9vw,104px);width:auto;opacity:.9;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.trust-row img:hover{opacity:1;transform:translateY(-2px)}
@media(max-width:560px){.trust-row{gap:26px}.trust-row img{height:58px}}

/* ── 22. Contact page: form + provider blocks ────────────── */
.form-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(28px,4vw,56px);align-items:start}
@media(max-width:880px){.form-grid{grid-template-columns:1fr}}
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--sans);font-size:.82rem;font-weight:600;letter-spacing:.03em;color:var(--txt-on-light);margin-bottom:8px}
.field label .req{color:var(--red-deep)}
.field input,.field textarea{width:100%;font-family:var(--sans);font-size:1rem;color:var(--txt-on-light);background:#fff;border:1px solid var(--line-on-light);border-radius:10px;padding:13px 15px;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--steel);box-shadow:0 0 0 3px var(--steel-wash)}
.radio-row{display:flex;flex-wrap:wrap;gap:10px}
.radio-row label{display:inline-flex;align-items:center;gap:8px;margin:0;font-weight:400;padding:10px 16px;border:1px solid var(--line-on-light);border-radius:100px;background:#fff;cursor:pointer;transition:border-color .2s var(--ease),background .2s var(--ease)}
.radio-row input{appearance:none;-webkit-appearance:none;width:14px;height:14px;border:1.5px solid var(--steel-deep);border-radius:50%;margin:0}
.radio-row input:checked{background:var(--steel);border-color:var(--steel)}
.radio-row label:has(input:checked){border-color:var(--steel);background:var(--steel-wash)}
.form-note{font-size:.82rem;color:var(--txt-on-light-mute);margin-top:10px}
.field.consent{display:flex;gap:12px;align-items:flex-start;margin-bottom:22px}
.field.consent input{flex:0 0 auto;width:18px;height:18px;margin:2px 0 0;accent-color:var(--steel)}
.field.consent label{margin:0;font-weight:400;font-size:.9rem;line-height:1.5;color:var(--txt-on-light-mute)}
.field.consent a{color:var(--steel-deep);font-weight:600}
.contact-card{background:var(--ink);color:var(--txt-on-dark);border-radius:var(--radius);padding:clamp(24px,3vw,34px)}
.contact-card h3{color:#fff;margin-bottom:18px}
.contact-card .contact-line{margin-bottom:14px}
.contact-card .contact-line a{color:var(--steel-bright)}
.contact-card .reassure{color:var(--txt-on-dark-mute);font-size:.9rem;margin-top:16px}

/* Provider-grouped hospital blocks */
.providers{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,28px)}
@media(max-width:880px){.providers{grid-template-columns:1fr}}
.provider{background:var(--ink-3);border:1px solid var(--line-on-dark);border-radius:var(--radius);padding:clamp(22px,2.5vw,30px);display:flex;flex-direction:column}
.provider .prov-logo{height:clamp(84px,9vw,108px);width:auto;max-width:300px;margin-bottom:30px;object-fit:contain;object-position:left center}
.hosp + .hosp{margin-top:20px;padding-top:20px;border-top:1px solid var(--line-on-dark)}
.hosp h4{font-family:var(--serif);font-weight:400;font-size:1.18rem;color:#fff;margin-bottom:8px;letter-spacing:-.01em}
.hosp .addr{color:var(--txt-on-dark-mute);font-size:.9rem;line-height:1.5;margin-bottom:6px}
.hosp .tel{display:inline-block;color:var(--steel-bright);font-size:.9rem;font-weight:600}
.hosp-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:16px}
.hosp-actions .btn{padding:9px 17px;font-size:.82rem}

/* ── 23. Phase-1 revisions, round 2 + 3 ──────────────────── */
/* C. Bold card titles (treatment + location cards) */
.card h3{margin-bottom:14px;font-weight:500}
/* A. Card pills, exact spec values: 10px, tight, left-aligned, 14px gap under title */
.card .tag{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:100px;line-height:1.4;margin:0 0 14px;align-self:flex-start}
.card .pills{align-self:flex-start;justify-content:flex-start;gap:8px;margin:0 0 14px}
.card .pills .tag{margin:0}
/* B. Pill colours matching each image glow (soft tints, darker text of same hue) */
.tag.t-gold{background:rgba(193,150,42,.14);border-color:rgba(193,150,42,.42);color:#876607}
.tag.t-red{background:rgba(168,50,47,.12);border-color:rgba(168,50,47,.42);color:var(--red-deep)}
.tag.t-orange{background:rgba(198,108,38,.15);border-color:rgba(198,108,38,.44);color:#964c10}

/* C. Utility bar phone + email in the steel accent */
.util-left a{color:var(--steel-bright)}
.util-left a:hover{color:#fff}

/* E. Small map in each location tile */
.loc-map{order:3;margin-top:16px;border-radius:10px;overflow:hidden;border:1px solid var(--line-on-light);aspect-ratio:16/10;background:var(--paper-2)}
.loc-map iframe{width:100%;height:100%;border:0;display:block}

/* F. Trust badges sit under the CTA buttons on the navy band, no heading, no divider */
.cta-badges{margin-top:clamp(34px,4vw,48px)}

/* ── 14. Responsive ──────────────────────────────────────── */
@media(max-width:1000px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:880px){
  .nav-links,.nav-cta .btn,.nav-tel{display:none}
  .nav-burger{display:flex}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-portrait{max-width:380px;order:-1}
  .feature{grid-template-columns:1fr;gap:30px}
  .feature.flip .feature-media{order:0}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:26px}
}
@media(max-width:560px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .hero-actions .btn,.cta-band .btn{width:100%;justify-content:center}
  .footer-grid{grid-template-columns:1fr}
  h2{font-size:clamp(1.7rem,7vw,2.2rem)}
}

/* ── 15. Reduced motion ──────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}
