/* =========================================================
   THE PERFORMANCE LAB — MVP
   Merged Variant A (dark editorial) + Variant B (data/report card)
   Utilitarian, field-manual palette. No fluff.
   ========================================================= */

:root {
  --ink:       #0a0a0a;        /* matte black base */
  --ink-2:     #111111;
  --ink-3:     #171715;
  --bone:      #EFEBDF;        /* warm paper — brightened */
  --bone-2:    #dcd7c5;        /* body text — brightened for contrast */
  --ash:       #8a867a;
  --ash-2:     #5a5750;
  --od:        #a8c449;        /* olive drab primary — brighter still */
  --od-d:      #708e2f;        /* deeper olive */
  --od-ink:    #3a481f;
  --rust:      #8B3A2B;        /* muted rust — sparingly */
  --amber:     #b87e2a;
  --hair:      rgba(232,228,216,0.12);
  --hair-hard: rgba(232,228,216,0.26);
  --maxw: 1280px;
  --pad:  clamp(16px, 3.5vw, 48px);

  --ff-display: "Barlow Condensed", "Barlow", "Oswald", "Arial Narrow", sans-serif;
  --ff-body:    "Barlow", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --ff-mono:    "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--ink);
  color: var(--bone);
  font-family: var(--ff-body);
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
}

/* ---------- TOPO OVERLAY (body-wide) ---------- */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.05;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='800' viewBox='0 0 800 800'><g fill='none' stroke='%23E8E4D8' stroke-width='0.6'><path d='M0,400 C120,340 220,460 340,400 C460,340 560,460 680,400 C760,370 800,410 800,400'/><path d='M0,420 C120,360 220,480 340,420 C460,360 560,480 680,420 C760,390 800,430 800,420'/><path d='M0,440 C120,380 220,500 340,440 C460,380 560,500 680,440 C760,410 800,450 800,440'/><path d='M0,380 C120,320 220,440 340,380 C460,320 560,440 680,380 C760,350 800,390 800,380'/><path d='M0,360 C120,300 220,420 340,360 C460,300 560,420 680,360 C760,330 800,370 800,360'/><path d='M0,460 C120,400 220,520 340,460 C460,400 560,520 680,460 C760,430 800,470 800,460'/><path d='M0,340 C120,280 220,400 340,340 C460,280 560,400 680,340 C760,310 800,350 800,340'/><path d='M0,480 C120,420 220,540 340,480 C460,420 560,540 680,480 C760,450 800,490 800,480'/><path d='M0,320 C120,260 220,380 340,320 C460,260 560,380 680,320 C760,290 800,330 800,320'/><path d='M0,500 C120,440 220,560 340,500 C460,440 560,560 680,500 C760,470 800,510 800,500'/><path d='M0,300 C120,240 220,360 340,300 C460,240 560,360 680,300 C760,270 800,310 800,300'/><path d='M0,520 C120,460 220,580 340,520 C460,460 560,580 680,520 C760,490 800,530 800,520'/><path d='M0,280 C120,220 220,340 340,280 C460,220 560,340 680,280 C760,250 800,290 800,280'/><path d='M0,540 C120,480 220,600 340,540 C460,480 560,600 680,540 C760,510 800,550 800,540'/><path d='M0,260 C120,200 220,320 340,260 C460,200 560,320 680,260 C760,230 800,270 800,260'/><path d='M0,560 C120,500 220,620 340,560 C460,500 560,620 680,560 C760,530 800,570 800,560'/><path d='M0,240 C120,180 220,300 340,240 C460,180 560,300 680,240 C760,210 800,250 800,240'/><path d='M0,580 C120,520 220,640 340,580 C460,520 560,640 680,580 C760,550 800,590 800,580'/><path d='M0,220 C120,160 220,280 340,220 C460,160 560,280 680,220 C760,190 800,230 800,220'/><path d='M0,600 C120,540 220,660 340,600 C460,540 560,660 680,600 C760,570 800,610 800,600'/><path d='M0,200 C120,140 220,260 340,200 C460,140 560,260 680,200 C760,170 800,210 800,200'/><path d='M0,620 C120,560 220,680 340,620 C460,560 560,680 680,620 C760,590 800,630 800,620'/><path d='M0,180 C120,120 220,240 340,180 C460,120 560,240 680,180 C760,150 800,190 800,180'/><path d='M0,640 C120,580 220,700 340,640 C460,580 560,700 680,640 C760,610 800,650 800,640'/><path d='M0,160 C120,100 220,220 340,160 C460,100 560,220 680,160 C760,130 800,170 800,160'/><path d='M0,660 C120,600 220,720 340,660 C460,600 560,720 680,660 C760,630 800,670 800,660'/><path d='M0,140 C120,80 220,200 340,140 C460,80 560,200 680,140 C760,110 800,150 800,140'/><path d='M0,680 C120,620 220,740 340,680 C460,620 560,740 680,680 C760,650 800,690 800,680'/><path d='M0,120 C120,60 220,180 340,120 C460,60 560,180 680,120 C760,90 800,130 800,120'/><path d='M0,700 C120,640 220,760 340,700 C460,640 560,760 680,700 C760,670 800,710 800,700'/></g></svg>");
  background-size: 800px 800px;
}

body > * { position: relative; z-index: 2; }

a { color: inherit; text-decoration: none; }
img, video { max-width: 100%; display: block; }

/* ---------- NAV ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  display: flex; align-items: center;
  padding: 16px var(--pad);
  gap: 28px;
  background: linear-gradient(180deg, rgba(10,10,10,0.9) 0%, rgba(10,10,10,0.55) 65%, rgba(10,10,10,0) 100%);
  backdrop-filter: blur(8px);
}
.mark { display: inline-flex; align-items: baseline; gap: 10px; }
.mark-num {
  font-family: var(--ff-mono); font-size: 11px; color: var(--od);
  letter-spacing: 0.2em; text-transform: uppercase;
}
.mark-name {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.01em;
}
.nav-links {
  display: flex; gap: 22px; margin-left: auto;
  font-family: var(--ff-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--bone-2);
}
.nav-links a { position: relative; padding: 6px 0; }
.nav-links a:hover { color: var(--od); }
.nav-links a:hover::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0;
  height: 1px; background: var(--od);
}
.nav-cta {
  font-family: var(--ff-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.16em;
  padding: 10px 14px;
  border: 1px solid var(--hair-hard);
  transition: background .2s, color .2s, border-color .2s;
}
.nav-cta:hover { background: var(--od); color: var(--ink); border-color: var(--od); }

.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 22px; height: 1px; background: var(--bone); margin: 5px 0; }

/* ---------- HERO ---------- */
.hero {
  position: relative; min-height: 100vh;
  display: flex; align-items: flex-end;
  overflow: hidden;
  padding-bottom: 32px;
}
.hero-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
  filter: grayscale(0.4) contrast(1.08) brightness(0.5);
}
.hero-scrim {
  position: absolute; inset: 0;
  background:
    radial-gradient(120% 80% at 30% 40%, rgba(10,10,10,0.35), rgba(10,10,10,0.75) 60%),
    linear-gradient(180deg, rgba(10,10,10,0.55) 0%, rgba(10,10,10,0.25) 45%, rgba(10,10,10,0.94) 100%);
  z-index: 1;
}
.topo {
  position: absolute; inset: 0; z-index: 2; pointer-events: none; opacity: 0.08;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400' viewBox='0 0 400 400'><g fill='none' stroke='%236b8238' stroke-width='0.7'><path d='M0,200 C60,170 110,230 170,200 C230,170 280,230 340,200 C380,185 400,205 400,200'/><path d='M0,220 C60,190 110,250 170,220 C230,190 280,250 340,220 C380,205 400,225 400,220'/><path d='M0,240 C60,210 110,270 170,240 C230,210 280,270 340,240 C380,225 400,245 400,240'/><path d='M0,180 C60,150 110,210 170,180 C230,150 280,210 340,180 C380,165 400,185 400,180'/><path d='M0,160 C60,130 110,190 170,160 C230,130 280,190 340,160 C380,145 400,165 400,160'/><path d='M0,260 C60,230 110,290 170,260 C230,230 280,290 340,260 C380,245 400,265 400,260'/><path d='M0,140 C60,110 110,170 170,140 C230,110 280,170 340,140 C380,125 400,145 400,140'/><path d='M0,280 C60,250 110,310 170,280 C230,250 280,310 340,280 C380,265 400,285 400,280'/></g></svg>");
  background-size: 400px 400px;
  mix-blend-mode: screen;
}
.hero-frame {
  position: relative; z-index: 3;
  width: 100%; max-width: var(--maxw);
  margin: 0 auto; padding: 0 var(--pad);
}
.hero-meta {
  display: flex; gap: 12px; flex-wrap: wrap;
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--bone-2);
  margin-bottom: 24px;
}
.tick { padding: 5px 10px; border: 1px solid var(--hair-hard); }
.tick-od { color: var(--od); border-color: var(--od); }

.hero-headline {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(44px, 8.5vw, 130px);
  line-height: 0.96;
  letter-spacing: -0.02em;
  margin: 0;
}
.hero-headline .line { display: block; }
.hero-headline em {
  font-style: italic;
  font-weight: 500;
  color: var(--od);
}
.hero-headline .line-accent {
  color: var(--bone);
  position: relative;
}
.hero-headline .line-small {
  font-size: 0.45em;
  font-weight: 400;
  font-style: italic;
  color: var(--bone-2);
  letter-spacing: -0.005em;
  margin-top: 0.35em;
  line-height: 1.2;
}

.hero-bottom {
  display: grid; grid-template-columns: 1fr auto;
  gap: 28px; align-items: end;
  margin-top: clamp(24px, 4.5vh, 48px);
  padding-top: 22px;
  border-top: 1px solid var(--hair);
}
.hero-lede {
  max-width: 52ch; font-size: 15px; color: var(--bone-2);
  margin: 0;
}
.hero-ctas { display: flex; gap: 10px; flex-wrap: wrap; }

.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--ff-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.16em;
  padding: 13px 20px;
  transition: all .2s ease;
  cursor: pointer; border: 1px solid transparent;
}
.btn-primary { background: var(--od); color: var(--ink); border-color: var(--od); }
.btn-primary:hover { background: transparent; color: var(--od); }
.btn-ghost { color: var(--bone); border-color: var(--hair-hard); }
.btn-ghost:hover { border-color: var(--bone); background: var(--bone); color: var(--ink); }

/* Hero metrics bar */
.hero-metrics {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.hm {
  padding: 14px 18px 14px 0;
  border-right: 1px solid var(--hair);
  display: flex; flex-direction: column; gap: 4px;
}
.hm:last-child { border-right: 0; }
.hm-label {
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ash);
}
.hm-value {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 28px; color: var(--od);
  letter-spacing: -0.01em;
}
.hm-unit {
  font-family: var(--ff-mono); font-size: 11px; font-weight: 400;
  color: var(--bone-2); letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-left: 4px;
}

/* Readout overlay */
.readout {
  position: absolute;
  z-index: 3;
  right: var(--pad); top: 96px;
  width: 240px;
  background: rgba(10,10,10,0.82);
  border: 1px solid var(--hair-hard);
  padding: 12px 14px 10px;
  display: flex; flex-direction: column; gap: 8px;
  backdrop-filter: blur(4px);
}
@media (max-width: 1100px) { .readout { display: none; } }
.readout-row {
  display: grid; grid-template-columns: 70px 1fr 36px;
  gap: 8px; align-items: center;
}
.readout-label {
  font-family: var(--ff-mono); font-size: 9px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bone-2);
}
.readout-bar {
  height: 4px; background: rgba(232,228,216,0.1); position: relative;
  overflow: hidden;
}
.readout-fill {
  position: absolute; inset: 0 auto 0 0;
  background: var(--bone-2);
  transition: width .6s ease;
}
.readout-fill-amber { background: var(--amber); }
.readout-fill-od { background: var(--od); }
.readout-num {
  font-family: var(--ff-mono); font-size: 10px;
  color: var(--bone); text-align: right; letter-spacing: 0.05em;
}

.hero-scroll {
  position: absolute; z-index: 3;
  right: var(--pad); top: 50%; transform: translateY(-50%);
  font-family: var(--ff-mono); font-size: 9px;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--bone-2);
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  writing-mode: vertical-rl;
}
.line-v { display: block; width: 1px; height: 50px; background: var(--bone-2); animation: pulse 2.2s ease infinite; }
@keyframes pulse { 0%,100% { opacity: 0.3; } 50% { opacity: 1; } }

/* ---------- TICKER ---------- */
.ticker {
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  overflow: hidden; white-space: nowrap;
  background: var(--ink-2);
}
.ticker-track {
  display: inline-flex; gap: 22px;
  padding: 16px 0;
  font-family: var(--ff-display); font-weight: 700; font-style: italic;
  font-size: clamp(18px, 2.2vw, 30px);
  color: var(--bone-2);
  animation: slide 36s linear infinite;
}
.ticker-track span { padding: 0 4px; }
.ticker-track span:nth-child(even) { color: var(--od); }
@keyframes slide { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ---------- SECTION CHROME ---------- */
section { padding: clamp(64px, 9vw, 120px) var(--pad); max-width: var(--maxw); margin: 0 auto; }
.section-head { margin-bottom: clamp(36px, 5vw, 68px); max-width: 1000px; }
.eyebrow {
  font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--od);
  display: inline-block; margin-bottom: 18px;
  padding-bottom: 5px; border-bottom: 1px solid var(--od);
}
.section-title {
  font-family: var(--ff-display); font-weight: 700;
  font-size: clamp(34px, 5.5vw, 76px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 0 0 16px;
}
.section-title em { font-style: italic; font-weight: 500; color: var(--od); }
.section-sub {
  max-width: 60ch; color: var(--bone-2); font-size: 15px;
}

.u-od { color: var(--od); }

/* ---------- AUDIENCE ---------- */
.audience {
  padding: clamp(44px, 6.5vw, 88px) var(--pad);
  max-width: var(--maxw);
  margin: 0 auto;
  border-top: 1px solid var(--hair);
}
.audience-head { margin-bottom: 32px; }
.audience-head .eyebrow {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--od);
  display: inline-block;
  margin-bottom: 14px;
}
.audience-title {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(28px, 3.4vw, 48px);
  line-height: 1.02;
  margin: 0;
  letter-spacing: -0.01em;
}
.audience-title em {
  font-style: italic;
  color: var(--od);
  font-weight: 500;
}
.audience-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.aud-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 26px 24px 22px;
  background: var(--ink-2);
  border: 1px solid var(--hair-hard);
  color: var(--bone);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
  overflow: hidden;
}
.aud-card:hover {
  border-color: var(--od);
  transform: translateY(-2px);
  background: var(--ink-3);
}
.aud-icon {
  color: var(--od);
  display: inline-flex;
}
.aud-card h3 {
  font-family: var(--ff-display);
  font-size: 24px;
  font-weight: 700;
  margin: 0;
  letter-spacing: -0.01em;
}
.aud-card p {
  font-size: 14px;
  color: var(--bone-2);
  line-height: 1.5;
  margin: 0;
  flex: 1;
}
.aud-cta {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--od);
  border-top: 1px solid var(--hair);
  padding-top: 12px;
  margin-top: 4px;
}

/* ---------- ABOUT ---------- */
.about { position: relative; }
.about-grid {
  display: grid; grid-template-columns: 1fr;
  gap: clamp(28px, 5vw, 80px);
  align-items: start; max-width: 880px;
}
.about-copy .lead {
  font-family: var(--ff-body); font-weight: 500;
  font-size: clamp(18px, 1.9vw, 22px);
  line-height: 1.45; color: var(--bone);
  margin: 0 0 22px;
  padding-left: 18px; border-left: 2px solid var(--od);
}
.about-copy p { max-width: 58ch; color: var(--bone-2); }

.about-pillars {
  list-style: none; margin: 36px 0 0; padding: 0;
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 0; border-top: 1px solid var(--hair);
}
.about-pillars li {
  padding: 22px 20px 24px 0;
  border-bottom: 1px solid var(--hair);
  display: block;
  font-size: 16px; line-height: 1.5; color: var(--bone-2);
}
.about-pillars li:nth-child(odd) { border-right: 1px solid var(--hair); padding-right: 28px; }
.about-pillars li:nth-child(even) { padding-left: 28px; }
.about-pillars strong {
  display: block;
  color: var(--bone); font-weight: 600;
  font-size: 18px; margin: 8px 0 6px;
  font-family: var(--ff-display);
}
.about-pillars .ap-body {
  display: block;
  color: var(--bone-2); font-size: 15px; line-height: 1.55;
}
.about-pillars .ap-num {
  display: block;
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.24em;
  color: var(--od); text-transform: uppercase; font-weight: 500;
}
@media (max-width: 640px) {
  .about-pillars { grid-template-columns: 1fr; }
  .about-pillars li:nth-child(odd) { border-right: none; padding-right: 0; }
  .about-pillars li:nth-child(even) { padding-left: 0; }
}

.about-vid-wrap {
  position: relative;
  margin-top: 28px;
  aspect-ratio: 16/9;
  max-width: 440px;
  border: 1px solid var(--hair-hard);
  overflow: hidden;
  background: var(--ink-2);
}
.about-vid {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.5) contrast(1.05) brightness(0.7);
}
.about-vid-label {
  position: absolute; left: 12px; bottom: 10px;
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--od);
  background: rgba(10,10,10,0.75);
  padding: 4px 8px;
  border: 1px solid var(--hair-hard);
}

.about-founder { position: sticky; top: 100px; }
.founder-photo { aspect-ratio: 4/5; background: var(--ink-2); overflow: hidden; margin-bottom: 18px; }
.photo-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background:
    repeating-linear-gradient(135deg, rgba(107,130,56,0.09) 0 2px, transparent 2px 11px),
    radial-gradient(120% 120% at 30% 20%, rgba(107,130,56,0.22), transparent 60%),
    linear-gradient(180deg, #14180d, #0a0c07);
  color: var(--bone-2);
  border: 1px solid var(--hair);
}
.photo-mono {
  font-family: var(--ff-display); font-style: italic; font-weight: 700;
  font-size: 32px; letter-spacing: -0.01em; color: var(--bone);
}
.photo-sub {
  font-family: var(--ff-mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--od); margin-top: 8px; text-align: center; padding: 0 14px;
}
.founder-bio h3 {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 24px; margin: 0 0 10px; letter-spacing: -0.01em;
}
.founder-bio p { color: var(--bone-2); font-size: 15px; margin: 0 0 14px; }
.creds {
  list-style: none; padding: 0; margin: 14px 0 0;
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bone-2);
}
.creds li { padding: 8px 0; border-top: 1px solid var(--hair); }

/* ---------- WHY ---------- */
.why { background: var(--ink); border-top: 1px solid var(--hair); }
.why-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: var(--hair); border: 1px solid var(--hair);
}
.why-tile {
  background: var(--ink);
  padding: 28px 24px;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 220px;
  transition: background .2s;
}
.why-tile:hover { background: var(--ink-3); }
.why-num {
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.22em; color: var(--od);
}
.why-tile h3 {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 22px; margin: 4px 0 2px;
  letter-spacing: -0.01em;
}
.why-tile p {
  font-size: 14px; color: var(--bone-2); margin: 0;
}

/* ---------- PROGRAMS ---------- */
.programs { background: linear-gradient(180deg, var(--ink) 0%, #060606 100%); max-width: none; padding-left: var(--pad); padding-right: var(--pad); }
.programs > * { max-width: var(--maxw); margin-left: auto; margin-right: auto; }
.programs-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--hair); border: 1px solid var(--hair);
}
.program {
  background: var(--ink);
  padding: 32px 26px;
  display: flex; flex-direction: column;
  min-height: 380px;
  position: relative;
  transition: background .25s ease;
}
.program:hover { background: var(--ink-3); }
.program:hover .program-num { color: var(--od); }
.program header { display: flex; align-items: baseline; gap: 14px; margin-bottom: 18px; }
.program-num {
  font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.22em; color: var(--ash);
  transition: color .2s;
}
.program h3 {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 32px; margin: 0; letter-spacing: -0.01em;
}
.prg-variants {
  font-family: var(--ff-mono); font-weight: 500;
  font-size: 12px; letter-spacing: 0.12em;
  color: var(--od); text-transform: uppercase;
  display: inline-block; margin-left: 6px; vertical-align: middle;
}
.program-line {
  font-family: var(--ff-display); font-style: italic;
  font-size: 17px; color: var(--bone); margin: 0 0 18px;
}
.program-dev {
  list-style: none; padding: 0; margin: 0 0 18px;
  display: flex; flex-wrap: wrap; gap: 6px;
}
.program-dev li {
  font-family: var(--ff-mono); font-size: 9px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--od);
  padding: 5px 8px;
  border: 1px solid var(--od-d);
}
.program-note {
  font-size: 13px; color: var(--ash); margin: 0 0 16px;
  padding-top: 16px; border-top: 1px solid var(--hair);
}
.program-stats {
  margin-top: auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1px; background: var(--hair-hard);
  border: 1px solid var(--hair-hard);
}
.program-stats > div {
  background: var(--ink-2);
  padding: 10px 12px;
  display: flex; flex-direction: column; gap: 2px;
}
.program-stats span {
  font-family: var(--ff-mono); font-size: 9px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--ash);
}
.program-stats strong {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 15px; color: var(--bone);
  letter-spacing: -0.005em;
}
.program-cta { justify-content: space-between; }
.program-cta .program-arrow {
  font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--od); margin-top: auto;
  display: inline-block; padding-top: 18px; border-top: 1px solid var(--od-d);
}
.prg-footnote {
  margin: 26px 0 0;
  font-family: var(--ff-mono); font-size: 10px;
  color: var(--ash); letter-spacing: 0.04em;
  max-width: 72ch;
}
.prg-footnote span { color: var(--od); margin-right: 6px; }

/* ---------- COACH SECTION (single) ---------- */
.coach-section { }
.coach-single {
  display: grid; grid-template-columns: 60px 260px 1fr;
  gap: 32px; align-items: start;
  padding: 30px 0;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  max-width: 900px;
}
.coach-num {
  font-family: var(--ff-mono); font-size: 12px;
  letter-spacing: 0.22em; color: var(--od);
}
.coach-photo { aspect-ratio: 1; background: var(--ink-2); }
.coach-ph {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display); font-style: italic; font-weight: 700;
  font-size: 42px; letter-spacing: -0.01em; color: var(--bone);
  background:
    repeating-linear-gradient(45deg, rgba(107,130,56,0.09) 0 3px, transparent 3px 14px),
    linear-gradient(135deg, #14180d, #0a0c07);
  border: 1px solid var(--hair);
}
.coach-body h3 {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 28px; margin: 0 0 12px; letter-spacing: -0.01em;
}
.coach-role { font-family: var(--ff-body); font-weight: 400; font-size: 14px; color: var(--ash); font-style: italic; }
.coach-body p { color: var(--bone-2); max-width: 58ch; }
.coach-creds {
  list-style: none; padding: 0; margin-top: 14px;
  display: flex; gap: 10px; flex-wrap: wrap;
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--od);
}
.coach-creds li { padding: 5px 8px; border: 1px solid var(--od-d); }

/* ---------- PROOF ---------- */
.proof { background: var(--ink); }

/* Commit ticker */
.commit-ticker {
  text-align: center;
  padding: 36px 0 28px;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  margin-bottom: 40px;
}
.ct-num {
  font-family: var(--ff-display); font-weight: 900;
  font-size: clamp(96px, 14vw, 180px);
  color: var(--od);
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: 8px;
}
.ct-label {
  font-family: var(--ff-display); font-style: italic; font-weight: 500;
  font-size: clamp(18px, 2.2vw, 28px);
  color: var(--bone-2);
}

.subhead {
  font-family: var(--ff-display); font-weight: 700;
  font-size: clamp(24px, 2.8vw, 36px);
  letter-spacing: -0.01em;
  margin: 40px 0 8px;
}
.subcopy { color: var(--ash); margin: 0 0 24px; font-size: 14px; }

/* Big credential */
.cred-big {
  padding: 28px 0 10px;
  border-bottom: 1px solid var(--hair);
  margin: 0 0 40px;
}
.cred-line {
  font-family: var(--ff-display);
  font-size: clamp(32px, 5vw, 76px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.3em 0.5em;
}
.cred-num {
  font-family: var(--ff-mono);
  color: var(--od);
  font-weight: 600;
  font-size: 0.85em;
}
.cred-word { font-weight: 700; }
.cred-tag em {
  font-style: italic;
  font-weight: 500;
  color: var(--bone-2);
}

/* Report card */
.report {
  background: var(--ink-2);
  border: 1px solid var(--hair-hard);
  margin: 0 0 40px;
  padding: 0;
}
.report-head {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--hair);
  background: rgba(10,10,10,0.6);
  align-items: center;
}
.report-head > div { display: flex; flex-direction: column; gap: 4px; }
.report-head .report-name { text-align: center; }
.report-head .report-date { text-align: right; }
.report-label, .report-date span {
  font-family: var(--ff-mono); font-size: 9px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ash);
}
.report-id {
  font-family: var(--ff-mono); font-size: 11px;
  color: var(--od); letter-spacing: 0.08em;
}
.report-name strong {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 18px; color: var(--bone);
}
.report-name span {
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ash);
}
.report-date strong {
  font-family: var(--ff-mono); font-size: 12px; color: var(--bone);
  letter-spacing: 0.06em;
}
.report-grid { padding: 18px 22px; display: flex; flex-direction: column; gap: 14px; }
.rpt-row {
  display: grid;
  grid-template-columns: 160px 140px 1fr 80px 80px;
  gap: 14px; align-items: center;
}
.rpt-name {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 15px; color: var(--bone);
}
.rpt-base {
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ash);
}
.rpt-bar {
  height: 6px; background: rgba(232,228,216,0.08);
  position: relative; overflow: hidden;
}
.rpt-bar-fill {
  position: absolute; inset: 0 auto 0 0;
  background: var(--od);
  width: 0; animation: barGrow 1.4s ease-out forwards;
}
.rpt-bar-good { background: var(--od); }
@keyframes barGrow { from { transform: scaleX(0); transform-origin: left; } to { transform: scaleX(1); transform-origin: left; } }
.rpt-now {
  font-family: var(--ff-mono); font-size: 12px;
  color: var(--bone); text-align: right; letter-spacing: 0.04em;
}
.rpt-delta {
  font-family: var(--ff-mono); font-size: 11px;
  color: var(--od); text-align: right;
  letter-spacing: 0.06em; font-weight: 500;
  padding: 4px 8px;
  border: 1px solid var(--od-d);
  background: rgba(107,130,56,0.08);
}
.report-foot {
  padding: 12px 22px;
  display: flex; justify-content: space-between;
  border-top: 1px solid var(--hair);
  background: rgba(10,10,10,0.4);
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ash);
}

/* Logo row (8 slots) */
.logo-row {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 10px;
  padding: 20px 0 32px;
  border-bottom: 1px solid var(--hair);
  margin-bottom: 32px;
}
.logo-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 18px 8px;
  border: 1px solid var(--hair);
  background: var(--ink-2);
  min-height: 100px;
  filter: grayscale(1);
  opacity: 0.72;
}
.logo-slot span {
  font-family: var(--ff-mono);
  font-size: 10px;
  color: var(--ash);
  letter-spacing: 0.08em;
}
.logo-slot em {
  font-family: var(--ff-body);
  font-style: normal;
  font-size: 11px;
  color: var(--bone-2);
  margin-top: 6px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 500;
  line-height: 1.3;
}

/* Commit log */
.commit-log {
  list-style: none; padding: 0; margin: 0 0 40px;
  border: 1px solid var(--hair-hard);
  background: var(--ink-2);
}
.commit-log li {
  display: grid;
  grid-template-columns: 1.6fr 1fr 2fr 0.5fr;
  gap: 20px; align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid var(--hair);
  font-family: var(--ff-mono); font-size: 12px;
  letter-spacing: 0.05em;
  color: var(--bone-2);
  transition: background .2s;
}
.commit-log li:hover {
  background: var(--ink-3);
  color: var(--bone);
}
.commit-log li:last-child { border-bottom: 0; }
.cl-name {
  color: var(--bone); font-weight: 500;
}
.cl-sport {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 10px;
  color: var(--od);
}
.cl-route { color: var(--bone-2); }
.cl-year {
  color: var(--ash);
  text-align: right;
  font-size: 11px;
}

.testis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.testi {
  margin: 0; padding: 28px 24px;
  background: var(--ink-2);
  border: 1px solid var(--hair);
  position: relative;
}
.testi::before {
  content: "\201C";
  position: absolute; top: 4px; left: 12px;
  font-family: var(--ff-display); font-size: 72px; line-height: 1;
  color: var(--od); opacity: 0.5;
}
.testi p {
  font-family: var(--ff-display); font-style: italic;
  font-size: 16px; line-height: 1.5; color: var(--bone);
  margin: 0 0 16px; padding-top: 12px;
}
.testi cite {
  font-family: var(--ff-mono); font-style: normal;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ash);
}
.testi-photo {
  width: 60px; height: 60px;
  border-radius: 50%;
  background: var(--ink-3);
  border: 1px solid var(--hair-hard);
  font-family: var(--ff-mono);
  font-size: 9px;
  color: var(--ash);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 12px;
  padding: 6px;
}

/* ---------- SCHEDULE ---------- */
.schedule { background: var(--ink); }
.cal-wrap { display: grid; grid-template-columns: 1fr 1.3fr; gap: 36px; }
.cal-wrap-single { grid-template-columns: 1fr; max-width: 680px; margin: 0 auto; }
.cal-embed {
  aspect-ratio: 1;
  background: var(--ink-2);
  border: 1px solid var(--hair);
}
.cal-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 18px; padding: 32px; text-align: center;
  background:
    repeating-linear-gradient(45deg, rgba(107,130,56,0.06) 0 2px, transparent 2px 14px);
}
.cal-mono {
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.22em;
  color: var(--od); text-transform: uppercase;
  padding: 7px 12px; border: 1px dashed var(--od);
}
.cal-caption {
  font-family: var(--ff-display); font-style: italic; font-weight: 700;
  font-size: 22px; color: var(--bone); max-width: 22ch;
}

.cal-week h3 {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 22px; margin: 0 0 18px;
  letter-spacing: -0.01em;
}
.week-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 6px; margin-bottom: 16px;
}
.wg-col { display: flex; flex-direction: column; gap: 6px; }
.wg-day {
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ash); padding-bottom: 6px; border-bottom: 1px solid var(--hair);
}
.wg-slot {
  padding: 10px 8px; font-size: 11px; line-height: 1.3;
  font-family: var(--ff-mono); letter-spacing: 0.04em;
  border: 1px solid var(--hair);
  background: var(--ink-2);
  color: var(--bone-2);
}
.wg-group { border-color: var(--od-d); color: var(--od); background: rgba(107,130,56,0.08); }
.wg-private { border-color: var(--rust); color: var(--rust); background: rgba(139,58,43,0.1); }
.wg-camp { border-color: var(--bone-2); color: var(--bone); background: rgba(232,228,216,0.06); }
.wg-open { color: var(--ash); background: transparent; border-style: dashed; }
.wg-rest-s { color: var(--ash-2); background: transparent; border: 1px dashed var(--hair-hard); text-align: center; }

.wg-key {
  display: flex; flex-wrap: wrap; gap: 18px;
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--ash);
}
.wg-key span { display: inline-flex; align-items: center; gap: 8px; }
.sw { width: 12px; height: 10px; display: inline-block; }
.sw-group { background: rgba(107,130,56,0.3); border: 1px solid var(--od); }
.sw-priv { background: rgba(139,58,43,0.3); border: 1px solid var(--rust); }
.sw-camp { background: rgba(232,228,216,0.2); border: 1px solid var(--bone-2); }
.sw-open { background: transparent; border: 1px dashed var(--ash); }

/* ---------- PRICING ---------- */
.pricing { background: linear-gradient(180deg, #060606 0%, var(--ink) 100%); max-width: none; padding-left: var(--pad); padding-right: var(--pad); }
.pricing > * { max-width: var(--maxw); margin-left: auto; margin-right: auto; }
.tiers {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--hair);
  border: 1px solid var(--hair);
}
.tier {
  background: var(--ink); padding: 36px 28px;
  display: flex; flex-direction: column;
  position: relative;
}
.tier-featured {
  background: linear-gradient(180deg, rgba(107,130,56,0.08), rgba(107,130,56,0) 40%), var(--ink);
  border: 1px solid var(--od-d);
  margin: -1px;
}
.tier-flag {
  position: absolute; top: -1px; right: -1px;
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 6px 10px;
  background: var(--od); color: var(--ink);
}
.tier-head { margin-bottom: 16px; }
.tier-label {
  display: block; font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--od); margin-bottom: 12px;
}
.tier-price {
  font-family: var(--ff-display); font-weight: 700;
  font-size: 56px; line-height: 1; letter-spacing: -0.03em;
  color: var(--bone);
  display: inline-flex; align-items: baseline;
}
.tier-dollar { font-size: 22px; font-weight: 500; color: var(--ash); margin-right: 4px; }
.tier-per { font-size: 14px; font-family: var(--ff-mono); color: var(--ash); margin-left: 6px; font-weight: 400; letter-spacing: 0.1em; text-transform: uppercase; }
.tier-price-gated {
  font-family: var(--ff-display);
  font-size: clamp(22px, 2.2vw, 30px);
  font-style: italic;
  font-weight: 500;
  line-height: 1.1;
  color: var(--od);
  display: block;
}
.tier-gated-sub {
  display: block;
  font-family: var(--ff-mono);
  font-size: 10px;
  font-style: normal;
  font-weight: 400;
  color: var(--ash);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: 6px;
}
.tier-desc { color: var(--bone-2); font-size: 14px; margin: 0 0 18px; }
.tier-list {
  list-style: none; padding: 0; margin: 0 0 22px;
  font-size: 13px; color: var(--bone-2);
}
.tier-list li { padding: 8px 0; border-top: 1px solid var(--hair); }
.tier-list li::before { content: "—"; color: var(--od); margin-right: 10px; }
.tier-cta { margin-top: auto; justify-content: center; text-align: center; }
.pricing-fine {
  margin-top: 28px; text-align: center; max-width: 62ch; margin-left: auto; margin-right: auto;
  font-family: var(--ff-display); font-style: italic; color: var(--ash);
  font-size: 15px;
}

/* ---------- FAQ ---------- */
.faq-list {
  border-top: 1px solid var(--hair);
}
.faq-list details {
  border-bottom: 1px solid var(--hair);
  padding: 20px 0;
}
.faq-list summary {
  cursor: pointer;
  font-family: var(--ff-display); font-weight: 700;
  font-size: clamp(17px, 2vw, 22px);
  letter-spacing: -0.01em;
  list-style: none;
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 20px;
}
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after {
  content: "+"; font-family: var(--ff-mono); color: var(--od);
  font-weight: 400; font-size: 22px; transition: transform .25s ease;
}
.faq-list details[open] summary::after { content: "–"; }
.faq-list details p {
  margin: 12px 0 0; max-width: 70ch; color: var(--bone-2); font-size: 15px;
}

/* ---------- TRIAL ---------- */
.trial { background: var(--ink-2); max-width: none; padding-left: var(--pad); padding-right: var(--pad); border-top: 1px solid var(--hair); }
.trial-grid {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px;
  align-items: start;
}
.trial-copy p { color: var(--bone-2); max-width: 48ch; }
.trial-contacts {
  list-style: none; padding: 0; margin: 28px 0 0;
}
.trial-contacts li {
  display: grid; grid-template-columns: 100px 1fr;
  gap: 20px; padding: 14px 0;
  border-top: 1px solid var(--hair);
  font-size: 14px; color: var(--bone);
}
.trial-contacts li span {
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--od);
}
.trial-contacts a:hover { color: var(--od); }

.trial-form {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 14px;
  background: var(--ink); border: 1px solid var(--hair);
  padding: 28px;
}
.trial-form label { display: grid; gap: 5px; }
.trial-form label span {
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--ash);
}
.trial-form input, .trial-form select, .trial-form textarea {
  background: var(--ink-2);
  border: 1px solid var(--hair);
  color: var(--bone);
  font-family: var(--ff-body); font-size: 14px;
  padding: 11px 13px; outline: none;
  transition: border-color .2s;
}
.trial-form input:focus, .trial-form select:focus, .trial-form textarea:focus {
  border-color: var(--od);
}
.trial-msg { grid-column: 1 / -1; }
.trial-submit { grid-column: 1 / -1; justify-content: center; }
.trial-fine { grid-column: 1 / -1; margin: 0; text-align: center; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ash); }

/* ---------- FOOTER ---------- */
.foot {
  background: #050505; padding: 72px var(--pad) 36px;
  border-top: 1px solid var(--hair);
}
.foot-top {
  max-width: var(--maxw); margin: 0 auto 54px;
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 28px;
}
.foot-mark .mark-num { color: var(--od); }
.foot-mark .mark-name {
  font-family: var(--ff-display); font-weight: 700;
  font-size: clamp(34px, 5.5vw, 66px); letter-spacing: -0.02em;
}
.foot-tag {
  font-family: var(--ff-display); font-style: italic; font-weight: 500;
  font-size: clamp(18px, 2.2vw, 28px); color: var(--od);
  text-align: right; line-height: 1.1;
}
.foot-grid {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 36px;
  padding-top: 36px;
  border-top: 1px solid var(--hair);
}
.foot-grid h4 {
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--od); margin: 0 0 14px;
}
.foot-grid p, .foot-grid a { font-size: 13px; color: var(--bone-2); }
.foot-grid a:hover { color: var(--od); }

.foot-bottom {
  max-width: var(--maxw); margin: 54px auto 0;
  padding-top: 22px; border-top: 1px solid var(--hair);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--ash);
}
.foot-bzm a { color: var(--od); border-bottom: 1px solid var(--od); padding-bottom: 1px; }

/* ---------- REVEAL ---------- */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .8s ease, transform .8s ease; }
.reveal.is-in { opacity: 1; transform: none; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1100px) {
  .logo-row { grid-template-columns: repeat(4, 1fr); }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 960px) {
  .programs-grid { grid-template-columns: repeat(2, 1fr); }
  .testis { grid-template-columns: repeat(2, 1fr); }
  .tiers { grid-template-columns: 1fr; }
  .cal-wrap { grid-template-columns: 1fr; }
  .about-grid { grid-template-columns: 1fr; }
  .about-founder { position: static; }
  .trial-grid { grid-template-columns: 1fr; gap: 36px; }
  .foot-grid { grid-template-columns: repeat(2, 1fr); }
  .coach-single { grid-template-columns: 40px 180px 1fr; gap: 20px; }
  .audience-grid { grid-template-columns: 1fr; }
  .hero-metrics { grid-template-columns: repeat(2, 1fr); }
  .readout { display: none; }
  .report-head { grid-template-columns: 1fr; gap: 10px; }
  .report-head .report-name, .report-head .report-date { text-align: left; }
  .rpt-row { grid-template-columns: 1fr 1fr; gap: 8px; }
  .rpt-bar { grid-column: 1 / -1; }
  .commit-log li { grid-template-columns: 1fr 1fr; gap: 6px; }
  .cl-route { grid-column: 1 / -1; }
  .cl-year { grid-column: 2; }
}

@media (max-width: 768px) {
  .nav-links { display: none; position: fixed; top: 58px; left: 0; right: 0; flex-direction: column; background: var(--ink); padding: 22px var(--pad); gap: 16px; border-bottom: 1px solid var(--hair); }
  .nav-links.is-open { display: flex; }
  .nav-cta { display: none; }
  .nav-toggle { display: block; margin-left: auto; }
  .hero-bottom { grid-template-columns: 1fr; }
  .hero-scroll { display: none; }
  .week-grid { grid-template-columns: repeat(3, 1fr); }
  .week-grid .wg-col { min-width: 0; }
  .trial-form { grid-template-columns: 1fr; padding: 22px; }
  .foot-top { flex-direction: column; align-items: flex-start; }
  .foot-tag { text-align: left; }
  .coach-single { grid-template-columns: 1fr; }
  .coach-photo { max-width: 240px; }
  .logo-row { grid-template-columns: repeat(2, 1fr); }
  .why-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .programs-grid { grid-template-columns: 1fr; }
  .testis { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr; }
  .week-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-meta .tick { font-size: 10px; padding: 4px 8px; }
  .tier { padding: 28px 20px; }
  .hero-metrics { grid-template-columns: 1fr 1fr; }
  .ct-num { font-size: clamp(72px, 22vw, 110px); }
}
