body { background: var(--parch); color: var(--ink); }
.wrap { padding: 0 72px; }
.section { padding: 120px 0; }

/* ==========================================================
   CS-CL3 — THE MONEY PAGE
   Unique visual: animated accounting ledger + break-even dial
   ========================================================== */

/* ── HERO ────────────────────────────────────────── */
.hero {
  min-height: 100vh; background: var(--void);
  display: flex; flex-direction: column;
  padding-top: 64px; position: relative; overflow: hidden;
}
.hero::before {
  content: ''; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  background-size: 256px; pointer-events: none; z-index: 0; opacity: .6;
}
.hero::after {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 65% 55% at 100% 50%, rgba(21,128,61,.07) 0%, transparent 55%),
    radial-gradient(ellipse 55% 65% at 0% 100%, rgba(181,136,58,.05) 0%, transparent 55%);
  pointer-events: none; z-index: 0;
}
.hero-grid {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size: 80px 80px;
}
/* Ghost — 43 (the multiple) */
.hero-ghost {
  position: absolute; right: -2%; top: 50%; transform: translateY(-52%);
  font-family: 'Playfair Display', serif;
  font-size: min(50vw, 640px);
  font-weight: 700; line-height: 1; color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,.04);
  pointer-events: none; user-select: none;
  letter-spacing: -.04em; z-index: 1;
}
.hero-content {
  position: relative; z-index: 2;
  max-width: 1160px; margin: 0 auto;
  padding: 0 72px 100px; width: 100%;
  display: flex; flex-direction: column; flex: 1;
}
.hero-top {
  flex: 1; display: flex; flex-direction: column;
  justify-content: center; padding: 64px 0 48px;
}
.hero-kicker {
  font-family: 'DM Mono', monospace; font-size: 11px;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold-l); display: flex; align-items: center; gap: 14px; margin-bottom: 48px;
}
.hero-kicker::before { content: ''; width: 36px; height: 1px; background: var(--gold); display: block; }
.hero-kicker .sep { opacity: .4; }
.hero-h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(52px, 7.5vw, 108px);
  font-weight: 400; line-height: .93; letter-spacing: -.03em;
  color: var(--snow); max-width: 820px;
}
.hero-h1 em { font-style: italic; color: var(--gold-l); }
.hero-h1 .g-em { font-style: italic; color: var(--green-l); }
.hero-rule {
  width: 100%; height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,.12) 0%, transparent 65%);
  margin-bottom: 48px; flex-shrink: 0;
}
.hero-bottom { display: grid; grid-template-columns: 1fr auto; gap: 80px; align-items: end; }
.hero-desc {
  font-size: 17px; line-height: 1.8;
  color: rgba(248,248,246,.5); max-width: 520px; font-weight: 300;
}
.hero-desc strong { color: rgba(248,248,246,.8); font-weight: 500; }
.hero-stats { display: flex; border: 1px solid var(--border-d); flex-shrink: 0; }
.hs {
  padding: 28px 36px; background: rgba(255,255,255,.035);
  border-right: 1px solid var(--border-d);
  transition: background .3s; text-align: center; min-width: 130px;
}
.hs:last-child { border-right: none; }
.hs:hover { background: rgba(255,255,255,.07); }
.hs-val {
  font-family: 'Playfair Display', serif; font-size: 38px; font-weight: 700;
  color: var(--snow); line-height: 1; margin-bottom: 7px; letter-spacing: -.025em;
}
.hs-val .acc  { color: var(--gold-l); }
.hs-val .gacc { color: var(--green-l); }
.hs-lbl {
  font-family: 'DM Mono', monospace; font-size: 9px;
  letter-spacing: .14em; text-transform: uppercase; color: rgba(248,248,246,.28);
}

/* ==========================================================
   S1 — THE ACCOUNTING LEDGER (centrepiece)
   A full debit/credit financial statement. The one visual
   that doesn't exist in any other case study in this portfolio.
   ========================================================== */

.ledger-wrap {
  margin-top: 64px; background: var(--void);
  border: 1px solid var(--border-d);
  overflow: hidden;
}

/* Ledger header */
.ledger-header {
  display: grid; grid-template-columns: 1fr 200px 200px;
  background: rgba(181,136,58,.08);
  border-bottom: 1px solid rgba(181,136,58,.2);
}
.lh-cell {
  padding: 18px 28px;
  font-family: 'DM Mono', monospace; font-size: 10px;
  letter-spacing: .22em; text-transform: uppercase;
  border-right: 1px solid rgba(181,136,58,.15);
}
.lh-cell:last-child { border-right: none; }
.lh-cell.dr { color: var(--red);     }
.lh-cell.cr { color: var(--green-l); }
.lh-cell.desc { color: rgba(248,248,246,.35); }

/* Ledger section headers */
.ledger-section-head {
  padding: 10px 28px;
  background: rgba(255,255,255,.025);
  border-bottom: 1px solid var(--border-d);
  font-family: 'DM Mono', monospace; font-size: 9px;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(248,248,246,.22);
}

/* Ledger rows */
.ledger-row {
  display: grid; grid-template-columns: 1fr 200px 200px;
  border-bottom: 1px solid var(--border-d);
  transition: background .2s;
}
.ledger-row:last-child { border-bottom: none; }
.ledger-row:hover { background: rgba(255,255,255,.025); }
.ledger-row.total-row {
  background: rgba(22,163,74,.07);
  border-top: 1px solid rgba(22,163,74,.25);
  border-bottom: 1px solid rgba(22,163,74,.25);
}
.ledger-row.total-row:hover { background: rgba(22,163,74,.1); }
.ledger-row.invest-total {
  background: rgba(185,28,28,.05);
  border-top: 1px solid rgba(185,28,28,.15);
}

.lr-desc {
  padding: 20px 28px;
  border-right: 1px solid var(--border-d);
  display: flex; flex-direction: column; justify-content: center;
}
.lr-main { font-size: 14px; font-weight: 500; color: rgba(248,248,246,.75); }
.lr-sub  { font-size: 12px; color: rgba(248,248,246,.3); margin-top: 3px; }
.ledger-row.total-row .lr-main { color: var(--green-l); font-weight: 600; font-size: 15px; }
.ledger-row.invest-total .lr-main { color: rgba(248,248,246,.9); font-weight: 600; }

.lr-val {
  padding: 20px 28px;
  border-right: 1px solid var(--border-d);
  display: flex; align-items: center; justify-content: flex-end;
  font-family: 'DM Mono', monospace;
}
.lr-val:last-child { border-right: none; }

.lr-num {
  font-family: 'Playfair Display', serif;
  font-size: 22px; font-weight: 700; letter-spacing: -.02em;
}
.lr-num.dr { color: #f87171; }
.lr-num.cr { color: var(--green-l); }
.lr-num.cr-big {
  color: var(--green-l);
  font-size: 32px;
}
.lr-num.dr-total { color: #f87171; font-size: 26px; }
.lr-num.muted { color: rgba(248,248,246,.2); font-size: 13px; font-family: 'Instrument Sans', sans-serif; font-style: italic; }

/* Ledger footer — the multiple */
.ledger-footer {
  display: grid; grid-template-columns: 1fr auto;
  gap: 48px; align-items: center;
  padding: 48px 52px;
  background: rgba(22,163,74,.06);
  border-top: 2px solid var(--green-l);
}
.lf-label {
  font-family: 'DM Mono', monospace; font-size: 10px;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(248,248,246,.3); margin-bottom: 10px;
}
.lf-verdict {
  font-family: 'Playfair Display', serif;
  font-size: 22px; font-weight: 400; color: var(--snow);
  line-height: 1.2; letter-spacing: -.01em;
}
.lf-verdict em { font-style: italic; color: var(--green-l); }
.lf-multiple {
  font-family: 'Playfair Display', serif;
  font-size: 96px; font-weight: 700; line-height: 1;
  color: var(--green-l); letter-spacing: -.04em;
  white-space: nowrap;
}
.lf-multiple span { font-size: 44px; color: rgba(22,163,74,.5); }

/* ── S2: THE BREAK-EVEN ──────────────────────────── */
/*
  Unique visual: a comparison panel showing the abyss between
  "covers needed to break even" and "covers actually attributed."
  Nothing like it in the portfolio.
*/
.breakeven-wrap {
  margin-top: 64px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 3px; background: var(--parch-dd);
}

.be-panel {
  padding: 64px 56px;
  display: flex; flex-direction: column;
}
.be-panel.needed { background: var(--white); }
.be-panel.actual { background: var(--void); }

.be-eyebrow {
  font-family: 'DM Mono', monospace; font-size: 10px;
  letter-spacing: .2em; text-transform: uppercase;
  margin-bottom: 20px;
}
.be-panel.needed .be-eyebrow { color: var(--mute); }
.be-panel.actual .be-eyebrow { color: var(--green-l); }

.be-num {
  font-family: 'Playfair Display', serif;
  font-size: 104px; font-weight: 700; line-height: 1;
  letter-spacing: -.04em; margin-bottom: 10px;
}
.be-panel.needed .be-num { color: var(--ink); }
.be-panel.actual .be-num { color: var(--green-l); }

.be-unit {
  font-size: 16px; font-weight: 600; margin-bottom: 24px;
}
.be-panel.needed .be-unit { color: var(--mute); }
.be-panel.actual .be-unit { color: rgba(248,248,246,.5); }

.be-desc {
  font-size: 15px; line-height: 1.8; flex: 1;
}
.be-panel.needed .be-desc { color: var(--mute); }
.be-panel.actual .be-desc { color: rgba(248,248,246,.4); }
.be-panel.needed .be-desc strong { color: var(--ink); }
.be-panel.actual .be-desc strong { color: var(--snow); }

/* Visual covers meter — stacked bars */
.be-meter { margin-top: 32px; }
.be-meter-label {
  font-family: 'DM Mono', monospace; font-size: 9px;
  letter-spacing: .16em; text-transform: uppercase;
  margin-bottom: 8px;
}
.be-panel.needed .be-meter-label { color: var(--mute); }
.be-panel.actual .be-meter-label { color: rgba(248,248,246,.28); }
.be-meter-track {
  height: 10px; position: relative; overflow: hidden;
}
.be-panel.needed .be-meter-track { background: var(--parch-d); }
.be-panel.actual .be-meter-track { background: rgba(255,255,255,.05); }
.be-meter-fill {
  height: 100%; width: 0;
  transition: width 1.4s cubic-bezier(.22,1,.36,1);
}
.be-panel.needed .be-meter-fill { background: var(--mute); }
.be-panel.actual .be-meter-fill {
  background: linear-gradient(90deg, var(--green-l), rgba(22,163,74,.6));
}

/* The chasm — connector between panels */
.be-chasm {
  grid-column: 1 / -1;
  background: var(--void);
  padding: 40px 56px;
  display: flex; align-items: center; gap: 48px;
  border-top: 1px solid var(--border-d);
}
.be-chasm-num {
  font-family: 'Playfair Display', serif;
  font-size: 72px; font-weight: 700; line-height: 1;
  color: var(--gold-l); letter-spacing: -.04em; flex-shrink: 0;
}
.be-chasm-txt {
  font-size: 17px; line-height: 1.75; color: rgba(248,248,246,.5);
}
.be-chasm-txt strong { color: var(--snow); font-weight: 500; }

/* ── S3: WHERE THE MONEY CAME FROM ───────────────── */
/*
  Four channel cards — each showing covers attributed,
  revenue implied, and the mechanism. Unique layout:
  two tall left cards + right column with stacked detail.
*/
.channel-grid {
  margin-top: 64px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3px; background: var(--parch-dd);
}
.ch-card {
  background: var(--white); padding: 52px 48px;
  transition: background .25s; display: flex; flex-direction: column;
}
.ch-card:hover { background: var(--parch); }
.ch-card.dark { background: var(--void); }
.ch-card.dark:hover { background: var(--void-l); }

.ch-cat {
  font-family: 'DM Mono', monospace; font-size: 9px;
  letter-spacing: .2em; text-transform: uppercase;
  margin-bottom: 16px;
}
.ch-card:not(.dark) .ch-cat { color: var(--mute); }
.ch-card.dark       .ch-cat { color: rgba(248,248,246,.28); }

.ch-covers {
  font-family: 'Playfair Display', serif;
  font-size: 64px; font-weight: 700; line-height: 1;
  letter-spacing: -.035em; margin-bottom: 6px;
}
.ch-card:not(.dark) .ch-covers { color: var(--ink); }
.ch-card.dark       .ch-covers { color: var(--gold-l); }
.ch-covers .unit { font-size: 26px; color: var(--green-l); }

.ch-cover-lbl {
  font-size: 13px; font-weight: 600; margin-bottom: 20px;
}
.ch-card:not(.dark) .ch-cover-lbl { color: var(--mute); }
.ch-card.dark       .ch-cover-lbl { color: rgba(248,248,246,.35); }

.ch-implied {
  display: flex; align-items: baseline; gap: 8px;
  padding: 14px 18px;
  margin-bottom: 24px; width: fit-content;
}
.ch-card:not(.dark) .ch-implied { background: var(--green-bg); }
.ch-card.dark       .ch-implied { background: rgba(22,163,74,.1); }
.ch-implied-lbl {
  font-family: 'DM Mono', monospace; font-size: 9px;
  letter-spacing: .14em; text-transform: uppercase; color: var(--green-l);
}
.ch-implied-val {
  font-family: 'Playfair Display', serif;
  font-size: 20px; font-weight: 700; color: var(--green-l);
  letter-spacing: -.02em;
}

.ch-desc { font-size: 14px; line-height: 1.75; flex: 1; }
.ch-card:not(.dark) .ch-desc { color: var(--mute); }
.ch-card.dark       .ch-desc { color: rgba(248,248,246,.4); }
.ch-card:not(.dark) .ch-desc strong { color: var(--ink); font-weight: 600; }
.ch-card.dark       .ch-desc strong { color: var(--snow); font-weight: 500; }

/* ── S4: THE COMPOUNDING ARGUMENT ───────────────── */
/*
  What 43× looks like when the infrastructure is permanent.
  Year-over-year projection grid. Unique to this CS.
*/
.compound-block {
  margin-top: 64px; background: var(--void);
  padding: 72px; position: relative; overflow: hidden;
}
.compound-block::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 60% at 100% 100%, rgba(181,136,58,.06) 0%, transparent 55%);
  pointer-events: none;
}

.compound-intro {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px; margin-bottom: 56px; padding-bottom: 56px;
  border-bottom: 1px solid var(--border-d);
  position: relative; z-index: 1;
}
.ci-eyebrow {
  font-family: 'DM Mono', monospace; font-size: 10px;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(248,248,246,.28); margin-bottom: 16px;
}
.ci-h {
  font-family: 'Playfair Display', serif;
  font-size: 32px; font-weight: 400; color: var(--snow);
  line-height: 1.1; letter-spacing: -.02em; margin-bottom: 0;
}
.ci-h em { font-style: italic; color: var(--gold-l); }
.ci-right {
  font-size: 15px; line-height: 1.85; color: rgba(248,248,246,.45);
  padding-top: 4px;
}
.ci-right strong { color: var(--snow); font-weight: 500; }

/* Year rows */
.compound-years {
  display: flex; flex-direction: column; gap: 3px;
  position: relative; z-index: 1;
}

.cy-row {
  display: grid; grid-template-columns: 100px 1fr 180px 160px;
  gap: 0; background: rgba(255,255,255,.03);
  border-left: 3px solid transparent;
  transition: background .2s;
}
.cy-row:hover { background: rgba(255,255,255,.05); }
.cy-row.y1 { border-left-color: var(--gold);    }
.cy-row.y2 { border-left-color: var(--green-l); }
.cy-row.y3 { border-left-color: rgba(22,163,74,.55); }
.cy-row.future { border-left-color: rgba(22,163,74,.25); }

.cy-cell {
  padding: 22px 24px;
  border-right: 1px solid var(--border-d);
  display: flex; align-items: center;
}
.cy-cell:last-child { border-right: none; }

.cy-year {
  font-family: 'DM Mono', monospace; font-size: 11px;
  letter-spacing: .1em; color: rgba(248,248,246,.3);
}
.cy-row.y1 .cy-year { color: var(--gold-l); }
.cy-row.y2 .cy-year,
.cy-row.y3 .cy-year { color: var(--green-l); }

.cy-what {
  font-size: 13px; font-weight: 500; color: rgba(248,248,246,.55);
}
.cy-row.y1 .cy-what { color: rgba(248,248,246,.75); }
.cy-row.y2 .cy-what { color: rgba(248,248,246,.75); }

.cy-infra {
  display: flex; flex-direction: column; gap: 3px;
}
.cy-infra-item {
  font-family: 'DM Mono', monospace; font-size: 9px;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 3px 10px; width: fit-content;
}
.cy-infra-item.live { background: var(--green-bg); color: var(--green-l); }
.cy-infra-item.comp { background: rgba(181,136,58,.1); color: var(--gold-l); }
.cy-infra-item.next { background: rgba(255,255,255,.04); color: rgba(248,248,246,.2); }

.cy-roi {
  font-family: 'Playfair Display', serif;
  font-size: 28px; font-weight: 700; color: var(--snow);
  letter-spacing: -.02em; justify-content: flex-end;
}
.cy-row.y2 .cy-roi { color: var(--green-l); }
.cy-row.y3 .cy-roi,
.cy-row.future .cy-roi { color: rgba(22,163,74,.6); font-size: 22px; }

/* Compound note */
.compound-note {
  margin-top: 32px; padding: 24px 28px;
  background: rgba(181,136,58,.06); border-left: 3px solid var(--gold);
  position: relative; z-index: 1;
}
.compound-note-txt {
  font-size: 14px; line-height: 1.75; color: rgba(248,248,246,.5);
}
.compound-note-txt strong { color: var(--gold-l); font-weight: 500; }

/* ── S5: THE ASSUMPTIONS (transparency section) ──── */
/*
  Shows the conservative methodology openly —
  what was claimed vs what could have been claimed.
  Builds credibility by showing the numbers were deliberately understated.
*/
.assumptions-layout {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 3px; background: var(--border-l); margin-top: 64px;
}
.as-panel {
  padding: 56px 52px;
}
.as-panel.conservative { background: var(--white); }
.as-panel.full         { background: var(--parch); }

.as-tag {
  font-family: 'DM Mono', monospace; font-size: 9px;
  letter-spacing: .2em; text-transform: uppercase;
  display: flex; align-items: center; gap: 10px; margin-bottom: 20px;
}
.as-panel.conservative .as-tag { color: var(--green-l); }
.as-panel.conservative .as-tag::before { content: ''; width: 20px; height: 1px; background: var(--green-l); display: block; }
.as-panel.full .as-tag { color: var(--amber); }
.as-panel.full .as-tag::before { content: ''; width: 20px; height: 1px; background: var(--amber); display: block; }

.as-h {
  font-family: 'Playfair Display', serif;
  font-size: 24px; font-weight: 400; line-height: 1.1;
  letter-spacing: -.015em; margin-bottom: 28px;
}
.as-panel.conservative .as-h { color: var(--ink); }
.as-panel.full .as-h { color: var(--ink); }
.as-h em { font-style: italic; }
.as-panel.conservative .as-h em { color: var(--green-l); }
.as-panel.full .as-h em { color: var(--amber); }

.as-rows { display: flex; flex-direction: column; gap: 0; }
.as-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 14px 0; border-bottom: 1px solid var(--border-l);
}
.as-row:first-child { border-top: 1px solid var(--border-l); }
.as-k { font-size: 13px; color: var(--mute); }
.as-v { font-size: 15px; font-weight: 600; }
.as-panel.conservative .as-v.chosen { color: var(--green-l); }
.as-panel.full .as-v.full-v { color: var(--amber); }
.as-v.neutral { color: var(--ink); }

.as-result-big {
  margin-top: 28px; padding: 28px 32px;
}
.as-panel.conservative .as-result-big { background: var(--green-bg); }
.as-panel.full         .as-result-big { background: var(--amber-bg); }
.as-result-label {
  font-family: 'DM Mono', monospace; font-size: 9px;
  letter-spacing: .18em; text-transform: uppercase; margin-bottom: 8px;
}
.as-panel.conservative .as-result-label { color: var(--green-l); }
.as-panel.full         .as-result-label { color: var(--amber); }
.as-result-num {
  font-family: 'Playfair Display', serif;
  font-size: 48px; font-weight: 700; letter-spacing: -.03em; line-height: 1;
}
.as-panel.conservative .as-result-num { color: var(--green-l); }
.as-panel.full         .as-result-num { color: var(--amber); }
.as-result-sub { font-size: 13px; margin-top: 6px; }
.as-panel.conservative .as-result-sub { color: rgba(21,128,61,.6); }
.as-panel.full         .as-result-sub { color: rgba(180,83,9,.7); }

/* ── S6: ROI ─────────────────────────────────────── */
.roi-block {
  background: var(--green-l); padding: 72px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
}
.roi-label {
  font-family: 'DM Mono', monospace; font-size: 10px;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,255,255,.5); margin-bottom: 16px;
}
.roi-big {
  font-family: 'Playfair Display', serif;
  font-size: 88px; font-weight: 700; line-height: 1;
  color: var(--white); letter-spacing: -.04em; margin-bottom: 12px;
}
.roi-sub { font-size: 16px; color: rgba(255,255,255,.65); line-height: 1.65; }
.roi-sub strong { color: var(--white); font-weight: 600; }
.roi-right p {
  font-size: 16px; line-height: 1.85;
  color: rgba(255,255,255,.7); margin-bottom: 24px;
}
.roi-right p:last-child { margin-bottom: 0; }
.roi-right strong { color: var(--white); font-weight: 500; }

/* ── CTA ─────────────────────────────────────────── */
.cta-section {
  background: var(--void); padding: 160px 72px;
  text-align: center; position: relative; overflow: hidden;
}
.cta-section::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(181,136,58,.07) 0%, transparent 65%);
  pointer-events: none;
}
.cta-section::after {
  content: ''; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  background-size: 256px; pointer-events: none; opacity: .5;
}
.cta-inner { position: relative; z-index: 2; max-width: 680px; margin: 0 auto; }
.cta-kicker {
  font-family: 'DM Mono', monospace; font-size: 11px;
  letter-spacing: .24em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 36px; display: flex; align-items: center; justify-content: center; gap: 16px;
}
.cta-kicker::before, .cta-kicker::after { content: ''; display: block; width: 40px; height: 1px; background: var(--gold); }
.cta-h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(36px, 5vw, 68px);
  font-weight: 400; line-height: 1.05;
  letter-spacing: -.025em; color: var(--snow); margin-bottom: 28px;
}
.cta-h2 em { font-style: italic; color: var(--gold-l); }
.cta-sub {
  font-size: 17px; line-height: 1.8;
  color: rgba(248,248,246,.42); margin-bottom: 52px; font-weight: 300;
  max-width: 500px; margin-left: auto; margin-right: auto;
}
.cta-actions { display: flex; align-items: center; justify-content: center; gap: 20px; flex-wrap: wrap; }
.cta-note {
  margin-top: 24px; font-family: 'DM Mono', monospace; font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase; color: rgba(248,248,246,.2);
}

@media (max-width: 1360px) {
  .hero-bottom { grid-template-columns: 1fr; gap: 48px; }
  .hero-stats { width: fit-content; max-width: 100%; }
}

/* ── RESPONSIVE ──────────────────────────────────── */
@media (max-width: 1060px) {
  .wrap { padding: 0 48px; }
  .hero-content { padding: 0 48px 80px; }
  .hero-bottom { grid-template-columns: 1fr; gap: 48px; }
  .ledger-header,
  .ledger-row { grid-template-columns: 1fr 160px 160px; }
  .breakeven-wrap { grid-template-columns: 1fr; }
  .be-chasm { flex-direction: column; gap: 16px; }
  .be-chasm-num { font-size: 52px; }
  .channel-grid { grid-template-columns: 1fr; }
  .compound-intro { grid-template-columns: 1fr; gap: 28px; }
  .cy-row { grid-template-columns: 80px 1fr 160px; }
  .cy-cell:nth-child(3) { display: none; }
  .assumptions-layout { grid-template-columns: 1fr; }
  .roi-block { grid-template-columns: 1fr; padding: 56px 48px; gap: 40px; }
  .roi-big { font-size: 64px; }
  .compound-block { padding: 48px; }
  .site-footer { grid-template-columns: 1fr; padding: 40px; }
  .footer-bottom { padding: 20px 40px; }
  .cta-section { padding: 120px 48px; }
}
@media (max-width: 720px) {
  .nav { padding: 0 24px; }
  .nav-links, .nav-cta { display: none; }
  .nav-toggle { display: flex; }
  .wrap { padding: 0 24px; }
  .hero-content { padding: 0 24px 80px; }
  .hero-h1 { font-size: clamp(46px, 11vw, 80px); }
  .hero-stats { flex-direction: column; }
  .hs { border-right: none; border-bottom: 1px solid var(--border-d); }
  .hs:last-child { border-bottom: none; }
  .ledger-header,
  .ledger-row { grid-template-columns: 1fr 130px; }
  .ledger-header .lh-cell.dr,
  .ledger-row .lr-val:first-of-type { display: none; }
  .be-num { font-size: 72px; }
  .be-panel { padding: 44px 32px; }
  .cy-row { grid-template-columns: 56px 1fr 88px; }
  .lf-multiple { font-size: 72px; }
  .ledger-footer { flex-direction: column; gap: 16px; }
  .compound-block { padding: 32px 24px; }
  .roi-block { padding: 48px 24px; }
  .cta-section { padding: 80px 24px; }
  .site-footer { padding: 40px 24px; gap: 32px; }
  .footer-bottom { padding: 20px 24px; flex-direction: column; gap: 8px; text-align: center; }
}
