/* =========================================================
   Trinity Comprehensive Healthcare — 2026 Visual System
   Fluid responsive: clamp() type, vh/vw rhythm, em internals
   ========================================================= */

:root {
  /* Brand — preserved from existing system */
  --medical-blue: #0161A2;
  --medical-blue-deep: #024074;
  --healing-teal: #2F7F8F;
  --vitality-green: #3DD470;
  --vitality-green-deep: #1F9F4F;
  --warm-gold: #DCBF3A;
  --light-gold: #ECD66D;
  --cream: #F8ECB3;
  --cream-soft: #FBF3D2;

  /* 2026 extensions */
  --ink: #0B1F33;
  --ink-soft: #2C3E50;
  --muted: #5C6F80;
  --hairline: rgba(11, 31, 51, 0.10);
  --hairline-strong: rgba(11, 31, 51, 0.18);
  --surface: #FAF7F2;        /* warm off-white base */
  --surface-elev: #FFFFFF;
  --surface-warm: #F4EFE5;
  --surface-mint: #E8F5EC;

  /* Semantic */
  --bg: var(--surface);
  --fg: var(--ink);
  --accent: var(--medical-blue);
  --accent-2: var(--vitality-green);

  /* Fluid type scale — clamp(min, preferred, max) */
  --fs-xs:   clamp(0.75rem, 0.70rem + 0.20vw, 0.85rem);
  --fs-sm:   clamp(0.85rem, 0.80rem + 0.25vw, 0.95rem);
  --fs-base: clamp(1.00rem, 0.92rem + 0.35vw, 1.15rem);
  --fs-md:   clamp(1.10rem, 1.00rem + 0.50vw, 1.35rem);
  --fs-lg:   clamp(1.30rem, 1.10rem + 0.90vw, 1.75rem);
  --fs-xl:   clamp(1.75rem, 1.40rem + 1.50vw, 2.50rem);
  --fs-2xl:  clamp(2.25rem, 1.60rem + 2.80vw, 3.75rem);
  --fs-3xl:  clamp(2.75rem, 1.80rem + 4.20vw, 5.50rem);
  --fs-4xl:  clamp(3.25rem, 2.00rem + 5.50vw, 7.00rem);

  /* Fluid spacing */
  --s-1: clamp(0.25rem, 0.20rem + 0.20vw, 0.40rem);
  --s-2: clamp(0.50rem, 0.40rem + 0.40vw, 0.75rem);
  --s-3: clamp(0.75rem, 0.60rem + 0.60vw, 1.10rem);
  --s-4: clamp(1.00rem, 0.80rem + 0.80vw, 1.50rem);
  --s-5: clamp(1.50rem, 1.10rem + 1.50vw, 2.50rem);
  --s-6: clamp(2.00rem, 1.40rem + 2.50vw, 4.00rem);
  --s-7: clamp(3.00rem, 2.00rem + 4.00vw, 6.00rem);
  --s-8: clamp(4.00rem, 2.60rem + 6.00vw, 9.00rem);

  --radius-xs: 0.5em;
  --radius-sm: 0.75em;
  --radius-md: 1.25em;
  --radius-lg: 1.75em;
  --radius-xl: 2.5em;
  --radius-pill: 999em;

  --shadow-soft: 0 1px 2px rgba(11,31,51,.04), 0 8px 24px rgba(11,31,51,.06);
  --shadow-card: 0 1px 2px rgba(11,31,51,.04), 0 18px 40px rgba(11,31,51,.08);
  --shadow-elev: 0 2px 4px rgba(11,31,51,.04), 0 30px 60px rgba(11,31,51,.12);

  --container: min(92vw, 1320px);
  --container-narrow: min(88vw, 920px);

  --ease: cubic-bezier(.2,.7,.2,1);
  --dur: 320ms;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}

html, body { margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--fg);
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  font-size: var(--fs-base);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
}

/* Density modes (tweakable) */
body[data-density="compact"] { --s-5: clamp(1.1rem, .9rem + 1vw, 2rem); --s-6: clamp(1.6rem, 1.1rem + 2vw, 3rem); --s-7: clamp(2.2rem, 1.5rem + 3vw, 4.5rem); --s-8: clamp(3rem, 2rem + 4.5vw, 6.5rem); }
body[data-density="spacious"] { --s-6: clamp(2.6rem, 1.8rem + 3.2vw, 5.2rem); --s-7: clamp(4rem, 2.6rem + 5vw, 8rem); --s-8: clamp(5.5rem, 3.4rem + 7.5vw, 12rem); }

/* Theme variants */
body[data-theme="warm"] { --bg: #FAF7F2; --surface: #FAF7F2; --surface-warm: #F4EFE5; }
body[data-theme="clinical"] { --bg: #F4F7FA; --surface: #F4F7FA; --surface-warm: #E8EEF5; --surface-mint: #E6F1E9; }
body[data-theme="botanical"] { --bg: #F2F6F0; --surface: #F2F6F0; --surface-warm: #E6EFE3; --surface-mint: #DEEBE0; }

/* Accent variants */
body[data-accent="blue"] { --accent: var(--medical-blue); --accent-2: var(--vitality-green); }
body[data-accent="teal"] { --accent: var(--healing-teal); --accent-2: var(--vitality-green); }
body[data-accent="green"] { --accent: var(--vitality-green-deep); --accent-2: var(--medical-blue); }

h1, h2, h3, h4 {
  font-family: 'Bricolage Grotesque', 'Plus Jakarta Sans', system-ui, sans-serif;
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.04;
  margin: 0;
  color: var(--ink);
  text-wrap: balance;
}
p { text-wrap: pretty; margin: 0; }

.serif {
  font-family: 'Instrument Serif', 'Bricolage Grotesque', serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.01em;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; padding: 0; }

img { display: block; max-width: 100%; height: auto; }

/* Focus */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* Containers */
.container { width: var(--container); margin-inline: auto; }
.container-narrow { width: var(--container-narrow); margin-inline: auto; }

/* Section padding rhythm */
.section { padding-block: var(--s-7); }
.section-tight { padding-block: var(--s-6); }
.section-big { padding-block: var(--s-8); }

/* ============= BUTTONS ============= */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.9em 1.5em;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: var(--fs-sm);
  letter-spacing: -0.005em;
  min-height: 44px;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease), color var(--dur) var(--ease);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary { background: var(--ink); color: var(--surface); }
.btn-primary:hover { background: var(--accent); box-shadow: 0 12px 28px rgba(1,97,162,.25); }

.btn-accent { background: var(--accent); color: white; }
.btn-accent:hover { box-shadow: 0 12px 28px rgba(1,97,162,.30); }

.btn-ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--hairline-strong);
}
.btn-ghost:hover { background: var(--ink); color: var(--surface); border-color: var(--ink); }

.btn-soft {
  background: var(--surface-elev);
  color: var(--ink);
  box-shadow: var(--shadow-soft);
}

.btn-link {
  display: inline-flex; align-items: center; gap: .5em;
  padding: 0; min-height: 0;
  font-weight: 600; font-size: var(--fs-sm);
  border-radius: 0;
  color: var(--ink);
}
.btn-link::after {
  content: "→";
  transition: transform var(--dur) var(--ease);
}
.btn-link:hover::after { transform: translateX(4px); }

/* ============= TAG / EYEBROW ============= */
.eyebrow {
  display: inline-flex; align-items: center; gap: .5em;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 600;
  color: var(--accent);
}
.eyebrow .dot { width: .45em; height: .45em; border-radius: 50%; background: var(--accent-2); }

.chip {
  display: inline-flex; align-items: center; gap: .4em;
  padding: 0.4em 0.85em;
  border-radius: var(--radius-pill);
  font-size: var(--fs-xs);
  font-weight: 600;
  background: var(--surface-elev);
  border: 1px solid var(--hairline);
  color: var(--ink-soft);
}
.chip.active { background: var(--ink); color: var(--surface); border-color: var(--ink); }

/* ============= HEADER ============= */
.site-header {
  position: sticky; top: 0; z-index: 100;
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  background: color-mix(in oklab, var(--bg) 78%, transparent);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.site-header.scrolled { border-bottom-color: var(--hairline); }
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-4);
  padding-block: clamp(0.7rem, 0.4rem + 0.8vw, 1.1rem);
}
.brand {
  display: inline-flex; align-items: center; gap: 0.65em;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 600;
  font-size: var(--fs-md);
  letter-spacing: -0.02em;
}
.brand-mark {
  width: 2.4em; height: 2.4em;
  display: grid; place-items: center;
  border-radius: 50%;
  background: transparent;
  overflow: hidden;
  flex-shrink: 0;
}
.brand-mark img, .brand-mark svg {
  width: 100%; height: 100%;
  display: block;
}
.brand-text { display: flex; flex-direction: column; line-height: 1; }
.brand-text small { font-family: 'Plus Jakarta Sans', sans-serif; font-style: normal; font-weight: 500; font-size: 0.55em; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-top: 0.4em; }

.nav-desktop {
  display: none;
  align-items: center;
  gap: clamp(1rem, 0.4rem + 1.6vw, 2.2rem);
}
@media (min-width: 980px) {
  .nav-desktop { display: flex; }
}
.nav-link {
  position: relative;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink-soft);
  padding: 0.4em 0;
  transition: color var(--dur) var(--ease);
}
.nav-link::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: -2px;
  height: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur) var(--ease);
}
.nav-link:hover { color: var(--ink); }
.nav-link:hover::after, .nav-link.active::after { transform: scaleX(1); }

.header-actions { display: flex; align-items: center; gap: var(--s-3); }

.lang-toggle {
  display: inline-flex;
  background: var(--surface-elev);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  padding: 3px;
  font-size: var(--fs-xs);
  font-weight: 600;
}
.lang-toggle button {
  padding: 0.5em 0.9em;
  border-radius: var(--radius-pill);
  color: var(--muted);
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
  min-height: 32px;
}
.lang-toggle button.active { background: var(--ink); color: var(--surface); }

.menu-btn {
  display: grid; place-items: center;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--surface-elev);
  border: 1px solid var(--hairline);
}
@media (min-width: 980px) {
  .menu-btn { display: none; }
}
.menu-btn span {
  display: block; width: 18px; height: 1.5px;
  background: var(--ink);
  position: relative;
}
.menu-btn span::before, .menu-btn span::after {
  content: ""; position: absolute; left: 0; width: 18px; height: 1.5px; background: var(--ink);
  transition: transform var(--dur) var(--ease), top var(--dur) var(--ease);
}
.menu-btn span::before { top: -6px; }
.menu-btn span::after { top: 6px; }
.menu-btn.open span { background: transparent; }
.menu-btn.open span::before { top: 0; transform: rotate(45deg); }
.menu-btn.open span::after { top: 0; transform: rotate(-45deg); }

/* Mobile menu drawer */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: 90;
  padding: max(var(--s-7), 5rem) var(--s-5) var(--s-5);
  transform: translateY(-100%);
  transition: transform 400ms var(--ease);
  overflow-y: auto;
}
.mobile-menu.open { transform: translateY(0); }
.mobile-menu nav { display: flex; flex-direction: column; gap: var(--s-3); }
.mobile-menu a {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: var(--fs-xl);
  font-weight: 500;
  letter-spacing: -0.02em;
  padding-block: 0.3em;
  border-bottom: 1px solid var(--hairline);
}
.mobile-menu .mm-foot { margin-top: var(--s-5); display: flex; flex-direction: column; gap: var(--s-3); font-size: var(--fs-sm); color: var(--muted); }

/* ============= HERO ============= */
.hero {
  padding-top: clamp(2rem, 1rem + 3vw, 4rem);
  padding-bottom: clamp(2rem, 1rem + 4vw, 5rem);
  position: relative;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
  align-items: end;
}
@media (min-width: 900px) {
  .hero-grid { grid-template-columns: 1.2fr 1fr; }
}
.hero h1 {
  font-size: var(--fs-4xl);
  letter-spacing: -0.035em;
  line-height: 0.95;
}
.hero h1 .accent { color: var(--accent); }
.hero h1 .serif-em { font-family: 'Instrument Serif', serif; font-style: italic; font-weight: 400; letter-spacing: -0.02em; }
.hero-sub {
  margin-top: var(--s-4);
  max-width: 32em;
  font-size: var(--fs-md);
  color: var(--ink-soft);
}
.hero-cta {
  margin-top: var(--s-5);
  display: flex; flex-wrap: wrap; gap: var(--s-3);
}
.hero-meta {
  display: flex; align-items: center; gap: var(--s-3);
  margin-top: var(--s-5);
  font-size: var(--fs-xs);
  color: var(--muted);
  flex-wrap: wrap;
}
.hero-meta-item { display: inline-flex; align-items: center; gap: 0.5em; }
.hero-meta-item .ico { width: 1em; height: 1em; border-radius: 50%; background: var(--accent-2); flex-shrink: 0; }

/* Hero visual */
.hero-visual {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: linear-gradient(150deg, var(--surface-warm), var(--cream-soft));
  box-shadow: var(--shadow-card);
}
.hero-visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.hero-visual::after {
  /* Subtle bottom vignette so floating cards stay legible */
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(11,31,51,0.18) 100%);
  pointer-events: none;
}
.hero-stat-card {
  position: absolute;
  background: var(--surface-elev);
  border-radius: var(--radius-md);
  padding: var(--s-3) var(--s-4);
  box-shadow: var(--shadow-elev);
  font-size: var(--fs-xs);
}
.hero-stat-card .big {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: var(--fs-xl);
  font-weight: 500;
  letter-spacing: -0.03em;
  display: block;
  color: var(--ink);
  line-height: 1;
}
.hero-stat-card .lbl { color: var(--muted); margin-top: 0.25em; display: block; }
.hero-stat-card.top { top: 5%; right: -8%; }
.hero-stat-card.bottom { bottom: 8%; left: -10%; }
@media (max-width: 700px) {
  .hero-stat-card.top { right: 4%; }
  .hero-stat-card.bottom { left: 4%; }
}

/* Trust strip */
.trust-strip {
  border-block: 1px solid var(--hairline);
  padding-block: var(--s-4);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-4);
}
@media (min-width: 700px) { .trust-strip { grid-template-columns: repeat(4, 1fr); } }
.trust-item { display: flex; flex-direction: column; gap: 0.2em; }
.trust-item .num {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: var(--fs-xl);
  font-weight: 500;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--ink);
}
.trust-item .lbl { font-size: var(--fs-xs); color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; }

/* ============= SECTION HEADERS ============= */
.s-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
  margin-bottom: var(--s-6);
  align-items: end;
}
@media (min-width: 900px) {
  .s-head.split { grid-template-columns: 1.4fr 1fr; gap: var(--s-5); }
}
.s-head h2 {
  font-size: var(--fs-2xl);
  letter-spacing: -0.028em;
}
.s-head h2 .em { font-family: 'Instrument Serif', serif; font-style: italic; font-weight: 400; color: var(--accent); }
.s-head p { color: var(--ink-soft); max-width: 40em; font-size: var(--fs-md); }

/* ============= SERVICE PILLARS ============= */
.pillars {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
}
@media (min-width: 720px) { .pillars { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .pillars { grid-template-columns: repeat(4, 1fr); } }

.pillar {
  background: var(--surface-elev);
  border-radius: var(--radius-md);
  padding: var(--s-5);
  border: 1px solid var(--hairline);
  display: flex; flex-direction: column; gap: var(--s-3);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
  cursor: pointer;
  min-height: 18em;
}
.pillar:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
  border-color: transparent;
}
.pillar-num {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: var(--fs-lg);
  color: var(--accent);
  line-height: 1;
}
.pillar h3 {
  font-size: var(--fs-lg);
  letter-spacing: -0.025em;
}
.pillar p { color: var(--muted); font-size: var(--fs-sm); }
.pillar-tags {
  margin-top: auto;
  display: flex; flex-wrap: wrap; gap: 0.4em;
}
.pillar-tags span {
  font-size: var(--fs-xs);
  padding: 0.3em 0.7em;
  border-radius: var(--radius-pill);
  background: var(--surface-warm);
  color: var(--ink-soft);
  font-weight: 500;
}

/* ============= EDITORIAL DUO IMAGE BAND ============= */
.duo-band {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
  margin-bottom: var(--s-7);
}
@media (min-width: 800px) {
  .duo-band { grid-template-columns: 1.4fr 1fr; }
}
.duo-img {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  aspect-ratio: 4 / 3;
  background: var(--surface-warm);
}
.duo-img.tall { aspect-ratio: 4 / 5; }
.duo-img img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 700ms var(--ease);
}
.duo-img:hover img { transform: scale(1.03); }
.duo-img .tag {
  position: absolute;
  bottom: var(--s-3);
  left: var(--s-3);
  background: color-mix(in oklab, var(--surface) 95%, transparent);
  backdrop-filter: blur(8px);
  padding: 0.5em 0.9em;
  border-radius: var(--radius-pill);
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--ink);
}

/* ============= FEATURED TREATMENTS (editorial) ============= */
.featured-list {
  display: grid;
  gap: var(--s-3);
}
.feat-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-4);
  padding-block: var(--s-5);
  border-top: 1px solid var(--hairline);
  align-items: start;
}
.feat-row:last-child { border-bottom: 1px solid var(--hairline); }
@media (min-width: 800px) {
  .feat-row { grid-template-columns: 6em 1fr 1.2fr 1fr auto; align-items: center; gap: var(--s-5); }
}
.feat-num {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: var(--fs-lg);
  color: var(--muted);
}
.feat-name {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: var(--fs-lg);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.feat-desc {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
}
.feat-cat {
  font-size: var(--fs-xs);
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.feat-cta {
  font-size: var(--fs-xs);
  display: inline-flex; align-items: center; gap: 0.4em;
  padding: 0.6em 0.95em;
  border-radius: var(--radius-pill);
  border: 1px solid var(--hairline-strong);
  color: var(--ink);
  font-weight: 600;
  transition: all var(--dur) var(--ease);
  min-height: 36px;
}
.feat-cta:hover { background: var(--ink); color: var(--surface); border-color: var(--ink); }

/* ============= ABOUT / DOCTOR ============= */
.about-block {
  background: var(--surface-warm);
  border-radius: var(--radius-lg);
  padding: clamp(2rem, 1.4rem + 3vw, 5rem);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
}
@media (min-width: 900px) {
  .about-block { grid-template-columns: 1fr 1.3fr; gap: var(--s-6); align-items: center; }
}
.about-portrait {
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-md);
  background: linear-gradient(150deg, var(--cream-soft), var(--surface-warm));
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}
.about-portrait img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.about-text h2 {
  font-size: var(--fs-2xl);
  letter-spacing: -0.028em;
  margin-bottom: var(--s-4);
}
.about-text .quote {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: var(--fs-xl);
  color: var(--ink);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-bottom: var(--s-4);
}
.about-text .desc { color: var(--ink-soft); font-size: var(--fs-md); margin-bottom: var(--s-4); }
.about-attrib-list {
  display: flex; flex-direction: column; gap: var(--s-3);
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px solid var(--hairline);
}
.about-attrib {
  display: flex; align-items: center; gap: var(--s-3);
}
.about-attrib .avatar {
  width: 3em; height: 3em; border-radius: 50%;
  background: var(--ink); color: var(--surface);
  display: grid; place-items: center;
  font-family: 'Instrument Serif', serif; font-style: italic;
  font-size: 1.1em;
}
.about-attrib .name { font-weight: 600; font-size: var(--fs-sm); }
.about-attrib .role { font-size: var(--fs-xs); color: var(--muted); }

/* ============= WHY US grid ============= */
.why-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
}
@media (min-width: 700px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .why-grid { grid-template-columns: repeat(4, 1fr); } }
.why-card {
  padding: var(--s-5);
  border-radius: var(--radius-md);
  background: var(--surface-elev);
  border: 1px solid var(--hairline);
  display: flex; flex-direction: column; gap: var(--s-3);
}
.why-icon {
  width: 2.6em; height: 2.6em;
  border-radius: 50%;
  display: grid; place-items: center;
  background: var(--surface-mint);
  color: var(--vitality-green-deep);
}
.why-card:nth-child(2) .why-icon { background: color-mix(in oklab, var(--medical-blue) 14%, transparent); color: var(--medical-blue); }
.why-card:nth-child(3) .why-icon { background: color-mix(in oklab, var(--warm-gold) 22%, transparent); color: #8B7517; }
.why-card:nth-child(4) .why-icon { background: color-mix(in oklab, var(--healing-teal) 18%, transparent); color: var(--healing-teal); }
.why-card h3 { font-size: var(--fs-md); }
.why-card p { font-size: var(--fs-sm); color: var(--ink-soft); }

/* ============= TESTIMONIAL CAROUSEL ============= */
.testi-wrap {
  background: var(--ink);
  color: var(--surface);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
}
@media (min-width: 960px) {
  .testi-wrap { grid-template-columns: 0.8fr 1.2fr; }
}
.testi-photo {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
@media (min-width: 960px) {
  .testi-photo { aspect-ratio: auto; }
}
.testi-photo img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.testi-photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(11,31,51,.55) 100%);
}
@media (min-width: 960px) {
  .testi-photo::after {
    background: linear-gradient(90deg, transparent 50%, rgba(11,31,51,.4) 100%);
  }
}
.testi-content {
  padding: clamp(2rem, 1.4rem + 3vw, 5rem);
}
.testi-wrap h2 { color: var(--surface); }
.testi-head {
  display: flex; justify-content: space-between; align-items: end;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}
.testi-track {
  display: flex;
  gap: var(--s-4);
  transition: transform 500ms var(--ease);
}
.testi-card {
  flex: 0 0 100%;
  display: flex; flex-direction: column;
  gap: var(--s-4);
}
.testi-stars { display: inline-flex; gap: 0.2em; color: var(--warm-gold); font-size: var(--fs-sm); }
.testi-quote {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: var(--fs-xl);
  line-height: 1.25;
  letter-spacing: -0.01em;
  max-width: 26em;
}
.testi-by { display: flex; align-items: center; gap: var(--s-3); }
.testi-by .av {
  width: 3em; height: 3em; border-radius: 50%;
  background: var(--surface); color: var(--ink);
  display: grid; place-items: center;
  font-family: 'Instrument Serif', serif; font-style: italic; font-size: 1.1em;
}
.testi-by .nm { font-weight: 600; font-size: var(--fs-sm); }
.testi-by .tx { font-size: var(--fs-xs); opacity: .65; }
.testi-controls { display: flex; gap: var(--s-2); }
.testi-controls button {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.2);
  color: var(--surface);
  display: grid; place-items: center;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.testi-controls button:hover { background: var(--surface); color: var(--ink); }

/* ============= FAQ ============= */
.faq-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
}
@media (min-width: 900px) {
  .faq-grid { grid-template-columns: 1fr 1.6fr; gap: var(--s-6); align-items: start; }
}
.faq-cats {
  display: flex; flex-wrap: wrap; gap: 0.4em;
}
@media (min-width: 900px) {
  .faq-cats { flex-direction: column; align-items: flex-start; position: sticky; top: 6rem; }
}
.faq-cats button {
  font-size: var(--fs-sm);
  padding: 0.6em 1em;
  border-radius: var(--radius-pill);
  color: var(--muted);
  transition: all var(--dur) var(--ease);
  min-height: 40px;
}
.faq-cats button.active { background: var(--ink); color: var(--surface); }
.faq-list { display: flex; flex-direction: column; }
.faq-item {
  border-top: 1px solid var(--hairline);
  padding-block: var(--s-4);
}
.faq-item:last-child { border-bottom: 1px solid var(--hairline); }
.faq-q {
  display: flex; justify-content: space-between; align-items: center; gap: var(--s-3);
  width: 100%;
  text-align: left;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: var(--fs-md);
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--ink);
  padding: 0;
  min-height: 44px;
}
.faq-q .plus {
  flex-shrink: 0;
  width: 1.8em; height: 1.8em;
  border-radius: 50%;
  border: 1px solid var(--hairline-strong);
  display: grid; place-items: center;
  font-size: 0.8em;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.faq-item.open .faq-q .plus { transform: rotate(45deg); background: var(--ink); color: var(--surface); border-color: var(--ink); }
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 400ms var(--ease), padding 400ms var(--ease);
}
.faq-item.open .faq-a {
  max-height: 30em;
  padding-top: var(--s-3);
}
.faq-a p { color: var(--ink-soft); font-size: var(--fs-sm); max-width: 38em; }

/* ============= CONTACT ============= */
.contact-block {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
}
@media (min-width: 900px) {
  .contact-block { grid-template-columns: 1.1fr 1fr; gap: var(--s-6); }
}
.contact-info { display: flex; flex-direction: column; gap: var(--s-5); }
.contact-block h2 { font-size: var(--fs-2xl); letter-spacing: -0.028em; }
.contact-line {
  display: flex; gap: var(--s-4);
  padding-block: var(--s-4);
  border-top: 1px solid var(--hairline);
  align-items: start;
}
.contact-line .lbl {
  font-size: var(--fs-xs);
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  flex: 0 0 7em;
  padding-top: 0.3em;
}
.contact-line .val { font-size: var(--fs-md); color: var(--ink); line-height: 1.4; }
.contact-line .val a:hover { color: var(--accent); }

.contact-form {
  background: var(--surface-elev);
  border-radius: var(--radius-md);
  padding: clamp(1.5rem, 1rem + 2vw, 3rem);
  border: 1px solid var(--hairline);
  display: flex; flex-direction: column; gap: var(--s-3);
}
.field { display: flex; flex-direction: column; gap: 0.4em; }
.field label {
  font-size: var(--fs-xs);
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
}
.field input, .field textarea, .field select {
  font: inherit;
  background: var(--surface);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-sm);
  padding: 0.85em 1em;
  color: var(--ink);
  min-height: 48px;
  width: 100%;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--surface-elev);
}
.field textarea { min-height: 8em; resize: vertical; }
.field.error input, .field.error textarea, .field.error select { border-color: #C8392E; background: #FBE9E7; }
.field-err { color: #C8392E; font-size: var(--fs-xs); }
.row-2 { display: grid; grid-template-columns: 1fr; gap: var(--s-3); }
@media (min-width: 540px) { .row-2 { grid-template-columns: 1fr 1fr; } }

.form-success {
  padding: var(--s-3);
  background: var(--surface-mint);
  border-radius: var(--radius-sm);
  color: var(--vitality-green-deep);
  font-weight: 600;
  font-size: var(--fs-sm);
  display: flex; align-items: center; gap: 0.5em;
}

/* ============= FOOTER ============= */
.site-foot {
  background: var(--ink);
  color: color-mix(in oklab, var(--surface) 80%, transparent);
  padding-block: var(--s-7) var(--s-5);
  margin-top: var(--s-7);
}
.foot-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
@media (min-width: 800px) {
  .foot-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; }
}
.foot-brand .brand { color: var(--surface); }
.foot-brand .brand-mark { background: var(--surface); }
.foot-brand .brand-mark img { padding: 0; }
.foot-brand p { margin-top: var(--s-3); color: color-mix(in oklab, var(--surface) 60%, transparent); font-size: var(--fs-sm); max-width: 22em; }
.foot-col h4 {
  color: var(--surface);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 600;
  margin-bottom: var(--s-3);
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.foot-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.7em; font-size: var(--fs-sm); }
.foot-col a { color: color-mix(in oklab, var(--surface) 70%, transparent); transition: color var(--dur) var(--ease); }
.foot-col a:hover { color: var(--surface); }

.foot-bottom {
  display: flex; justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--s-3);
  padding-top: var(--s-4);
  font-size: var(--fs-xs);
  color: color-mix(in oklab, var(--surface) 50%, transparent);
}
.foot-bottom .links { display: flex; gap: var(--s-4); flex-wrap: wrap; }

/* ============= MAP / LOCATION ============= */
.map-block {
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: var(--surface-warm);
  position: relative;
  border: 1px solid var(--hairline);
}
.map-block iframe {
  border: 0;
  width: 100%;
  height: 100%;
  display: block;
  filter: grayscale(.15) saturate(.9);
}

/* ============= CTA BANNER ============= */
.cta-banner {
  background: var(--ink);
  color: var(--surface);
  border-radius: var(--radius-lg);
  padding: clamp(2rem, 1.4rem + 3vw, 5rem);
  display: grid;
  gap: var(--s-5);
  grid-template-columns: 1fr;
  position: relative;
  overflow: hidden;
}
@media (min-width: 800px) {
  .cta-banner { grid-template-columns: 1.5fr 1fr; align-items: center; }
}
.cta-banner h2 {
  color: var(--surface);
  font-size: var(--fs-3xl);
  letter-spacing: -0.03em;
}
.cta-banner h2 .em { color: var(--accent-2); font-family: 'Instrument Serif', serif; font-style: italic; font-weight: 400; }
.cta-banner p { color: color-mix(in oklab, var(--surface) 70%, transparent); font-size: var(--fs-md); margin-top: var(--s-3); max-width: 32em; }
.cta-banner .actions { display: flex; flex-wrap: wrap; gap: var(--s-3); }
.cta-banner .btn-primary { background: var(--surface); color: var(--ink); }
.cta-banner .btn-primary:hover { background: var(--accent-2); color: var(--ink); }
.cta-banner .btn-ghost { color: var(--surface); border-color: rgba(255,255,255,.25); }
.cta-banner .btn-ghost:hover { background: var(--surface); color: var(--ink); border-color: var(--surface); }

/* ============= ACCESSIBILITY UTILS ============= */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; top: -3em; left: 1em;
  background: var(--ink); color: var(--surface);
  padding: 0.6em 1em; border-radius: var(--radius-sm);
  font-size: var(--fs-sm); font-weight: 600;
  z-index: 200;
  transition: top var(--dur) var(--ease);
}
.skip-link:focus { top: 1em; }

/* Reveal on scroll - subtle slide only, no opacity gating */
.reveal { transform: translateY(14px); transition: transform 600ms var(--ease); }
.reveal.in { transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .reveal { transform: none; transition: none; }
}
