/* ==========================================================================
   ER Of Fort Worth — Main Design System
   Premium Editorial Medical Aesthetic
   ========================================================================== */

/* ---------- 1. Design Tokens ---------- */
:root {
  /* Brand palette */
  --color-ink:        #0A1F2D;   /* deep editorial text */
  --color-navy:       #0B3954;   /* primary medical navy */
  --color-navy-700:   #0E4565;
  --color-navy-500:   #1A6A95;
  --color-navy-100:   #E4EEF4;
  --color-navy-50:    #F2F7FA;

  --color-cream:      #FBFAF6;   /* page background */
  --color-cream-200:  #F4F0E6;
  --color-cream-400:  #E8DFC8;

  --color-emergency:  #C9183A;   /* emergency red */
  --color-emergency-700: #A60E2D;
  --color-emergency-100: #FCE8EC;

  --color-mint:       #1F8A6A;   /* trust accent */
  --color-mint-100:   #DEF1E9;

  --color-gold:       #B8893A;   /* warm accent */
  --color-line:       #DCD3C0;   /* hairlines */
  --color-muted:      #6A7785;
  --color-white:      #FFFFFF;
  --color-black:      #07131C;

  /* Typography */
  --font-display: 'Fraunces', 'Times New Roman', serif;
  --font-body:    'Manrope', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  /* Type scale (fluid) */
  --fs-12: clamp(0.72rem, 0.7rem + 0.1vw, 0.78rem);
  --fs-14: clamp(0.82rem, 0.78rem + 0.2vw, 0.92rem);
  --fs-16: 1rem;
  --fs-18: clamp(1.05rem, 1rem + 0.25vw, 1.15rem);
  --fs-20: clamp(1.15rem, 1.1rem + 0.3vw, 1.3rem);
  --fs-24: clamp(1.35rem, 1.2rem + 0.7vw, 1.6rem);
  --fs-32: clamp(1.7rem, 1.4rem + 1.4vw, 2.2rem);
  --fs-44: clamp(2.2rem, 1.7rem + 2.4vw, 3.1rem);
  --fs-60: clamp(2.8rem, 2.1rem + 3.4vw, 4.2rem);
  --fs-80: clamp(3.4rem, 2.4rem + 5vw, 5.5rem);

  /* Spacing */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;

  /* Radius */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-xl: 32px;
  --radius-pill: 999px;

  /* Shadow */
  --shadow-xs: 0 1px 2px rgba(10,31,45,.06);
  --shadow-sm: 0 4px 14px -4px rgba(10,31,45,.08);
  --shadow-md: 0 12px 32px -10px rgba(10,31,45,.14);
  --shadow-lg: 0 30px 60px -20px rgba(10,31,45,.22);
  --shadow-emergency: 0 14px 30px -8px rgba(201,24,58,.35);

  /* Motion */
  --ease-out: cubic-bezier(.22,.61,.36,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  /* Layout */
  --container: 1240px;
  --container-narrow: 880px;
  --nav-height: 84px;
}

/* ---------- 2. Reset & base ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-16);
  line-height: 1.6;
  color: var(--color-ink);
  background: var(--color-cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

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

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color .2s var(--ease-out);
}

ul, ol {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* ---------- 3. Typography ---------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--color-ink);
  letter-spacing: -0.02em;
  line-height: 1.08;
  margin: 0 0 var(--space-5);
  font-variation-settings: "opsz" 96, "SOFT" 30;
}

h1 { font-size: var(--fs-80); font-variation-settings: "opsz" 144, "SOFT" 50; }
h2 { font-size: var(--fs-60); font-variation-settings: "opsz" 96, "SOFT" 40; }
h3 { font-size: var(--fs-44); font-variation-settings: "opsz" 72, "SOFT" 30; }
h4 { font-size: var(--fs-32); font-variation-settings: "opsz" 48, "SOFT" 20; }
h5 { font-size: var(--fs-24); }
h6 { font-size: var(--fs-20); }

.display-italic {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 80;
  color: var(--color-navy);
}

p { margin: 0 0 var(--space-4); max-width: 68ch; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--fs-12);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-emergency);
  margin-bottom: var(--space-5);
}
.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--color-emergency);
}

.lede {
  font-size: var(--fs-20);
  line-height: 1.55;
  color: var(--color-muted);
  max-width: 60ch;
}

/* ---------- 4. Layout primitives ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--space-5);
}
.container--narrow { max-width: var(--container-narrow); }

.section {
  padding: var(--space-10) 0;
  position: relative;
}
.section--sm { padding: var(--space-8) 0; }
.section--tight { padding: var(--space-7) 0; }

.grid { display: grid; gap: var(--space-6); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
@media (min-width: 901px) and (max-width: 1100px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- 5. Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: 16px 28px;
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: var(--fs-16);
  font-weight: 600;
  letter-spacing: -0.005em;
  transition: all .35s var(--ease-out);
  position: relative;
  overflow: hidden;
  will-change: transform;
  text-align: center;
  justify-content: center;
  white-space: nowrap;
  border: 1.5px solid transparent;
}

.btn--primary {
  background: var(--color-navy);
  color: var(--color-cream);
}
.btn--primary:hover {
  background: var(--color-navy-700);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn--emergency {
  background: var(--color-emergency);
  color: var(--color-white);
  box-shadow: var(--shadow-emergency);
}
.btn--emergency:hover {
  background: var(--color-emergency-700);
  transform: translateY(-2px);
  box-shadow: 0 18px 36px -8px rgba(201,24,58,.5);
}
.btn--emergency::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: inherit;
  background: var(--color-emergency);
  z-index: -1;
  opacity: .35;
  animation: pulse-ring 2.4s var(--ease-out) infinite;
}

.btn--ghost {
  background: transparent;
  color: var(--color-ink);
  border-color: var(--color-line);
}
.btn--ghost:hover {
  border-color: var(--color-navy);
  background: var(--color-navy-50);
}

.btn--lg { padding: 20px 36px; font-size: var(--fs-18); }
.btn--sm { padding: 10px 18px; font-size: var(--fs-14); }

.btn svg { width: 18px; height: 18px; transition: transform .3s var(--ease-out); }
.btn:hover svg { transform: translateX(3px); }

@keyframes pulse-ring {
  0% { transform: scale(1); opacity: .35; }
  70% { transform: scale(1.18); opacity: 0; }
  100% { transform: scale(1.18); opacity: 0; }
}

/* ---------- 6. Top emergency bar ---------- */
.emergency-bar {
  background: var(--color-emergency);
  color: var(--color-white);
  font-size: var(--fs-14);
  font-weight: 500;
  letter-spacing: -0.005em;
}
.emergency-bar__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
  padding: 10px var(--space-5);
  flex-wrap: wrap;
}
.emergency-bar__pulse {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  animation: pulse-dot 1.6s ease-in-out infinite;
  margin-right: var(--space-2);
  vertical-align: middle;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .4; transform: scale(.7); }
}
.emergency-bar a {
  color: #fff;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.emergency-bar a:hover { text-decoration-thickness: 2px; }

/* ---------- 7. Navigation ---------- */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(251, 250, 246, 0.85);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid transparent;
  transition: all .3s var(--ease-out);
}
.nav.is-scrolled {
  border-bottom-color: var(--color-line);
  box-shadow: var(--shadow-xs);
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--nav-height);
  gap: var(--space-6);
}

.logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-display);
  font-size: var(--fs-24);
  font-weight: 500;
  color: var(--color-ink);
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 48;
}
.logo__mark {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  background: var(--color-navy);
  color: var(--color-cream);
  border-radius: 12px;
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  font-style: italic;
  position: relative;
}
.logo__mark::before {
  content: "+";
  position: absolute;
  top: -3px;
  right: -3px;
  width: 18px;
  height: 18px;
  background: var(--color-emergency);
  color: #fff;
  font-size: 14px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--font-body);
  font-weight: 700;
  line-height: 1;
}
.logo small {
  display: block;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.22em;
  font-weight: 600;
  color: var(--color-muted);
  text-transform: uppercase;
  margin-top: 2px;
}

.nav__menu {
  display: flex;
  align-items: center;
  gap: var(--space-6);
}
.nav__menu a {
  font-size: var(--fs-14);
  font-weight: 500;
  color: var(--color-ink);
  position: relative;
  padding: 6px 0;
}
.nav__menu a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--color-navy);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .35s var(--ease-out);
}
.nav__menu a:hover::after,
.nav__menu a.is-active::after {
  transform: scaleX(1);
  transform-origin: left;
}

.nav__has-children { position: relative; }
.nav__dropdown {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  min-width: 320px;
  background: var(--color-white);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  pointer-events: none;
  transition: all .3s var(--ease-out);
}
.nav__has-children:hover .nav__dropdown,
.nav__has-children:focus-within .nav__dropdown {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav__dropdown a {
  display: block;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  font-size: var(--fs-14);
}
.nav__dropdown a:hover {
  background: var(--color-cream-200);
}
.nav__dropdown a::after { display: none; }

.nav__cta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.nav__toggle {
  display: none;
  width: 44px;
  height: 44px;
  position: relative;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  padding: 10px;
}
.nav__toggle span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--color-ink);
  transition: all .3s var(--ease-out);
}
.nav__toggle.is-open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav__toggle.is-open span:nth-child(2) { opacity: 0; }
.nav__toggle.is-open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (max-width: 1100px) {
  .nav__menu, .nav__cta .btn--ghost { display: none; }
  .nav__toggle { display: flex; }
}

.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--color-cream);
  z-index: 99;
  padding: calc(var(--nav-height) + var(--space-5)) var(--space-5) var(--space-5);
  transform: translateX(100%);
  transition: transform .4s var(--ease-out);
  overflow-y: auto;
}
.mobile-menu.is-open { transform: translateX(0); }
.mobile-menu nav ul { display: flex; flex-direction: column; gap: var(--space-2); }
.mobile-menu nav a {
  display: block;
  padding: 14px 0;
  font-family: var(--font-display);
  font-size: var(--fs-32);
  border-bottom: 1px solid var(--color-line);
}
.mobile-menu .btn { margin-top: var(--space-5); width: 100%; }

/* ---------- 8. Hero ---------- */
.hero {
  position: relative;
  padding: var(--space-9) 0 var(--space-10);
  overflow: hidden;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
.hero__bg::before {
  content: "";
  position: absolute;
  top: -10%;
  right: -10%;
  width: 60%;
  height: 80%;
  background: radial-gradient(ellipse at center, rgba(11,57,84,.06), transparent 70%);
  filter: blur(40px);
}
.hero__bg::after {
  content: "";
  position: absolute;
  bottom: -20%;
  left: -10%;
  width: 50%;
  height: 70%;
  background: radial-gradient(ellipse at center, rgba(201,24,58,.05), transparent 70%);
  filter: blur(60px);
}

.hero__grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--space-8);
  align-items: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 980px) {
  .hero__grid { grid-template-columns: 1fr; gap: var(--space-7); }
}

.hero h1 {
  font-size: var(--fs-80);
  margin-bottom: var(--space-6);
}
.hero h1 .accent {
  font-style: italic;
  color: var(--color-navy);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  position: relative;
  display: inline-block;
}
.hero h1 .accent::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0.08em;
  height: 0.18em;
  background: var(--color-emergency);
  opacity: .18;
  z-index: -1;
  border-radius: 4px;
}

.hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-line);
  flex-wrap: wrap;
}
.hero__meta .badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-14);
  font-weight: 500;
  color: var(--color-muted);
}
.hero__meta .badge::before {
  content: "";
  width: 8px;
  height: 8px;
  background: var(--color-mint);
  border-radius: 50%;
}

.hero__cta {
  display: flex;
  gap: var(--space-4);
  margin-top: var(--space-6);
  flex-wrap: wrap;
}

.hero__visual {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--color-navy-100);
  box-shadow: var(--shadow-lg);
}
.hero__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease-out);
}
.hero__visual:hover img { transform: scale(1.04); }

.hero__visual-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,31,45,.6) 100%);
}

.hero__floating-card {
  position: absolute;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(14px);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-md);
  border: 1px solid rgba(255,255,255,.5);
  animation: float 4s ease-in-out infinite;
}
.hero__floating-card--wait {
  bottom: var(--space-5);
  left: var(--space-5);
}
.hero__floating-card--open {
  top: var(--space-5);
  right: var(--space-5);
  animation-delay: -2s;
}
.hero__floating-card .label {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
  font-weight: 600;
  margin-bottom: 4px;
}
.hero__floating-card .value {
  font-family: var(--font-display);
  font-size: var(--fs-32);
  color: var(--color-ink);
  font-variation-settings: "opsz" 48, "SOFT" 30;
}
.hero__floating-card .value small {
  font-family: var(--font-body);
  font-size: var(--fs-14);
  color: var(--color-muted);
  font-weight: 500;
}
.hero__floating-card .pulse-green {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-mint);
  margin-right: var(--space-2);
  position: relative;
}
.hero__floating-card .pulse-green::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: var(--color-mint);
  opacity: .4;
  animation: pulse-ring 2s infinite;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

/* ---------- 9. Trust strip ---------- */
.trust-strip {
  padding: var(--space-7) 0;
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}
.trust-strip__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-7);
  align-items: center;
}
.trust-stat {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.trust-stat__num {
  font-family: var(--font-display);
  font-size: var(--fs-60);
  line-height: 1;
  color: var(--color-navy);
  font-variation-settings: "opsz" 96, "SOFT" 50;
}
.trust-stat__num .unit { font-size: 0.5em; color: var(--color-muted); margin-left: 4px; }
.trust-stat__label {
  font-size: var(--fs-14);
  color: var(--color-muted);
  letter-spacing: 0.02em;
}
.trust-stat__divider {
  width: 1px;
  height: 60%;
  background: var(--color-line);
}
@media (max-width: 760px) {
  .trust-strip__grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
}

/* ---------- 10. Service cards (editorial) ---------- */
.services-section {
  background: var(--color-cream);
}
.section-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-7);
  align-items: end;
  margin-bottom: var(--space-8);
}
@media (max-width: 900px) {
  .section-header { grid-template-columns: 1fr; gap: var(--space-5); }
}
.section-header__right { text-align: right; }
@media (max-width: 900px) { .section-header__right { text-align: left; } }

.service-card {
  background: var(--color-white);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: relative;
  transition: all .4s var(--ease-out);
  overflow: hidden;
}
.service-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-700) 100%);
  opacity: 0;
  transition: opacity .4s var(--ease-out);
  z-index: 0;
}
.service-card > * { position: relative; z-index: 1; }
.service-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: transparent;
}
.service-card:hover::before { opacity: 1; }
.service-card:hover h4,
.service-card:hover p,
.service-card:hover .service-card__index,
.service-card:hover .service-card__arrow { color: var(--color-cream); }

.service-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
}
.service-card__index {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-20);
  color: var(--color-emergency);
  transition: color .4s var(--ease-out);
}
.service-card__icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  background: var(--color-navy-50);
  border-radius: 14px;
  color: var(--color-navy);
  transition: all .4s var(--ease-out);
  flex-shrink: 0;
}
.service-card:hover .service-card__icon {
  background: rgba(255,255,255,.15);
  color: #fff;
}
.service-card__icon svg { width: 26px; height: 26px; }
.service-card h4 {
  font-size: var(--fs-24);
  margin: 0;
  transition: color .4s var(--ease-out);
}
.service-card p {
  font-size: var(--fs-14);
  color: var(--color-muted);
  margin: 0;
  transition: color .4s var(--ease-out);
}
.service-card__arrow {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-14);
  font-weight: 600;
  color: var(--color-navy);
  transition: all .4s var(--ease-out);
}
.service-card:hover .service-card__arrow { gap: 14px; }
.service-card__arrow svg { width: 18px; height: 18px; }

/* ---------- 11. Editorial split section ---------- */
.split-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (max-width: 980px) {
  .split-section { grid-template-columns: 1fr; gap: var(--space-7); }
}
.split-section--reverse > :first-child { order: 2; }
@media (max-width: 980px) {
  .split-section--reverse > :first-child { order: 0; }
}
.split-image {
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--color-navy-100);
  position: relative;
}
.split-image img { width: 10%; height: 50%; object-fit: cover; }

/* ---------- 12. Process steps ---------- */
.process-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.process-step {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: var(--space-5);
  padding: var(--space-5) 0;
  border-bottom: 1px solid var(--color-line);
  align-items: start;
  transition: all .3s var(--ease-out);
}
.process-step:last-child { border-bottom: none; }
.process-step:hover { padding-left: var(--space-3); }
.process-step__num {
  font-family: var(--font-display);
  font-size: var(--fs-44);
  font-style: italic;
  color: var(--color-emergency);
  font-variation-settings: "opsz" 72, "SOFT" 80;
  line-height: 1;
}
.process-step h5 { font-size: var(--fs-24); margin-bottom: 8px; }
.process-step p { font-size: var(--fs-14); color: var(--color-muted); margin: 0; }

/* ---------- 13. Locations grid ---------- */
.locations-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--color-line);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 900px) { .locations-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .locations-grid { grid-template-columns: 1fr; } }

.location-tile {
  background: var(--color-white);
  padding: var(--space-5) var(--space-5);
  transition: all .3s var(--ease-out);
  display: flex;
  flex-direction: column;
  gap: 6px;
  position: relative;
  overflow: hidden;
}
.location-tile:hover {
  background: var(--color-navy);
  color: var(--color-cream);
}
.location-tile:hover .location-tile__city,
.location-tile:hover .location-tile__distance,
.location-tile:hover .location-tile__arrow { color: var(--color-cream); }
.location-tile__city {
  font-family: var(--font-display);
  font-size: var(--fs-24);
  color: var(--color-ink);
  font-variation-settings: "opsz" 48, "SOFT" 30;
  transition: color .3s;
}
.location-tile__state {
  font-size: var(--fs-12);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-emergency);
  font-weight: 600;
}
.location-tile__distance {
  font-size: var(--fs-14);
  color: var(--color-muted);
  margin-top: auto;
  transition: color .3s;
}
.location-tile__arrow {
  position: absolute;
  top: var(--space-5);
  right: var(--space-5);
  width: 28px;
  height: 28px;
  color: var(--color-muted);
  transition: all .3s var(--ease-out);
}
.location-tile:hover .location-tile__arrow {
  transform: rotate(-45deg);
  color: var(--color-cream);
}

/* ---------- 14. Testimonials ---------- */
.testimonial {
  background: var(--color-cream-200);
  padding: var(--space-7);
  border-radius: var(--radius-lg);
  position: relative;
}
.testimonial__quote {
  font-family: var(--font-display);
  font-size: var(--fs-32);
  line-height: 1.3;
  color: var(--color-ink);
  font-variation-settings: "opsz" 48, "SOFT" 30;
  margin-bottom: var(--space-5);
  font-style: italic;
}
.testimonial__quote::before {
  content: "\201C";
  font-family: var(--font-display);
  font-size: 4em;
  position: absolute;
  top: 10px;
  left: 24px;
  color: var(--color-emergency);
  opacity: .2;
  line-height: 1;
}
.testimonial__author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-line);
}
.testimonial__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--color-navy);
  color: var(--color-cream);
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-20);
}
.testimonial__name { font-weight: 600; }
.testimonial__role { font-size: var(--fs-14); color: var(--color-muted); }
.testimonial__stars {
  position: absolute;
  top: var(--space-5);
  right: var(--space-5);
  color: var(--color-gold);
  display: flex;
  gap: 2px;
}
.testimonial__stars svg { width: 16px; height: 16px; fill: currentColor; }

/* ---------- 15. CTA banner ---------- */
.cta-banner {
  background: var(--color-navy);
  color: var(--color-cream);
  border-radius: var(--radius-xl);
  padding: var(--space-9) var(--space-8);
  position: relative;
  overflow: hidden;
  text-align: center;
}
.cta-banner::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -20%;
  width: 80%;
  height: 200%;
  background: radial-gradient(ellipse at center, rgba(201,24,58,.25), transparent 60%);
  filter: blur(50px);
  pointer-events: none;
}
.cta-banner__inner { position: relative; z-index: 1; max-width: 720px; margin: 0 auto; }
.cta-banner h2 { color: var(--color-cream); margin-bottom: var(--space-5); }
.cta-banner h2 .italic {
  font-style: italic;
  color: var(--color-emergency-100);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.cta-banner p { color: rgba(251,250,246,.7); margin: 0 auto var(--space-6); }
.cta-banner__buttons { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }
.cta-banner .btn--ghost { color: var(--color-cream); border-color: rgba(251,250,246,.3); }
.cta-banner .btn--ghost:hover { background: rgba(251,250,246,.1); border-color: var(--color-cream); }

/* ---------- 16. FAQ accordion ---------- */
.faq-list { display: flex; flex-direction: column; }
.faq-item {
  border-bottom: 1px solid var(--color-line);
}
.faq-item__btn {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-5);
  padding: var(--space-5) 0;
  text-align: left;
  font-family: var(--font-display);
  font-size: var(--fs-24);
  color: var(--color-ink);
  transition: color .3s;
  font-variation-settings: "opsz" 48, "SOFT" 20;
}
.faq-item__btn:hover { color: var(--color-emergency); }
.faq-item__icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  position: relative;
  margin-top: 4px;
}
.faq-item__icon::before,
.faq-item__icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 14px;
  height: 1.5px;
  background: var(--color-ink);
  transform: translate(-50%, -50%);
  transition: transform .3s var(--ease-out);
}
.faq-item__icon::after { transform: translate(-50%, -50%) rotate(90deg); }
.faq-item.is-open .faq-item__icon::after { transform: translate(-50%, -50%) rotate(0); }

.faq-item__body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .4s var(--ease-out);
}
.faq-item.is-open .faq-item__body { grid-template-rows: 1fr; }
.faq-item__body > div { overflow: hidden; }
.faq-item__body p {
  padding-bottom: var(--space-5);
  color: var(--color-muted);
  max-width: 70ch;
  margin: 0;
}

/* ---------- 17. Footer ---------- */
.footer {
  background: var(--color-ink);
  color: var(--color-cream-200);
  padding: var(--space-9) 0 var(--space-5);
  position: relative;
}
.footer__top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--space-7);
  padding-bottom: var(--space-7);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
@media (max-width: 900px) {
  .footer__top { grid-template-columns: 1fr 1fr; gap: var(--space-6); }
}
@media (max-width: 540px) { .footer__top { grid-template-columns: 1fr; } }

.footer__brand .logo { color: var(--color-cream); margin-bottom: var(--space-4); }
.footer__brand .logo small { color: rgba(255,255,255,.4); }
.footer__brand p {
  font-size: var(--fs-14);
  color: rgba(255,255,255,.6);
  line-height: 1.6;
  margin-bottom: var(--space-5);
}
.footer__address {
  font-style: normal;
  font-size: var(--fs-14);
  color: rgba(255,255,255,.7);
  line-height: 1.6;
}
.footer__address strong { color: var(--color-cream); display: block; margin-bottom: 4px; font-weight: 600; }

.footer__col h6 {
  color: var(--color-cream);
  font-family: var(--font-body);
  font-size: var(--fs-12);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}
.footer__col ul { display: flex; flex-direction: column; gap: var(--space-2); }
.footer__col a {
  font-size: var(--fs-14);
  color: rgba(255,255,255,.6);
  transition: color .2s;
}
.footer__col a:hover { color: var(--color-cream); }

.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-5);
  font-size: var(--fs-12);
  color: rgba(255,255,255,.4);
  flex-wrap: wrap;
  gap: var(--space-3);
}
.footer__bottom a { color: rgba(255,255,255,.5); margin-left: var(--space-4); }
.footer__bottom a:hover { color: var(--color-cream); }
.footer__phone {
  font-family: var(--font-body, 'Manrope', sans-serif);
  font-size: 16px;
  color: #fff;
  font-style: normal;
  display: inline-block;
  margin: 4px 0 0;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-decoration: none;
  transition: color 200ms;
}
.footer__phone:hover {
  color: var(--color-red) !important;
}

/* ---------- 18. Floating CTA buttons ---------- */
.floating-cta {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 80;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-end;
}
.floating-cta__call {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: 14px 20px;
  background: var(--color-emergency);
  color: #fff;
  border-radius: var(--radius-pill);
  font-weight: 600;
  box-shadow: var(--shadow-emergency);
  font-size: var(--fs-14);
  transition: all .3s var(--ease-out);
}
.floating-cta__call:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 36px -8px rgba(201,24,58,.5);
}
.floating-cta__call svg { width: 18px; height: 18px; }
.floating-cta__call .ring {
  position: relative;
  width: 28px;
  height: 28px;
  background: rgba(255,255,255,.2);
  border-radius: 50%;
  display: grid;
  place-items: center;
}
.floating-cta__call .ring::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: rgba(255,255,255,.3);
  animation: pulse-ring 2s infinite;
}

.chatbot-toggle {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--color-navy);
  color: var(--color-cream);
  display: grid;
  place-items: center;
  box-shadow: var(--shadow-md);
  transition: all .3s var(--ease-out);
  position: relative;
}
.chatbot-toggle:hover { transform: scale(1.08); background: var(--color-navy-700); }
.chatbot-toggle svg { width: 26px; height: 26px; }
.chatbot-toggle__badge {
  position: absolute;
  top: -2px;
  right: -2px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-mint);
  border: 2px solid var(--color-cream);
}

/* ---------- 19. Breadcrumbs ---------- */
.breadcrumbs {
  padding: var(--space-5) 0;
  font-size: var(--fs-14);
  color: var(--color-muted);
  border-bottom: 1px solid var(--color-line);
}
.breadcrumbs ol { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.breadcrumbs li { display: flex; align-items: center; gap: var(--space-2); }
.breadcrumbs li + li::before { content: "/"; color: var(--color-line); }
.breadcrumbs a:hover { color: var(--color-navy); text-decoration: underline; }
.breadcrumbs [aria-current] { color: var(--color-ink); font-weight: 500; }

/* ---------- 20. Page hero (inner) ---------- */
.page-hero {
  padding: var(--space-8) 0 var(--space-7);
  background: linear-gradient(180deg, var(--color-cream-200) 0%, var(--color-cream) 100%);
  border-bottom: 1px solid var(--color-line);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -20%;
  width: 60%;
  height: 200%;
  background: radial-gradient(ellipse at center, rgba(11,57,84,.06), transparent 70%);
  pointer-events: none;
}
.page-hero__inner { position: relative; z-index: 1; max-width: 880px; }
.page-hero h1 { font-size: var(--fs-60); margin-bottom: var(--space-5); }
.page-hero .lede { font-size: var(--fs-20); max-width: 60ch; }

/* ---------- 21. Animations (intersection observer) ---------- */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .9s var(--ease-out), transform .9s var(--ease-out);
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}

/* ---------- 22. Utility helpers ---------- */
.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;
}
.text-muted { color: var(--color-muted); }
.text-center { text-align: center; }
.mb-0 { margin-bottom: 0; }
.mt-0 { margin-top: 0; }
.divider {
  height: 1px;
  background: var(--color-line);
  margin: var(--space-7) 0;
  border: 0;
}

/* ---------- 23. Tag chips ---------- */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-12);
  font-weight: 600;
  letter-spacing: 0.05em;
  background: var(--color-navy-50);
  color: var(--color-navy);
  border: 1px solid var(--color-navy-100);
}
.tag--emergency { background: var(--color-emergency-100); color: var(--color-emergency-700); border-color: rgba(201,24,58,.2); }
.tag--mint { background: var(--color-mint-100); color: var(--color-mint); border-color: rgba(31,138,106,.2); }

/* ============================================================
   v2 ENHANCEMENTS — Dark mode, scanning animations, 3D icons,
   location filter, premium polish
   ============================================================ */

/* --- Theme tokens: light (default) + dark --- */
:root {
  --bg-page: #FBFAF6;
  --bg-elev: #FFFFFF;
  --bg-soft: #F4F0E6;
  --bg-strip: #0B3954;
  --text: #0A1F2D;
  --text-muted: #5A6B78;
  --text-on-dark: #FBFAF6;
  --border: rgba(11,57,84,0.08);
  --border-strong: rgba(11,57,84,0.18);
  --shadow-sm: 0 1px 2px rgba(10,31,45,0.06), 0 2px 6px rgba(10,31,45,0.04);
  --shadow-md: 0 4px 12px rgba(10,31,45,0.08), 0 12px 32px rgba(10,31,45,0.06);
  --shadow-lg: 0 12px 32px rgba(10,31,45,0.12), 0 32px 80px rgba(10,31,45,0.10);
  --glass-bg: rgba(255,255,255,0.72);
  --glass-bg-strong: rgba(255,255,255,0.92);
  --glass-border: rgba(255,255,255,0.6);
  --accent: var(--color-navy, #0B3954);
  --accent-2: var(--color-mint, #1F8A6A);
  --emergency: var(--color-emergency, #C9183A);
  --grid-line: rgba(11,57,84,0.06);
}

html[data-theme="dark"] {
  --bg-page: #07141C;
  --bg-elev: #0F2230;
  --bg-soft: #112B3C;
  --bg-strip: #050F16;
  --text: #EAF2F7;
  --text-muted: #95A8B5;
  --text-on-dark: #EAF2F7;
  --border: rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.18);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4), 0 2px 6px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.45), 0 12px 32px rgba(0,0,0,0.35);
  --shadow-lg: 0 12px 32px rgba(0,0,0,0.55), 0 32px 80px rgba(0,0,0,0.5);
  --glass-bg: rgba(15,34,48,0.72);
  --glass-bg-strong: rgba(15,34,48,0.92);
  --glass-border: rgba(255,255,255,0.10);
  --accent: #6FB6E0;
  --accent-2: #4DD4A8;
  --emergency: #FF5C7A;
  --grid-line: rgba(255,255,255,0.05);
}

html { color-scheme: light; transition: color 200ms ease, background 200ms ease; }
html[data-theme="dark"] { color-scheme: dark; }

body {
  background: var(--bg-page);
  color: var(--text);
  transition: background 300ms ease, color 300ms ease;
}

/* Re-skin core surfaces using new tokens — overrides previous absolute colors */
.nav,
.nav.is-stuck { background: var(--glass-bg); backdrop-filter: blur(20px) saturate(180%); -webkit-backdrop-filter: blur(20px) saturate(180%); border-bottom: 1px solid var(--glass-border); }
html[data-theme="dark"] .nav a { color: var(--text); }
html[data-theme="dark"] .nav__dropdown { background: var(--bg-elev); border: 1px solid var(--border); }
html[data-theme="dark"] .nav__dropdown a { color: var(--text); }
html[data-theme="dark"] .nav__dropdown a:hover { background: var(--bg-soft); }
html[data-theme="dark"] .mobile-menu { background: var(--bg-elev); }
html[data-theme="dark"] .mobile-menu a { color: var(--text); }
html[data-theme="dark"] .logo small { color: var(--text-muted); }

/* Service / generic cards re-skinned */
html[data-theme="dark"] .service-card,
html[data-theme="dark"] .treatment-card,
html[data-theme="dark"] .feature-card,
html[data-theme="dark"] .blog-card,
html[data-theme="dark"] .contact-card,
html[data-theme="dark"] .testimonial,
html[data-theme="dark"] .location-tile,
html[data-theme="dark"] .checkin-card { background: var(--bg-elev); border-color: var(--border); color: var(--text); }
html[data-theme="dark"] .service-card h3,
html[data-theme="dark"] .treatment-card h3,
html[data-theme="dark"] .feature-card h3,
html[data-theme="dark"] .blog-card h3,
html[data-theme="dark"] .location-tile h3 { color: var(--text); }
html[data-theme="dark"] .service-card p,
html[data-theme="dark"] .blog-card p,
html[data-theme="dark"] .location-tile p { color: var(--text-muted); }
html[data-theme="dark"] .trust-strip,
html[data-theme="dark"] .insurance-strip { background: var(--bg-soft); border-color: var(--border); }
html[data-theme="dark"] .stat .num { color: var(--accent); }
html[data-theme="dark"] .faq__item { border-color: var(--border); }
html[data-theme="dark"] .faq__q { color: var(--text); }
html[data-theme="dark"] .faq__a { color: var(--text-muted); }
html[data-theme="dark"] .split-section,
html[data-theme="dark"] .cta-banner-section,
html[data-theme="dark"] section.bg-cream { background: var(--bg-soft); }
html[data-theme="dark"] .footer { background: var(--bg-strip); }
html[data-theme="dark"] .breadcrumbs a { color: var(--text-muted); }
html[data-theme="dark"] .page-hero { background: linear-gradient(135deg, var(--bg-soft), var(--bg-elev)); }

/* --- Theme toggle button (premium pill switch) --- */
.theme-toggle {
  position: relative;
  width: 56px; height: 30px;
  border-radius: 999px;
  background: linear-gradient(135deg, #e9e4d6, #f7f3e7);
  border: 1px solid var(--border-strong);
  cursor: pointer;
  display: inline-flex; align-items: center;
  padding: 3px; margin-right: 6px;
  transition: background 300ms ease, border-color 300ms ease;
  flex-shrink: 0;
}
.theme-toggle__knob {
  position: relative; z-index: 2;
  width: 24px; height: 24px;
  background: linear-gradient(135deg, #fff, #f0ead8);
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(10,31,45,0.18), inset 0 -2px 4px rgba(0,0,0,0.06);
  transition: transform 350ms cubic-bezier(0.34,1.56,0.64,1), background 300ms ease;
  display: grid; place-items: center;
}
.theme-toggle__knob svg { width: 14px; height: 14px; color: #C9183A; }
.theme-toggle__knob .icon-moon { display: none; }
html[data-theme="dark"] .theme-toggle { background: linear-gradient(135deg, #0a1c2a, #15324a); }
html[data-theme="dark"] .theme-toggle__knob { transform: translateX(26px); background: linear-gradient(135deg, #1a3147, #0a1c2a); }
html[data-theme="dark"] .theme-toggle__knob .icon-sun { display: none; }
html[data-theme="dark"] .theme-toggle__knob .icon-moon { display: block; color: #ffd56b; }
.theme-toggle::before, .theme-toggle::after {
  position: absolute; top: 50%; transform: translateY(-50%);
  font-size: 11px; pointer-events: none; opacity: 0.5;
}
.theme-toggle::before { content: "☀"; left: 8px; }
.theme-toggle::after { content: "☾"; right: 9px; }

/* --- Scanning hero overlay (real-time medical scan feel) --- */
.hero-scan {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  isolation: isolate;
}
.hero-scan__img {
  width: 100%; height: 100%; display: block;
  object-fit: cover;
  filter: saturate(1.08) contrast(1.02);
}
.hero-scan__grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(31,138,106,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,138,106,0.12) 1px, transparent 1px);
  background-size: 28px 28px;
  mix-blend-mode: screen;
  pointer-events: none;
}
.hero-scan__beam {
  position: absolute; inset: 0;
  background: linear-gradient(180deg,
    transparent 0%, transparent 38%,
    rgba(31,212,168,0.0) 45%,
    rgba(31,212,168,0.35) 50%,
    rgba(31,212,168,0.0) 55%,
    transparent 62%, transparent 100%);
  mix-blend-mode: screen;
  animation: scanBeam 4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes scanBeam {
  0%, 100% { transform: translateY(-60%); opacity: 0.6; }
  50% { transform: translateY(60%); opacity: 1; }
}
.hero-scan__corner {
  position: absolute; width: 28px; height: 28px;
  border: 2px solid #1FD4A8; opacity: 0.85;
  pointer-events: none;
}
.hero-scan__corner.tl { top: 16px; left: 16px; border-right: 0; border-bottom: 0; }
.hero-scan__corner.tr { top: 16px; right: 16px; border-left: 0; border-bottom: 0; }
.hero-scan__corner.bl { bottom: 16px; left: 16px; border-right: 0; border-top: 0; }
.hero-scan__corner.br { bottom: 16px; right: 16px; border-left: 0; border-top: 0; }
.hero-scan__hud {
  position: absolute; left: 18px; bottom: 18px;
  background: rgba(7,20,28,0.72);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(31,212,168,0.35);
  border-radius: 14px;
  padding: 10px 14px;
  display: flex; align-items: center; gap: 10px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  color: #1FD4A8;
  font-size: 11px; letter-spacing: 0.08em;
}
.hero-scan__hud .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #1FD4A8; box-shadow: 0 0 12px #1FD4A8;
  animation: pulseDot 1.4s ease-in-out infinite;
}
.hero-scan__hud .vital { color: #fff; font-weight: 700; margin-left: 6px; letter-spacing: 0.04em; }
@keyframes pulseDot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.8); }
}

/* ECG line - SVG path that "draws" continuously */
.ecg-strip {
  position: absolute; left: 0; right: 0; top: 28px;
  height: 60px; pointer-events: none;
  opacity: 0.9;
}
.ecg-strip svg { width: 100%; height: 100%; display: block; }
.ecg-strip path {
  stroke: #1FD4A8;
  stroke-width: 2;
  fill: none;
  stroke-dasharray: 1400;
  stroke-dashoffset: 1400;
  filter: drop-shadow(0 0 6px rgba(31,212,168,0.65));
  animation: ecgDraw 3.5s linear infinite;
}
@keyframes ecgDraw {
  0% { stroke-dashoffset: 1400; }
  60% { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -1400; }
}

/* --- 3D icon platform --- */
.icon-3d {
  width: 80px; height: 80px;
  position: relative;
  perspective: 600px;
  display: inline-grid; place-items: center;
}
.icon-3d__inner {
  width: 100%; height: 100%;
  position: relative;
  transform-style: preserve-3d;
  animation: float3d 6s ease-in-out infinite;
}
@keyframes float3d {
  0%, 100% { transform: rotateX(8deg) rotateY(-12deg) translateY(0); }
  50% { transform: rotateX(-6deg) rotateY(12deg) translateY(-6px); }
}
.icon-3d__face {
  position: absolute; inset: 0;
  border-radius: 22px;
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 70%, #000));
  display: grid; place-items: center;
  color: #fff;
  box-shadow:
    inset 0 2px 4px rgba(255,255,255,0.25),
    inset 0 -4px 8px rgba(0,0,0,0.2),
    0 10px 24px rgba(11,57,84,0.25);
}
.icon-3d__face svg { width: 38px; height: 38px; }
.icon-3d__shadow {
  position: absolute; inset: auto 6px -10px 6px; height: 14px;
  background: radial-gradient(ellipse, rgba(10,31,45,0.35), transparent 70%);
  filter: blur(6px);
  animation: shadow3d 6s ease-in-out infinite;
}
@keyframes shadow3d {
  0%, 100% { opacity: 0.55; transform: scale(1); }
  50% { opacity: 0.30; transform: scale(0.78); }
}
.icon-3d--mint .icon-3d__face { background: linear-gradient(135deg, #2bcf9a, #0e6a48); }
.icon-3d--red .icon-3d__face { background: linear-gradient(135deg, #ee3b5b, #8a0d24); }
.icon-3d--amber .icon-3d__face { background: linear-gradient(135deg, #f7b249, #b87004); }

/* Pulse halo behind icons */
.icon-3d::before {
  content: ""; position: absolute; inset: -8px;
  border-radius: 28px;
  background: radial-gradient(circle, rgba(31,138,106,0.22), transparent 65%);
  animation: haloBreath 4s ease-in-out infinite;
}
@keyframes haloBreath { 0%,100%{transform:scale(0.95);opacity:.5;} 50%{transform:scale(1.1);opacity:0.9;} }

/* --- Modern location section (Google Maps + filter) --- */
.location-modern {
  padding: 96px 0;
  background: var(--bg-soft);
  position: relative;
  overflow: hidden;
}
.location-modern::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--accent-2) 18%, transparent), transparent 40%),
    radial-gradient(circle at 100% 100%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 40%);
  pointer-events: none;
}
.location-modern__wrap { display: grid; grid-template-columns: 1.1fr 1fr; gap: 40px; align-items: stretch; position: relative; }
.location-modern__map {
  border-radius: 24px; overflow: hidden;
  box-shadow: var(--shadow-lg);
  background: var(--bg-elev);
  min-height: 520px; position: relative;
  border: 1px solid var(--border);
}
.location-modern__map iframe { width: 100%; height: 100%; min-height: 520px; border: 0; display: block; }
.location-modern__map-overlay {
  position: absolute; top: 18px; left: 18px;
  background: var(--glass-bg-strong);
  backdrop-filter: blur(16px);
  border-radius: 16px;
  padding: 16px 18px;
  display: flex; gap: 14px; align-items: center;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
}
.location-modern__pin {
  width: 44px; height: 44px; border-radius: 14px;
  background: linear-gradient(135deg, var(--emergency), #8a0d24);
  display: grid; place-items: center; color: #fff;
  box-shadow: 0 8px 18px rgba(201,24,58,0.35);
  flex-shrink: 0;
}
.location-modern__pin svg { width: 22px; height: 22px; }
.location-modern__overlay-text { display: flex; flex-direction: column; gap: 2px; }
.location-modern__overlay-text strong { font-family: var(--font-display); font-size: 16px; color: var(--text); }
.location-modern__overlay-text span { font-size: 12px; color: var(--text-muted); }
.location-modern__map-actions {
  position: absolute; bottom: 18px; left: 18px; right: 18px;
  display: flex; gap: 10px; flex-wrap: wrap;
}
.location-modern__map-actions .btn { flex: 1 1 auto; min-width: 0; }

.location-modern__info { display: flex; flex-direction: column; gap: 20px; }
.location-modern__info h2 { font-family: var(--font-display); font-size: clamp(28px, 4vw, 44px); line-height: 1.05; letter-spacing: -0.02em; margin: 0; color: var(--text); }
.location-modern__info > p { color: var(--text-muted); font-size: 17px; line-height: 1.6; margin: 0; }
.location-modern__facts { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.location-modern__fact {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 14px; padding: 16px;
  display: flex; gap: 12px; align-items: flex-start;
}
.location-modern__fact-icon {
  width: 38px; height: 38px; border-radius: 11px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
  display: grid; place-items: center; flex-shrink: 0;
}
.location-modern__fact-icon svg { width: 18px; height: 18px; }
.location-modern__fact strong { display: block; font-size: 13px; color: var(--text-muted); font-weight: 500; }
.location-modern__fact span { font-size: 15px; color: var(--text); font-weight: 600; }
.location-modern__cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 4px; }

/* --- Location filter UI --- */
.locfilter {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 22px;
  margin-bottom: 36px;
  box-shadow: var(--shadow-sm);
}
.locfilter__row { display: grid; grid-template-columns: 1fr auto auto; gap: 14px; align-items: end; }
.locfilter__field { display: flex; flex-direction: column; gap: 6px; }
.locfilter__field label { font-size: 13px; color: var(--text-muted); font-weight: 600; }
.locfilter__input, .locfilter__select {
  appearance: none; -webkit-appearance: none;
  background: var(--bg-page);
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  padding: 12px 14px;
  font: inherit;
  color: var(--text);
  transition: border-color 200ms;
}
.locfilter__input:focus, .locfilter__select:focus { outline: none; border-color: var(--accent); }
.locfilter__hint { margin-top: 12px; font-size: 13px; color: var(--text-muted); display: flex; align-items: center; gap: 8px; }
.locfilter__hint .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent-2); }

/* Enhanced location tiles with distance pill */
.location-tile { position: relative; transition: transform 240ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 240ms; }
.location-tile:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.location-tile__distance {
  position: absolute; top: 14px; right: 14px;
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
  color: var(--accent-2);
  padding: 4px 10px; border-radius: 999px;
  font-size: 12px; font-weight: 600;
  border: 1px solid color-mix(in srgb, var(--accent-2) 30%, transparent);
}
.location-tile__actions { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.location-tile__actions a { font-size: 13px; padding: 8px 12px; border-radius: 10px; text-decoration: none; transition: all 200ms; }
.loctile-link--page { background: var(--accent); color: #fff; }
.loctile-link--map { background: var(--bg-soft); color: var(--text); border: 1px solid var(--border); }
.loctile-link--map:hover { background: var(--bg-page); }
.loctile-link--page:hover { filter: brightness(1.1); }

/* Sort + count toolbar */
.locfilter__meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; padding: 0 4px; }
.locfilter__count { font-size: 14px; color: var(--text-muted); }
.locfilter__count strong { color: var(--text); font-weight: 700; }

/* --- Premium polish: section eyebrows, dividers --- */
.section-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body);
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-2);
  padding: 6px 14px; border-radius: 999px;
  background: color-mix(in srgb, var(--accent-2) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent-2) 24%, transparent);
  margin-bottom: 18px;
}
.section-eyebrow::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-2);
  box-shadow: 0 0 10px var(--accent-2);
  animation: pulseDot 1.6s ease-in-out infinite;
}

/* --- Reviews grid --- */
.reviews-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 22px; }
.review-card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 26px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
  transition: transform 240ms, box-shadow 240ms;
}
.review-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.review-card__quote-mark {
  position: absolute; top: 14px; right: 18px;
  font-family: var(--font-display); font-size: 64px; line-height: 1;
  color: color-mix(in srgb, var(--accent) 14%, transparent);
  pointer-events: none;
}
.review-card__stars { display: inline-flex; gap: 3px; color: #f5b800; font-size: 16px; }
.review-card__body { font-size: 16px; line-height: 1.55; color: var(--text); margin: 0; }
.review-card__author { display: flex; align-items: center; gap: 12px; margin-top: 6px; }
.review-card__avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; display: grid; place-items: center;
  font-weight: 700; font-size: 16px; flex-shrink: 0;
}
.review-card__author-meta { display: flex; flex-direction: column; }
.review-card__author-meta strong { font-weight: 600; color: var(--text); font-size: 15px; }
.review-card__author-meta span { font-size: 12px; color: var(--text-muted); }
.review-card__source {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--text-muted);
  padding: 4px 10px; border-radius: 999px;
  background: var(--bg-soft);
  align-self: flex-start;
}

.review-stats-bar {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 18px; margin-bottom: 36px;
}
.review-stat {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 16px; padding: 22px;
  text-align: center;
}
.review-stat__num { font-family: var(--font-display); font-size: 38px; line-height: 1; color: var(--accent); font-weight: 600; }
.review-stat__num.gold { color: #f5b800; }
.review-stat__label { font-size: 13px; color: var(--text-muted); margin-top: 6px; }

/* --- Doctor cards --- */
.doctors-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 26px; }
.doctor-card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 22px;
  overflow: hidden;
  transition: transform 280ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 280ms;
  display: flex; flex-direction: column;
}
.doctor-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.doctor-card__photo {
  aspect-ratio: 4/5; overflow: hidden;
  background: linear-gradient(135deg, var(--bg-soft), var(--bg-elev));
  position: relative;
}
.doctor-card__photo img { width: 100%; height: 100%; object-fit: cover; transition: transform 700ms ease; }
.doctor-card:hover .doctor-card__photo img { transform: scale(1.05); }
.doctor-card__photo::after {
  content: ""; position: absolute; inset: auto 0 0 0; height: 50%;
  background: linear-gradient(180deg, transparent, rgba(10,31,45,0.55));
  pointer-events: none;
}
.doctor-card__badge {
  position: absolute; top: 14px; left: 14px;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
  padding: 5px 11px; border-radius: 999px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  color: var(--accent); text-transform: uppercase;
  z-index: 2;
}
.doctor-card__body { padding: 22px; display: flex; flex-direction: column; gap: 10px; }
.doctor-card__name { font-family: var(--font-display); font-size: 22px; line-height: 1.15; color: var(--text); margin: 0; }
.doctor-card__role { font-size: 14px; color: var(--accent-2); font-weight: 600; letter-spacing: 0.02em; }
.doctor-card__bio { font-size: 14px; line-height: 1.55; color: var(--text-muted); margin: 4px 0 0; }
.doctor-card__specs { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.doctor-card__specs span {
  font-size: 11px; padding: 3px 9px; border-radius: 999px;
  background: var(--bg-soft); color: var(--text); font-weight: 500;
}

/* --- Career cards --- */
.careers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 22px; }
.career-card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 26px;
  display: flex; flex-direction: column; gap: 12px;
  transition: transform 240ms, box-shadow 240ms, border-color 240ms;
  position: relative; overflow: hidden;
}
.career-card::before {
  content: ""; position: absolute; top: 0; left: 0; width: 4px; height: 100%;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  transform: scaleY(0); transform-origin: top; transition: transform 300ms ease;
}
.career-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.career-card:hover::before { transform: scaleY(1); }
.career-card__type {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent-2);
}
.career-card__title { font-family: var(--font-display); font-size: 22px; line-height: 1.2; color: var(--text); margin: 0; }
.career-card__meta { display: flex; gap: 14px; flex-wrap: wrap; color: var(--text-muted); font-size: 13px; }
.career-card__meta span { display: inline-flex; align-items: center; gap: 5px; }
.career-card__meta svg { width: 14px; height: 14px; }
.career-card__desc { font-size: 14px; line-height: 1.55; color: var(--text-muted); margin: 4px 0 0; }
.career-card__cta { margin-top: 10px; display: inline-flex; align-items: center; gap: 6px; color: var(--accent); font-weight: 600; text-decoration: none; font-size: 14px; }
.career-card__cta:hover { gap: 10px; }

.career-perks { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 18px; margin: 36px 0; }
.career-perk {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 16px; padding: 22px;
  display: flex; flex-direction: column; gap: 8px;
}
.career-perk__icon {
  width: 42px; height: 42px; border-radius: 12px;
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
  color: var(--accent-2);
  display: grid; place-items: center;
}
.career-perk__icon svg { width: 22px; height: 22px; }
.career-perk h4 { font-family: var(--font-display); font-size: 17px; margin: 0; color: var(--text); }
.career-perk p { font-size: 14px; color: var(--text-muted); margin: 0; line-height: 1.5; }

/* --- Page image hero (used on enhanced pages) --- */
.page-image-hero {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  margin: 32px 0;
  aspect-ratio: 21/9;
  box-shadow: var(--shadow-lg);
}
.page-image-hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
.page-image-hero::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(11,57,84,0.55), rgba(11,57,84,0.1));
}
.page-image-hero__caption {
  position: absolute; bottom: 24px; left: 24px; right: 24px;
  color: #fff; z-index: 2;
}
.page-image-hero__caption strong { font-family: var(--font-display); font-size: clamp(22px, 3vw, 32px); display: block; }
.page-image-hero__caption span { opacity: 0.85; font-size: 14px; }

/* --- Premium float reveal (already exists, add subtler stagger) --- */
.reveal-stagger > * { transition-delay: calc(var(--i, 0) * 70ms); }

/* --- Responsive overrides --- */
@media (max-width: 980px) {
  .location-modern__wrap { grid-template-columns: 1fr; }
  .location-modern__map, .location-modern__map iframe { min-height: 380px; }
  .locfilter__row { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .location-modern { padding: 64px 0; }
  .location-modern__facts { grid-template-columns: 1fr; }
  .hero-scan__hud { left: 12px; bottom: 12px; padding: 8px 10px; font-size: 10px; }
  .hero-scan__corner { width: 20px; height: 20px; }
  .theme-toggle { width: 50px; height: 28px; }
  .theme-toggle__knob { width: 22px; height: 22px; }
  html[data-theme="dark"] .theme-toggle__knob { transform: translateX(22px); }
}
@media (max-width: 560px) {
  .reviews-grid, .careers-grid, .doctors-grid { grid-template-columns: 1fr; }
  .review-stats-bar { grid-template-columns: repeat(2, 1fr); }
}

/* Reduced motion respect */
@media (prefers-reduced-motion: reduce) {
  .hero-scan__beam, .ecg-strip path, .icon-3d__inner, .icon-3d__shadow,
  .icon-3d::before, .hero-scan__hud .dot, .section-eyebrow::before {
    animation: none !important;
  }
}

/* ============================================================
   v2.1 BUGFIX PASS — logo wrap, dark-mode hero text,
   mobile emergency bar, nav crowding with 7-8 items
   ============================================================ */

/* Logo: keep "ER Of Fort Worth" on a single line; tagline beneath. */
.logo { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; flex-shrink: 0; min-width: 0; }
.logo > span:last-child {
  display: inline-flex; flex-direction: column; line-height: 1.05;
  font-family: var(--font-display, 'Fraunces', serif);
  font-weight: 600; font-size: 19px; color: var(--text);
  white-space: nowrap;
}
.logo small {
  font-family: var(--font-body, 'Manrope', sans-serif);
  font-weight: 500; font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--text-muted);
  margin-top: 2px; white-space: nowrap;
}
html[data-theme="dark"] .logo > span:last-child { color: var(--text); }
html[data-theme="dark"] .logo small { color: var(--text-muted); }

/* Logo mark — keep crisp at small sizes */
.logo__mark {
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--accent, #0B3954);
  color: #FBFAF6; font-family: var(--font-display, serif);
  font-style: italic; font-size: 24px; font-weight: 600;
  display: grid; place-items: center;
  position: relative; flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(11,57,84,0.18);
}
.logo__mark::after {
  content: "+"; position: absolute; top: -4px; right: -4px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--emergency, #C9183A);
  color: #fff; font-family: var(--font-body, sans-serif);
  font-size: 12px; font-weight: 700; font-style: normal;
  display: grid; place-items: center; line-height: 1;
}

/* Nav — give it room for 7 items + theme toggle + 2 CTAs */
.nav__inner { gap: 18px; }
.nav__menu ul { gap: 22px; }
.nav__menu a { font-size: 14.5px; }

/* Compact CTAs so everything fits on standard laptops */
.nav__cta { gap: 8px; align-items: center; flex-wrap: nowrap; }
.nav__cta .btn--sm { padding: 9px 14px; font-size: 13.5px; }

/* Show 7-item nav from 1180px+; below that, collapse to hamburger early */
@media (max-width: 1180px) {
  .nav__menu { display: none; }
  .nav__toggle { display: flex !important; }
}
@media (min-width: 1181px) {
  .nav__toggle { display: none !important; }
}

/* Emergency bar — compact on tablet, hide stat on mobile */
.emergency-bar__inner { flex-wrap: wrap; row-gap: 4px; padding: 8px 16px; font-size: 13px; }
@media (max-width: 860px) {
  .emergency-bar__inner > *:nth-child(3) { display: none; } /* hide "Average Wait Time" on mobile */
  .emergency-bar__inner { justify-content: center; gap: 14px; }
}
@media (max-width: 560px) {
  .emergency-bar__inner { font-size: 12px; padding: 6px 12px; }
  .emergency-bar__inner > * { flex: 0 0 auto; }
}

/* Hero — dark-mode text fix (heading was painted with --color-ink, invisible on dark) */
.hero__title,
.hero h1,
.hero__copy h1,
.hero p { color: var(--text); }
.hero__copy p { color: var(--text-muted); }
.hero__eyebrow { color: var(--emergency); }
html[data-theme="dark"] .hero__title,
html[data-theme="dark"] .hero h1,
html[data-theme="dark"] .hero__copy h1 { color: var(--text); }
html[data-theme="dark"] .hero__copy p,
html[data-theme="dark"] .hero p { color: var(--text-muted); }

/* Generic hardcoded ink colors that broke in dark mode — sweep them */
html[data-theme="dark"] h1,
html[data-theme="dark"] h2,
html[data-theme="dark"] h3,
html[data-theme="dark"] h4,
html[data-theme="dark"] h5,
html[data-theme="dark"] h6 { color: var(--text); }
html[data-theme="dark"] p { color: var(--text-muted); }
html[data-theme="dark"] strong, html[data-theme="dark"] b { color: var(--text); }

/* Highlight/underline accent under "without the wait" — keep it visible on dark */
html[data-theme="dark"] .hero__title em,
html[data-theme="dark"] .hero h1 em,
html[data-theme="dark"] .hero h1 .accent,
html[data-theme="dark"] .accent-underline { color: var(--text); }

/* Buttons — ghost button text gets light in dark mode */
html[data-theme="dark"] .btn--ghost {
  border-color: var(--border-strong);
  color: var(--text);
  background: transparent;
}
html[data-theme="dark"] .btn--ghost:hover { background: var(--bg-soft); }

/* Hero background gradient — was a warm cream; use page bg in dark */
.hero { background: var(--bg-page); }
.hero__bg { background: radial-gradient(ellipse at top left, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 50%); }

/* "Online Check-In" pill in nav — keep contrast in dark */
html[data-theme="dark"] .nav__cta .btn--ghost { color: var(--text); border-color: var(--border-strong); }

/* Trust strip / counters legible on dark */
html[data-theme="dark"] .trust-stat__num { color: var(--accent); }
html[data-theme="dark"] .trust-stat__label { color: var(--text-muted); }

/* Section eyebrow on dark */
html[data-theme="dark"] .section-eyebrow { color: var(--accent-2); }
html[data-theme="dark"] .eyebrow { color: var(--emergency); }

/* Floating hero cards: re-skin for dark mode */
html[data-theme="dark"] .hero__floating-card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  color: var(--text);
  box-shadow: var(--shadow-md);
}
html[data-theme="dark"] .hero__floating-card .label { color: var(--text-muted); }
html[data-theme="dark"] .hero__floating-card .value { color: var(--text); }

/* Article body / blog text in dark */
html[data-theme="dark"] .article p,
html[data-theme="dark"] .article li,
html[data-theme="dark"] .article ul,
html[data-theme="dark"] .article ol { color: var(--text); }
html[data-theme="dark"] .article a { color: var(--accent); }

/* Page hero text in dark */
html[data-theme="dark"] .page-hero h1 { color: var(--text); }
html[data-theme="dark"] .page-hero p { color: var(--text-muted); }
html[data-theme="dark"] .page-hero .eyebrow { color: var(--emergency); }

/* Forms in dark */
html[data-theme="dark"] input,
html[data-theme="dark"] textarea,
html[data-theme="dark"] select {
  background: var(--bg-page); color: var(--text);
  border-color: var(--border-strong);
}
html[data-theme="dark"] label { color: var(--text); }

/* Final mobile-menu width sanity */
@media (max-width: 560px) {
  .mobile-menu { width: 100%; max-width: 360px; }
  .logo > span:last-child { font-size: 17px; }
  .logo small { font-size: 9px; }
}

/* ============================================================
   v2.2 polish — trimmed nav (6 items), hero SVG composition,
   structure refinements
   ============================================================ */

/* Nav with 6 items + theme toggle + 2 CTAs fits 1080px+ */
@media (max-width: 1080px) {
  .nav__menu { display: none; }
  .nav__toggle { display: flex !important; }
}
@media (min-width: 1081px) {
  .nav__toggle { display: none !important; }
  .nav__menu ul { gap: 26px; }
}

/* Tighten emergency-bar one more notch on phones */
@media (max-width: 700px) {
  .emergency-bar { font-size: 12px; }
  .emergency-bar__inner { padding: 7px 14px; gap: 12px; }
  .emergency-bar__inner > *:first-child .emergency-bar__pulse { width: 6px; height: 6px; }
}

/* Hero scan with SVG: gentler grid blend so the illustration reads */
.hero-scan__grid { opacity: 0.55; mix-blend-mode: multiply; }
html[data-theme="dark"] .hero-scan__grid { mix-blend-mode: screen; opacity: 0.35; }
.hero-scan__beam { opacity: 0.8; }

/* SVG hero img should fill its frame cleanly */
.hero-scan__img { width: 100%; height: 100%; aspect-ratio: 1200/750; object-fit: cover; object-position: center; }
@media (max-width: 980px) {
  .hero-scan__img { aspect-ratio: 1200/700; }
}

/* Location pages: hero visual SVG container — round nicely on all sizes */
.location-hero__visual { border-radius: 22px; overflow: hidden; box-shadow: var(--shadow-md); background: var(--bg-soft); border: 1px solid var(--border); }
.location-hero__visual img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 1200/750; display: block; }

/* Better paragraph rhythm and section spacing across the site */
.article-section, section.container { padding-top: 56px; padding-bottom: 56px; }
section.container h2 { margin-top: 0; }

/* Improve service-card hover (sweep gradient) */
.service-card { position: relative; overflow: hidden; }
.service-card::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 0%, transparent), color-mix(in srgb, var(--accent-2) 8%, transparent));
  opacity: 0; transition: opacity 320ms ease;
  pointer-events: none;
}
.service-card:hover::after { opacity: 1; }

/* Better card focus rings (a11y) */
.service-card:focus-visible,
.location-tile:focus-visible,
.doctor-card:focus-visible,
.review-card:focus-visible,
.career-card:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

/* Page hero on location pages reads cleaner */
.location-hero {
  padding: 56px 0 36px;
  background: linear-gradient(180deg, var(--bg-soft) 0%, var(--bg-page) 100%);
}
html[data-theme="dark"] .location-hero {
  background: linear-gradient(180deg, var(--bg-elev) 0%, var(--bg-page) 100%);
}
.location-hero__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 36px; align-items: center; }
@media (max-width: 900px) {
  .location-hero__grid { grid-template-columns: 1fr; }
}

/* Buttons row spacing on hero */
.hero__cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }

/* Section eyebrow text contrast on dark page hero */
.page-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-size: 12px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--emergency);
  margin-bottom: 14px;
}
html[data-theme="dark"] .page-hero__eyebrow { color: var(--emergency); }

/* Smooth scroll for in-page anchors (e.g. #map) */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

/* Footer dark fix — make small text readable in both modes */
.footer, .footer * { color: rgba(255,255,255,0.78); }
.footer h6, .footer strong { color: #fff; }
.footer a { color: rgba(255,255,255,0.78); }
.footer a:hover { color: #fff; }

/* Final small-screen tweaks */
@media (max-width: 480px) {
  .hero__cta-row .btn { width: 100%; }
  .hero__meta { flex-direction: column; align-items: flex-start; gap: 6px; }
}

/* ============================================================
   v2.4 — six-issue fix pass
   ============================================================ */

/* --- ISSUE 1: Hero empty space below image --- */
.hero__visual { position: relative; aspect-ratio: 1200/750; display: block; max-width: 100%; }
.hero-scan { width: 100%; height: 100%; aspect-ratio: auto; }
@media (max-width: 980px) {
  .hero__visual { aspect-ratio: 1200/720; margin: 0 auto; }
}
/* Floating cards now overlap onto the image edge, not below in empty space */
.hero__floating-card {
  position: absolute;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px 18px;
  box-shadow: var(--shadow-md);
  z-index: 3;
  min-width: 160px;
}
.hero__floating-card--open { top: 28px; right: -18px; }
.hero__floating-card--wait { bottom: -14px; left: -22px; }
.hero__floating-card .label { font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-muted); font-weight: 600; display: flex; align-items: center; gap: 6px; }
.hero__floating-card .value { font-family: var(--font-display); font-size: 26px; line-height: 1; color: var(--text); margin-top: 4px; }
.hero__floating-card .pulse-green { width: 8px; height: 8px; border-radius: 50%; background: #1FD4A8; box-shadow: 0 0 10px #1FD4A8; animation: pulseDot 1.4s ease-in-out infinite; }
@media (max-width: 720px) {
  .hero__floating-card--open { top: 18px; right: 8px; }
  .hero__floating-card--wait { bottom: -8px; left: 8px; }
  .hero__floating-card { padding: 10px 14px; min-width: 130px; }
  .hero__floating-card .value { font-size: 20px; }
}

/* --- ISSUE 2: Services filterable card grid --- */
.svc-filter {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 22px;
  margin: 24px 0 36px;
  box-shadow: var(--shadow-sm);
}
.svc-filter__row { display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: end; }
.svc-filter__field { display: flex; flex-direction: column; gap: 6px; }
.svc-filter__field label { font-size: 13px; color: var(--text-muted); font-weight: 600; }
.svc-filter__input {
  appearance: none; background: var(--bg-page);
  border: 1px solid var(--border-strong); border-radius: 12px;
  padding: 12px 14px 12px 42px; font: inherit; color: var(--text);
  transition: border-color 200ms;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%235A6B78' stroke-width='2'><circle cx='11' cy='11' r='8'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>");
  background-repeat: no-repeat; background-position: 14px center;
}
.svc-filter__input:focus { outline: none; border-color: var(--accent); }
.svc-pills { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.svc-pill {
  padding: 8px 16px; border-radius: 999px; cursor: pointer;
  font-size: 13px; font-weight: 600;
  background: var(--bg-soft);
  color: var(--text); border: 1px solid var(--border);
  transition: all 220ms ease;
  user-select: none;
}
.svc-pill:hover { border-color: var(--accent); transform: translateY(-1px); }
.svc-pill.is-active { background: var(--accent); color: #fff; border-color: var(--accent); box-shadow: 0 4px 12px color-mix(in srgb, var(--accent) 35%, transparent); }

.svc-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 22px;
}
.svc-card {
  position: relative; overflow: hidden;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 26px;
  text-decoration: none; color: var(--text);
  display: flex; flex-direction: column; gap: 14px;
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 320ms, border-color 320ms;
  opacity: 0; transform: translateY(16px);
  animation: svcFadeIn 480ms forwards;
}
@keyframes svcFadeIn { to { opacity: 1; transform: translateY(0); } }
.svc-card:hover { transform: translateY(-6px); border-color: var(--border-strong); box-shadow: var(--shadow-lg); }
.svc-card.is-hidden { display: none; }
.svc-card__icon {
  width: 56px; height: 56px; border-radius: 16px;
  display: grid; place-items: center; color: #fff;
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #000));
  box-shadow: 0 6px 16px color-mix(in srgb, var(--accent) 35%, transparent);
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1);
}
.svc-card:hover .svc-card__icon { transform: rotate(-6deg) scale(1.05); }
.svc-card__icon svg { width: 26px; height: 26px; }
.svc-card--cardiac .svc-card__icon { background: linear-gradient(135deg,#ee3b5b,#8a0d24); box-shadow: 0 6px 16px rgba(238,59,91,0.35); }
.svc-card--infection .svc-card__icon { background: linear-gradient(135deg,#f7b249,#b87004); box-shadow: 0 6px 16px rgba(247,178,73,0.35); }
.svc-card--trauma .svc-card__icon { background: linear-gradient(135deg,#ff7e3f,#c14a13); box-shadow: 0 6px 16px rgba(255,126,63,0.35); }
.svc-card--neuro .svc-card__icon { background: linear-gradient(135deg,#9b6ee8,#5a3296); box-shadow: 0 6px 16px rgba(155,110,232,0.35); }
.svc-card--diagnostic .svc-card__icon { background: linear-gradient(135deg,#5fa8d6,#1d4870); box-shadow: 0 6px 16px rgba(95,168,214,0.35); }
.svc-card--treatment .svc-card__icon { background: linear-gradient(135deg,#2bcf9a,#0e6a48); box-shadow: 0 6px 16px rgba(43,207,154,0.35); }
.svc-card--pediatric .svc-card__icon { background: linear-gradient(135deg,#ff8fbe,#a83866); box-shadow: 0 6px 16px rgba(255,143,190,0.35); }
.svc-card__category {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-muted);
}
.svc-card h3 { font-family: var(--font-display); font-size: 22px; line-height: 1.15; margin: 0; color: var(--text); }
.svc-card p { font-size: 14.5px; line-height: 1.55; color: var(--text-muted); margin: 0; flex: 1; }
.svc-card__more { display: inline-flex; align-items: center; gap: 6px; color: var(--accent); font-weight: 600; font-size: 14px; margin-top: 8px; transition: gap 220ms ease; }
.svc-card:hover .svc-card__more { gap: 10px; }
.svc-grid--empty { padding: 40px; text-align: center; color: var(--text-muted); background: var(--bg-soft); border-radius: 16px; }

.svc-count { font-size: 14px; color: var(--text-muted); margin-bottom: 18px; }
.svc-count strong { color: var(--text); font-weight: 700; }

/* --- ISSUE 3: Location tile fixes --- */
.location-tile h3 {
  font-family: var(--font-display);
  font-size: 24px; line-height: 1.15; margin: 0 0 6px;
  padding-right: 88px; /* room for distance pill */
  color: var(--text);
}
.location-tile p { font-size: 14px; color: var(--text-muted); margin: 0 0 14px; line-height: 1.5; }
.location-tile__distance {
  position: absolute; top: 22px; right: 22px;
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
  color: var(--accent-2); padding: 5px 11px; border-radius: 999px;
  font-size: 12px; font-weight: 700;
  border: 1px solid color-mix(in srgb, var(--accent-2) 32%, transparent);
  white-space: nowrap;
}
.location-tile { padding: 24px; }
.locations-grid--big { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.location-tile__actions a { flex: 0 1 auto; }

/* --- ISSUE 4: Dark mode hide fix on split-section headings --- */
.split-section h2, .split-section h3, .split-section .lede,
.split-section p, .split-section li,
.display-italic {
  color: var(--text);
}
.split-section h2 .display-italic,
h2 .display-italic, h3 .display-italic, .display-italic {
  font-family: var(--font-display); font-style: italic; color: var(--accent);
}
html[data-theme="dark"] .split-section h2,
html[data-theme="dark"] .split-section h3 { color: var(--text); }
html[data-theme="dark"] .split-section .lede,
html[data-theme="dark"] .split-section p,
html[data-theme="dark"] .split-section li { color: var(--text-muted); }
html[data-theme="dark"] .display-italic { color: var(--accent); }
/* Background on light split-section was cream; on dark use elev */
html[data-theme="dark"] .split-section,
html[data-theme="dark"] section[style*="background"],
html[data-theme="dark"] section.bg-cream { background: var(--bg-soft) !important; }

/* --- ISSUE 5: Contact-card fixes (icon size + clear hierarchy) --- */
.contact-card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 32px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 22px; align-items: center;
  transition: transform 280ms, box-shadow 280ms;
  position: relative;
  overflow: hidden;
}
.contact-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.contact-card__icon {
  width: 52px; height: 52px; border-radius: 14px;
  display: grid; place-items: center;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
  flex-shrink: 0;
}
.contact-card__icon svg { width: 24px; height: 24px; }
.contact-card__content { min-width: 0; }
.contact-card__title {
  font-family: var(--font-display); font-size: 26px;
  line-height: 1.1; margin: 0 0 6px; color: var(--text);
}
.contact-card__body { font-size: 15px; color: var(--text-muted); line-height: 1.5; margin: 0; }
.contact-card__body a { color: var(--text); font-weight: 600; text-decoration: none; }
.contact-card__body a:hover { color: var(--accent); }
.contact-card__cta {
  background: var(--accent);
  color: #fff !important;
  padding: 12px 22px; border-radius: 999px;
  font-weight: 600; font-size: 14px;
  text-decoration: none; white-space: nowrap;
  transition: filter 200ms;
}
.contact-card__cta:hover { filter: brightness(1.1); color: #fff !important; }
.contact-card__cta--emergency { background: var(--emergency); }
.contact-card__cta--ghost { background: transparent; color: var(--text) !important; border: 1.5px solid var(--border-strong); }
.contact-card__cta--ghost:hover { background: var(--bg-soft); color: var(--text) !important; }
.contact-card__pill {
  display: inline-flex; align-items: center; gap: 6px;
  background: color-mix(in srgb, var(--accent-2) 12%, transparent);
  color: var(--accent-2);
  padding: 4px 12px; border-radius: 999px;
  font-size: 12px; font-weight: 700;
  margin-top: 8px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 30%, transparent);
}
.contact-card__pill::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-2); box-shadow: 0 0 8px var(--accent-2);
  animation: pulseDot 1.4s ease-in-out infinite;
}
@media (max-width: 720px) {
  .contact-card { grid-template-columns: 1fr; text-align: left; padding: 24px; }
  .contact-card__cta { justify-self: start; }
}

/* --- ISSUE 6: Insurance marquee (continuous left-to-right scroll) --- */
.insurance-marquee {
  padding: 64px 0;
  background: var(--bg-strip);
  color: var(--text-on-dark);
  overflow: hidden;
  position: relative;
}
.insurance-marquee__head { text-align: center; max-width: 720px; margin: 0 auto 36px; padding: 0 24px; }
.insurance-marquee__head .eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: #1FD4A8; font-weight: 600;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(31,212,168,0.12); border: 1px solid rgba(31,212,168,0.28);
  margin-bottom: 14px;
}
.insurance-marquee__head h2 {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 44px);
  line-height: 1.05; letter-spacing: -0.02em; margin: 0 0 12px;
  color: #fff;
}
.insurance-marquee__head p { color: rgba(255,255,255,0.7); font-size: 16px; line-height: 1.6; margin: 0; }
.marquee {
  display: flex; gap: 24px;
  width: max-content;
  animation: marqueeScroll 38s linear infinite;
}
.marquee--reverse { animation-direction: reverse; animation-duration: 42s; }
.insurance-marquee:hover .marquee { animation-play-state: paused; }
@keyframes marqueeScroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.marquee__viewport {
  display: flex; gap: 24px;
  mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.ins-logo {
  flex: 0 0 auto;
  width: 200px; height: 88px;
  background: rgba(255,255,255,0.97);
  border-radius: 14px;
  display: grid; place-items: center;
  padding: 14px 20px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.6);
  transition: transform 320ms, box-shadow 320ms;
}
.ins-logo:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.45); }
.ins-logo svg { max-width: 100%; max-height: 100%; width: auto; height: auto; }
.ins-logo__text {
  font-family: var(--font-body), sans-serif;
  font-weight: 800; letter-spacing: -0.02em;
  font-size: 22px; line-height: 1; text-align: center;
  display: flex; flex-direction: column; gap: 2px;
}
.ins-logo__text small {
  font-size: 9px; letter-spacing: 0.16em;
  font-weight: 600; text-transform: uppercase; opacity: 0.7;
}

/* Brand-color variants for the insurer tiles */
.ins-bcbs .ins-logo__text { color: #0066b3; }
.ins-aetna .ins-logo__text { color: #7d3f98; }
.ins-cigna .ins-logo__text { color: #00a651; }
.ins-uhc .ins-logo__text { color: #002677; }
.ins-humana .ins-logo__text { color: #84c44a; }
.ins-medicare .ins-logo__text { color: #003c71; }
.ins-tricare .ins-logo__text { color: #0a3d62; }
.ins-medicaid .ins-logo__text { color: #c00000; }
.ins-anthem .ins-logo__text { color: #0066a4; }
.ins-firsthealth .ins-logo__text { color: #d63027; }
.ins-multiplan .ins-logo__text { color: #1d4870; }
.ins-ambetter .ins-logo__text { color: #6abf4b; }

/* The trust-strip "Insurance & coverage" section needs dark legibility */
.insurance-strip { background: var(--bg-strip); color: var(--text-on-dark); }
.insurance-strip h2, .insurance-strip h3, .insurance-strip strong { color: #fff; }
.insurance-strip p, .insurance-strip .eyebrow { color: rgba(255,255,255,0.75); }

/* --- General polish: avoid the empty-space issue on hero on mobile too --- */
.hero { padding: 64px 0 96px; position: relative; overflow: hidden; }
@media (max-width: 980px) {
  .hero { padding: 48px 0 80px; }
  .hero__grid { grid-template-columns: 1fr; gap: 36px; }
}
.hero__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }

/* Larger floating CTA on mobile won't overlap chatbot if positioned correctly */
@media (max-width: 720px) {
  .floating-cta { bottom: 80px !important; }
}

/* ============================================================
   v2.5 FINAL BUGFIX PASS — overrides all previous breakpoint
   conflicts. Place at end of file so cascade always wins.
   ============================================================ */

/* === ISSUE 1: Nav menu visible on desktop, hamburger on narrower screens.
   Single authoritative rule pair — wipes out all prior conflicts. === */
@media (max-width: 1100px) {
  .nav__menu { display: none !important; }
  .nav__toggle { display: flex !important; }
  .nav__cta .btn--ghost { display: none !important; }
}
@media (min-width: 1101px) {
  .nav__menu { display: flex !important; align-items: center; gap: 22px; }
  .nav__menu ul { gap: 22px !important; display: flex; align-items: center; list-style: none; padding: 0; margin: 0; }
  .nav__toggle { display: none !important; }
  .nav__cta .btn--ghost { display: inline-flex !important; }
}

/* === ISSUE 2: Floating CTA — icon-only circle, never overlaps content === */
.floating-cta {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 60;
  display: flex; flex-direction: column; align-items: flex-end; gap: 10px;
  pointer-events: none;
}
.floating-cta > * { pointer-events: auto; }
.floating-cta a, .floating-cta button {
  width: 56px; height: 56px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: var(--emergency, #C9183A);
  color: #fff;
  box-shadow: 0 8px 24px rgba(201,24,58,0.4), 0 2px 6px rgba(0,0,0,0.2);
  text-decoration: none;
  font-size: 0; /* hide any text label */
  position: relative;
  transition: transform 240ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 240ms;
}
.floating-cta a:hover, .floating-cta button:hover { transform: scale(1.08); }
.floating-cta a svg, .floating-cta button svg {
  width: 24px; height: 24px;
  stroke: #fff; fill: none; stroke-width: 2;
}
.floating-cta a::before {
  content: ""; position: absolute; inset: -6px;
  border-radius: 50%;
  border: 2px solid var(--emergency, #C9183A);
  opacity: 0; animation: floatRing 2s ease-out infinite;
  pointer-events: none;
}
@keyframes floatRing {
  0% { transform: scale(0.9); opacity: 0.6; }
  100% { transform: scale(1.4); opacity: 0; }
}
.floating-cta__chat {
  background: var(--accent, #0B3954) !important;
  box-shadow: 0 6px 18px rgba(11,57,84,0.35) !important;
}
.floating-cta__chat::before { display: none !important; }
.floating-cta__label {
  display: none; /* never show text — icon only */
}
/* On mobile, the floating CTA stays bottom-right; same icon size */
@media (max-width: 480px) {
  .floating-cta { right: 14px; bottom: 14px; gap: 8px; }
  .floating-cta a, .floating-cta button { width: 52px; height: 52px; }
}

/* === ISSUE 3: Trust counter robustness — final value always pinned === */
[data-count] { font-variant-numeric: tabular-nums; }
.trust-stat__num { white-space: nowrap; }

/* === ISSUE 4: Homepage location-tile arrow + distance — clean layout === */
.location-tile {
  display: flex; flex-direction: column; gap: 4px;
  padding: 22px 24px 24px;
  position: relative;
}
.location-tile__state {
  font-size: 11px; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--emergency);
  margin-bottom: 8px;
}
.location-tile__city {
  font-family: var(--font-display, 'Fraunces', serif);
  font-size: 28px; line-height: 1.05;
  color: var(--text);
  margin-bottom: 8px;
}
.location-tile__distance {
  position: absolute; top: 22px; right: 22px;
  background: color-mix(in srgb, var(--accent-2) 14%, transparent);
  color: var(--accent-2); padding: 5px 12px; border-radius: 999px;
  font-size: 12px; font-weight: 700;
  border: 1px solid color-mix(in srgb, var(--accent-2) 32%, transparent);
  white-space: nowrap; line-height: 1;
}
.location-tile__arrow {
  display: none !important; /* not needed — distance pill already shows on right */
}
html[data-theme="dark"] .location-tile { background: var(--bg-elev); border: 1px solid var(--border); }
html[data-theme="dark"] .location-tile__city { color: var(--text); }

/* === ISSUE 5: Empty space between sections — tighten section padding === */
.section { padding: 80px 0; }
@media (max-width: 720px) { .section { padding: 56px 0; } }
.section + .section, section + section { margin-top: 0; }
/* Specifically the "What to expect" / steps section runs too tall when image is short */
.split-section { padding: 72px 0; align-items: stretch; }
.split-section .split { align-items: center; }

/* === ISSUE 6: Dark mode services-section heading visibility (force) === */
html[data-theme="dark"] .services-section h2,
html[data-theme="dark"] .services-section h2 *,
html[data-theme="dark"] .section h2,
html[data-theme="dark"] .section h2 *:not(.display-italic):not(.accent):not(.eyebrow) {
  color: var(--text) !important;
}
html[data-theme="dark"] .display-italic,
html[data-theme="dark"] .accent,
html[data-theme="dark"] h2 .accent,
html[data-theme="dark"] h1 .accent { color: var(--accent) !important; }
html[data-theme="dark"] .services-section .lede,
html[data-theme="dark"] .section .lede,
html[data-theme="dark"] .section p { color: var(--text-muted) !important; }
/* The hero __title accent on the homepage uses underline-accent ::after — keep that pink */

/* === Trust strip in dark mode — ensure numbers + labels read === */
html[data-theme="dark"] .trust-strip { background: var(--bg-soft); }
html[data-theme="dark"] .trust-stat__num { color: var(--text); }
html[data-theme="dark"] .trust-stat__label { color: var(--text-muted); }
html[data-theme="dark"] .trust-stat .unit { color: var(--accent); }

/* === Insurance marquee in light mode also needs proper bg === */
.insurance-marquee { background: var(--bg-strip); }

/* === "How a visit works" content alignment fix — image side fills properly === */
.split-section .split-image { display: flex; align-items: center; height: 100%; }
.split-section .split-image img { width: 100%; height: 100%; object-fit: cover; border-radius: 18px; max-height: 540px; }

/* === Ensure top sections never have unreasonable empty space === */
.section--narrow { padding: 56px 0; }


/* Chatbot toggle inside floating-cta — also a 56px circle */
.floating-cta .chatbot-toggle {
  width: 56px; height: 56px;
  border-radius: 50% !important;
  background: var(--accent, #0B3954) !important;
  border: none;
  box-shadow: 0 6px 18px rgba(11,57,84,0.35);
  display: grid; place-items: center;
  cursor: pointer;
  position: relative;
  font-size: 0;
}
.floating-cta .chatbot-toggle svg { width: 22px; height: 22px; color: #fff; stroke: #fff; }
.floating-cta .chatbot-toggle__badge {
  position: absolute; top: 4px; right: 4px;
  width: 10px; height: 10px; border-radius: 50%;
  background: #1FD4A8;
  box-shadow: 0 0 8px #1FD4A8;
  animation: pulseDot 1.6s ease-in-out infinite;
}
.floating-cta .ring {
  display: grid; place-items: center;
  width: 100%; height: 100%;
}

/* Counter safety — ensure the value is always within bounds, never huge */
.trust-stat__num span[data-count] { display: inline-block; min-width: 1ch; }

/* ============================================================
   v2.6 — Hero positioning, feature cards, process layout,
   verified reviews, social media animations
   ============================================================ */

/* === 1. Hero image — move slightly up by aligning the visual to the top
   instead of vertically center === */
.hero__grid { align-items: start !important; padding-top: 24px; }
.hero__visual { margin-top: -24px; }
@media (max-width: 980px) {
  .hero__visual { margin-top: 12px; }
}
/* Bottom floating card sits over the image, never cuts it off */
.hero__floating-card--wait { bottom: -10px; left: -16px; }
.hero__floating-card--open { top: 22px; right: -18px; }

/* === 2. Feature cards — premium card design === */
.feature-card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 26px 24px;
  display: flex; flex-direction: column;
  gap: 14px;
  position: relative; overflow: hidden;
  transition: transform 300ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 300ms, border-color 300ms;
}
.feature-card::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 6%, transparent), transparent 50%);
  pointer-events: none; opacity: 0;
  transition: opacity 300ms ease;
}
.feature-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 14px 40px -12px rgba(11,57,84,0.18), 0 6px 14px rgba(11,57,84,0.06);
  border-color: var(--border-strong);
}
.feature-card:hover::before { opacity: 1; }
.feature-card__icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #000));
  color: #fff;
  box-shadow: 0 6px 14px color-mix(in srgb, var(--accent) 28%, transparent);
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1);
}
.feature-card:hover .feature-card__icon { transform: rotate(-8deg) scale(1.06); }
.feature-card__icon svg { width: 26px; height: 26px; stroke: #fff !important; stroke-width: 2 !important; }
.feature-card h5 {
  font-family: var(--font-display, 'Fraunces', serif);
  font-size: 20px; line-height: 1.15;
  color: var(--text); margin: 0;
}
.feature-card p { font-size: 14px; color: var(--text-muted); margin: 0; line-height: 1.55; }

/* Stagger reveals for the 4-card row */
.feature-card:nth-child(1) { transition-delay: 0ms; }
.feature-card:nth-child(2) { transition-delay: 80ms; }
.feature-card:nth-child(3) { transition-delay: 160ms; }
.feature-card:nth-child(4) { transition-delay: 240ms; }

/* Distinct color hint per card */
.feature-card:nth-child(1) .feature-card__icon { background: linear-gradient(135deg,#1FD4A8,#0e6a48); box-shadow: 0 6px 14px rgba(31,212,168,0.32); }
.feature-card:nth-child(2) .feature-card__icon { background: linear-gradient(135deg,#0B3954,#072434); box-shadow: 0 6px 14px rgba(11,57,84,0.32); }
.feature-card:nth-child(3) .feature-card__icon { background: linear-gradient(135deg,#5fa8d6,#1d4870); box-shadow: 0 6px 14px rgba(95,168,214,0.32); }
.feature-card:nth-child(4) .feature-card__icon { background: linear-gradient(135deg,#9b6ee8,#5a3296); box-shadow: 0 6px 14px rgba(155,110,232,0.32); }

/* === 3. "How a visit works" — image stays on its side, not under text === */
.split-section { display: block; }
.split-section > .container { display: block; }
.split-section .split-section,
section.section .split-section {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 56px; align-items: center;
}
@media (max-width: 900px) {
  section.section .split-section { grid-template-columns: 1fr !important; gap: 36px; }
}
.split-image { position: relative; }
.split-image img {
  width: 100%; height: auto;
  border-radius: 18px;
  object-fit: cover;
  display: block;
  max-height: 600px;
}
/* The process-list section: image left column, text right column, no overlap */
.process-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 22px; position: relative; z-index: 2; }
.process-step { display: grid; grid-template-columns: 56px 1fr; gap: 18px; align-items: start; padding-bottom: 20px; border-bottom: 1px solid var(--border); }
.process-step:last-child { border-bottom: none; padding-bottom: 0; }
.process-step__num {
  font-family: var(--font-display, 'Fraunces', serif);
  font-style: italic;
  font-size: 32px; line-height: 1;
  color: var(--emergency);
}
.process-step h5 {
  font-family: var(--font-display, 'Fraunces', serif);
  font-size: 19px; line-height: 1.2;
  color: var(--text); margin: 0 0 6px;
}
.process-step p { font-size: 14.5px; color: var(--text-muted); margin: 0; line-height: 1.55; }

/* === 4. Reviews / testimonials verified badge === */
.testimonial__name-row {
  display: inline-flex; align-items: center; gap: 6px;
}
.verified-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px; border-radius: 50%;
  background: #1d9bf0; /* Twitter/X verified blue */
  color: #fff;
  flex-shrink: 0;
}
.verified-badge svg { width: 11px; height: 11px; }
.verified-badge--lg { width: 18px; height: 18px; }
.verified-badge--lg svg { width: 12px; height: 12px; }
.testimonial__verified-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.02em;
  color: #1d9bf0;
  margin-left: 8px;
}

/* === 5. Social media bar — beautiful animated icons === */
.social-bar {
  padding: 64px 0;
  background: linear-gradient(135deg, var(--bg-soft), var(--bg-page));
  text-align: center;
  position: relative; overflow: hidden;
}
.social-bar::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 30%, color-mix(in srgb, var(--accent-2) 8%, transparent), transparent 40%),
    radial-gradient(circle at 80% 70%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 40%);
  pointer-events: none;
}
.social-bar__inner { position: relative; }
.social-bar__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-2);
  padding: 6px 14px; border-radius: 999px;
  background: color-mix(in srgb, var(--accent-2) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent-2) 24%, transparent);
  margin-bottom: 18px;
}
.social-bar__eyebrow::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-2);
  box-shadow: 0 0 10px var(--accent-2);
  animation: pulseDot 1.6s ease-in-out infinite;
}
.social-bar h2 {
  font-family: var(--font-display); font-size: clamp(28px, 4vw, 42px);
  line-height: 1.1; letter-spacing: -0.02em;
  color: var(--text); margin: 0 0 12px;
}
.social-bar p { color: var(--text-muted); font-size: 16px; line-height: 1.6; margin: 0 0 32px; max-width: 560px; margin-inline: auto; }
.social-icons {
  display: flex; gap: 16px; justify-content: center;
  flex-wrap: wrap;
}
.social-icon {
  width: 56px; height: 56px;
  border-radius: 16px;
  display: grid; place-items: center;
  color: #fff;
  background: var(--accent);
  position: relative;
  text-decoration: none;
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 320ms;
  overflow: hidden;
  box-shadow: 0 6px 16px rgba(11,57,84,0.18);
}
.social-icon svg {
  width: 24px; height: 24px;
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1);
  position: relative; z-index: 2;
}
.social-icon::before {
  content: ""; position: absolute; inset: 0;
  background: var(--social-bg, linear-gradient(135deg, #0B3954, #072434));
  z-index: 1;
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1);
  transform: translateY(0%);
}
.social-icon::after {
  content: ""; position: absolute; inset: 0;
  background: var(--social-hover, linear-gradient(135deg, #1FD4A8, #0e6a48));
  z-index: 0;
}
.social-icon:hover { transform: translateY(-6px) rotate(-6deg); box-shadow: 0 14px 28px rgba(0,0,0,0.2); }
.social-icon:hover::before { transform: translateY(100%); }
.social-icon:hover svg { transform: scale(1.15) rotate(8deg); }

.social-icon--facebook  { --social-bg: linear-gradient(135deg,#1877f2,#0a4daa); --social-hover: linear-gradient(135deg,#1877f2,#0a4daa); }
.social-icon--instagram { --social-bg: linear-gradient(135deg,#0B3954,#072434); --social-hover: linear-gradient(135deg,#f09433,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%); }
.social-icon--twitter   { --social-bg: linear-gradient(135deg,#0B3954,#072434); --social-hover: linear-gradient(135deg,#1d2024,#000); }
.social-icon--linkedin  { --social-bg: linear-gradient(135deg,#0077b5,#004876); --social-hover: linear-gradient(135deg,#0077b5,#004876); }
.social-icon--youtube   { --social-bg: linear-gradient(135deg,#0B3954,#072434); --social-hover: linear-gradient(135deg,#ff0000,#cc0000); }
.social-icon--tiktok    { --social-bg: linear-gradient(135deg,#0B3954,#072434); --social-hover: linear-gradient(135deg,#69c9d0,#000); }
.social-icon--google    { --social-bg: linear-gradient(135deg,#0B3954,#072434); --social-hover: linear-gradient(135deg,#4285f4,#34a853 33%,#fbbc05 66%,#ea4335); }
.social-icon--yelp      { --social-bg: linear-gradient(135deg,#0B3954,#072434); --social-hover: linear-gradient(135deg,#d32323,#aa0000); }

@media (max-width: 480px) {
  .social-icon { width: 50px; height: 50px; border-radius: 14px; }
  .social-icon svg { width: 22px; height: 22px; }
  .social-icons { gap: 12px; }
}

/* Footer social section (smaller, in footer) */
.footer__social { display: flex; gap: 12px; margin-top: 16px; }
.footer__social a {
  width: 38px; height: 38px; border-radius: 50%;
  display: grid; place-items: center;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.85);
  transition: all 280ms cubic-bezier(0.34,1.56,0.64,1);
  text-decoration: none;
}
.footer__social a svg { width: 17px; height: 17px; }
.footer__social a:hover {
  transform: translateY(-4px) scale(1.06);
  background: var(--accent-2);
  color: #fff;
}


/* ============================================================
   v2.6 — 5-issue beautify pass
   ============================================================ */

/* === FIX 1: Hero image — crop to top so building sits higher === */
.hero-scan__img {
  object-fit: cover;
  object-position: center 28%;   /* pulls the visible portion upward */
}
@media (max-width: 720px) {
  .hero-scan__img { object-position: center 35%; }
}

/* === FIX 2: Beautified feature cards (4-tile feature grid) === */
.feature-card {
  position: relative;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 14px;
  overflow: hidden;
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 320ms, border-color 320ms;
}
.feature-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  transform: scaleX(0); transform-origin: left;
  transition: transform 420ms cubic-bezier(0.65,0,0.35,1);
}
.feature-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: transparent; }
.feature-card:hover::before { transform: scaleX(1); }
.feature-card::after {
  content: ""; position: absolute; bottom: -40px; right: -40px;
  width: 140px; height: 140px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent-2) 22%, transparent), transparent 70%);
  opacity: 0; transition: opacity 400ms ease;
  pointer-events: none;
}
.feature-card:hover::after { opacity: 1; }
.feature-card__icon {
  width: 58px; height: 58px;
  border-radius: 16px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 65%, #000));
  color: #fff;
  box-shadow: 0 8px 18px color-mix(in srgb, var(--accent) 28%, transparent), inset 0 1px 0 rgba(255,255,255,0.18);
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1);
}
.feature-card:hover .feature-card__icon { transform: rotate(-8deg) scale(1.08); }
.feature-card__icon svg { width: 26px; height: 26px; }
.feature-card:nth-child(1) .feature-card__icon { background: linear-gradient(135deg, #2bcf9a, #0e6a48); }
.feature-card:nth-child(2) .feature-card__icon { background: linear-gradient(135deg, #5fa8d6, #1d4870); }
.feature-card:nth-child(3) .feature-card__icon { background: linear-gradient(135deg, #f7b249, #b87004); }
.feature-card:nth-child(4) .feature-card__icon { background: linear-gradient(135deg, #9b6ee8, #5a3296); }
.feature-card h5 {
  font-family: var(--font-display, 'Fraunces', serif);
  font-size: 22px; line-height: 1.15; margin: 0;
  color: var(--text);
}
.feature-card p {
  font-size: 14.5px; line-height: 1.55; color: var(--text-muted); margin: 0;
}
html[data-theme="dark"] .feature-card { background: var(--bg-elev); border-color: var(--border); }
html[data-theme="dark"] .feature-card h5 { color: var(--text); }

/* === FIX 3: "How a visit works" — image side-by-side, no overlap === */
.split-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0px;
  align-items: center;
  padding: 50px 0;
}
.split-section > * { min-width: 0; }
.split-image {
  position: relative;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  background: transparent;
}

.split-image img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 600ms ease;
}
.split-image:hover img { transform: scale(1.04); }
@media (max-width: 900px) {
  .split-section { grid-template-columns: 1fr; gap: 36px; padding: 56px 0; }
  .split-image { aspect-ratio: 16/10; max-height: 380px; }
}
/* Process list — clean spacing so steps don't crowd the image */
.process-list { list-style: none; padding: 0; margin: 24px 0 0; display: flex; flex-direction: column; }
.process-step {
  display: grid; grid-template-columns: 56px 1fr; gap: 18px;
  padding: 18px 0;
  border-bottom: 1px solid var(--border);
  align-items: flex-start;
}
.process-step:last-child { border-bottom: none; }
.process-step__num {
  font-family: var(--font-display, serif);
  font-style: italic; font-size: 28px; line-height: 1;
  color: var(--emergency);
  font-weight: 600;
}
.process-step h5 {
  font-family: var(--font-display, serif);
  font-size: 19px; line-height: 1.2; margin: 0 0 4px; color: var(--text);
}
.process-step p { font-size: 14.5px; line-height: 1.55; color: var(--text-muted); margin: 0; }

/* === FIX 4: Verified blue tick + beautified review cards === */
.verified-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  color: #1DA1F2;
  flex-shrink: 0;
  margin-left: 4px;
}
.verified-badge svg {
  width: 100%; height: 100%;
  fill: currentColor;
  stroke: none;
  filter: drop-shadow(0 1px 2px rgba(29,161,242,0.35));
  transition: transform 240ms ease;
}
.verified-badge:hover svg { transform: scale(1.15); }
.testimonial__name-row {
  display: inline-flex; align-items: center; gap: 4px;
  flex-wrap: wrap;
}
.testimonial__verified-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #1DA1F2;
  background: rgba(29,161,242,0.10);
  border: 1px solid rgba(29,161,242,0.25);
  padding: 2px 8px; border-radius: 999px;
  margin-left: 4px;
  white-space: nowrap;
}

/* Polished testimonial cards */
.testimonial {
  position: relative;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 16px;
  transition: transform 280ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 280ms;
  overflow: hidden;
}
.testimonial:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.testimonial::before {
  content: "“";
  position: absolute;
  top: 14px; left: 22px;
  font-family: var(--font-display, serif);
  font-size: 78px;
  color: color-mix(in srgb, var(--emergency) 14%, transparent);
  line-height: 1;
  pointer-events: none;
}
.testimonial__stars { display: inline-flex; gap: 4px; color: #f5b800; align-self: flex-end; }
.testimonial__stars svg { width: 18px; height: 18px; fill: currentColor; filter: drop-shadow(0 1px 1px rgba(0,0,0,0.06)); }
.testimonial__quote {
  font-family: var(--font-display, 'Fraunces', serif);
  font-style: italic;
  font-size: 19px; line-height: 1.5;
  color: var(--text); margin: 0;
}
.testimonial__author {
  display: flex; align-items: center; gap: 14px;
  padding-top: 18px; margin-top: auto;
  border-top: 1px solid var(--border);
}
.testimonial__avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent-2) 60%, var(--accent)));
  color: #fff;
  display: grid; place-items: center;
  font-family: var(--font-display, serif);
  font-size: 18px; font-weight: 600;
  flex-shrink: 0;
}
.testimonial__name {
  font-weight: 600; color: var(--text); font-size: 15px;
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.testimonial__role { font-size: 13px; color: var(--text-muted); margin-top: 2px; }
html[data-theme="dark"] .testimonial { background: var(--bg-elev); border-color: var(--border); }

/* === FIX 5: Social media section with animated icons === */
.social-section {
  padding: 80px 0;
  background: var(--bg-page);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.social-section::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 15% 30%, color-mix(in srgb, var(--accent-2) 8%, transparent), transparent 50%),
    radial-gradient(circle at 85% 70%, color-mix(in srgb, var(--accent) 6%, transparent), transparent 50%);
  pointer-events: none;
}
.social-section__head { position: relative; z-index: 1; max-width: 640px; margin: 0 auto 36px; padding: 0 24px; }
.social-section__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-2); font-weight: 600;
  padding: 6px 14px; border-radius: 999px;
  background: color-mix(in srgb, var(--accent-2) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent-2) 24%, transparent);
  margin-bottom: 14px;
}
.social-section h2 {
  font-family: var(--font-display, 'Fraunces', serif);
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.1; letter-spacing: -0.02em;
  margin: 0 0 10px; color: var(--text);
}
.social-section p { color: var(--text-muted); font-size: 16px; line-height: 1.55; margin: 0; }

.social-grid {
  position: relative; z-index: 1;
  display: flex; justify-content: center; flex-wrap: wrap;
  gap: 18px;
  margin: 0 auto; max-width: 980px;
  padding: 0 24px;
}
.social-icon {
  position: relative;
  width: 68px; height: 68px;
  border-radius: 18px;
  display: grid; place-items: center;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  color: var(--text);
  text-decoration: none;
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 320ms, border-color 320ms;
  overflow: hidden;
}
.social-icon svg { width: 28px; height: 28px; transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1); z-index: 2; position: relative; }
.social-icon::before {
  content: ""; position: absolute; inset: 0;
  border-radius: 18px;
  background: var(--brand, var(--accent));
  opacity: 0;
  transition: opacity 320ms ease;
}
.social-icon:hover { transform: translateY(-6px) rotate(-3deg); border-color: transparent; box-shadow: 0 10px 24px rgba(0,0,0,0.18); }
.social-icon:hover::before { opacity: 1; }
.social-icon:hover svg { color: #fff; transform: scale(1.15); }
.social-icon:hover .social-icon__label { opacity: 1; transform: translateY(0); }
.social-icon__label {
  position: absolute; bottom: -32px; left: 50%; transform: translateX(-50%) translateY(4px);
  font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
  background: var(--text); color: var(--bg-page);
  padding: 4px 9px; border-radius: 6px;
  white-space: nowrap; pointer-events: none;
  opacity: 0; transition: opacity 200ms, transform 200ms;
}
.social-icon__label::before {
  content: ""; position: absolute; top: -3px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 6px; height: 6px; background: var(--text);
}
/* Brand color tokens per platform */
.social-icon--facebook { --brand: #1877F2; }
.social-icon--instagram { --brand: linear-gradient(135deg,#f9ce34,#ee2a7b 50%,#6228d7); }
.social-icon--twitter { --brand: #000; }
.social-icon--youtube { --brand: #FF0000; }
.social-icon--tiktok { --brand: linear-gradient(135deg,#25F4EE,#000 50%,#FE2C55); }
.social-icon--linkedin { --brand: #0A66C2; }
.social-icon--google { --brand: #4285F4; }
.social-icon--yelp { --brand: #D32323; }
.social-icon--whatsapp { --brand: #25D366; }
.social-icon--pinterest { --brand: #BD081C; }
/* Instagram + TikTok need gradient backgrounds via overlay */
.social-icon--instagram::before { background: linear-gradient(135deg,#f9ce34,#ee2a7b 50%,#6228d7); }
.social-icon--tiktok::before { background: linear-gradient(135deg,#25F4EE 0%,#000 45%,#FE2C55 100%); }

/* Continuous gentle bobbing for visual life */
.social-icon { animation: socialBob 4s ease-in-out infinite; animation-delay: var(--bob-delay, 0s); }
.social-icon:hover { animation: none; }
@keyframes socialBob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}
@media (max-width: 480px) {
  .social-icon { width: 56px; height: 56px; }
  .social-icon svg { width: 22px; height: 22px; }
}


/* Footer social icons — visible on navy background */
.footer-social-icon {
  width: 38px;
  height: 38px;
  display: grid !important;
  place-items: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.10) !important;
  color: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  transition: all 240ms cubic-bezier(0.34,1.56,0.64,1);
  text-decoration: none;
}
.footer-social-icon svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}
.footer-social-icon:hover {
  background: var(--color-red) !important;
  color: #fff !important;
  border-color: var(--color-red) !important;
  transform: translateY(-3px) scale(1.08);
  box-shadow: 0 6px 14px rgba(208,2,27,0.4);
}

/* ============================================================
   v3.0 — BRAND REBUILD
   New palette: Red #D0021B · Navy #202060 · White #FFFFFF
   No more dark mode toggle. Justified text. Premium polish.
   ============================================================ */

:root,
html,
html[data-theme="light"],
html[data-theme="dark"] {
  /* Brand tokens */
  --color-red: #D0021B;
  --color-red-dark: #A50016;
  --color-red-light: #F5E5E8;
  --color-navy: #202060;
  --color-navy-dark: #14143E;
  --color-navy-light: #ECECF5;
  --color-white: #FFFFFF;

  /* Functional aliases (overwrite earlier v2 tokens) */
  --bg-page: #FFFFFF;
  --bg-elev: #FFFFFF;
  --bg-soft: #F8F8FB;
  --bg-strip: #202060;
  --bg-strip-dark: #14143E;
  --text: #14143E;
  --text-muted: #5C6479;
  --text-on-dark: #FFFFFF;
  --border: rgba(32,32,96,0.10);
  --border-strong: rgba(32,32,96,0.20);
  --shadow-sm: 0 1px 2px rgba(20,20,62,0.06), 0 2px 6px rgba(20,20,62,0.04);
  --shadow-md: 0 4px 12px rgba(20,20,62,0.08), 0 12px 32px rgba(20,20,62,0.07);
  --shadow-lg: 0 12px 32px rgba(20,20,62,0.12), 0 32px 80px rgba(20,20,62,0.10);
  --shadow-red: 0 8px 20px rgba(208,2,27,0.28);
  --shadow-navy: 0 8px 20px rgba(32,32,96,0.22);
  --glass-bg: rgba(255,255,255,0.85);
  --glass-bg-strong: rgba(255,255,255,0.96);
  --glass-border: rgba(32,32,96,0.10);
  --accent: #202060;
  --accent-2: #D0021B;
  --emergency: #D0021B;
  --color-cream: #FFFFFF;
  --color-cream-200: #F8F8FB;
  --color-ink: #14143E;
  --color-mint: #202060;
  --grid-line: rgba(32,32,96,0.05);
  color-scheme: light !important;
}

/* === Kill the theme toggle UI globally === */
.theme-toggle,
.theme-toggle__knob,
.icon-sun,
.icon-moon { display: none !important; }

/* === Justified body text on prose blocks === */
.article p, .article li,
.page-hero__lede,
.section p,
.split-section p,
.lede,
.contact-card__body,
.svc-card p,
.feature-card p,
.review-card__body,
.doctor-card__bio,
.career-card__desc {
  text-align: justify;
  text-justify: inter-word;
  hyphens: auto;
}
/* But NOT inside short labels or headings */
.section h1, .section h2, .section h3, .hero h1, .page-hero h1,
.svc-card__category, .review-card__author span, .feature-card h5,
.location-tile p, .testimonial__quote, .blog-card p,
.contact-card__title, .doctor-card__name, .career-card__title { text-align: left; }

/* === Body background reset === */
body {
  background: var(--bg-page) !important;
  color: var(--text) !important;
}

/* === Brand-colored buttons === */
.btn--emergency, .contact-card__cta--emergency {
  background: var(--color-red) !important;
  color: #fff !important;
  border-color: var(--color-red) !important;
  box-shadow: var(--shadow-red);
}
.btn--emergency:hover { background: var(--color-red-dark) !important; }
.btn--primary {
  background: var(--color-navy) !important;
  color: #fff !important;
  border-color: var(--color-navy) !important;
  box-shadow: var(--shadow-navy);
}
.btn--primary:hover { background: var(--color-navy-dark) !important; }
.btn--ghost {
  background: transparent !important;
  color: var(--color-navy) !important;
  border: 1.5px solid rgba(32,32,96,0.30) !important;
}
.btn--ghost:hover { background: var(--color-navy-light) !important; border-color: var(--color-navy) !important; }

/* === Emergency bar (top) === */
.emergency-bar { background: var(--color-red) !important; color: #fff !important; }
.emergency-bar a, .emergency-bar strong { color: #fff !important; }

/* === Logo lockup with PNG === */
.logo {
  display: inline-flex !important;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  flex-shrink: 0;
}
.logo__img {
  width: 48px; height: 48px;
  display: block;
  object-fit: contain;
}
.logo > span.logo-wordmark {
  display: inline-flex; flex-direction: column;
  line-height: 1.05;
  font-family: var(--font-display, 'Fraunces', Georgia, serif);
  font-weight: 700; font-size: 19px; color: var(--color-navy);
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.logo .logo-wordmark small {
  font-family: var(--font-body, 'Manrope', sans-serif);
  font-weight: 600; font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--color-red);
  margin-top: 3px;
}
/* Hide old SVG mark from earlier builds */
.logo__mark { display: none !important; }
@media (max-width: 720px) {
  .logo__img { width: 40px; height: 40px; }
  .logo > span.logo-wordmark { font-size: 17px; }
  .logo .logo-wordmark small { font-size: 9px; }
}

/* === Navigation polish — navy underline === */
.nav { background: rgba(255,255,255,0.95) !important; backdrop-filter: blur(16px) saturate(180%); border-bottom: 1px solid var(--border) !important; }
.nav__menu a { color: var(--color-navy) !important; font-weight: 500; }
.nav__menu a:hover { color: var(--color-red) !important; }
.nav__menu a::after { background: var(--color-red) !important; }
.nav__dropdown { background: #fff !important; border: 1px solid var(--border) !important; box-shadow: var(--shadow-md) !important; }
.nav__dropdown a { color: var(--color-navy) !important; }
.nav__dropdown a:hover { background: var(--color-navy-light) !important; color: var(--color-red) !important; }

/* === Hero accent underline === */
.hero h1 .accent { color: var(--color-red) !important; font-style: italic; position: relative; }
.hero h1 .accent::after { background: linear-gradient(90deg, var(--color-red), transparent) !important; opacity: 0.35; }

/* === Section eyebrows === */
.eyebrow, .section-eyebrow { color: var(--color-red) !important; }
.section-eyebrow { background: var(--color-red-light) !important; border-color: rgba(208,2,27,0.25) !important; }
.section-eyebrow::before { background: var(--color-red) !important; box-shadow: 0 0 10px var(--color-red) !important; }

/* === Trust strip === */
.trust-strip { background: var(--bg-soft) !important; border-top: 1px solid var(--border) !important; border-bottom: 1px solid var(--border) !important; }
.trust-stat__num { color: var(--color-navy) !important; }
.trust-stat__label { color: var(--text-muted) !important; }
.trust-stat .unit { color: var(--color-red) !important; }

/* === Service cards — clean white with navy gradient hover === */
.svc-card { background: #fff !important; border: 1px solid var(--border) !important; }
.svc-card:hover { border-color: var(--color-navy) !important; }
.svc-card h3 { color: var(--color-navy) !important; }
.svc-card__category { color: var(--color-red) !important; }
.svc-card__more { color: var(--color-red) !important; }
.svc-card--cardiac .svc-card__icon { background: linear-gradient(135deg, var(--color-red), var(--color-red-dark)) !important; }
.svc-card--infection .svc-card__icon,
.svc-card--trauma .svc-card__icon,
.svc-card--neuro .svc-card__icon,
.svc-card--diagnostic .svc-card__icon,
.svc-card--treatment .svc-card__icon,
.svc-card--pediatric .svc-card__icon { background: linear-gradient(135deg, var(--color-navy), var(--color-navy-dark)) !important; }
.svc-pill.is-active { background: var(--color-red) !important; color: #fff !important; border-color: var(--color-red) !important; }

/* === Feature cards (Under 10 min wait etc.) === */
.feature-card { background: #fff !important; border: 1px solid var(--border) !important; }
.feature-card h5 { color: var(--color-navy) !important; }
.feature-card::before { background: linear-gradient(90deg, var(--color-navy), var(--color-red)) !important; }
.feature-card:nth-child(1) .feature-card__icon,
.feature-card:nth-child(3) .feature-card__icon { background: linear-gradient(135deg, var(--color-navy), var(--color-navy-dark)) !important; }
.feature-card:nth-child(2) .feature-card__icon,
.feature-card:nth-child(4) .feature-card__icon { background: linear-gradient(135deg, var(--color-red), var(--color-red-dark)) !important; }

/* === Process steps === */
.process-step__num { color: var(--color-red) !important; }
.process-step h5 { color: var(--color-navy) !important; }

/* === Locations === */
.location-tile, .locations-grid .location-tile { background: #fff !important; border: 1px solid var(--border) !important; }
.location-tile__state, .location-tile__city { color: var(--color-navy) !important; }
.location-tile__state { color: var(--color-red) !important; }
.location-tile__distance {
  background: var(--color-red-light) !important;
  color: var(--color-red) !important;
  border-color: rgba(208,2,27,0.25) !important;
}
.location-tile__city { color: var(--color-navy) !important; }
.loctile-link--page { background: var(--color-navy) !important; color: #fff !important; }
.loctile-link--map { background: var(--color-navy-light) !important; color: var(--color-navy) !important; }

/* === Testimonials === */
.testimonial { background: var(--bg-soft) !important; border: 1px solid var(--border) !important; }
.testimonial__avatar { background: linear-gradient(135deg, var(--color-navy), var(--color-red)) !important; }
.testimonial__quote { color: var(--color-navy) !important; }
.testimonial::before { color: var(--color-red-light) !important; }
.verified-badge { color: #1DA1F2 !important; }
.testimonial__verified-pill { color: #1DA1F2 !important; background: rgba(29,161,242,0.10) !important; border-color: rgba(29,161,242,0.25) !important; }

/* === Insurance marquee === */
.insurance-marquee { background: var(--color-navy) !important; color: #fff !important; }
.insurance-marquee__head h2 { color: #fff !important; }
.insurance-marquee__head p { color: rgba(255,255,255,0.78) !important; }
.insurance-marquee__head .eyebrow { color: #fff !important; background: rgba(208,2,27,0.25) !important; border-color: rgba(208,2,27,0.4) !important; }

/* === Modern location section === */
.location-modern { background: var(--bg-soft) !important; }
.location-modern__pin { background: linear-gradient(135deg, var(--color-red), var(--color-red-dark)) !important; }

/* === Footer === */
.footer { background: var(--color-navy) !important; color: rgba(255,255,255,0.78) !important; }
.footer h6, .footer strong, .footer .logo-wordmark { color: #fff !important; }
.footer .logo-wordmark small { color: rgba(255,255,255,0.65) !important; }
.footer a { color: rgba(255,255,255,0.72) !important; }
.footer a:hover { color: var(--color-red) !important; }

/* === Page heros === */
.page-hero {
  background: linear-gradient(135deg, var(--bg-soft) 0%, #fff 100%) !important;
  border-bottom: 1px solid var(--border);
  padding: 80px 0 64px;
}
.page-hero h1 { color: var(--color-navy) !important; }
.page-hero__eyebrow, .page-hero .eyebrow { color: var(--color-red) !important; }

/* === Reviews page polish === */
.review-card { background: #fff !important; border: 1px solid var(--border) !important; }
.review-card__quote-mark { color: rgba(32,32,96,0.10) !important; }
.review-stat__num { color: var(--color-navy) !important; }
.review-stat__num.gold { color: #f5b800 !important; }

/* === Doctors page === */
.doctor-card { background: #fff !important; border: 1px solid var(--border) !important; }
.doctor-card__name { color: var(--color-navy) !important; }
.doctor-card__role { color: var(--color-red) !important; }
.doctor-card__badge { color: var(--color-navy) !important; }

/* === Careers page === */
.career-card { background: #fff !important; border: 1px solid var(--border) !important; }
.career-card::before { background: linear-gradient(180deg, var(--color-navy), var(--color-red)) !important; }
.career-card__title { color: var(--color-navy) !important; }
.career-card__type, .career-card__cta { color: var(--color-red) !important; }
.career-perk__icon { background: var(--color-red-light) !important; color: var(--color-red) !important; }

/* === FAQ accordion modernized === */
.faq-categories {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin: 24px 0 32px;
}
.faq-cat {
  padding: 10px 18px; border-radius: 999px; cursor: pointer;
  font-size: 13px; font-weight: 600; letter-spacing: 0.02em;
  background: #fff; color: var(--color-navy);
  border: 1px solid var(--border);
  transition: all 220ms ease;
}
.faq-cat:hover { border-color: var(--color-navy); transform: translateY(-1px); }
.faq-cat.is-active { background: var(--color-navy); color: #fff; border-color: var(--color-navy); }
.faq-list { display: flex; flex-direction: column; gap: 12px; }
.faq-item {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color 240ms ease, box-shadow 240ms ease;
}
.faq-item:hover { border-color: var(--border-strong); box-shadow: var(--shadow-sm); }
.faq-item[open] { border-color: var(--color-navy); box-shadow: var(--shadow-md); }
.faq-item summary {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 22px 24px;
  cursor: pointer;
  font-family: var(--font-display, serif);
  font-size: 18px; line-height: 1.3;
  color: var(--color-navy); font-weight: 600;
  list-style: none;
  transition: background 220ms;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: ""; flex-shrink: 0;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--color-red-light);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23D0021B' stroke-width='3' stroke-linecap='round'><line x1='12' y1='5' x2='12' y2='19'/><line x1='5' y1='12' x2='19' y2='12'/></svg>");
  background-repeat: no-repeat; background-position: center;
  transition: transform 320ms cubic-bezier(0.65,0,0.35,1), background-color 320ms;
}
.faq-item[open] summary::after { transform: rotate(45deg); background-color: var(--color-red); background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='3' stroke-linecap='round'><line x1='12' y1='5' x2='12' y2='19'/><line x1='5' y1='12' x2='19' y2='12'/></svg>"); }
.faq-item summary:hover { background: var(--color-navy-light); }
.faq-item__body {
  padding: 0 24px 24px;
  color: var(--text-muted);
  font-size: 15.5px; line-height: 1.7;
  text-align: justify;
  border-top: 1px solid var(--border);
  margin-top: -1px; padding-top: 18px;
  animation: faqSlide 320ms ease;
}
@keyframes faqSlide {
  from { opacity: 0; transform: translateY(-6px); }
  to { opacity: 1; transform: translateY(0); }
}
.faq-item.is-hidden { display: none; }

/* === Blog cards modernized === */
.blog-card {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 18px;
  overflow: hidden;
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 320ms, border-color 320ms;
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
}
.blog-card:hover { transform: translateY(-6px); border-color: var(--color-navy) !important; box-shadow: var(--shadow-lg); }
.blog-card__image {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--bg-soft);
}
.blog-card__image img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 600ms ease;
}
.blog-card:hover .blog-card__image img { transform: scale(1.08); }
.blog-card__image::after {
  content: ""; position: absolute; inset: auto 0 0 0; height: 50%;
  background: linear-gradient(180deg, transparent, rgba(20,20,62,0.15));
  pointer-events: none;
}
.blog-card__body { padding: 26px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.blog-card__meta { display: flex; align-items: center; gap: 10px; font-size: 12px; color: var(--text-muted); }
.blog-card__meta .tag {
  background: var(--color-red-light);
  color: var(--color-red);
  padding: 4px 10px; border-radius: 999px;
  font-weight: 700; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
}
.blog-card__meta .tag--emergency { background: var(--color-red); color: #fff; }
.blog-card__meta .dot { width: 3px; height: 3px; background: var(--text-muted); border-radius: 50%; }
.blog-card h4 {
  font-family: var(--font-display, serif);
  font-size: 22px; line-height: 1.25; margin: 0;
  color: var(--color-navy);
  letter-spacing: -0.01em;
}
.blog-card p { font-size: 14.5px; line-height: 1.55; color: var(--text-muted); margin: 0; flex: 1; text-align: justify; }
.blog-card__link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--color-red); font-weight: 600; font-size: 14px;
  margin-top: 6px;
  transition: gap 220ms;
}
.blog-card__link::after { content: "→"; transition: transform 220ms; }
.blog-card:hover .blog-card__link { gap: 10px; }

/* === Blog article (individual post) page === */
.article-layout {
  display: grid; grid-template-columns: 1fr 260px;
  gap: 56px; align-items: flex-start;
}
.article-toc {
  position: sticky; top: 100px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 22px;
  max-height: calc(100vh - 140px);
  overflow: auto;
}
.article-toc h6 {
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--color-red); font-weight: 700;
  margin: 0 0 14px;
}
.article-toc ol { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.article-toc a {
  display: block;
  font-size: 14px; line-height: 1.4;
  color: var(--text-muted); text-decoration: none;
  padding: 6px 10px; border-radius: 8px;
  border-left: 2px solid transparent;
  transition: all 200ms ease;
}
.article-toc a:hover, .article-toc a.is-active {
  color: var(--color-navy);
  background: #fff;
  border-left-color: var(--color-red);
}
.article-body { max-width: 720px; }
.article-body h2 {
  font-family: var(--font-display, serif);
  font-size: clamp(24px, 3vw, 32px);
  line-height: 1.15; margin: 48px 0 18px;
  color: var(--color-navy);
  letter-spacing: -0.02em;
}
.article-body h3 {
  font-family: var(--font-display, serif);
  font-size: 22px; line-height: 1.2; margin: 32px 0 12px;
  color: var(--color-navy);
}
.article-body p, .article-body li {
  font-size: 17px; line-height: 1.7;
  color: #2a2a4a;
  text-align: justify; hyphens: auto;
  margin: 0 0 18px;
}
.article-body a { color: var(--color-red); font-weight: 600; }
.article-body strong { color: var(--color-navy); }
.article-body ul, .article-body ol { padding-left: 22px; margin: 0 0 22px; }
.article-body li { margin-bottom: 8px; text-align: left; }
.article-body blockquote {
  border-left: 4px solid var(--color-red);
  background: var(--color-red-light);
  padding: 22px 28px;
  border-radius: 12px;
  margin: 28px 0;
  font-family: var(--font-display, serif);
  font-style: italic;
  font-size: 19px;
  color: var(--color-navy);
}
.article-body img { width: 100%; height: auto; border-radius: 14px; margin: 28px 0; }

/* Author bio */
.article-author {
  display: flex; gap: 18px; align-items: center;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  margin: 40px 0;
}
.article-author__avatar {
  width: 64px; height: 64px; border-radius: 50%;
  background: linear-gradient(135deg, var(--color-navy), var(--color-red));
  flex-shrink: 0;
}
.article-author__meta strong {
  display: block; font-family: var(--font-display, serif);
  font-size: 18px; color: var(--color-navy); margin-bottom: 4px;
}
.article-author__meta span { font-size: 14px; color: var(--text-muted); display: block; }
.article-author__meta p { margin: 8px 0 0; font-size: 14px; color: var(--text-muted); line-height: 1.55; text-align: left; }

/* Related posts */
.related-posts {
  margin: 64px 0 0;
  padding: 48px 0 0;
  border-top: 1px solid var(--border);
}
.related-posts h3 {
  font-family: var(--font-display, serif);
  font-size: 24px; color: var(--color-navy); margin: 0 0 24px;
}
.related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 22px; }

@media (max-width: 980px) {
  .article-layout { grid-template-columns: 1fr; gap: 32px; }
  .article-toc { position: static; max-height: none; }
}

/* === About page sections === */
.about-hero {
  background: linear-gradient(135deg, var(--color-navy), var(--color-navy-dark));
  color: #fff;
  padding: 96px 0;
  position: relative;
  overflow: hidden;
}
.about-hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 15% 30%, rgba(208,2,27,0.18), transparent 50%),
    radial-gradient(circle at 85% 70%, rgba(255,255,255,0.08), transparent 50%);
  pointer-events: none;
}
.about-hero h1 { color: #fff; font-size: clamp(36px, 5vw, 64px); line-height: 1.05; letter-spacing: -0.02em; max-width: 900px; margin: 16px 0; }
.about-hero p { color: rgba(255,255,255,0.85); font-size: 18px; line-height: 1.6; max-width: 760px; }
.about-hero .eyebrow { color: var(--color-red); background: rgba(208,2,27,0.18); border: 1px solid rgba(208,2,27,0.4); padding: 6px 14px; border-radius: 999px; display: inline-block; }

.about-mv {
  padding: 96px 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.about-mv__card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 40px;
  position: relative;
  overflow: hidden;
  transition: transform 320ms, box-shadow 320ms;
}
.about-mv__card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.about-mv__card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 5px;
  background: linear-gradient(90deg, var(--color-red), var(--color-navy));
}
.about-mv__icon {
  width: 64px; height: 64px;
  border-radius: 16px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--color-navy), var(--color-navy-dark));
  color: #fff;
  margin-bottom: 18px;
  box-shadow: var(--shadow-navy);
}
.about-mv__card--vision .about-mv__icon { background: linear-gradient(135deg, var(--color-red), var(--color-red-dark)); box-shadow: var(--shadow-red); }
.about-mv__card h3 {
  font-family: var(--font-display, serif);
  font-size: 30px; line-height: 1.1; margin: 0 0 14px;
  color: var(--color-navy); letter-spacing: -0.02em;
}
.about-mv__card p { font-size: 16px; line-height: 1.7; color: var(--text-muted); margin: 0; text-align: justify; }

.about-stats {
  background: var(--color-navy);
  color: #fff;
  padding: 64px 0;
}
.about-stats__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 32px; text-align: center;
}
.about-stat__num {
  font-family: var(--font-display, serif);
  font-size: clamp(40px, 5vw, 60px);
  line-height: 1;
  color: #fff;
  font-weight: 600;
}
.about-stat__num .accent { color: var(--color-red); }
.about-stat__label { color: rgba(255,255,255,0.78); font-size: 13px; letter-spacing: 0.10em; text-transform: uppercase; margin-top: 8px; font-weight: 600; }

@media (max-width: 720px) {
  .about-mv { grid-template-columns: 1fr; padding: 64px 0; }
  .about-stats__grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
}

/* === Events page === */
.events-hero {
  background: linear-gradient(135deg, var(--color-navy), var(--color-navy-dark));
  color: #fff;
  padding: 80px 0;
  position: relative; overflow: hidden;
}
.events-hero h1 { color: #fff; }
.events-hero p { color: rgba(255,255,255,0.85); max-width: 720px; }
.events-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 26px;
  margin-top: 36px;
}
.event-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform 320ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 320ms;
}
.event-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.event-card__image {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--bg-soft);
}
.event-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms; }
.event-card:hover .event-card__image img { transform: scale(1.08); }
.event-card__date {
  position: absolute; top: 16px; left: 16px;
  background: #fff;
  border-radius: 12px;
  padding: 10px 14px;
  display: flex; flex-direction: column; align-items: center;
  box-shadow: var(--shadow-md);
  min-width: 60px;
}
.event-card__date strong {
  display: block; font-family: var(--font-display, serif);
  font-size: 24px; line-height: 1; color: var(--color-red);
}
.event-card__date span {
  font-size: 11px; letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--color-navy); font-weight: 700; margin-top: 4px;
}
.event-card__body { padding: 24px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.event-card__tag {
  display: inline-flex; align-self: flex-start;
  background: var(--color-navy-light); color: var(--color-navy);
  padding: 4px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
}
.event-card h3 {
  font-family: var(--font-display, serif);
  font-size: 22px; line-height: 1.2; margin: 0;
  color: var(--color-navy);
}
.event-card__meta {
  display: flex; flex-direction: column; gap: 6px;
  font-size: 14px; color: var(--text-muted);
}
.event-card__meta span { display: flex; align-items: center; gap: 8px; }
.event-card__meta svg { width: 16px; height: 16px; color: var(--color-red); flex-shrink: 0; }
.event-card p { font-size: 14.5px; line-height: 1.55; color: var(--text-muted); margin: 0; flex: 1; text-align: justify; }
.event-card__cta {
  background: var(--color-red); color: #fff !important;
  padding: 12px 20px; border-radius: 999px;
  font-weight: 600; font-size: 14px;
  text-align: center; text-decoration: none;
  margin-top: 4px;
  transition: background 220ms;
}
.event-card__cta:hover { background: var(--color-red-dark); }

/* === Counter-up animations & reveal === */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity 720ms ease, transform 720ms cubic-bezier(0.16,1,0.3,1); }
.reveal.is-visible { opacity: 1; transform: none; }

/* === Image card hover (for blog featured images etc) === */
img { max-width: 100%; height: auto; }

/* === FAQ floating-cta — no overlap on body === */
.floating-cta { bottom: 24px !important; right: 24px !important; }

/* === Strip out all dark theme overrides === */
html[data-theme="dark"] *,
html[data-theme="dark"] {
  /* re-inherit light tokens — already done via var() override above */
}

/* === Improved heading hierarchy === */
h1, h2, h3, h4, h5, h6 { color: var(--color-navy); }
h1, h2 { letter-spacing: -0.02em; }
h1 .accent, h2 .accent, h3 .accent, .display-italic { color: var(--color-red) !important; }

/* === Final touches === */
::selection { background: var(--color-red); color: #fff; }
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--bg-soft); }
::-webkit-scrollbar-thumb { background: rgba(32,32,96,0.30); border-radius: 5px; }
::-webkit-scrollbar-thumb:hover { background: var(--color-navy); }

/* ============================================================
   v3.1 — ISSUE FIX PASS
   ============================================================ */

/* === ISSUE 3 & 4: Dark-section text legibility (CTA banner + Events hero)
   White text on navy gradient, was inheriting old --text token === */
.cta-banner-section,
.cta-banner,
section.cta-banner,
.cta-banner-section .container,
.events-hero,
.about-hero {
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-navy-dark) 100%) !important;
  color: #fff !important;
  position: relative;
  overflow: hidden;
}
.cta-banner-section h2,
.cta-banner h2,
.cta-banner-section h1, .cta-banner h1,
.events-hero h1, .events-hero h2,
.about-hero h1, .about-hero h2 { color: #fff !important; }
.cta-banner-section h2 .accent, .cta-banner h2 .accent,
.cta-banner-section h2 em, .cta-banner h2 em,
.cta-banner-section h2 .display-italic,
.events-hero h1 .display-italic,
.about-hero h1 .display-italic { color: var(--color-red) !important; opacity: 1 !important; }
.cta-banner-section p, .cta-banner p,
.cta-banner-section .lede,
.events-hero p,
.about-hero p { color: rgba(255,255,255,0.82) !important; }
.cta-banner-section a:not(.btn), .cta-banner a:not(.btn) { color: #fff !important; }
.cta-banner-section .eyebrow, .cta-banner .eyebrow,
.events-hero .eyebrow,
.about-hero .eyebrow {
  background: rgba(208,2,27,0.18) !important;
  border: 1px solid rgba(208,2,27,0.42) !important;
  color: #fff !important;
  display: inline-block;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
}
.cta-banner-section .eyebrow::before, .cta-banner .eyebrow::before {
  background: var(--color-red) !important;
  box-shadow: 0 0 10px var(--color-red) !important;
}
/* Decorative glow on dark sections */
.cta-banner-section::before, .cta-banner::before,
.events-hero::before, .about-hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 18% 24%, rgba(208,2,27,0.20), transparent 50%),
    radial-gradient(circle at 82% 76%, rgba(255,255,255,0.06), transparent 50%);
  pointer-events: none;
}
.cta-banner-section > *, .cta-banner > *,
.events-hero > *, .about-hero > * { position: relative; z-index: 1; }

/* Online Check-In link on dark CTA banner — make white text-only readable */
.cta-banner-section a.btn--ghost, .cta-banner a.btn--ghost {
  color: #fff !important;
  border-color: rgba(255,255,255,0.4) !important;
  background: transparent !important;
}
.cta-banner-section a.btn--ghost:hover, .cta-banner a.btn--ghost:hover {
  background: rgba(255,255,255,0.10) !important;
  border-color: #fff !important;
}

/* === ISSUE 7: Location page hero — sane sizes + visible illustration === */
.location-hero h1 {
  font-size: clamp(36px, 5.5vw, 60px) !important;
  line-height: 1.05 !important;
  margin: 14px 0 18px !important;
  letter-spacing: -0.02em;
}
.location-hero__grid {
  grid-template-columns: 1.1fr 0.9fr !important;
  gap: 48px !important;
  align-items: center !important;
}
.location-hero__visual {
  aspect-ratio: 4/3 !important;
  border-radius: 22px !important;
  overflow: hidden;
  box-shadow: var(--shadow-md);
  background: var(--bg-soft);
}
.location-hero__visual img,
.location-hero__visual picture {
  width: 100% !important;
  height: 100% !important;
  display: block;
  object-fit: cover !important;
}
.location-hero__visual picture img { object-fit: cover !important; }
@media (max-width: 900px) {
  .location-hero__grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .location-hero h1 { font-size: clamp(32px, 7vw, 44px) !important; }
}

/* === ISSUE 5: Mobile menu — full width, no clipping === */
.mobile-menu {
  width: 100% !important;
  max-width: 100% !important;
  padding: 24px !important;
  padding-top: calc(var(--nav-height, 84px) + 24px) !important;
}
.mobile-menu nav { width: 100%; }
.mobile-menu ul {
  list-style: none; padding: 0; margin: 0 0 24px;
  display: flex; flex-direction: column; gap: 4px;
}
.mobile-menu li { width: 100%; }
.mobile-menu a {
  display: block;
  padding: 14px 0;
  font-size: 18px;
  font-weight: 500;
  color: var(--color-navy) !important;
  text-decoration: none;
  border-bottom: 1px solid var(--border);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mobile-menu a:hover { color: var(--color-red) !important; }
.mobile-menu .btn { width: 100%; justify-content: center; }

/* === ISSUE 2: Homepage FAQ — reduce h2 size, polish === */
.section .section-header h2,
section h2.faq-section-heading,
section .reveal h2 {
  font-size: clamp(28px, 4vw, 44px) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.02em;
}

/* Plus FAQ item (homepage uses .faq__item, FAQ page uses .faq-item) — unify */
.faq__item, .faq-item {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  margin: 0 0 12px;
  overflow: hidden;
  transition: border-color 240ms, box-shadow 240ms;
}
.faq__item:hover, .faq-item:hover { border-color: var(--border-strong) !important; box-shadow: var(--shadow-sm); }
.faq__item[open], .faq-item[open] { border-color: var(--color-navy) !important; }
.faq__q, .faq-item summary {
  display: flex !important; align-items: center !important; justify-content: space-between !important;
  padding: 22px 24px !important;
  cursor: pointer;
  font-family: var(--font-display, 'Fraunces', serif) !important;
  font-size: 18px !important;
  line-height: 1.3 !important;
  color: var(--color-navy) !important;
  font-weight: 600 !important;
  list-style: none;
}
.faq__q::marker, .faq-item summary::marker,
.faq__q::-webkit-details-marker, .faq-item summary::-webkit-details-marker { display: none !important; }
.faq__q::after, .faq-item summary::after {
  content: "" !important; flex-shrink: 0;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--color-red-light);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23D0021B' stroke-width='3' stroke-linecap='round'><line x1='12' y1='5' x2='12' y2='19'/><line x1='5' y1='12' x2='19' y2='12'/></svg>");
  background-repeat: no-repeat; background-position: center;
  transition: transform 320ms cubic-bezier(0.65,0,0.35,1), background-color 320ms;
}
.faq__item[open] .faq__q::after, .faq-item[open] summary::after {
  transform: rotate(45deg) !important; background-color: var(--color-red) !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='3' stroke-linecap='round'><line x1='12' y1='5' x2='12' y2='19'/><line x1='5' y1='12' x2='19' y2='12'/></svg>") !important;
}
.faq__a, .faq-item__body {
  padding: 0 24px 24px !important;
  color: var(--text-muted) !important;
  font-size: 15.5px !important;
  line-height: 1.7 !important;
  text-align: justify;
  border-top: 1px solid var(--border);
  padding-top: 18px !important;
}

/* === ISSUE 1: Insurance page logos — proper grid === */
.insurance-list,
section .insurance-section ul,
.container ul.insurance-logos,
section.insurance-page .insurance-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 18px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 32px 0 !important;
}
.insurance-list li,
.insurance-grid .ins-card {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 22px 24px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--color-navy) !important;
  list-style: none !important;
  margin: 0 !important;
  text-align: left !important;
  transition: transform 240ms, box-shadow 240ms, border-color 240ms;
  position: relative;
  padding-left: 56px !important;
}
.insurance-list li::before {
  content: "";
  position: absolute;
  left: 18px; top: 50%;
  transform: translateY(-50%);
  width: 24px; height: 24px;
  background: var(--color-red-light);
  border-radius: 6px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23D0021B' stroke-width='3' stroke-linecap='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-repeat: no-repeat; background-position: center;
}
.insurance-list li:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-navy) !important;
}

/* === ISSUE 6: Event card images that 404 — swap with stable photos === */
/* (We'll fix the URLs in HTML — CSS just ensures the image area always renders something) */
.event-card__image {
  background: linear-gradient(135deg, var(--color-navy-light), var(--color-red-light)) !important;
}
.event-card__image img {
  background: var(--bg-soft);
}

/* === Hero CTA section global polish === */
.cta-banner-section, section.cta-banner {
  padding: 96px 0 !important;
  text-align: center;
}
.cta-banner-section .container, .cta-banner .container {
  max-width: 820px;
  margin: 0 auto;
}
.cta-banner-section .btn--emergency, .cta-banner .btn--emergency {
  background: var(--color-red) !important;
  color: #fff !important;
  font-size: 17px !important;
  padding: 18px 36px !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 24px rgba(208,2,27,0.4) !important;
}

/* === Heading sizes globally clamped (mobile too) === */
h1 { font-size: clamp(32px, 4.5vw, 56px); }
section h2 { font-size: clamp(28px, 4vw, 44px); }

/* === Final small-screen fixes for mobile menu nav-toggle === */
.nav__toggle {
  width: 44px; height: 44px;
  background: transparent;
  border: 1px solid var(--border-strong);
  border-radius: 10px;
  cursor: pointer;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
.nav__toggle span {
  display: block;
  width: 22px; height: 2px;
  background: var(--color-navy);
  border-radius: 1px;
  transition: transform 280ms, opacity 280ms;
}

/* ============================================================
   v3.2 — FULL RESPONSIVE OPTIMIZATION PASS
   Mobile-first refinements for homepage, service, location,
   and all template pages. Touch targets, no horizontal scroll,
   fluid type, smarter stacking.
   ============================================================ */

/* === GLOBAL: prevent any horizontal overflow === */
html, body { overflow-x: hidden; max-width: 100vw; }
img, video, iframe { max-width: 100%; }
* { box-sizing: border-box; min-width: 0; }
.container { width: min(100% - 32px, 1200px); margin-inline: auto; padding-left: 0; padding-right: 0; }
@media (max-width: 720px) { .container { width: calc(100% - 24px); } }

/* === HERO: hide floating decorative cards on mobile (they cause clipping) === */
@media (max-width: 720px) {
  .hero__floating-card { display: none !important; }
  .hero { padding: 40px 0 56px !important; }
  .hero__grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .hero h1 { font-size: clamp(34px, 9vw, 48px) !important; line-height: 1.05 !important; }
  .hero__copy p { font-size: 16px !important; line-height: 1.55 !important; text-align: left !important; }
  .hero__cta { flex-direction: column; gap: 10px; align-items: stretch; }
  .hero__cta .btn { width: 100%; justify-content: center; }
  .hero__visual { aspect-ratio: 4/3 !important; max-width: 100%; }
  .hero-scan__hud { display: none; }
  .ecg-strip { display: none; }
  .hero-scan__corner { display: none; }
}

/* === GENERAL: fluid headings, padding === */
@media (max-width: 720px) {
  h1, .page-hero h1 { font-size: clamp(28px, 7vw, 40px) !important; line-height: 1.1 !important; }
  h2, section h2 { font-size: clamp(24px, 6vw, 36px) !important; line-height: 1.15 !important; }
  h3, section h3 { font-size: clamp(20px, 5vw, 26px) !important; }
  .section, section.section { padding: 48px 0 !important; }
  .page-hero { padding: 56px 0 36px !important; }
  .container > * + *,
  section + section { margin-top: 0; }
}

/* === EMERGENCY BAR: stack & shrink on mobile === */
@media (max-width: 720px) {
  .emergency-bar { font-size: 11.5px !important; }
  .emergency-bar__inner { padding: 7px 12px !important; gap: 10px !important; flex-wrap: wrap; justify-content: center; }
  .emergency-bar__inner > *:nth-child(3) { display: none; }
}

/* === NAV: tidy mobile === */
@media (max-width: 720px) {
  .nav { padding: 8px 0; }
  .nav__inner { gap: 8px !important; }
  .logo__img { width: 36px !important; height: 36px !important; }
  .logo > span.logo-wordmark { font-size: 15px !important; }
  .logo .logo-wordmark small { font-size: 8px !important; letter-spacing: 0.14em; }
  .nav__cta { gap: 6px !important; }
  .nav__cta .btn--ghost { display: none !important; }
  .nav__cta .btn--emergency.btn--sm {
    font-size: 12.5px !important;
    padding: 7px 10px !important;
  }
  .nav__cta .btn--emergency.btn--sm svg { width: 14px; height: 14px; }
}
@media (max-width: 380px) {
  .logo > span.logo-wordmark { font-size: 13px !important; }
  .logo .logo-wordmark small { font-size: 7px !important; }
}

/* === SERVICE PAGE: stack on mobile, TOC becomes inline === */
.service-layout__grid { display: grid; grid-template-columns: 240px 1fr; gap: 48px; padding: 48px 0; }
.service-layout__side { position: sticky; top: 100px; align-self: start; }
.service-layout__main { min-width: 0; }
.service-layout__main h2 {
  font-family: var(--font-display, serif);
  font-size: clamp(26px, 3.5vw, 36px);
  line-height: 1.1; letter-spacing: -0.02em;
  margin: 40px 0 16px;
  color: var(--color-navy);
}
.service-layout__main h2:first-child { margin-top: 0; }
.service-layout__main h3 { font-size: clamp(20px, 2.5vw, 24px); color: var(--color-navy); margin: 28px 0 12px; }
.service-layout__main p, .service-layout__main li {
  font-size: 16.5px; line-height: 1.7; color: var(--text);
  text-align: justify; hyphens: auto;
}
.service-layout__main li { text-align: left; margin-bottom: 8px; }
.service-layout__main ul, .service-layout__main ol { padding-left: 22px; margin: 0 0 22px; }

.toc {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px;
}
.toc h6, .toc__title {
  font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--color-red); font-weight: 700;
  margin: 0 0 14px;
}
.toc ol, .toc ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.toc a {
  display: block;
  font-size: 14px;
  color: var(--text-muted);
  text-decoration: none;
  padding: 8px 10px;
  border-radius: 8px;
  border-left: 2px solid transparent;
  transition: all 200ms ease;
}
.toc a:hover, .toc a.is-active { color: var(--color-navy); background: #fff; border-left-color: var(--color-red); }

@media (max-width: 980px) {
  .service-layout__grid { grid-template-columns: 1fr !important; gap: 24px; padding: 32px 0; }
  .service-layout__side { position: static !important; order: -1; }
  .toc { padding: 16px; }
  .toc ol, .toc ul {
    flex-direction: row; flex-wrap: wrap; gap: 6px;
  }
  .toc a { padding: 6px 12px; border-left: none; border: 1px solid var(--border); border-radius: 999px; font-size: 13px; }
  .toc a.is-active, .toc a:hover { background: var(--color-navy); color: #fff; border-color: var(--color-navy); }
}
@media (max-width: 720px) {
  .service-layout__main h2 { font-size: clamp(22px, 5.5vw, 28px) !important; margin: 28px 0 12px !important; }
  .service-layout__main p, .service-layout__main li { font-size: 15.5px !important; }
}

/* Service page treatment cards / condition lists === */
.treatment-grid, .conditions-grid, .symptom-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}
@media (max-width: 480px) {
  .treatment-grid, .conditions-grid, .symptom-grid { grid-template-columns: 1fr; }
}

/* === LOCATION PAGE: stack content sections on mobile === */
@media (max-width: 720px) {
  .location-hero { padding: 36px 0 24px !important; }
  .location-hero__visual { aspect-ratio: 16/10 !important; max-height: 240px; }
  .location-hero h1 { font-size: clamp(28px, 7vw, 38px) !important; margin: 10px 0 14px !important; }
  .location-hero p.page-hero__lede { font-size: 15.5px !important; line-height: 1.55; }
  .hero__meta { flex-direction: column !important; align-items: flex-start !important; gap: 6px !important; font-size: 14px; }
  .location-modern { padding: 56px 0 !important; }
  .location-modern__wrap { grid-template-columns: 1fr !important; gap: 28px !important; }
  .location-modern__map, .location-modern__map iframe { min-height: 280px !important; }
  .location-modern__info h2 { font-size: clamp(24px, 5.5vw, 30px) !important; }
  .location-modern__facts { grid-template-columns: 1fr !important; }
  .location-modern__cta { flex-direction: column; }
  .location-modern__cta .btn { width: 100%; }
  .feature-grid { grid-template-columns: 1fr !important; gap: 12px; }
  .pill-row { gap: 8px; }
  .pill { font-size: 12.5px; padding: 7px 12px; }
  .article-section, section.article-section { padding: 36px 0; }
}

/* === HOMEPAGE service grid + location grid === */
@media (max-width: 720px) {
  .svc-grid, .grid-3, .grid-4 { grid-template-columns: 1fr !important; gap: 14px; }
  .svc-card { padding: 22px; }
  .svc-card h3 { font-size: 19px; }
  .grid-2 { grid-template-columns: 1fr !important; gap: 14px !important; }

  .feature-card { padding: 24px 22px; }
  .feature-card h5 { font-size: 19px; }
  .feature-card p { font-size: 14.5px; }

  .locations-grid, .locations-grid--big { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
  .location-tile { padding: 16px; }
  .location-tile__city { font-size: 18px !important; }
  .location-tile__state { font-size: 10px !important; }
  .location-tile__distance { font-size: 10.5px; padding: 3px 8px; top: 14px; right: 14px; }
  .location-tile p { font-size: 12.5px; }
  .location-tile__actions { gap: 6px; }
  .location-tile__actions a { font-size: 12px; padding: 6px 10px; }
}
@media (max-width: 420px) {
  .locations-grid, .locations-grid--big { grid-template-columns: 1fr !important; }
}

/* === TRUST STRIP / STATS === */
@media (max-width: 720px) {
  .trust-strip { padding: 32px 0 !important; }
  .trust-strip__grid { grid-template-columns: repeat(2, 1fr) !important; gap: 20px !important; }
  .trust-stat__num, .stat .num { font-size: clamp(28px, 7vw, 40px) !important; }
  .trust-stat__label { font-size: 11px !important; }
}

/* === PROCESS / SPLIT SECTIONS === */
@media (max-width: 720px) {
  .split-section { grid-template-columns: 1fr !important; padding: 48px 0 !important; gap: 28px !important; }
  .split-image { aspect-ratio: 16/10 !important; max-height: 280px !important; }
  .process-list { margin-top: 16px; }
  .process-step { grid-template-columns: 44px 1fr !important; gap: 12px; padding: 14px 0; }
  .process-step__num { font-size: 22px; }
  .process-step h5 { font-size: 17px; }
  .process-step p { font-size: 14.5px; }
}

/* === TESTIMONIALS / REVIEWS === */
@media (max-width: 720px) {
  .testimonial { padding: 24px 22px; }
  .testimonial__quote { font-size: 17px; line-height: 1.5; }
  .reviews-grid { grid-template-columns: 1fr !important; gap: 14px; }
  .review-card { padding: 22px; }
  .review-stats-bar { grid-template-columns: repeat(2, 1fr) !important; gap: 12px; }
}

/* === DOCTORS / CAREERS / EVENTS GRIDS === */
@media (max-width: 720px) {
  .doctors-grid, .careers-grid, .events-grid {
    grid-template-columns: 1fr !important; gap: 14px;
  }
  .event-card__body, .doctor-card__body, .career-card { padding: 22px; }
  .event-card h3, .doctor-card__name, .career-card__title { font-size: 19px; }
}

/* === INSURANCE MARQUEE === */
@media (max-width: 720px) {
  .insurance-marquee { padding: 48px 0 !important; }
  .insurance-marquee__head h2 { font-size: clamp(24px, 6vw, 32px) !important; }
  .ins-logo { width: 150px !important; height: 70px !important; padding: 10px 14px !important; }
  .marquee { gap: 14px !important; }
  .marquee__viewport { gap: 14px !important; }
}

/* === SOCIAL ICONS GRID === */
@media (max-width: 720px) {
  .social-section { padding: 48px 0 !important; }
  .social-section h2 { font-size: clamp(24px, 6vw, 32px) !important; }
  .social-grid { gap: 12px !important; }
  .social-icon { width: 52px !important; height: 52px !important; }
  .social-icon svg { width: 22px !important; height: 22px !important; }
}

/* === FAQ === */
@media (max-width: 720px) {
  .faq-categories { gap: 6px; margin: 16px 0 22px; }
  .faq-cat { padding: 8px 13px; font-size: 12.5px; }
  .faq-item summary, .faq__q { padding: 18px 18px !important; font-size: 16px !important; }
  .faq-item summary::after, .faq__q::after { width: 28px !important; height: 28px !important; }
  .faq-item__body, .faq__a { padding: 0 18px 20px !important; font-size: 14.5px !important; }
}

/* === BLOG CARDS === */
@media (max-width: 720px) {
  .blog-grid { grid-template-columns: 1fr !important; gap: 18px; }
  .blog-card__body { padding: 22px; }
  .blog-card h4 { font-size: 20px; }
}

/* === CONTACT GRID === */
@media (max-width: 720px) {
  .contact-grid { gap: 14px !important; }
  .contact-card { grid-template-columns: 1fr !important; text-align: left; padding: 22px !important; gap: 14px !important; }
  .contact-card__title { font-size: 22px !important; }
  .contact-card__cta { justify-self: stretch !important; text-align: center; width: 100%; }
  .contact-card__icon { width: 44px !important; height: 44px !important; }
}

/* === MODERN LOCATION (homepage section) === */
@media (max-width: 720px) {
  .location-modern__map { min-height: 240px; }
  .location-modern__map iframe { min-height: 240px !important; }
  .location-modern__map-overlay { top: 12px !important; left: 12px !important; padding: 10px 12px !important; }
  .location-modern__overlay-text strong { font-size: 14px; }
  .location-modern__overlay-text span { font-size: 11px; }
  .location-modern__pin { width: 36px !important; height: 36px !important; }
  .location-modern__map-actions { bottom: 12px !important; left: 12px !important; right: 12px !important; flex-direction: column; gap: 8px; }
  .location-modern__map-actions .btn { width: 100%; }
}

/* === ABOUT page === */
@media (max-width: 720px) {
  .about-hero { padding: 56px 0 !important; }
  .about-hero h1 { font-size: clamp(30px, 7.5vw, 40px) !important; }
  .about-hero p { font-size: 15.5px !important; }
  .about-mv { grid-template-columns: 1fr !important; padding: 48px 0 !important; gap: 16px !important; }
  .about-mv__card { padding: 28px !important; }
  .about-mv__card h3 { font-size: 24px !important; }
  .about-stats { padding: 40px 0 !important; }
  .about-stats__grid { grid-template-columns: repeat(2, 1fr) !important; gap: 20px !important; }
  .about-stat__num { font-size: clamp(28px, 7vw, 38px) !important; }
  .about-stat__label { font-size: 11px !important; }
}

/* === CTA banner === */
@media (max-width: 720px) {
  .cta-banner-section, section.cta-banner { padding: 56px 0 !important; }
  .cta-banner-section h2, .cta-banner h2 { font-size: clamp(26px, 6.5vw, 36px) !important; }
  .cta-banner-section p, .cta-banner p { font-size: 14.5px !important; }
  .cta-banner-section .btn--emergency, .cta-banner .btn--emergency { font-size: 15px !important; padding: 14px 26px !important; width: 100%; }
}

/* === FLOATING CTA === */
@media (max-width: 720px) {
  .floating-cta { right: 14px !important; bottom: 16px !important; gap: 8px !important; }
  .floating-cta a, .floating-cta button, .floating-cta .chatbot-toggle { width: 48px !important; height: 48px !important; }
  .floating-cta a svg, .floating-cta button svg, .floating-cta .chatbot-toggle svg { width: 20px !important; height: 20px !important; }
}

/* === FOOTER === */
@media (max-width: 720px) {
  .footer { padding: 48px 0 24px !important; }
  .footer__top { grid-template-columns: 1fr !important; gap: 28px !important; }
  .footer__col h6 { font-size: 12px; margin-bottom: 10px; }
  .footer__col ul li { padding: 4px 0; }
  .footer__bottom { flex-direction: column !important; gap: 12px; padding: 20px 0; text-align: center; font-size: 12.5px; }
  .footer__social { gap: 10px !important; padding: 22px 0 18px !important; }
  .footer-social-icon { width: 32px !important; height: 32px !important; }
  .footer-social-icon svg { width: 14px !important; height: 14px !important; }
}

/* === BREADCRUMBS === */
@media (max-width: 720px) {
  .breadcrumbs { font-size: 12.5px; padding: 12px 0; flex-wrap: wrap; }
}

/* === Touch targets — minimum 44x44 for all interactive === */
.btn, button, a.btn { min-height: 44px; }
.nav__menu a, .mobile-menu a, .footer a { min-height: 36px; display: inline-flex; align-items: center; }
.footer ul a { min-height: 32px; }

/* === Tablet (721-980px) tightening === */
@media (min-width: 721px) and (max-width: 980px) {
  .container { width: min(100% - 40px, 1200px); }
  .hero__grid { grid-template-columns: 1fr 0.85fr; gap: 32px; }
  .locations-grid--big { grid-template-columns: repeat(3, 1fr) !important; }
  .svc-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .reviews-grid, .doctors-grid, .careers-grid, .events-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* === Desktop (>=1101px) — keep clean wide layouts === */
@media (min-width: 1101px) {
  .locations-grid--big { grid-template-columns: repeat(4, 1fr); }
  .svc-grid { grid-template-columns: repeat(3, 1fr); }
}

/* === Smooth section transitions === */
section { scroll-margin-top: 100px; }

/* === Print clean-up (just in case) === */
@media print {
  .nav, .floating-cta, .chatbot-toggle, .emergency-bar, .mobile-menu, .insurance-marquee, .social-section { display: none !important; }
  body { background: #fff; color: #000; }
}

/* === Tighten very-large screens (>1600px) so content doesn't stretch too far === */
@media (min-width: 1600px) {
  .container { max-width: 1280px; }
}

/* ============================================================
   v3.3 — Homepage polish
   ============================================================ */

/* Soft-bg section variant */
.section--soft { background: var(--bg-soft); }

/* Conditions extra header */
.conditions-extra { margin-top: 64px; }
.conditions-extra h5 {
  font-family: var(--font-display, serif);
  font-size: clamp(18px, 2.5vw, 22px);
  color: var(--color-navy);
  margin: 0 0 24px;
  font-weight: 600;
}

/* Location-modern header — centered intro */
.location-modern__header {
  text-align: center;
  margin-bottom: 48px;
}
.location-modern__header h2 {
  font-family: var(--font-display, serif);
  font-size: clamp(32px, 5vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 12px 0 0;
}

/* Insurance note in location-modern info column */
.location-modern__insurance-note {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 18px 20px;
  margin-top: 12px;
  background: var(--color-navy-light);
  border: 1px solid var(--border);
  border-radius: 14px;
  border-left: 4px solid var(--color-red);
}
.location-modern__insurance-note strong {
  font-family: var(--font-display, serif);
  font-size: 16px;
  color: var(--color-navy);
}
.location-modern__insurance-note span {
  font-size: 14px;
  color: var(--text-muted);
  line-height: 1.55;
}
.location-modern__insurance-note a {
  color: var(--color-red);
  font-weight: 600;
}

/* Footer polish — 5 columns now */
.footer__top {
  grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
}
@media (max-width: 1100px) {
  .footer__top {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 720px) {
  .footer__top {
    grid-template-columns: 1fr 1fr !important;
  }
  .footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 480px) {
  .footer__top {
    grid-template-columns: 1fr !important;
  }
}

/* Footer social — center always */
.footer__social {
  display: flex !important;
  justify-content: center;
  gap: 14px;
  padding: 32px 0 24px;
  border-top: 1px solid rgba(255,255,255,0.08);
  margin-top: 32px;
  flex-wrap: wrap;
}

/* Footer bottom — legal links spaced */
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.08);
  margin-top: 8px;
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  flex-wrap: wrap;
  gap: 14px;
}
.footer__legal {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
}
.footer__legal a {
  color: rgba(255,255,255,0.65) !important;
  font-size: 13px;
  transition: color 200ms;
}
.footer__legal a:hover {
  color: #fff !important;
}
@media (max-width: 560px) {
  .footer__bottom {
    flex-direction: column;
    text-align: center;
    gap: 12px;
  }
  .footer__legal {
    justify-content: center;
    gap: 16px;
  }
}

/* Process step number circles (replaces roman numerals) */
.process-step__num {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: var(--color-red-light) !important;
  color: var(--color-red) !important;
  display: grid !important;
  place-items: center !important;
  font-family: var(--font-display, serif) !important;
  font-size: 20px !important;
  font-style: normal !important;
  font-weight: 700 !important;
  flex-shrink: 0;
  border: 2px solid var(--color-red);
}

/* Eyebrow centered helper */
.eyebrow[style*="justify-content:center"]::before {
  display: none;
}
/* Footer — kill empty space, tighten rhythm */
.footer {
  padding: 64px 0 24px !important;
}
.footer__top {
  padding-bottom: 40px !important;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  align-items: start;
}
.footer__brand p {
  margin-bottom: 16px !important;
  max-width: 320px;
}
.footer__address {
  font-style: normal;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.72);
}
.footer__address strong {
  color: #fff !important;
  display: block;
  margin-bottom: 4px;
  font-weight: 600;
  font-size: 14px;
}
.footer__social {
  padding: 24px 0 !important;
  margin-top: 0 !important;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.footer__bottom {
  margin-top: 0 !important;
  padding-top: 20px !important;
}
/* ============================================================
   "Full coverage map" tile — final visible fix
   ============================================================ */
.location-tile.location-tile--all,
a.location-tile.location-tile--all {
  background: var(--color-navy) !important;
  color: #fff !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: 8px !important;
  padding: 22px 24px 24px !important;
  position: relative !important;
  overflow: visible !important;
  min-height: 140px;
}

/* Pill at top */
.location-tile--all .location-tile__state {
  position: static !important;
  display: inline-flex !important;
  align-self: flex-start !important;
  background: rgba(255,255,255,0.14) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
  padding: 4px 11px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  margin: 0 !important;
  width: auto !important;
  height: auto !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  bottom: auto !important;
}

/* "15+ Areas" heading */
.location-tile--all .location-tile__city {
  position: static !important;
  color: #fff !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--font-display, 'Fraunces', serif) !important;
  font-size: 28px !important;
  line-height: 1.05 !important;
}

/* "Full coverage map →" line at the bottom — most important fix */
.location-tile--all .location-tile__distance {
  all: unset;
  position: static !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: rgba(255,255,255,0.85) !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  margin-top: auto !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  white-space: normal !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  width: auto !important;
  height: auto !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  bottom: auto !important;
}

.location-tile--all:hover {
  background: var(--color-navy-dark) !important;
  transform: translateY(-3px);
}
.location-tile--all:hover .location-tile__city,
.location-tile--all:hover .location-tile__state,
.location-tile--all:hover .location-tile__distance {
  color: inherit;
}
/* ============================================================
   MOBILE SECTION SPACING — kill the gap between split sections
   ============================================================ */
@media (max-width: 720px) {
  /* Tighten the main section wrapper */
  .section,
  section.section {
    padding: 32px 0 !important;
  }
  
  /* Split section has its own padding from v3.2 — kill it */
  .split-section,
  section.section .split-section {
    padding: 0 !important;
    margin: 0 !important;
    gap: 20px !important;
  }
  
  /* The split-image had aspect-ratio 4/5 making it tall — make it shorter */
  .split-section .split-image {
    aspect-ratio: 16/11 !important;
    max-height: 260px !important;
    margin: 0 !important;
  }
  .split-section .split-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  
  /* Ensure no margin on first/last children of split sections */
  .split-section > *:first-child { margin-top: 0 !important; }
  .split-section > *:last-child { margin-bottom: 0 !important; }
  .split-section .reveal > *:first-child { margin-top: 0 !important; }
  .split-section .reveal > *:last-child { margin-bottom: 0 !important; }
  
  /* The h2 and lede inside split-sections — tighter spacing */
  .split-section h2 {
    margin: 0 0 12px !important;
    font-size: clamp(24px, 6vw, 30px) !important;
    line-height: 1.1 !important;
  }
  .split-section .lede,
  .split-section > div > p {
    margin: 0 0 18px !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
  }
  
  /* "What to expect" eyebrow + feature grid inside should be tight */
  .split-section .eyebrow {
    margin-bottom: 8px !important;
  }
  .split-section .grid {
    gap: 12px !important;
  }
  
  /* Section--soft (the gray "How a visit works" background) — tighter */
  .section--soft {
    padding: 32px 0 !important;
  }
  
  /* Process-list inside split-section — tighter */
  .process-list {
    margin: 0 !important;
  }
  .process-step {
    padding: 12px 0 !important;
  }
}

/* Phone — even tighter */
@media (max-width: 480px) {
  .section,
  section.section,
  .section--soft {
    padding: 28px 0 !important;
  }
  .split-section .split-image {
    max-height: 220px !important;
  }
  .split-section {
    gap: 16px !important;
  }
}
/* ============================================================
   v3.3 — HOMEPAGE POLISH (consolidated)
   ============================================================ */

/* Soft-bg section variant */
.section--soft { background: var(--bg-soft); }

/* Conditions extra header */
.conditions-extra { margin-top: 64px; }
.conditions-extra h5 {
  font-family: var(--font-display, serif);
  font-size: clamp(18px, 2.5vw, 22px);
  color: var(--color-navy);
  margin: 0 0 24px;
  font-weight: 600;
}

/* Location-modern centered header */
.location-modern__header {
  text-align: center;
  margin-bottom: 48px;
}
.location-modern__header h2 {
  font-family: var(--font-display, serif);
  font-size: clamp(32px, 5vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 12px 0 0;
}

/* Insurance note card in location-modern */
.location-modern__insurance-note {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 18px 20px;
  margin-top: 12px;
  background: var(--color-navy-light);
  border: 1px solid var(--border);
  border-radius: 14px;
  border-left: 4px solid var(--color-red);
}
.location-modern__insurance-note strong {
  font-family: var(--font-display, serif);
  font-size: 16px;
  color: var(--color-navy);
}
.location-modern__insurance-note span {
  font-size: 14px;
  color: var(--text-muted);
  line-height: 1.55;
}
.location-modern__insurance-note a {
  color: var(--color-red);
  font-weight: 600;
}

/* Process step number circles */
.process-step__num {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: var(--color-red-light) !important;
  color: var(--color-red) !important;
  display: grid !important;
  place-items: center !important;
  font-family: var(--font-display, serif) !important;
  font-size: 20px !important;
  font-style: normal !important;
  font-weight: 700 !important;
  flex-shrink: 0;
  border: 2px solid var(--color-red);
}

/* "Full coverage map" tile — visible content */
.location-tile.location-tile--all,
a.location-tile.location-tile--all {
  background: var(--color-navy) !important;
  color: #fff !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: 8px !important;
  padding: 22px 24px 24px !important;
  position: relative !important;
  overflow: visible !important;
  min-height: 140px;
}
.location-tile--all .location-tile__state {
  position: static !important;
  display: inline-flex !important;
  align-self: flex-start !important;
  background: rgba(255,255,255,0.14) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
  padding: 4px 11px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  margin: 0 !important;
  width: auto !important;
  height: auto !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  bottom: auto !important;
}
.location-tile--all .location-tile__city {
  position: static !important;
  color: #fff !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--font-display, 'Fraunces', serif) !important;
  font-size: 28px !important;
  line-height: 1.05 !important;
}
.location-tile--all .location-tile__distance {
  all: unset;
  position: static !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: rgba(255,255,255,0.85) !important;
  font-family: var(--font-body, 'Manrope', sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  margin-top: auto !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  white-space: normal !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  width: auto !important;
  height: auto !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  bottom: auto !important;
}
.location-tile--all:hover {
  background: var(--color-navy-dark) !important;
  transform: translateY(-3px);
}

/* Footer phone — normal size, not giant italic */
.footer__phone {
  font-family: var(--font-body, 'Manrope', sans-serif);
  font-size: 16px;
  color: #fff;
  font-style: normal;
  display: inline-block;
  margin: 4px 0 0;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-decoration: none;
  transition: color 200ms;
}
.footer__phone:hover {
  color: var(--color-red) !important;
}

/* Footer social icons — visible on navy */
.footer-social-icon {
  width: 38px;
  height: 38px;
  display: grid !important;
  place-items: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.10) !important;
  color: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  transition: all 240ms cubic-bezier(0.34,1.56,0.64,1);
  text-decoration: none;
}
.footer-social-icon svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}
.footer-social-icon:hover {
  background: var(--color-red) !important;
  color: #fff !important;
  border-color: var(--color-red) !important;
  transform: translateY(-3px) scale(1.08);
  box-shadow: 0 6px 14px rgba(208,2,27,0.4);
}

/* Footer base — kill empty space */
.footer {
  padding: 64px 0 24px !important;
}
.footer__top {
  padding-bottom: 40px !important;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  align-items: start;
  grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
}
.footer__brand p {
  margin-bottom: 16px !important;
  max-width: 320px;
}
.footer__address {
  font-style: normal;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.72);
}
.footer__address strong {
  color: #fff !important;
  display: block;
  margin-bottom: 4px;
  font-weight: 600;
  font-size: 14px;
}
.footer__social {
  display: flex !important;
  justify-content: center;
  gap: 14px;
  padding: 24px 0 !important;
  margin-top: 0 !important;
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-wrap: wrap;
}
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 20px !important;
  margin-top: 0 !important;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  flex-wrap: wrap;
  gap: 14px;
}
.footer__legal {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
}
.footer__legal a {
  color: rgba(255,255,255,0.65) !important;
  font-size: 13px;
  transition: color 200ms;
}
.footer__legal a:hover {
  color: #fff !important;
}

/* Footer tablet breakpoint */
@media (max-width: 1100px) {
  .footer__top {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .footer__brand { grid-column: 1 / -1; }
}

/* ============================================================
   MOBILE — Tighter sections + 2-col footer + testimonial fix
   ============================================================ */
@media (max-width: 720px) {
  /* --- Section spacing — kill gap between stacked split sections --- */
  .section,
  section.section {
    padding: 32px 0 !important;
  }
  .split-section,
  section.section .split-section {
    padding: 0 !important;
    margin: 0 !important;
    gap: 20px !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .split-section .split-image {
    aspect-ratio: 16/11 !important;
    max-height: 260px !important;
    margin: 0 !important;
  }
  .split-section .split-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .split-section > *:first-child { margin-top: 0 !important; }
  .split-section > *:last-child { margin-bottom: 0 !important; }
  .split-section h2 {
    margin: 0 0 12px !important;
    font-size: clamp(24px, 6vw, 30px) !important;
    line-height: 1.1 !important;
  }
  .split-section .lede,
  .split-section > div > p {
    margin: 0 0 18px !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
  }
  .split-section .eyebrow { margin-bottom: 8px !important; }
  .split-section .grid { gap: 12px !important; }
  .section--soft { padding: 32px 0 !important; }
  .process-list { margin: 0 !important; }
  .process-step { padding: 12px 0 !important; }
  
  /* --- Testimonial cards --- */
  .testimonial {
    padding: 26px 22px !important;
    border-radius: 18px !important;
  }
  .testimonial__stars {
    position: static !important;
    display: flex !important;
    gap: 3px !important;
    margin: 0 0 16px !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    width: auto !important;
  }
  .testimonial__stars svg {
    width: 16px !important;
    height: 16px !important;
    fill: #F5B82E !important;
  }
  .testimonial::before,
  .testimonial::after,
  .testimonial__quote::before,
  .testimonial__quote::after {
    display: none !important;
    content: none !important;
  }
  .testimonial__quote {
    font-family: var(--font-body, 'Manrope', sans-serif) !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
    font-style: normal !important;
    font-weight: 400 !important;
    color: var(--text, #2a2a3e) !important;
    margin: 0 0 18px !important;
    padding: 0 !important;
    text-indent: 0 !important;
  }
  .testimonial__author {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding-top: 14px;
    border-top: 1px solid rgba(0,0,0,0.06);
  }
  .testimonial__avatar {
    width: 42px !important;
    height: 42px !important;
    flex-shrink: 0;
    font-size: 16px !important;
  }
  .testimonial__name,
  .testimonial__name-row {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--text, #2a2a3e) !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    flex-wrap: wrap;
  }
  .testimonial__role {
    font-size: 12.5px !important;
    color: var(--text-muted, #6b7280) !important;
    margin-top: 2px !important;
    line-height: 1.3 !important;
  }
  .verified-badge {
    width: 16px !important;
    height: 16px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--color-navy, #202060) !important;
    flex-shrink: 0;
  }
  .verified-badge svg {
    width: 100% !important;
    height: 100% !important;
    color: inherit !important;
    fill: currentColor !important;
  }
  .testimonial__verified-pill {
    display: none !important;
  }
  
  /* --- Footer 2-col mobile layout --- */
  .footer {
    padding: 36px 0 18px !important;
  }
  .footer__top {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 24px 20px !important;
    padding: 0 0 24px !important;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }
  .footer__brand {
    grid-column: 1 / -1 !important;
    text-align: left;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    margin-bottom: 4px;
  }
  .footer__brand .logo { margin-bottom: 12px; }
  .footer__brand p {
    font-size: 13px !important;
    line-height: 1.5 !important;
    max-width: none !important;
    margin: 0 0 12px !important;
    color: rgba(255,255,255,0.7) !important;
  }
  .footer__address {
    font-size: 12.5px !important;
    line-height: 1.5 !important;
    color: rgba(255,255,255,0.65) !important;
  }
  .footer__address strong {
    display: block;
    color: #fff !important;
    font-weight: 600;
    font-size: 13px !important;
    margin-bottom: 3px;
  }
  .footer__phone {
    font-size: 16px !important;
    color: #fff !important;
    font-style: normal !important;
    font-weight: 700 !important;
    font-family: var(--font-body, 'Manrope', sans-serif) !important;
    display: inline-block;
    margin-top: 6px !important;
  }
  .footer__col {
    min-width: 0;
    margin: 0 !important;
    padding: 0 !important;
  }
  .footer__col h6 {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #fff !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase;
    margin: 0 0 10px !important;
    padding: 0 !important;
  }
  .footer__col ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: block !important;
  }
  .footer__col li {
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
  }
  .footer__col a {
    font-size: 13px !important;
    color: rgba(255,255,255,0.7) !important;
    padding: 4px 0 !important;
    line-height: 1.4 !important;
    display: block !important;
    min-height: 0 !important;
    text-decoration: none;
  }
  .footer__col a:hover { color: #fff !important; }
  .footer__social {
    display: flex !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 18px 0 !important;
    margin: 0 !important;
    border-top: 1px solid rgba(255,255,255,0.08);
    flex-wrap: wrap;
  }
  .footer-social-icon {
    width: 34px !important;
    height: 34px !important;
  }
  .footer-social-icon svg {
    width: 14px !important;
    height: 14px !important;
  }
  .footer__bottom {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 10px !important;
    padding: 16px 0 0 !important;
    margin: 0 !important;
    border-top: 1px solid rgba(255,255,255,0.08);
    font-size: 11.5px !important;
    color: rgba(255,255,255,0.55) !important;
    line-height: 1.5;
  }
  .footer__legal {
    display: flex !important;
    justify-content: center !important;
    gap: 14px !important;
    flex-wrap: wrap;
  }
  .footer__legal a {
    font-size: 11.5px !important;
    color: rgba(255,255,255,0.6) !important;
    padding: 2px 0 !important;
    min-height: 0 !important;
  }
}

@media (max-width: 480px) {
  .section,
  section.section,
  .section--soft {
    padding: 28px 0 !important;
  }
  .split-section .split-image {
    max-height: 220px !important;
  }
  .split-section { gap: 16px !important; }
}

@media (max-width: 380px) {
  .footer__top {
    gap: 20px 16px !important;
  }
  .footer__col a {
    font-size: 12.5px !important;
  }
}
/* ============================================================
   NAV — Dropdown chevron indicator on items with submenus
   ============================================================ */

.nav__has-children > a {
  position: relative;
  display: inline-flex !important;
  align-items: center;
  gap: 5px;
}

.nav__has-children > a::after {
  content: "";
  display: inline-block;
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  transition: transform 240ms cubic-bezier(0.4, 0, 0.2, 1);
  opacity: 0.55;
  margin-left: 4px;
  flex-shrink: 0;
}

/* ============================================================
   NAV — Checkmark badge on left of items with submenus
   ============================================================ */

.nav__has-children > a::before {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  margin-right: 7px;
  background: var(--color-red);
  color: #fff;
  border-radius: 50%;
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  flex-shrink: 0;
  transition: transform 220ms cubic-bezier(0.34, 1.56, 0.64, 1),
              background 220ms ease;
}

/* Gentle pop on hover */
.nav__has-children:hover > a::before,
.nav__has-children:focus-within > a::before {
  transform: scale(1.15);
  background: var(--color-navy);
}

/* Hide checkmark on mobile — mobile menu shows flat list */
@media (max-width: 980px) {
  .nav__has-children > a::before {
    display: none !important;
  }
}
/* ============================================================
   MOBILE — Remove empty space above/below split-section images
   ============================================================ */
@media (max-width: 720px) {
  /* Tighter section padding so the image sits close to neighboring content */
  .section,
  section.section,
  .section--soft {
    padding: 14px 0 !important;
  }
  
  /* Kill any margin/padding around split-images and shrink gap between text + image */
  .split-section {
    gap: 10px !important;
  }
  .split-section .split-image {
    margin: 0 !important;
    padding: 0 !important;
  }
}

@media (max-width: 480px) {
  .section,
  section.section,
  .section--soft {
    padding: 12px 0 !important;
  }
}
/* ============================================================
   FINAL — Nuke ALL empty space around split-section images on mobile
   ============================================================ */
@media (max-width: 720px) {
  /* Section wrapper — almost zero vertical padding around split images */
  section.section:has(> .container > .split-section),
  section.section--soft:has(> .container > .split-section) {
    padding: 4px 0 !important;
  }
  
  /* Container around split-section — no extra space */
  .section > .container,
  section.section > .container {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  
  /* Split-section itself — flex column, zero outer space, tight gap */
  .split-section,
  .section .split-section,
  section .split-section,
  section.section .split-section,
  section.section--soft .split-section {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: 1fr !important;
    padding: 0 !important;
    margin: 0 !important;
    gap: 14px !important;
    align-items: stretch !important;
  }
  
  /* Force-strip space from direct children of split-section */
  .split-section > *,
  .split-section > .reveal,
  .split-section > .split-image {
    margin: 0 !important;
    padding: 0 !important;
  }
  
  /* The image container — compact, no extra height */
  .split-section .split-image {
    display: block !important;
    position: relative !important;
    aspect-ratio: 16/10 !important;
    max-height: 240px !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    border-radius: 14px !important;
  }
  
  /* The image element — fill the container completely */
  .split-section .split-image img,
  .split-section .split-image > img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: inherit !important;
  }
}

/* Fallback for browsers without :has() support — covers most mobile Safari/Chrome */
@media (max-width: 720px) {
  .section,
  section.section,
  .section--soft {
    padding-top: 4px !important;
    padding-bottom: 4px !important;
  }
}

@media (max-width: 480px) {
  .section,
  section.section,
  .section--soft {
    padding-top: 2px !important;
    padding-bottom: 2px !important;
  }
  .split-section .split-image {
    max-height: 200px !important;
    aspect-ratio: 16/9 !important;
  }
  .split-section { gap: 12px !important; }
}
/* ============================================================
   FINAL — Image fills entire grid cell (kills empty space
   above/below image on desktop & tablet 2-column layouts)
   ============================================================ */

@media (min-width: 721px) {
  .split-section {
    align-items: stretch !important;
  }
  .split-section .split-image,
  .split-section > .split-image {
    align-self: stretch !important;
    height: auto !important;
    max-height: none !important;
    aspect-ratio: auto !important;
    min-height: 100% !important;
    margin: 0 !important;
    display: block !important;
  }
  .split-section .split-image img,
  .split-section > .split-image > img {
    width: 100% !important;
    height: 100% !important;
    min-height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 !important;
  }
}
/* ============================================================
   Restore sticky nav — overflow-x: hidden on html/body was
   breaking position: sticky on descendants. overflow-x: clip
   prevents horizontal overflow without disabling sticky.
   ============================================================ */
html,
body {
  overflow-x: clip !important;
}
.nav {
  position: sticky !important;
  top: 0 !important;
  z-index: 100;
}
/* ============================================================
   Nav dropdown — invisible bridge so the menu stays open while
   moving the mouse from the parent link to the dropdown items
   (closes the 12px gap that was breaking hover state)
   ============================================================ */
.nav__has-children .nav__dropdown::before {
  content: "";
  position: absolute;
  top: -14px;
  left: 0;
  right: 0;
  height: 14px;
  background: transparent;
}

/* Slight delay before closing — gives a forgiving "intent" buffer */
.nav__has-children .nav__dropdown {
  transition: opacity .25s var(--ease-out),
              transform .25s var(--ease-out),
              visibility 0s linear .15s;
  visibility: hidden;
}
.nav__has-children:hover .nav__dropdown,
.nav__has-children:focus-within .nav__dropdown {
  visibility: visible;
  transition: opacity .25s var(--ease-out),
              transform .25s var(--ease-out),
              visibility 0s linear 0s;
}