/* =========================================================================
   Built for HYROX — 12-Week 1:1 page styles
   Forked from the Tob Performance landing-page UI kit, extended with:
   hero variations, VSL video placeholder, solution grid, sign-up steps,
   featured testimonial, and the hero-variation switcher.
   All tokens come from colors_and_type.css.
   ========================================================================= */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root { --lp-gap: 90px; }

html { scroll-behavior: smooth; }

body {
  background: var(--warm-white);
  color: var(--black);
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
}

/* ---- BUTTONS ---- */
.lp-btn {
  display: inline-block;
  padding: 16px 32px;
  background: var(--black);
  color: var(--off-white);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--black);
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.lp-btn:hover { background: var(--accent); border-color: var(--accent); color: var(--black); }
.lp-btn--small { font-size: 11px; padding: 12px 22px; }
.lp-btn--gold { background: var(--accent); border-color: var(--accent); color: var(--black); }
.lp-btn--gold:hover { background: var(--off-white); border-color: var(--off-white); color: var(--black); }
.lp-btn--ghost-on-dark {
  background: transparent; color: var(--off-white); border-color: var(--off-white);
}
.lp-btn--ghost-on-dark:hover { background: var(--accent); color: var(--black); border-color: var(--accent); }
.lp-btn--full { display: block; text-align: center; width: 100%; margin-top: 28px; }

/* ---- PROOF BAR ---- */
.lp-proof-bar {
  background: var(--black); color: var(--off-white);
  padding: 14px 28px; text-align: center;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
}
.lp-proof-bar span.sep { color: var(--accent); margin: 0 8px; }

/* ---- NAV ---- */
.lp-nav {
  display: flex; justify-content: space-between; align-items: center;
  padding: 20px 32px;
  background: var(--black);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  position: sticky; top: 0; z-index: 50;
}
.lp-nav-logo {
  font-family: var(--font-display); font-weight: 800;
  font-size: 18px; letter-spacing: 0.02em;
  text-decoration: none; color: var(--off-white);
}
.lp-nav-logo span { color: var(--accent); }

/* =========================================================================
   HERO — three variations toggled by the switcher
   ========================================================================= */
.lp-hero {
  background: var(--black); color: var(--off-white);
  position: relative;
}
.hero-variant { display: none; }
.hero-variant.is-active { display: block; }

.lp-hero-tag {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--accent); display: block;
}
.lp-hero-h1 {
  font-family: var(--font-serif);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--off-white);
}
.lp-hero-h1 em { font-style: normal; color: var(--accent); font-weight: 600; }
.lp-hero-sub {
  font-family: var(--font-sans);
  line-height: 1.7;
  color: var(--on-dark-ink);
}
.lp-hero-note {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--on-dark-muted);
}

/* Variant A — centered, intro line, video below */
.heroA-inner {
  max-width: 1000px; margin: 0 auto; text-align: center;
  padding: 84px 32px 96px;
}
.heroA-inner .lp-hero-tag { margin-bottom: 34px; }
.heroA-inner .lp-hero-h1 { font-size: clamp(38px, 5vw, 66px); max-width: 17ch; margin: 0 auto 26px; }
.heroA-inner .lp-hero-sub { font-size: 17px; max-width: 560px; margin: 0 auto 30px; }
.heroA-videolead {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--on-dark-muted); margin-bottom: 18px;
}
.heroA-inner .vsl { max-width: 760px; margin: 0 auto 34px; }
.heroA-ctas { display: flex; gap: 22px; flex-wrap: wrap; align-items: center; justify-content: center; }

/* Variant B — split: text left, video right */
.heroB-inner {
  max-width: 1180px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.05fr; gap: 56px;
  align-items: center; padding: 80px 32px 88px;
}
.heroB-inner .lp-hero-tag { margin-bottom: 28px; }
.heroB-inner .lp-hero-h1 { font-size: clamp(34px, 4vw, 56px); margin-bottom: 24px; }
.heroB-inner .lp-hero-sub { font-size: 16px; max-width: 480px; margin-bottom: 30px; }
.heroB-ctas { display: flex; gap: 20px; flex-wrap: wrap; align-items: center; }
.heroB-videowrap .heroA-videolead { margin-bottom: 14px; }
@media(max-width: 820px) {
  .heroB-inner { grid-template-columns: 1fr; gap: 40px; }
}

/* Variant C — editorial statement, big headline, full-width video band below */
.heroC-inner {
  max-width: 1100px; margin: 0 auto;
  padding: 92px 32px 56px;
}
.heroC-inner .lp-hero-tag { margin-bottom: 30px; }
.heroC-inner .lp-hero-h1 {
  font-size: clamp(44px, 7vw, 92px);
  line-height: 1.04; max-width: 14ch; margin-bottom: 30px;
}
.heroC-row {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 40px; flex-wrap: wrap;
}
.heroC-inner .lp-hero-sub { font-size: 17px; max-width: 460px; }
.heroC-ctas { display: flex; gap: 20px; align-items: center; flex-wrap: wrap; }
.heroC-videoband {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 40px 32px 88px;
}
.heroC-videoband-inner { max-width: 1100px; margin: 0 auto; }
.heroC-videoband .heroA-videolead { margin-bottom: 16px; }

/* ---- VSL VIDEO PLACEHOLDER ---- */
.vsl {
  position: relative;
  aspect-ratio: 16 / 9;
  width: 100%;
  background: #161412;
  border: 1px solid rgba(255,255,255,0.10);
  overflow: hidden;
}
.vsl image-slot { position: absolute; inset: 0; width: 100%; height: 100%; }
.vsl-overlay {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 18px; pointer-events: none;
  background: linear-gradient(180deg, rgba(12,11,9,0.15), rgba(12,11,9,0.55));
}
.vsl-play {
  width: 76px; height: 76px; border-radius: 50%;
  border: 1.5px solid var(--accent);
  background: rgba(12,11,9,0.45);
  display: flex; align-items: center; justify-content: center;
}
.vsl-play::after {
  content: ""; display: block;
  width: 0; height: 0;
  border-left: 20px solid var(--accent);
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
  margin-left: 5px;
}
.vsl-label {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--on-dark-ink);
}

/* ---- HERO VARIATION SWITCHER ---- */
.hero-switcher {
  position: fixed; right: 18px; bottom: 18px; z-index: 200;
  background: var(--black); border: 1px solid var(--accent);
  padding: 9px 12px;
  display: flex; align-items: center; gap: 10px;
}
.hero-switcher-label {
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--on-dark-muted);
}
.hero-switcher button {
  font-family: var(--font-mono); font-size: 11px;
  width: 26px; height: 26px;
  background: transparent; color: var(--on-dark-ink);
  border: 1px solid rgba(255,255,255,0.18); cursor: pointer;
  transition: all 0.15s;
}
.hero-switcher button:hover { border-color: var(--accent); color: var(--off-white); }
.hero-switcher button.is-active { background: var(--accent); border-color: var(--accent); color: var(--black); }

/* ---- GENERIC SECTION ---- */
.lp-section { padding: var(--lp-gap) 32px; }
.lp-section--dark { background: var(--black); color: var(--off-white); }
.lp-section--off { background: var(--off-white); }
.lp-section-inner { max-width: 860px; margin: 0 auto; }
.lp-kicker {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--mid-gray); display: block; margin-bottom: 20px;
}
.lp-section--dark .lp-kicker { color: var(--accent); }
.lp-kicker--gold { color: var(--accent); }
.lp-divider {
  width: 36px; height: 2px; background: var(--accent);
  display: block; margin-bottom: 22px;
}
.lp-h2 {
  font-family: var(--font-serif);
  font-size: clamp(28px, 4vw, 46px);
  font-weight: 500; line-height: 1.12; margin-bottom: 28px;
  letter-spacing: -0.01em;
  color: var(--black);
}
.lp-section--dark .lp-h2 { color: var(--off-white); }
.lp-h2 em { font-style: normal; color: var(--accent); }
.lp-section-intro { color: var(--body-ink-soft); max-width: 640px; margin-bottom: 28px; }
.lp-section--dark .lp-section-intro { color: var(--on-dark-ink); }
.lp-body { color: var(--body-ink-soft); margin-bottom: 14px; }

/* ---- PAIN ---- */
.lp-pain-list { list-style: none; padding: 0; }
.lp-pain-list li {
  padding: 18px 0 18px 28px;
  border-bottom: 1px solid var(--section-border);
  font-size: 16px;
  color: var(--body-ink);
  position: relative;
  line-height: 1.7;
}
.lp-pain-list li:last-child { border-bottom: none; }
.lp-pain-list li::before {
  content: ""; position: absolute; left: 0; top: 28px;
  width: 6px; height: 6px; background: var(--accent); border-radius: 50%;
}
.lp-pain-callout {
  margin-top: 44px;
  padding: 28px 36px;
  border-left: 2px solid var(--accent);
  background: var(--accent-fill-08);
  max-width: 780px;
}
.lp-pain-callout p {
  font-family: var(--font-serif);
  font-size: clamp(19px, 2.2vw, 24px);
  line-height: 1.5; color: var(--black);
}
.lp-pain-callout em { font-style: normal; color: var(--accent-dark); }

/* ---- WHY FAIL ---- */
.lp-fail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-bottom: 36px; }
.lp-fail-card { padding-top: 28px; border-top: 1px solid var(--section-border); }
.lp-fail-num {
  font-family: var(--font-serif); font-size: 44px;
  color: var(--light-gray); line-height: 1; margin-bottom: 18px;
}
.lp-fail-h3 {
  font-family: var(--font-serif); font-size: 22px; font-weight: 400;
  line-height: 1.2; margin-bottom: 10px; color: var(--black);
}
.lp-fail-card p { font-size: 14px; color: var(--body-ink-soft); line-height: 1.7; }
@media(max-width: 640px) { .lp-fail-grid { grid-template-columns: 1fr; } }

/* ---- SOLUTION (3 benefit blocks on dark) ---- */
.sol-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 28px; border-top: 1px solid #2e2c2a; }
.sol-card { padding: 34px 26px 30px; border-right: 1px solid #2e2c2a; }
.sol-card:last-child { border-right: none; }
.sol-num {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 22px;
}
.sol-h3 {
  font-family: var(--font-serif); font-size: 24px; font-weight: 400;
  line-height: 1.2; margin-bottom: 14px; color: var(--off-white);
}
.sol-card p { font-size: 14px; line-height: 1.7; color: var(--on-dark-muted); }
@media(max-width: 720px) {
  .sol-grid { grid-template-columns: 1fr; }
  .sol-card { border-right: none; border-bottom: 1px solid #2e2c2a; }
  .sol-card:last-child { border-bottom: none; }
}

/* ---- OFFER ROWS (image-slot + text) ---- */
.lp-offer-row {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 40px; align-items: center;
  margin-bottom: 56px;
}
.lp-offer-row:last-child { margin-bottom: 0; }
.lp-offer-row--reverse .lp-offer-media { order: 2; }
.lp-offer-media { aspect-ratio: 4/3; }
.lp-offer-media image-slot { width: 100%; height: 100%; display: block; }
.lp-offer-kicker {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 16px; display: block;
}
.lp-offer-h3 {
  font-family: var(--font-serif); font-size: 26px; font-weight: 400;
  line-height: 1.2; margin-bottom: 14px; color: var(--black);
}
.lp-offer-text p { font-size: 15px; color: var(--body-ink-soft); line-height: 1.7; margin-bottom: 12px; }
.lp-offer-why {
  font-size: 13px; color: var(--accent-dark);
  padding-top: 12px; border-top: 1px solid var(--section-border);
  margin-top: 14px;
}
@media(max-width: 720px) {
  .lp-offer-row { grid-template-columns: 1fr; gap: 24px; }
  .lp-offer-row--reverse .lp-offer-media { order: 0; }
}

/* ---- MID-PAGE CTA BAND ---- */
.lp-cta-band {
  background: var(--dark-gray); color: var(--off-white);
  padding: 72px 32px; text-align: center;
}
.lp-cta-band-inner { max-width: 720px; margin: 0 auto; }
.lp-cta-band h2 {
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(26px, 3.4vw, 38px); line-height: 1.18;
  color: var(--off-white); margin-bottom: 14px;
}
.lp-cta-band h2 em { font-style: normal; color: var(--accent); }
.lp-cta-band p { color: var(--on-dark-ink); font-size: 16px; max-width: 520px; margin: 0 auto 30px; }

/* ---- SIGN-UP STEPS ---- */
.lp-steps { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 32px; margin-top: 28px; }
.lp-step { border-top: 2px solid var(--accent); padding-top: 24px; }
.lp-step-num {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent-dark); margin-bottom: 16px;
}
.lp-step-role {
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mid-gray); display: block; margin-bottom: 8px;
}
.lp-step-h4 {
  font-family: var(--font-serif); font-size: 22px; font-weight: 400;
  line-height: 1.25; margin-bottom: 12px; color: var(--black);
}
.lp-step p { font-size: 14px; line-height: 1.7; color: var(--body-ink-soft); }
@media(max-width: 720px) { .lp-steps { grid-template-columns: 1fr; } }

/* ---- ABOUT ---- */
.lp-about { padding: var(--lp-gap) 32px; }
.lp-about-inner {
  display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 50px; align-items: start;
  max-width: 1080px; margin: 0 auto;
}
.lp-about-photo { aspect-ratio: 3/4; }
.lp-about-photo image-slot { width: 100%; height: 100%; display: block; }
.lp-about p { font-size: 15px; line-height: 1.75; color: var(--body-ink); margin-bottom: 14px; }
.lp-creds { margin-top: 28px; }
.lp-cred { display: flex; gap: 14px; align-items: flex-start; margin-bottom: 10px; }
.lp-cred-dot { width: 6px; height: 6px; background: var(--accent); border-radius: 50%; margin-top: 9px; flex-shrink: 0; }
.lp-cred span { font-size: 15px; color: var(--body-ink-soft); }
@media(max-width: 720px) { .lp-about-inner { grid-template-columns: 1fr; } .lp-about-photo { aspect-ratio: 4/3; max-width: 420px; } }

/* ---- FEATURED TESTIMONIAL ---- */
.lp-testi-section { padding: var(--lp-gap) 32px; background: var(--off-white); }
.lp-testi-section-inner { max-width: 1080px; margin: 0 auto; }
.lp-featured-testi {
  display: grid; grid-template-columns: 0.85fr 1.15fr;
  background: var(--dark-gray); color: var(--off-white);
  margin-top: 14px;
}
.lp-featured-photo { min-height: 380px; }
.lp-featured-photo image-slot { width: 100%; height: 100%; display: block; }
.lp-featured-body { padding: 44px 44px 40px; }
.lp-featured-stat {
  display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap;
  margin-bottom: 22px;
}
.lp-featured-before {
  font-family: var(--font-mono); font-size: 15px;
  color: var(--on-dark-muted); text-decoration: line-through;
  text-decoration-color: var(--warning-dot);
}
.lp-featured-arrow { color: var(--accent); font-family: var(--font-mono); font-size: 14px; }
.lp-featured-after {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(34px, 5vw, 52px); letter-spacing: -0.02em;
  line-height: 1; color: var(--accent);
}
.lp-featured-quote {
  font-family: var(--font-serif); font-size: clamp(19px, 2.2vw, 24px);
  line-height: 1.45; color: var(--off-white); margin-bottom: 26px;
}
.lp-featured-name {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 24px; display: block;
}
.lp-featured-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 22px; }
.lp-featured-micro {
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--on-dark-muted); display: block; margin-bottom: 8px;
}
.lp-featured-grid p { font-size: 14px; line-height: 1.6; color: var(--on-dark-ink); }
.lp-testi-foot {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mid-gray); margin-top: 26px; text-align: center;
}
@media(max-width: 760px) {
  .lp-featured-testi { grid-template-columns: 1fr; }
  .lp-featured-photo { aspect-ratio: 4/3; min-height: 0; }
}

/* ---- PRICING ---- */
.lp-pricing { background: var(--black); color: var(--off-white); padding: var(--lp-gap) 32px; text-align: center; }
.lp-pricing .lp-divider { margin: 18px auto; }
.lp-pricing .lp-h2 { color: var(--off-white); }
.lp-pricing-subhead { color: var(--on-dark-ink); font-size: 16px; max-width: 560px; margin: 0 auto 44px; line-height: 1.6; }
.lp-pricing-card {
  position: relative; max-width: 460px; margin: 0 auto;
  border: 1px solid #2e2c2a; padding: 52px 44px 44px; text-align: left;
}
.lp-pricing-ribbon {
  position: absolute; top: 0; left: 50%; transform: translate(-50%, -50%);
  background: var(--accent); color: var(--black); padding: 10px 24px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase; white-space: nowrap;
}
.lp-pricing-tag {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent-dark); display: block; margin-bottom: 22px;
}
.lp-pricing-h3 {
  font-family: var(--font-serif); font-size: clamp(24px, 3vw, 30px);
  font-weight: 400; line-height: 1.2; color: var(--off-white); margin-bottom: 22px;
}
.lp-pricing-divider { width: 36px; height: 2px; background: var(--accent); margin: 0 0 22px; }
.lp-pricing-price {
  font-family: var(--font-display); font-weight: 800;
  font-size: 64px; line-height: 1; letter-spacing: -0.02em;
  color: var(--off-white); margin-bottom: 8px;
}
.lp-pricing-note {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--on-dark-muted); margin-bottom: 26px;
}
.lp-pricing-card ul { list-style: none; padding: 0; border-top: 1px solid #2e2c2a; }
.lp-pricing-card li {
  padding: 14px 0 14px 22px; border-bottom: 1px solid #2e2c2a;
  font-size: 14px; color: var(--on-dark-ink); position: relative;
}
.lp-pricing-card li::before {
  content: ""; position: absolute; left: 0; top: 21px;
  width: 12px; height: 1.5px; background: var(--accent);
}

/* ---- GUARANTEE ---- */
.lp-guarantee { padding: 78px 32px; background: var(--warm-white); text-align: center; }
.lp-guarantee-inner { max-width: 720px; margin: 0 auto; }
.lp-guarantee-badge {
  width: 92px; height: 92px; border: 2px solid var(--accent); border-radius: 50%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  margin: 0 auto 32px;
}
.lp-guarantee-num { font-family: var(--font-serif); font-size: 26px; color: var(--accent); line-height: 1; }
.lp-guarantee-text {
  font-family: var(--font-mono); font-size: 8px;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent-dark); margin-top: 4px;
}
.lp-guarantee h2 {
  font-family: var(--font-serif); font-size: clamp(26px, 3.6vw, 40px);
  font-weight: 500; line-height: 1.15; color: var(--black); margin-bottom: 22px;
}
.lp-guarantee h2 em { font-style: normal; color: var(--accent-dark); }
.lp-guarantee p { color: var(--body-ink-soft); font-size: 16px; max-width: 560px; margin: 0 auto 14px; }
.lp-guarantee em { font-style: normal; color: var(--accent-dark); font-weight: 500; }

/* ---- FAQ ---- */
.lp-faq { padding: var(--lp-gap) 32px; background: var(--warm-white); }
.lp-faq-inner { max-width: 860px; margin: 0 auto; }
.lp-faq-list { margin-top: 8px; }
.lp-faq-item { border-bottom: 1px solid var(--section-border); padding: 22px 0; cursor: pointer; }
.lp-faq-q {
  display: flex; align-items: flex-start; gap: 20px;
  font-family: var(--font-serif); font-size: 19px; font-weight: 400;
  line-height: 1.4; color: var(--black);
}
.lp-faq-plus { width: 16px; height: 16px; flex-shrink: 0; position: relative; margin-top: 8px; }
.lp-faq-plus::before, .lp-faq-plus::after {
  content: ""; position: absolute; background: var(--accent); transition: transform 0.25s;
}
.lp-faq-plus::before { left: 0; right: 0; top: 50%; height: 1.5px; transform: translateY(-50%); }
.lp-faq-plus::after  { top: 0; bottom: 0; left: 50%; width: 1.5px; transform: translateX(-50%); }
.lp-faq-item--open .lp-faq-plus::after { transform: translateX(-50%) scaleY(0); }
.lp-faq-a {
  font-family: var(--font-sans); font-size: 15px; line-height: 1.7;
  color: var(--body-ink-soft); padding-left: 36px; padding-top: 14px;
}

/* ---- CLOSING ---- */
.lp-closing { background: var(--black); color: var(--off-white); padding: 130px 32px; text-align: center; }
.lp-closing-inner { max-width: 720px; margin: 0 auto; }
.lp-closing-h2 {
  font-family: var(--font-serif); font-size: clamp(30px, 4.5vw, 54px);
  font-weight: 400; line-height: 1.15; color: var(--off-white); margin-bottom: 24px;
}
.lp-closing-h2 em { font-style: normal; color: var(--accent); }
.lp-closing p { color: var(--on-dark-muted); font-size: 16px; max-width: 500px; margin: 0 auto 40px; line-height: 1.65; }
.lp-closing-logo {
  margin-top: 56px; font-family: var(--font-display); font-weight: 800;
  font-size: 15px; letter-spacing: 0.02em; color: #555350;
}
.lp-closing-logo span { color: var(--accent); }

/* =========================================================================
   VISUAL-RHYTHM ADDITIONS — stat strip, photo quote band, station
   infographic, about timeline. Built to break up the text-heavy reading.
   ========================================================================= */

/* ---- STAT STRIP (sits on the black hero, closes it) ---- */
.lp-statstrip {
  background: var(--black);
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 0 32px 8px;
}
.lp-statstrip-inner {
  max-width: 1080px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(4, 1fr);
}
.lp-stat {
  padding: 40px 24px; text-align: center;
  border-right: 1px solid rgba(255,255,255,0.08);
}
.lp-stat:last-child { border-right: none; }
.lp-stat-num {
  font-family: var(--font-serif); font-weight: 600;
  font-size: clamp(40px, 5vw, 64px); line-height: 1;
  color: var(--accent); letter-spacing: -0.01em; margin-bottom: 14px;
}
.lp-stat-label {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--on-dark-muted); line-height: 1.5;
}
@media(max-width: 680px) {
  .lp-statstrip-inner { grid-template-columns: 1fr 1fr; }
  .lp-stat:nth-child(2) { border-right: none; }
  .lp-stat { border-bottom: 1px solid rgba(255,255,255,0.08); }
}

/* ---- FULL-BLEED PHOTO QUOTE BAND ---- */
.lp-quoteband {
  position: relative; min-height: 460px;
  display: flex; align-items: center; justify-content: center;
  padding: 96px 32px; overflow: hidden;
  background: var(--dark-gray);
}
.lp-quoteband image-slot { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.lp-quoteband-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(12,11,9,0.55), rgba(12,11,9,0.78));
}
.lp-quoteband-inner { position: relative; max-width: 900px; text-align: center; }
.lp-quoteband-kicker {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--accent); display: block; margin-bottom: 26px;
}
.lp-quoteband-text {
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(30px, 4.6vw, 58px); line-height: 1.18;
  letter-spacing: -0.01em; color: var(--off-white);
}
.lp-quoteband-text em { font-style: normal; color: var(--accent); }

/* ---- STATION INFOGRAPHIC ---- */
.lp-stations { padding: var(--lp-gap) 32px; background: var(--warm-white); }
.lp-stations-inner { max-width: 1080px; margin: 0 auto; }
.lp-stations-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--section-border);
  border-left: 1px solid var(--section-border);
  margin-top: 30px;
}
.lp-station {
  padding: 24px 22px 26px;
  border-right: 1px solid var(--section-border);
  border-bottom: 1px solid var(--section-border);
}
.lp-station-num {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.14em; color: var(--accent-dark); margin-bottom: 14px;
}
.lp-station-name {
  font-family: var(--font-serif); font-size: 21px; font-weight: 400;
  line-height: 1.15; color: var(--black); margin-bottom: 8px;
}
.lp-station-tag {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--mid-gray);
}
.lp-stations-note {
  margin-top: 28px; padding: 24px 30px;
  border-left: 2px solid var(--accent); background: var(--accent-fill-08);
  display: flex; gap: 20px; align-items: baseline; flex-wrap: wrap;
}
.lp-stations-note-num {
  font-family: var(--font-serif); font-size: 40px; color: var(--accent-dark); line-height: 1;
}
.lp-stations-note p {
  font-family: var(--font-serif); font-size: clamp(18px, 2vw, 23px);
  line-height: 1.45; color: var(--black); flex: 1; min-width: 240px;
}
.lp-stations-note em { font-style: normal; color: var(--accent-dark); }
@media(max-width: 820px) { .lp-stations-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width: 460px) { .lp-stations-grid { grid-template-columns: 1fr; } }

/* ---- ABOUT TIMELINE (replaces stacked paragraphs) ---- */
.lp-timeline { margin: 8px 0 8px; }
.lp-tl-item {
  display: grid; grid-template-columns: 64px 1fr; gap: 22px;
  padding: 22px 0; border-bottom: 1px solid var(--section-border);
}
.lp-tl-item:first-child { border-top: 1px solid var(--section-border); }
.lp-tl-num {
  font-family: var(--font-serif); font-size: 44px; line-height: 1;
  color: var(--accent); font-weight: 600;
}
.lp-tl-h4 {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--black); margin-bottom: 10px; padding-top: 8px;
}
.lp-tl-p { font-size: 15px; line-height: 1.7; color: var(--body-ink-soft); }

/* ---- TWO-UP TESTIMONIAL CARDS (asset format) ---- */
.lp-testi2-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 52px; margin-top: 36px;
}
@media(max-width: 800px) { .lp-testi2-grid { grid-template-columns: 1fr; gap: 64px; } }
.t2-photo { aspect-ratio: 764 / 491; width: 100%; margin-bottom: 26px; background: var(--dark-gray); }
.t2-photo image-slot { width: 100%; height: 100%; display: block; }
.t2-kicker {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-dark); margin-bottom: 20px;
}
.t2-quote {
  font-family: var(--font-serif);
  font-size: clamp(19px, 2.1vw, 23px); line-height: 1.5;
  color: var(--black); margin-bottom: 26px;
}
.t2-rule { height: 1px; background: var(--section-border); margin-bottom: 24px; }
.t2-stat { display: flex; align-items: baseline; gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.t2-stat-before {
  font-family: var(--font-mono); font-size: 16px;
  color: var(--mid-gray); text-decoration: line-through;
  text-decoration-color: var(--warning-dot);
}
.t2-stat-arrow { color: var(--accent-dark); font-family: var(--font-mono); font-size: 14px; }
.t2-stat-after {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(34px, 4.6vw, 46px); letter-spacing: -0.02em;
  line-height: 1; color: var(--accent-dark);
}
.t2-stat-label {
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mid-gray); margin-left: 4px;
}
.t2-block { margin-bottom: 20px; }
.t2-block:last-child { margin-bottom: 0; }
.t2-label {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--mid-gray); display: block; margin-bottom: 10px;
}
.t2-before { font-size: 15px; line-height: 1.7; color: var(--body-ink-soft); }
.t2-after {
  font-family: var(--font-serif); font-size: clamp(20px, 2.3vw, 26px);
  line-height: 1.3; color: var(--black);
}
.t2-after em { font-style: normal; color: var(--accent-dark); }
