/* =========================================================
   GROUNDLY — INVESTOR DECK v2
   Floating cards on cream. Lime accent. Monospace chrome.
   ========================================================= */

html {
  color-scheme: light only;
}

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

:root {
  --slide-w: 1920px;
  --slide-h: 1080px;

  /* ==========================================================
     TYPOGRAPHY DESIGN TOKENS — USE THESE FOR ALL TEXT
     ==========================================================
     FONT: Inter (body + display) / JetBrains Mono (labels only)
     ========================================================== */

  /* — Sizes — */
  --t-mega:      120px;  /* hero moments only: $3M, Thanks */
  --t-hero:       92px;  /* slide 1 title */
  --t-headline:   72px;  /* all other slide headlines (H2) */
  --t-title:      32px;  /* card titles (H3) */
  --t-lead:       24px;  /* subtitles, lead paragraphs */
  --t-body:       20px;  /* primary body text */
  --t-body-sm:    17px;  /* small body (only where space demands) */
  --t-label:      14px;  /* mono section labels */
  --t-tag:        12px;  /* mono small tags / chip text */

  /* — Weights — */
  --w-regular: 400;
  --w-medium:  500;
  --w-semibold:600;
  --w-bold:    700;

  /* — Line heights — */
  --lh-tight:   1.0;
  --lh-snug:    1.1;
  --lh-body:    1.5;
  --lh-relaxed: 1.45;

  /* — Letter spacing — */
  --ls-hero:     -0.04em;
  --ls-headline: -0.035em;
  --ls-title:    -0.025em;
  --ls-body:     -0.005em;
  --ls-mono:     0.08em;

  /* Palette */
  --bg: #e8e5dc;
  --card-light: #fbfaf5;
  --card-dark: #0d0d0e;
  --ink: #0d0d0e;
  --ink-dim: #6e6b63;
  --ink-on-dark: #f4f2eb;
  --ink-dim-on-dark: rgba(244, 242, 235, 0.55);
  --hairline: rgba(14, 14, 16, 0.1);
  --hairline-strong: rgba(14, 14, 16, 0.2);
  --hairline-on-dark: rgba(244, 242, 235, 0.12);

  --lime: #c8f15b;
  --lime-soft: #dff085;
  --lime-deep: #8fb72e;

  --font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: "JetBrains Mono", "SF Mono", Menlo, monospace;
}

/* ============================================================
   TYPE SYSTEM — applied globally, overridable per slide only
   when a hero moment requires it.

   HEADLINES (H2):  72px / 700 / -0.035em / lh 1.0
   LEADS (subtitle): 24px / 400 / -0.005em / lh 1.45
   CARD TITLES (H3): 32px / 700 / -0.025em / lh 1.1
   BODY:            20px / 400 / -0.005em / lh 1.5
   MONO LABEL:      14px / 500 / 0.08em / uppercase
   ============================================================ */

html,
body {
  height: 100%;
  font-family: var(--font-sans);
  background: var(--bg);
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  /* Disable double-tap-to-zoom so fast tap-zone nav stays smooth on mobile.
     Pinch-zoom still works. */
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image: radial-gradient(
    circle at 1px 1px,
    rgba(14, 14, 16, 0.04) 1px,
    transparent 0
  );
  background-size: 18px 18px;
  pointer-events: none;
  z-index: 1;
}

.viewport {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

.deck {
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--slide-w);
  height: var(--slide-h);
  transform-origin: center center;
  transform: translate(-50%, -50%) scale(1);
}

.slide {
  position: absolute;
  inset: 0;
  width: var(--slide-w);
  height: var(--slide-h);
  display: none;
}

.slide.active {
  display: block;
}

/* =========================================================
   CARD
   ========================================================= */
.card {
  position: absolute;
  inset: 48px;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(14, 14, 16, 0.04),
    0 12px 40px rgba(14, 14, 16, 0.08),
    0 40px 120px rgba(14, 14, 16, 0.06);
}

.card--light {
  background: var(--card-light);
  color: var(--ink);
}

.card--dark {
  background: var(--card-dark);
  color: var(--ink-on-dark);
}

.card--dark::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(244, 242, 235, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244, 242, 235, 0.03) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}
.card--dark > * {
  position: relative;
  z-index: 1;
}

/* =========================================================
   CHROME
   ========================================================= */

.chrome-bar {
  display: none;
}

/* Reclaim the space where chrome-bar used to live (≈36px top offset).
   Equalize top/bottom padding so content sits centered in the card. */
.card > .slide-1-card,
.card > .slide-3-card,
.card > .slide-4-intro-card,
.card > .slide-5-stack-card,
.card > .slide-5-card,
.card > .slide-6-card,
.card > .slide-9-card,
.card > .slide-9-card--new,
.card > .slide-11-merged-card,
.card > .slide-12-card,
.card > .slide-13-card {
  padding-top: 56px;
  padding-bottom: 56px;
}

/* Flex-column wrappers center their content vertically so leftover
   space distributes evenly above and below. */
.card > .slide-1-card,
.card > .slide-3-card,
.card > .slide-4-intro-card,
.card > .slide-5-stack-card,
.card > .slide-5-card,
.card > .slide-6-card,
.card > .slide-9-card,
.card > .slide-9-card--new,
.card > .slide-11-merged-card,
.card > .slide-12-card {
  justify-content: center;
}

.card--dark .chrome-bar {
  color: var(--ink-dim-on-dark);
}

.chrome-brand {
  display: flex;
  align-items: center;
  gap: 8px;
}

.chrome-brand-mark {
  width: 10px;
  height: 10px;
  background: var(--lime);
  border-radius: 2px;
}

.chrome-section {
  display: flex;
  gap: 24px;
}

.chrome-right {
  text-align: right;
}

/* Corner registration dots */
.reg-dot {
  position: absolute;
  width: 6px;
  height: 6px;
  background: var(--ink-dim);
  opacity: 0.35;
  z-index: 3;
}
.card--dark .reg-dot {
  background: var(--ink-dim-on-dark);
  opacity: 0.5;
}
.reg-dot--tl { top: 20px; left: 20px; }
.reg-dot--tr { top: 20px; right: 20px; }
.reg-dot--bl { bottom: 20px; left: 20px; }
.reg-dot--br { bottom: 20px; right: 20px; }

/* Label mono */
.label-mono {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: var(--t-label);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.card--dark .label-mono {
  color: var(--ink-dim-on-dark);
}
.label-mono .dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--lime);
  flex-shrink: 0;
}

/* Pills */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid var(--hairline);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
  background: transparent;
  white-space: nowrap;
}
.card--dark .pill {
  border-color: var(--hairline-on-dark);
  color: var(--ink-on-dark);
}
.pill--lime {
  background: var(--lime);
  border-color: var(--lime);
  color: var(--ink);
}
.pill--ink {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--ink-on-dark);
}
.pill--sm {
  padding: 5px 10px;
  font-size: var(--t-tag);
}

.dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--lime);
  flex-shrink: 0;
  display: inline-block;
}

/* Highlight word — always dark text on lime, regardless of card context */
.hl,
.surface-card__title em.hl,
.surface-card--prize .surface-card__title em.hl {
  font-style: normal;
  background: var(--lime);
  color: var(--ink);
  padding: 0.06em 10px 0.08em;
  margin: 0 -2px;
  border-radius: 8px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

/* Standard header block (label + title) */
.slide-header {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 40px;
}

/* =========================================================
   SLIDE 1 — TITLE
   ========================================================= */

.slide-1-card {
  position: relative;
  height: 100%;
  padding: 0;
  overflow: hidden;
}

/* Ambient scene — sits in the background, behind everything */
.s1-scene {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.s1-lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

/* Agent markers at top — represent ChatGPT/Claude/Gemini pulling from the layer */
.s1-agent {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  background: rgba(13, 13, 14, 0.92);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #f4f2eb;
  font-weight: 600;
  box-shadow: 0 4px 14px rgba(14, 14, 16, 0.15);
}

.s1-agent__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 8px rgba(200, 241, 91, 0.7);
}

.s1-agent--1 { top: 90px; right: 520px; }
.s1-agent--2 { top: 60px; right: 260px; }
.s1-agent--3 { top: 140px; right: 80px; }

/* Mini profile cards — scattered representing the registry */
.s1-mini {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px 10px 12px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(13, 13, 14, 0.08);
  border-radius: 10px;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 16px rgba(14, 14, 16, 0.06);
  max-width: 240px;
}

.s1-mini__mark {
  width: 14px;
  height: 14px;
  background: var(--lime);
  border-radius: 3px;
  flex-shrink: 0;
}

.s1-mini__body {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}

.s1-mini__name {
  font-size: 12px;
  font-weight: 700;
  color: #0d0d0e;
  letter-spacing: -0.01em;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.s1-mini__type {
  font-family: var(--font-mono);
  font-size: 9px;
  color: rgba(13, 13, 14, 0.55);
  letter-spacing: 0.08em;
}

.s1-mini--1 { bottom: 220px; right: 680px; transform: rotate(-3deg); }
.s1-mini--2 { bottom: 120px; right: 420px; transform: rotate(1.5deg); }
.s1-mini--3 { bottom: 240px; right: 100px; transform: rotate(2deg); }

/* Text overlay — sits above the scene */
.s1-overlay {
  position: absolute;
  inset: 72px 72px 72px 72px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  z-index: 3;
  pointer-events: none;
}

.s1-overlay > * { pointer-events: auto; }

.wordmark {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: inherit;
  align-self: flex-start;
}

.wordmark-mark {
  width: 16px;
  height: 16px;
  background: var(--lime);
  border-radius: 4px;
  box-shadow: 0 0 20px rgba(200, 241, 91, 0.6);
}

.s1-overlay__main {
  max-width: 980px;
}

.s1-headline {
  font-size: 88px;
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.04;
  max-width: 960px;
}

.s1-subhead {
  font-size: 19px;
  font-weight: 400;
  color: var(--ink);
  opacity: 0.8;
  line-height: 1.55;
  max-width: 540px;
  margin-top: 28px;
}

.s1-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  align-self: flex-start;
}

/* The hero card sits centered-right in the scene */
.hero-v2 {
  position: absolute;
  top: 50%;
  right: 140px;
  transform: translateY(-50%);
  z-index: 2;
  width: 440px;
}

/* =========================================================
   SLIDE 1 — HERO V2 · floating profile card + telemetry
   ========================================================= */

/* Tracking brackets (corners around the card area) */
.bracket {
  position: absolute;
  width: 20px;
  height: 20px;
  border: 1.5px solid rgba(13, 13, 14, 0.5);
  z-index: 3;
  pointer-events: none;
}
.bracket--tl { top: -30px; left: -30px; border-right: 0; border-bottom: 0; }
.bracket--tr { top: -30px; right: -30px; border-left: 0; border-bottom: 0; }
.bracket--bl { bottom: -30px; left: -30px; border-right: 0; border-top: 0; }
.bracket--br { bottom: -30px; right: -30px; border-left: 0; border-top: 0; }

/* The profile card itself — glass-panel look */
.profile-card {
  width: 100%;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.98) 0%,
    rgba(252, 250, 244, 0.98) 100%
  );
  border: 1px solid rgba(13, 13, 14, 0.08);
  border-radius: 20px;
  padding: 26px 28px 22px;
  position: relative;
  z-index: 2;
  box-shadow:
    0 1px 2px rgba(14, 14, 16, 0.04),
    0 20px 50px rgba(14, 14, 16, 0.12),
    0 60px 120px rgba(14, 14, 16, 0.1);
}

/* Subtle drop shadow ellipse beneath (suggests floating) */
.profile-card::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  bottom: -28px;
  height: 14px;
  background: radial-gradient(
    ellipse at center,
    rgba(14, 14, 16, 0.14) 0%,
    rgba(14, 14, 16, 0) 70%
  );
  z-index: -1;
}

.profile-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 14px;
  margin-bottom: 14px;
  border-bottom: 1px solid rgba(13, 13, 14, 0.08);
}

.profile-card__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.profile-card__brand-mark {
  width: 24px;
  height: 24px;
  background: var(--lime);
  border-radius: 5px;
  box-shadow: 0 0 14px rgba(200, 241, 91, 0.45);
}

.profile-card__brand-name {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #0d0d0e;
}

.profile-card__id {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: rgba(13, 13, 14, 0.45);
  font-weight: 500;
}

.profile-card__body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.profile-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(13, 13, 14, 0.05);
}

.profile-field:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.profile-field__label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(13, 13, 14, 0.5);
  font-weight: 600;
}

.profile-field__value {
  font-size: 14px;
  font-weight: 600;
  color: #0d0d0e;
  letter-spacing: -0.005em;
}

.profile-field__meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: rgba(13, 13, 14, 0.5);
  letter-spacing: 0.03em;
  margin-top: 1px;
}

.profile-field__value--verified {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.profile-field__check {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--lime);
  position: relative;
  flex-shrink: 0;
}

.profile-field__check::before {
  content: "";
  position: absolute;
  left: 3px;
  top: 4px;
  width: 4px;
  height: 7px;
  border: solid #0d0d0e;
  border-width: 0 1.6px 1.6px 0;
  transform: rotate(45deg);
}

.profile-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid rgba(13, 13, 14, 0.08);
}

.profile-card__hash {
  font-family: var(--font-mono);
  font-size: 9px;
  color: rgba(13, 13, 14, 0.4);
  letter-spacing: 0.03em;
}

.profile-card__live {
  font-family: var(--font-mono);
  font-size: 9.5px;
  color: var(--lime-deep);
  letter-spacing: 0.14em;
  font-weight: 700;
}

/* Telemetry annotations */
.telem {
  position: absolute;
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
  color: rgba(13, 13, 14, 0.75);
  z-index: 3;
  pointer-events: none;
}

.telem--tl {
  top: -70px;
  left: -30px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.telem--tl .telem__val {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #0d0d0e;
}

.telem--tl .telem__sub {
  font-size: 10.5px;
  color: rgba(13, 13, 14, 0.55);
  font-weight: 500;
}

.telem__leader {
  width: 80px;
  height: 30px;
  margin-top: 4px;
}

.telem--right {
  top: 50%;
  right: -170px;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.telem__row {
  display: flex;
  align-items: baseline;
  gap: 10px;
}

.telem__row .telem__time {
  font-size: 10px;
  color: rgba(13, 13, 14, 0.48);
  font-weight: 500;
  letter-spacing: 0.05em;
}

.telem__row .telem__label {
  font-size: 10.5px;
  color: #0d0d0e;
  font-weight: 700;
  letter-spacing: 0.12em;
}

/* =========================================================
   SLIDE 2 — TEAM
   ========================================================= */

/* slide-2-card is now the GRAY inner layer sitting inside the white outer frame */
.slide-2-card {
  position: absolute;
  top: 44px;
  left: 44px;
  right: 44px;
  bottom: 44px;
  background: #eaeaea;
  border-radius: 24px;
  padding: 0;
  display: flex;
  gap: 28px;
  overflow: hidden;
}

/* LEFT dark sub-card — fits flush inside gray's left half */
.s2-left {
  flex: 2 1 0;
  min-width: 0;
  background: var(--card-dark);
  color: var(--ink-on-dark);
  border-top-left-radius: 24px;
  border-bottom-left-radius: 24px;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 20px;
  padding: 48px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.s2-left::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 70%;
  background: radial-gradient(
    ellipse 80% 100% at 50% 0%,
    rgba(200, 241, 91, 0.08),
    transparent 70%
  );
  pointer-events: none;
}

.s2-left::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(244, 242, 235, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244, 242, 235, 0.025) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}

.s2-left > * { position: relative; z-index: 2; }

.s2-left .label-mono {
  margin-bottom: 28px;
  color: rgba(244, 242, 235, 0.7);
}

.s2-left .label-mono .dot {
  background: var(--lime);
}

.s2-title {
  font-size: 62px;
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.0;
  margin-bottom: 28px;
  color: var(--ink-on-dark);
}

.s2-desc {
  font-size: 24px;
  line-height: 1.45;
  color: rgba(244, 242, 235, 0.88);
  margin-bottom: 40px;
  max-width: 560px;
  font-weight: 400;
  letter-spacing: -0.005em;
}

.s2-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.s2-pills .pill {
  background: rgba(244, 242, 235, 0.06);
  border-color: rgba(244, 242, 235, 0.14);
  color: rgba(244, 242, 235, 0.9);
  font-size: 12px;
}

/* Slides using the nested-layer pattern — pure white outer frame */
.slide[data-slide="2"] .card--light {
  background: #ffffff;
}

/* RIGHT — team content sits directly on the gray layer, no fill of its own */
.s2-right {
  flex: 3 1 0;
  min-width: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 24px 32px 24px 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  position: relative;
}

.member {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 32px;
  padding: 24px 4px;
  background: transparent;
  box-shadow: none;
  align-items: center;
  position: relative;
  border-radius: 0;
}

.member + .member {
  border-top: 1px solid rgba(14, 14, 16, 0.08);
}

.member__index {
  position: absolute;
  top: 30px;
  right: 4px;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  z-index: 2;
}

.member__photo {
  width: 220px;
  height: 220px;
  background: linear-gradient(135deg, #d6d3c9 0%, #a8a49c 60%, #88857d 100%);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(14, 14, 16, 0.28);
  font-size: 104px;
  font-weight: 600;
  letter-spacing: -0.03em;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  margin-bottom: 0;
  border: 1px solid rgba(14, 14, 16, 0.06);
}

.member__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(
    circle at 30% 30%,
    rgba(255, 255, 255, 0.3),
    transparent 55%
  );
}

.member__content {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding-right: 40px;
}

.member__name-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.member__name {
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--ink);
}

.member__verify {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  display: inline-block;
}

.member__role {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 14px;
}

.member__role--lead { color: var(--lime-deep); }

.member__bio {
  font-size: 22px;
  line-height: 1.4;
  color: var(--ink);
  font-weight: 400;
  letter-spacing: -0.005em;
}

.member__bio p + p {
  margin-top: 8px;
}

/* =========================================================
   SLIDE 3 — THE SHIFT
   ========================================================= */

/* slide-3-card — full dark slide (no nested pattern) */
.slide-3-card {
  position: absolute;
  top: 88px;
  left: 48px;
  right: 48px;
  bottom: 48px;
  padding: 32px 52px;
  display: flex;
  gap: 64px;
  align-items: center;
}

/* Subtle lime glow, top center */
.s3-glow {
  position: absolute;
  top: -10%;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  height: 70%;
  background: radial-gradient(
    ellipse at 50% 0%,
    rgba(200, 241, 91, 0.07),
    transparent 65%
  );
  pointer-events: none;
  z-index: 0;
}

/* LEFT — 33M hero directly on dark */
.s3-left {
  flex: 2 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.s3-left .label-mono {
  margin-bottom: 18px;
  color: rgba(244, 242, 235, 0.62);
}

.s3-left .label-mono .dot {
  background: var(--lime);
}

.s3-leadin {
  font-size: 20px;
  line-height: 1.4;
  color: rgba(244, 242, 235, 0.82);
  max-width: 520px;
  margin-bottom: 24px;
  font-weight: 400;
  letter-spacing: -0.005em;
}

.s3-megafigure {
  font-size: 220px;
  font-weight: 700;
  letter-spacing: -0.045em;
  line-height: 0.9;
  color: var(--ink-on-dark);
  margin-bottom: 20px;
}

.s3-megafigure em {
  font-style: normal;
  color: var(--lime);
}

.s3-megacaption {
  font-size: 24px;
  line-height: 1.4;
  color: rgba(244, 242, 235, 0.92);
  max-width: 520px;
  font-weight: 400;
  letter-spacing: -0.005em;
  margin-bottom: 36px;
}

.s3-megacaption p + p {
  margin-top: 8px;
}

.s3-megacaption strong {
  font-weight: 600;
  color: var(--ink-on-dark);
}

.s3-stats {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Disparity block — visual scale comparison: handful vs 33M */
.disparity {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 560px;
  padding: 16px 18px;
  border-radius: 12px;
  background: rgba(244, 242, 235, 0.04);
  border: 1px solid rgba(244, 242, 235, 0.1);
}

.disparity__row {
  display: grid;
  grid-template-columns: 84px 1fr 110px;
  align-items: center;
  gap: 14px;
}

.disparity__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.62);
  font-weight: 600;
}

.disparity__bar {
  display: block;
  height: 14px;
  background: rgba(244, 242, 235, 0.06);
  border-radius: 3px;
  overflow: hidden;
  position: relative;
}

.disparity__bar-fill {
  display: block;
  height: 100%;
  border-radius: 3px;
}

.disparity__bar--in .disparity__bar-fill {
  background: rgba(244, 242, 235, 0.55);
}

.disparity__bar--out .disparity__bar-fill {
  background: var(--lime);
}

.disparity__count {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--ink-on-dark);
  text-align: right;
  letter-spacing: 0.02em;
}

.disparity__footer {
  margin-top: 6px;
  padding-top: 12px;
  border-top: 1px solid rgba(244, 242, 235, 0.08);
  font-size: 15px;
  color: rgba(244, 242, 235, 0.82);
  line-height: 1.4;
}

.disparity__footer strong {
  color: var(--lime);
  font-weight: 700;
}

.disparity__brand {
  color: var(--lime);
  font-weight: 700;
}

.s3-stat {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  background: rgba(244, 242, 235, 0.04);
  border: 1px solid rgba(244, 242, 235, 0.1);
  border-radius: 12px;
}

.s3-stat__key {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.62);
  font-weight: 500;
}

.s3-stat__val {
  font-size: 17px;
  font-weight: 700;
  color: var(--ink-on-dark);
  letter-spacing: -0.005em;
}

.s3-stat__val--lime {
  color: var(--lime);
}

/* RIGHT — headline + narrative directly on dark */
.s3-right {
  flex: 3 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.s3-right .label-mono {
  margin-bottom: 28px;
  color: rgba(244, 242, 235, 0.62);
}

.s3-right .label-mono .dot {
  background: var(--lime);
}

.s3-headline {
  font-size: var(--t-headline);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.35;
  margin-bottom: 36px;
  color: var(--ink-on-dark);
}

.s3-headline .hl {
  padding: 0.01em 8px 0.02em;
  border-radius: 6px;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.s3-desc {
  font-size: 22px;
  line-height: 1.5;
  color: rgba(244, 242, 235, 0.9);
  max-width: 680px;
  font-weight: 400;
  letter-spacing: -0.005em;
}

.s3-desc p + p {
  margin-top: 18px;
}

.s3-desc strong {
  font-weight: 600;
  color: var(--ink-on-dark);
}

.s3-transition {
  margin-top: 36px;
  padding: 14px 18px;
  border: 1px solid rgba(244, 242, 235, 0.15);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.06em;
  color: rgba(244, 242, 235, 0.72);
  align-self: flex-start;
  background: rgba(244, 242, 235, 0.03);
}

.s3-transition__arrow {
  color: var(--lime);
  font-weight: 700;
}

.s3-personas {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: auto;
}

.s3-persona {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 16px;
  align-items: center;
  padding: 14px 18px;
  border: 1px solid rgba(244, 242, 235, 0.12);
  border-radius: 14px;
  background: rgba(244, 242, 235, 0.04);
}

.s3-persona__num {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.08em;
  color: var(--lime);
  font-weight: 600;
}

.s3-persona__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.s3-persona__name {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--ink-on-dark);
  line-height: 1.1;
}

.s3-persona__desc {
  font-size: 15px;
  color: rgba(244, 242, 235, 0.62);
  line-height: 1.3;
}

/* Page turner — the thin right strip */
.s3-pageturner {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 22px 20px;
  border-left: 1px dashed rgba(244, 242, 235, 0.18);
  padding-left: 28px;
  justify-content: center;
}

.s3-pageturner__header {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 14px;
  line-height: 1.3;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.72);
  margin-bottom: 8px;
  font-weight: 600;
}

.s3-pageturner__arrow {
  color: var(--lime);
  font-weight: 700;
  font-size: 16px;
}

.s3-pageturner__items {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.s3-pageturner__bridge {
  font-size: 18px;
  line-height: 1.4;
  color: rgba(244, 242, 235, 0.9);
  font-weight: 400;
  letter-spacing: -0.005em;
}

.s3-pageturner__bridge strong {
  color: var(--lime);
  font-weight: 700;
}

.s3-pageturner__bridge--lime {
  color: var(--lime);
  font-weight: 600;
  padding-top: 10px;
  margin-top: 6px;
  border-top: 1px solid rgba(200, 241, 91, 0.2);
}

.s3-pageturner__bridge--lime strong {
  color: var(--lime);
}

.s3-pt-item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid rgba(244, 242, 235, 0.12);
  border-radius: 12px;
  background: rgba(244, 242, 235, 0.03);
}

.s3-pt-item__num {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--lime);
  font-weight: 600;
  padding-top: 4px;
}

.s3-pt-item__body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.s3-pt-item__name {
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--ink-on-dark);
  line-height: 1.1;
}

.s3-pt-item__desc {
  font-size: var(--t-label);
  color: rgba(244, 242, 235, 0.62);
  line-height: 1.3;
}

.s3-pageturner__cta {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid rgba(244, 242, 235, 0.12);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.55);
  text-align: right;
  font-weight: 500;
}

/* =========================================================
   SLIDE 5 — 3 BURGERS (behavior / problem / fix per persona)
   ========================================================= */

.slide-5-stack-card {
  padding: 88px 56px 52px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s5s-header {
  margin-bottom: 30px;
}

.s5s-header .label-mono {
  margin-bottom: 14px;
}

.s5s-title {
  font-size: var(--t-headline);
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-headline);
  line-height: 1.05;
  color: var(--ink);
}

.s5s-title em {
  font-style: normal;
  color: var(--lime-deep);
}

.s5s-columns {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.s5s-column {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.s5s-column__header {
  padding: 14px 20px;
  display: flex;
  align-items: baseline;
  gap: 12px;
  border-radius: 14px;
  background: rgba(14, 14, 16, 0.04);
}

.s5s-column__num {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  font-weight: var(--w-medium);
}

.s5s-column__name {
  font-size: 26px;
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-title);
  color: var(--ink);
}

.s5s-layer {
  padding: 22px 24px;
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  overflow: hidden;
}

.s5s-layer--behavior {
  background: #eeece5;
  border: 1px solid var(--hairline);
  flex: 0 0 auto;
}

.s5s-layer--problem {
  background: #f4f0ed;
  border: 1px solid rgba(200, 80, 50, 0.12);
  flex: 1;
}

.s5s-layer--fix {
  background: var(--card-dark);
  color: var(--ink-on-dark);
  flex: 1;
  position: relative;
}

.s5s-layer--fix::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 80% 80% at 50% 0%,
    rgba(200, 241, 91, 0.08),
    transparent 70%
  );
  pointer-events: none;
}

.s5s-layer--fix > * { position: relative; z-index: 1; }

.s5s-layer__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
  font-weight: var(--w-medium);
}

.s5s-layer--fix .s5s-layer__label {
  color: var(--lime);
}

.s5s-layer__dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--ink-dim);
  flex-shrink: 0;
}

.s5s-layer--problem .s5s-layer__dot {
  background: #c04528;
}

.s5s-layer--fix .s5s-layer__dot {
  background: var(--lime);
}

.s5s-layer__text {
  font-size: var(--t-body);
  line-height: var(--lh-relaxed);
  color: var(--ink);
  flex: 1;
  letter-spacing: var(--ls-body);
  font-weight: var(--w-regular);
}

.s5s-layer--fix .s5s-layer__text {
  color: rgba(244, 242, 235, 0.9);
}

.s5s-layer__text strong {
  font-weight: var(--w-semibold);
  color: var(--ink);
}

.s5s-layer--fix .s5s-layer__text strong {
  color: var(--ink-on-dark);
}

.s5s-layer__metric {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--hairline);
  margin-top: 4px;
}

.s5s-layer--fix .s5s-layer__metric {
  border-top-color: rgba(244, 242, 235, 0.15);
}

.s5s-layer__metric-val {
  font-size: 28px;
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-title);
  line-height: 1;
  color: var(--ink);
}

.s5s-layer--fix .s5s-layer__metric-val {
  color: var(--lime);
}

.s5s-layer__metric-key {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  font-weight: var(--w-medium);
}

.s5s-layer--fix .s5s-layer__metric-key {
  color: rgba(244, 242, 235, 0.55);
}

/* =========================================================
   SLIDE 4 — HERE'S WHAT CHANGES (3 concrete scenarios, LEGACY)
   ========================================================= */

.slide-4-card {
  padding: 84px 56px 52px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s4-header {
  margin-bottom: 28px;
}

.s4-header .label-mono {
  margin-bottom: 14px;
}

.s4-title {
  font-size: var(--t-headline);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.0;
  margin-bottom: 14px;
  color: var(--ink);
}

.s4-title em {
  font-style: normal;
  color: var(--lime-deep);
}

.s4-sub {
  font-size: 22px;
  line-height: 1.4;
  color: var(--ink-dim);
  max-width: 1200px;
  font-weight: 400;
  letter-spacing: -0.005em;
}

.s4-scenarios {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}

.s4-anchor {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 16px;
  padding: 12px 24px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
  border-top: 1px solid rgba(14, 14, 16, 0.06);
}

.s4-anchor__dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--lime);
}

.s4-anchor strong {
  color: var(--ink);
  font-weight: 600;
}

.scenario {
  display: grid;
  grid-template-columns: 0.8fr 1.1fr 1.1fr;
  gap: 12px;
  flex: 1;
  align-items: stretch;
}

.scenario__persona {
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
}

.scenario__num {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  margin-bottom: 6px;
}

.scenario__persona-name {
  font-size: 32px;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1.05;
}

.scenario__persona-role {
  font-size: 16px;
  color: var(--ink-dim);
  line-height: 1.3;
  margin-top: 4px;
}

.scenario__today,
.scenario__with {
  padding: 20px 24px;
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 14px;
  position: relative;
  overflow: hidden;
}

.scenario__today {
  background: #f4f4f2;
  border: 1px solid rgba(14, 14, 16, 0.08);
}

.scenario__with {
  background: var(--card-dark);
  color: var(--ink-on-dark);
}

.scenario__with::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 80% 70% at 50% 0%,
    rgba(200, 241, 91, 0.07),
    transparent 70%
  );
  pointer-events: none;
}

.scenario__with > * { position: relative; z-index: 1; }

.scenario__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
}

.scenario__with .scenario__label {
  color: var(--lime);
}

.scenario__label-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(14, 14, 16, 0.25);
}

.scenario__with .scenario__label-dot {
  background: var(--lime);
}

.scenario__text {
  font-size: var(--t-body);
  line-height: var(--lh-relaxed);
  color: var(--ink);
  font-weight: var(--w-regular);
  letter-spacing: var(--ls-body);
  flex: 1;
}

.scenario__text strong {
  font-weight: 600;
}

.scenario__with .scenario__text {
  color: rgba(244, 242, 235, 0.88);
}

.scenario__outcome {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(14, 14, 16, 0.08);
}

.scenario__with .scenario__outcome {
  border-top-color: rgba(244, 242, 235, 0.15);
}

.scenario__outcome-val {
  font-size: 30px;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1;
}

.scenario__with .scenario__outcome-val {
  color: var(--lime);
}

.scenario__outcome-key {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  font-weight: 500;
}

.scenario__with .scenario__outcome-key {
  color: rgba(244, 242, 235, 0.55);
}

/* =========================================================
   SLIDE 5 — PRODUCT (4-card grid, Sophie-style placeholders)
   ========================================================= */

.slide-5-card {
  padding: 88px 56px 56px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s5-header {
  margin-bottom: 40px;
}

.s5-header .label-mono {
  margin-bottom: 18px;
}

.s5-title {
  font-size: var(--t-headline);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.0;
  margin-bottom: 20px;
  color: var(--ink);
}

.s5-title em {
  font-style: normal;
  color: var(--lime-deep);
}

.s5-sub {
  font-size: 22px;
  line-height: 1.45;
  color: var(--ink-dim);
  max-width: 1100px;
  font-weight: 400;
  letter-spacing: -0.005em;
}

.s5-sub p {
  margin: 0;
}

.s5-sub p + p {
  margin-top: 10px;
}

.s5-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  flex: 1;
}

.product-card {
  background: var(--card-light);
  border: 1px solid rgba(14, 14, 16, 0.08);
  border-radius: 22px;
  padding: 22px 24px 28px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 1px 2px rgba(14, 14, 16, 0.04),
              0 10px 28px rgba(14, 14, 16, 0.05),
              0 4px 12px rgba(14, 14, 16, 0.03);
  position: relative;
}

.product-card__photo {
  width: 100%;
  aspect-ratio: 5 / 4;
  background: linear-gradient(135deg, #d8d5cd 0%, #b8b4ac 60%, #a8a49c 100%);
  border-radius: 14px;
  margin-bottom: 22px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.product-card__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(
    circle at 30% 30%,
    rgba(255, 255, 255, 0.25),
    transparent 50%
  );
}

.product-card__index {
  font-family: var(--font-mono);
  font-size: 72px; /* intentional display number, not headline */
  font-weight: 700;
  letter-spacing: -0.03em;
  color: rgba(14, 14, 16, 0.18);
  position: relative;
  z-index: 1;
}

.product-card__label {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 12px;
}

.product-card__title {
  font-size: var(--t-title);
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-title);
  line-height: var(--lh-snug);
  margin-bottom: 16px;
  color: var(--ink);
}

.product-card__desc {
  font-size: var(--t-body);
  line-height: var(--lh-relaxed);
  color: var(--ink);
  flex: 1;
  font-weight: var(--w-regular);
  letter-spacing: var(--ls-body);
}

.product-card__desc p + p {
  margin-top: 8px;
}

.product-card__desc strong {
  font-weight: 600;
  color: var(--ink);
}

.product-card__tag {
  margin-top: 20px;
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(14, 14, 16, 0.06);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  align-self: flex-start;
}

/* =========================================================
   SLIDE 6 — REVENUE STREAMS (Mercedes-Y trinity)
   ========================================================= */

.slide-6-card {
  padding: 88px 48px 48px;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: 48px;
  align-items: stretch;
}

.s6-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: 24px;
}

.s6-left .label-mono {
  margin-bottom: 26px;
}

.s6-title {
  font-size: var(--t-headline);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.98;
  margin-bottom: 32px;
  color: var(--ink);
}

.s6-title em {
  font-style: normal;
  color: var(--lime-deep);
}

.s6-sub {
  font-size: 24px;
  line-height: 1.4;
  color: var(--ink);
  max-width: 620px;
  font-weight: 400;
  letter-spacing: -0.005em;
  margin-bottom: 36px;
}

.s6-sub p + p {
  margin-top: 10px;
}

.s6-sub strong {
  font-weight: 600;
}

.s6-monetize {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.s6-monetize-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
  padding: 16px 0;
  border-top: 1px solid rgba(14, 14, 16, 0.1);
}

.s6-monetize-row:last-child {
  border-bottom: 1px solid rgba(14, 14, 16, 0.1);
}

.s6-monetize-row__num {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--ink-dim);
}

.s6-monetize-row__what {
  font-size: 22px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.015em;
}

.s6-monetize-row__how {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.04em;
  color: var(--lime-deep);
  font-weight: 600;
}

/* Right side: the trinity diagram container */
.s6-right {
  display: flex;
  align-items: stretch;
  justify-content: center;
}

.trinity {
  position: relative;
  width: 100%;
  background: var(--card-dark);
  color: var(--ink-on-dark);
  border-radius: 24px;
  overflow: hidden;
}

.trinity::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 60% 60% at 50% 50%,
    rgba(200, 241, 91, 0.1),
    transparent 70%
  );
  pointer-events: none;
}

.trinity::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(244, 242, 235, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244, 242, 235, 0.03) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
}

.trinity__chrome {
  position: absolute;
  top: 20px;
  left: 24px;
  right: 24px;
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.5);
  z-index: 4;
}

.trinity__svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

/* The central Groundly hub */
.trinity__center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  background: var(--lime);
  color: var(--ink);
  padding: 28px 40px;
  border-radius: 20px;
  box-shadow: 0 0 80px rgba(200, 241, 91, 0.3);
  min-width: 200px;
  text-align: center;
}

.trinity__center-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: 0.7;
}

.trinity__center-name {
  font-size: 40px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--ink);
  line-height: 1;
}

/* Payer nodes positioned around center */
.trinity__node {
  position: absolute;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  background: rgba(244, 242, 235, 0.06);
  border: 1px solid rgba(244, 242, 235, 0.18);
  color: var(--ink-on-dark);
  padding: 18px 24px;
  border-radius: 16px;
  min-width: 180px;
  text-align: center;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.trinity__node--top {
  top: 8%;
  left: 50%;
  transform: translateX(-50%);
}

.trinity__node--bl {
  bottom: 8%;
  left: 6%;
}

.trinity__node--br {
  bottom: 8%;
  right: 6%;
}

.trinity__node-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.62);
}

.trinity__node-name {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--ink-on-dark);
  line-height: 1;
}

.trinity__node-model {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--lime);
  font-weight: 600;
  margin-top: 4px;
}

/* =========================================================
   SLIDE 7 — TRACTION
   ========================================================= */

.slide-7-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  height: 100%;
}

.s7-left {
  padding: 72px 56px 72px 72px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.s7-title {
  font-size: var(--t-headline);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.02;
  margin-top: 16px;
}

.s7-stats {
  margin-top: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.stat {
  padding: 22px;
  border: 1px solid var(--hairline);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.4);
}

.stat__val {
  font-size: 46px;
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--ink);
  margin-bottom: 8px;
}

.stat__key {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  line-height: 1.3;
}

.s7-right {
  background: var(--card-dark);
  color: var(--ink-on-dark);
  padding: 72px 72px 72px 56px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.s7-right::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(244, 242, 235, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244, 242, 235, 0.04) 1px, transparent 1px);
  background-size: 32px 32px;
}

.s7-right > * { position: relative; z-index: 2; }

.s7-right__label {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim-on-dark);
  margin-top: 24px;
  margin-bottom: 80px;
}

.quote-mark {
  font-size: 180px;
  font-weight: 700;
  color: var(--lime);
  line-height: 0.5;
  margin-bottom: 20px;
  font-family: Georgia, serif;
}

.quote-text {
  font-size: 46px;
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--ink-on-dark);
}

.quote-attr {
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 28px;
  border-top: 1px solid var(--hairline-on-dark);
}

.quote-attr__avatar {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--lime), var(--lime-deep));
}

.quote-attr__text {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim-on-dark);
  line-height: 1.4;
}

.quote-attr__text strong {
  color: var(--ink-on-dark);
  display: block;
  margin-bottom: 2px;
}

/* =========================================================
   SLIDE 8 — GTM + UNIT ECONOMICS
   ========================================================= */

.slide-8-card {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  height: 100%;
}

.s8-left {
  padding: 72px 56px 72px 72px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.s8-title {
  font-size: var(--t-headline);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.02;
  margin-top: 16px;
}

.s8-body {
  font-size: var(--t-body);
  line-height: var(--lh-body);
  color: var(--ink);
  margin-top: 32px;
  max-width: 620px;
  letter-spacing: var(--ls-body);
}

.s8-body p + p { margin-top: 14px; }

.s8-tam {
  margin-top: auto;
  padding: 24px;
  border: 1px solid var(--hairline);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.4);
}

.s8-tam__math {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 10px;
}

.s8-tam__val {
  font-size: 54px;
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--ink);
}
.s8-tam__val em {
  font-style: normal;
  color: var(--lime-deep);
}

.s8-right {
  background: var(--card-dark);
  color: var(--ink-on-dark);
  padding: 72px 72px 72px 56px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.s8-right::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(244, 242, 235, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244, 242, 235, 0.04) 1px, transparent 1px);
  background-size: 32px 32px;
}

.s8-right > * { position: relative; z-index: 2; }

.s8-right__label {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim-on-dark);
  margin-top: 24px;
  margin-bottom: 36px;
}

.s8-right__title {
  font-size: var(--t-title);
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-title);
  line-height: var(--lh-snug);
  margin-bottom: 40px;
}

.econ-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.econ-metric {
  padding: 20px;
  border: 1px solid var(--hairline-on-dark);
  border-radius: 14px;
}

.econ-metric__key {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim-on-dark);
  margin-bottom: 10px;
}

.econ-metric__val {
  font-size: 40px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--ink-on-dark);
}

.econ-metric__val--lime { color: var(--lime); }

.econ-metric__note {
  font-size: var(--t-tag);
  color: var(--ink-dim-on-dark);
  margin-top: 8px;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
}

/* Readable context text (replaces __note when we want real prose) */
.econ-metric__ctx {
  font-size: 12.5px;
  color: rgba(244, 242, 235, 0.72);
  margin-top: 10px;
  line-height: 1.45;
  letter-spacing: -0.005em;
}

/* Metrics with mini chart illustrations */
.econ-metric--viz {
  display: flex;
  flex-direction: column;
}

.econ-metric--viz .econ-metric__val {
  margin-bottom: 10px;
}

.econ-metric__chart {
  width: 100%;
  height: 42px;
  display: block;
  margin-bottom: 4px;
}

/* HTML/CSS payback timeline (no SVG stretch) */
.payback-timeline {
  width: 100%;
  margin-bottom: 4px;
}

.payback-timeline__axis {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.55);
  font-weight: 600;
  margin-bottom: 4px;
}

.payback-timeline__marker {
  color: #f4f2eb;
  font-weight: 700;
  position: relative;
  margin-left: -58px; /* pull label back so it sits near the 16.7% mark */
}

.payback-timeline__track {
  display: flex;
  height: 10px;
  border-radius: 3px;
  overflow: hidden;
  position: relative;
}

.payback-timeline__recover {
  width: 16.7%;
  background: rgba(244, 242, 235, 0.28);
}

.payback-timeline__profit {
  width: 83.3%;
  background: var(--lime);
}

/* Two-bar comparison for LTV:CAC */
.econ-metric__bars {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 4px;
}

.ratio-row {
  display: grid;
  grid-template-columns: 28px 1fr 40px;
  align-items: center;
  gap: 8px;
}

.ratio-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.55);
  font-weight: 600;
}

.ratio-bar {
  display: block;
  height: 10px;
  border-radius: 2px;
  min-width: 4px;
}

.ratio-bar--cac {
  background: rgba(244, 242, 235, 0.35);
}

.ratio-bar--ltv {
  background: var(--lime);
}

.ratio-val {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-on-dark);
  font-weight: 600;
  text-align: right;
}

/* =========================================================
   SLIDE 9 — THE CATEGORY PRIZE (base case vs upside case)
   ========================================================= */

.slide-9-card--new {
  padding: 88px 64px 56px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s9-header--new {
  margin-bottom: 28px;
}

.s9-header--new .label-mono {
  margin-bottom: 16px;
  color: rgba(244, 242, 235, 0.6);
}

.s9-header--new .label-mono .dot { background: var(--lime); }

.s9-title--new {
  font-size: var(--t-headline);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.0;
  margin-bottom: 18px;
  color: var(--ink-on-dark);
}

.s9-title--new em {
  font-style: normal;
  color: var(--lime);
}

.s9-sub--new {
  font-size: 22px;
  line-height: 1.45;
  color: rgba(244, 242, 235, 0.8);
  max-width: 1200px;
  font-weight: 400;
  letter-spacing: -0.005em;
}

.s9-cases {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  flex: 1;
}

/* timeline layout: small NOW · arrow · big THEN */
.s9-cases--timeline {
  display: grid;
  grid-template-columns: 320px 36px 1fr;
  align-items: stretch;
  gap: 14px;
}

.timeline-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
}

.timeline-arrow svg {
  width: 100%;
  height: 24px;
}

.timeline-marker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 11px;
  border-radius: 999px;
  background: rgba(244, 242, 235, 0.08);
  border: 1px solid rgba(244, 242, 235, 0.16);
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.75);
  font-weight: 500;
  align-self: flex-start;
  margin-bottom: 14px;
}

.timeline-marker--then {
  background: rgba(200, 241, 91, 0.12);
  border-color: rgba(200, 241, 91, 0.4);
  color: var(--lime);
  font-weight: 600;
}

.timeline-marker__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(244, 242, 235, 0.5);
}

.timeline-marker--then .timeline-marker__dot {
  background: var(--lime);
  box-shadow: 0 0 8px rgba(200, 241, 91, 0.7);
}

/* compact base case card on the left rail */
.case-card--compact {
  padding: 24px 22px 20px;
}

.case-card--compact .case-card__title--sm {
  font-size: 26px;
  margin-bottom: 0;
}

.case-card--compact .case-card__head {
  margin-bottom: 18px;
}

.case-card--compact .case-card__big {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(244, 242, 235, 0.12);
}

.case-card--compact .case-card__big-val {
  font-size: 56px;
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 0.95;
  color: var(--ink-on-dark);
}

.case-card--compact .case-card__big-key {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.55);
}

.case-card__hint--sm {
  font-size: 13px;
  line-height: 1.45;
  color: rgba(244, 242, 235, 0.6);
  margin: 14px 0 0;
}

.case-card__outcome--solo {
  align-self: stretch;
  text-align: center;
  margin-top: 14px;
  padding: 9px 14px;
}

.tier-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.tier-list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  background: rgba(244, 242, 235, 0.04);
  border: 1px solid rgba(244, 242, 235, 0.1);
  border-radius: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  color: rgba(244, 242, 235, 0.85);
}

.tier-list__name {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(244, 242, 235, 0.6);
  font-weight: 500;
}

.tier-list__price {
  font-weight: 700;
  color: #f4f2eb;
  font-size: 13px;
}

/* Hero THEN card */
.case-card--hero {
  padding: 22px 28px 20px;
}

.hero-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.hero-topbar .timeline-marker {
  margin-bottom: 0;
}

.case-card__label--inline {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lime);
  font-weight: 700;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1fr 270px;
  gap: 20px;
  flex: 1;
  margin-bottom: 14px;
  min-height: 0;
}

.hero-viz {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.hero-viz .case-card__viz {
  width: 100%;
  height: 100%;
  margin: 0;
  flex: 1;
}

/* Stacked explanation pillars in the right column */
.explain-pillars--stacked {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 0;
}

.explain-pillars--stacked .explain-pillar {
  padding: 12px 14px;
  gap: 6px;
  flex: 1;
  min-height: 0;
}

.explain-pillar {
  padding: 12px 14px 10px;
  border-radius: 10px;
  background: rgba(200, 241, 91, 0.04);
  border: 1px solid rgba(200, 241, 91, 0.18);
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.explain-pillar__num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  color: var(--lime);
  font-weight: 700;
  text-transform: uppercase;
}

.explain-pillar p {
  margin: 0;
  font-size: 12px;
  line-height: 1.5;
  color: rgba(244, 242, 235, 0.78);
}

.case-card {
  padding: 28px 30px 24px;
  border-radius: 20px;
  background: rgba(244, 242, 235, 0.04);
  border: 1px solid rgba(244, 242, 235, 0.1);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.case-card--upside {
  border: 1px solid rgba(200, 241, 91, 0.3);
  background: rgba(200, 241, 91, 0.03);
}

.case-card--upside::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 90% 100% at 50% 0%,
    rgba(200, 241, 91, 0.06),
    transparent 70%
  );
  pointer-events: none;
}

.case-card > * { position: relative; z-index: 1; }

.case-card__head {
  margin-bottom: 18px;
}

.case-card__head-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 8px;
}

.case-card__label {
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.6);
}

.case-card--upside .case-card__label { color: var(--lime); }

.case-card__big-val {
  font-size: 56px; /* hero metric, lives in the header row */
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 0.95;
  color: var(--ink-on-dark);
}

.case-card--upside .case-card__big-val { color: var(--lime); }

.case-card__title {
  font-size: 36px;
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-title);
  line-height: var(--lh-snug);
  color: var(--ink-on-dark);
  margin: 0 0 8px;
}

.case-card__hint {
  font-size: var(--t-body-sm);
  line-height: var(--lh-relaxed);
  color: rgba(244, 242, 235, 0.7);
  margin: 0;
  max-width: 92%;
}

.case-card__viz {
  width: 100%;
  flex: 1;
  margin: 14px 0 18px;
  display: block;
  min-height: 0;
}

.case-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid rgba(244, 242, 235, 0.12);
}

.case-card--upside .case-card__footer {
  border-top-color: rgba(200, 241, 91, 0.2);
}

.case-card__comp {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.55);
  font-weight: 500;
}

.case-card--upside .case-card__comp {
  color: var(--lime);
}

.case-card__outcome {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(244, 242, 235, 0.08);
  border: 1px solid rgba(244, 242, 235, 0.16);
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-on-dark);
  font-weight: 600;
}

.case-card--upside .case-card__outcome {
  background: rgba(200, 241, 91, 0.12);
  border-color: rgba(200, 241, 91, 0.35);
  color: var(--lime);
}

/* =========================================================
   SLIDE 9 (LEGACY) — CATEGORY PRIZE (THE NEW API)
   ========================================================= */

.slide-9-card {
  padding: 120px 72px 72px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s9-title {
  font-size: 108px;
  font-weight: 600;
  letter-spacing: -0.035em;
  line-height: 0.98;
  margin-top: 16px;
  color: var(--ink-on-dark);
}

.s9-sub {
  font-size: 20px;
  color: var(--ink-dim-on-dark);
  line-height: 1.55;
  margin-top: 32px;
  max-width: 900px;
}

.s9-bridge {
  margin-top: 56px;
  flex: 1;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 40px;
  align-items: center;
}

.bridge-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}

.bridge-col__label {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim-on-dark);
  margin-bottom: 6px;
}

.tool-chip {
  padding: 12px 16px;
  border: 1px solid var(--hairline-on-dark);
  border-radius: 10px;
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.04em;
  color: var(--ink-on-dark);
  background: rgba(244, 242, 235, 0.03);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.tool-chip__label { opacity: 0.6; font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; }

.bridge-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 32px 28px;
  background: var(--lime);
  border-radius: 20px;
  color: var(--ink);
  box-shadow: 0 0 80px rgba(200, 241, 91, 0.25);
  min-width: 260px;
}

.bridge-center__logo {
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.03em;
}

.bridge-center__surfaces {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
}

.bridge-center__tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  background: var(--ink);
  color: var(--lime);
  border-radius: 999px;
}

.bridge-biz {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 6px;
}

.biz-dot {
  aspect-ratio: 1;
  border-radius: 4px;
  background: rgba(244, 242, 235, 0.2);
}

.biz-dot--active { background: var(--lime); }

.bridge-math {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding: 24px;
  border: 1px solid var(--hairline-on-dark);
  border-radius: 14px;
}

.bridge-math__item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.bridge-math__key {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim-on-dark);
}

.bridge-math__val {
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--ink-on-dark);
}
.bridge-math__val--lime { color: var(--lime); }

/* =========================================================
   SLIDE 10 — COMPETITION
   ========================================================= */

.slide-10-card {
  padding: 120px 72px 72px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s10-title {
  font-size: var(--t-headline);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-top: 16px;
}

.s10-sub {
  font-size: 18px;
  color: var(--ink-dim);
  line-height: 1.5;
  margin-top: 16px;
  max-width: 700px;
}

.matrix-wrap {
  margin-top: 40px;
  flex: 1;
  display: grid;
  grid-template-columns: 56px 1fr;
  grid-template-rows: 1fr 56px;
  gap: 0;
}

.matrix-y-axis {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 16px 0;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
  text-align: center;
  align-items: center;
}

.matrix-x-axis {
  grid-column: 2;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 16px 0;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
}

.matrix {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 14px;
}

.matrix-cell {
  position: relative;
  padding: 26px;
  border: 1px solid var(--hairline);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.5);
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.matrix-cell--win {
  background: var(--lime);
  border-color: var(--lime);
}

.matrix-cell__label {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
}

.matrix-cell--win .matrix-cell__label { color: var(--ink); opacity: 0.7; }

.matrix-cell__logos {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.logo-chip {
  padding: 8px 14px;
  border-radius: 8px;
  background: rgba(14, 14, 16, 0.06);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
}

.matrix-cell--win .logo-chip {
  background: var(--ink);
  color: var(--lime);
  font-weight: 700;
  font-size: 22px;
  padding: 10px 18px;
  letter-spacing: -0.02em;
}

.matrix-cell__note {
  font-size: var(--t-label);
  line-height: 1.45;
  color: var(--ink);
  margin-top: auto;
}

.matrix-cell--win .matrix-cell__note { color: var(--ink); font-weight: 500; }

/* =========================================================
   SLIDE 11 — COMPETITION + RISKS (merged)
   ========================================================= */

.slide-11-merged-card {
  padding: 88px 56px 52px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s11m-header {
  margin-bottom: 30px;
}

.s11m-header .label-mono {
  margin-bottom: 14px;
}

.s11m-title {
  font-size: var(--t-headline);
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-headline);
  line-height: 1.05;
  margin-top: 10px;
  color: var(--ink);
}

.s11m-section-title {
  font-size: var(--t-title);
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-title);
  line-height: var(--lh-snug);
  color: var(--ink);
  margin-bottom: 24px;
}

.s11m-body {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: stretch;
}

.s11m-section-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: var(--t-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
  font-weight: 500;
  margin-bottom: 16px;
}

/* LEFT: Competition box (DARK) */
.s11m-competition {
  padding: 28px;
  border-radius: 22px;
  background: var(--card-dark);
  color: var(--ink-on-dark);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.s11m-competition::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(244, 242, 235, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244, 242, 235, 0.025) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
}

.s11m-competition > * { position: relative; z-index: 1; }

.s11m-competition .s11m-section-label {
  color: rgba(244, 242, 235, 0.6);
}

.s11m-competition .s11m-section-title {
  color: var(--ink-on-dark);
}

/* Competition 2x2 matrix */
.s11m-matrix {
  flex: 1;
  display: grid;
  grid-template-columns: 36px 1fr;
  grid-template-rows: 1fr 36px;
  gap: 0;
}

.s11m-matrix__y {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.55);
  padding: 8px 0;
  font-weight: 500;
}

.s11m-matrix__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 10px;
}

.s11m-matrix__x {
  grid-column: 2;
  display: flex;
  justify-content: space-between;
  padding: 10px 8px 0;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(244, 242, 235, 0.55);
  font-weight: 500;
}

.s11m-matrix__cell {
  padding: 14px 16px;
  border: 1px solid rgba(14, 14, 16, 0.06);
  border-radius: 12px;
  background: #f4f4f2;
  display: flex;
  flex-direction: column;
  gap: 10px;
  justify-content: space-between;
}

.s11m-matrix__cell--win {
  background: var(--lime);
  border-color: var(--lime);
}

.s11m-matrix__cell-logos {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.s11m-matrix__cell-logos .logo-chip {
  background: rgba(14, 14, 16, 0.06);
  color: var(--ink);
  padding: 5px 10px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
}

.s11m-matrix__cell-logos .logo-chip--win {
  background: var(--ink);
  color: var(--lime);
  font-weight: 700;
  font-size: 18px;
  padding: 7px 14px;
}

.s11m-matrix__cell-note {
  font-size: 14px;
  line-height: 1.35;
  color: var(--ink);
}

.s11m-matrix__cell--win .s11m-matrix__cell-note {
  color: var(--ink);
  font-weight: 600;
}

.s11m-matrix__cell-note strong { font-weight: 700; }

/* RIGHT: Risks box (outer container, dark — symmetric with competition) */
.s11m-risks {
  padding: 28px;
  border-radius: 22px;
  background: var(--card-dark);
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  overflow: hidden;
}

.s11m-risks::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(244, 242, 235, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244, 242, 235, 0.025) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
}

.s11m-risks > * { position: relative; z-index: 1; }

.s11m-risks > .s11m-section-label {
  margin-bottom: 8px;
  color: rgba(244, 242, 235, 0.6);
}

.s11m-risk-card {
  padding: 18px 22px;
  border: 1px solid rgba(14, 14, 16, 0.06);
  border-radius: 18px;
  background: #f4f4f2;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.s11m-risk-card__risk-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}

.s11m-risk-card__win-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px solid rgba(14, 14, 16, 0.06);
}

.s11m-risk-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  background: #ef4a3a;
  color: #ffffff;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  flex-shrink: 0;
}

.s11m-win-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--lime);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  flex-shrink: 0;
}

.s11m-risk-card__title {
  font-size: 20px;
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-title);
  line-height: 1.25;
  color: var(--ink);
  margin: 0;
  flex: 1;
  min-width: 200px;
}

.s11m-risk-card__win {
  font-size: var(--t-body-sm);
  line-height: var(--lh-relaxed);
  color: var(--ink);
  letter-spacing: var(--ls-body);
  margin: 0;
  flex: 1;
  min-width: 200px;
}

.s11m-risk-card__win strong {
  font-weight: 600;
  color: var(--ink);
}

/* =========================================================
   SLIDE 11 (LEGACY) — RISKS
   ========================================================= */

.slide-11-card {
  padding: 120px 72px 72px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s11-title {
  font-size: var(--t-headline);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-top: 16px;
}

.risk-grid {
  margin-top: 48px;
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 16px;
}

.risk-card {
  padding: 24px;
  border: 1px solid var(--hairline);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.4);
  display: flex;
  flex-direction: column;
}

.risk-card__header {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 14px;
}

.risk-card__risk {
  font-size: 17px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--ink);
  margin-bottom: 20px;
}

.risk-card__win-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--lime);
  color: var(--ink);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  align-self: flex-start;
  margin-bottom: 12px;
}

.risk-card__win {
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink);
}

/* =========================================================
   SLIDE 12 — THE ASK
   ========================================================= */

.slide-12-card {
  padding: 120px 72px 72px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s12-title {
  font-size: 120px;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1.05;
  margin-top: 16px;
  color: var(--ink-on-dark);
}

.s12-sub {
  font-size: var(--t-lead);
  color: var(--ink-dim-on-dark);
  line-height: var(--lh-relaxed);
  margin-top: 32px;
  max-width: 900px;
  font-weight: var(--w-regular);
}

.s12-sub p + p {
  margin-top: 10px;
}

.s12-sub em {
  font-style: normal;
  color: var(--lime);
  font-weight: var(--w-medium);
}

.s12-sub strong {
  color: var(--ink-on-dark);
  font-weight: var(--w-semibold);
}

.s12-sections {
  margin-top: 56px;
  flex: 1;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 40px;
}

.funds-bar {
  display: grid;
  grid-template-columns: 50fr 25fr 15fr 10fr;
  gap: 6px;
  border-radius: 18px;
  overflow: hidden;
  height: 200px;
}

.fund-segment {
  padding: 28px 30px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.fund-segment:nth-child(1) { background: var(--lime); color: var(--ink); }
.fund-segment:nth-child(2) { background: var(--lime-soft); color: var(--ink); }
.fund-segment:nth-child(3) { background: rgba(244, 242, 235, 0.12); color: var(--ink-on-dark); }
.fund-segment:nth-child(4) { background: rgba(244, 242, 235, 0.06); color: var(--ink-on-dark); }

.fund-segment__pct {
  font-size: 72px;
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1;
}

.fund-segment__label {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  opacity: 0.85;
  margin-top: 4px;
}

.fund-segment__amt {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1.5;
}

/* Milestone cards — compact stat format (content-sized, top-aligned) */
.milestones {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  align-self: start;
}

.milestone {
  padding: 18px 20px;
  border: 1px solid var(--hairline-on-dark);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.milestone__month {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lime);
  font-weight: 700;
}

.milestone__title {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.018em;
  color: var(--ink-on-dark);
  line-height: 1.15;
  margin-bottom: 2px;
}

.milestone__desc {
  font-size: 12.5px;
  line-height: 1.45;
  color: var(--ink-dim-on-dark);
}

/* =========================================================
   SLIDE 13 — THANKS
   ========================================================= */

.slide-13-card {
  padding: 88px 72px 56px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-align: left;
}

.s13-wordmark {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--ink-on-dark);
  margin-top: 20px;
}

.s13-title {
  font-size: 124px;
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 1.2;
  color: var(--ink-on-dark);
  margin-top: 32px;
  max-width: 1500px;
}

.s13-sub {
  font-size: var(--t-lead);
  color: var(--ink-dim-on-dark);
  line-height: var(--lh-relaxed);
  margin-top: 32px;
  max-width: 760px;
  font-weight: var(--w-regular);
}

.s13-sub p + p {
  margin-top: 10px;
}

.s13-sub strong {
  color: var(--ink-on-dark);
  font-weight: var(--w-semibold);
}

.s13-footer {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 40px;
}

.contact {
  padding: 22px;
  border: 1px solid var(--hairline-on-dark);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contact__label {
  font-family: var(--font-mono);
  font-size: var(--t-tag);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim-on-dark);
}

.contact__val {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink-on-dark);
}

.contact__val--lime { color: var(--lime); }

/* =========================================================
   SLIDE 4 — THREE THINGS HAPPENING
   ========================================================= */

.slide-4-intro-card {
  padding: 88px 56px 56px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.s4i-header {
  margin-bottom: 40px;
}

.s4i-header .label-mono {
  margin-bottom: 20px;
}

.s4i-title { /* tokenized */
  font-size: var(--t-headline);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.0;
  margin-bottom: 24px;
  color: var(--ink);
}

.s4i-title em {
  font-style: normal;
  color: var(--lime-deep);
}

.s4i-sub {
  font-size: 24px;
  line-height: 1.4;
  color: var(--ink-dim);
  max-width: 1200px;
  font-weight: 400;
  letter-spacing: -0.005em;
}

.s4i-surfaces {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  flex: 1;
}

.surface-card {
  background: #f4f4f2;
  border: 1px solid rgba(14, 14, 16, 0.08);
  border-radius: 22px;
  padding: 36px 32px 32px;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.surface-card--prize {
  background: var(--card-dark);
  color: var(--ink-on-dark);
  border-color: var(--card-dark);
}

.surface-card--prize::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 50%;
  background: radial-gradient(
    ellipse 80% 100% at 50% 0%,
    rgba(200, 241, 91, 0.08),
    transparent 70%
  );
  pointer-events: none;
}

.surface-card--prize > * {
  position: relative;
  z-index: 1;
}

.surface-card__index {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  margin-bottom: 32px;
}

.surface-card--prize .surface-card__index {
  color: var(--lime);
}

.surface-card__label {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 18px;
}

.surface-card--prize .surface-card__label {
  color: rgba(244, 242, 235, 0.62);
}

.surface-card__title {
  font-size: var(--t-title);
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-title);
  line-height: var(--lh-snug);
  margin-bottom: 24px;
  color: var(--ink);
}

.surface-card--prize .surface-card__title {
  color: var(--ink-on-dark);
}

.surface-card__title em {
  font-style: normal;
  color: var(--lime-deep);
}

.surface-card--prize .surface-card__title em {
  color: var(--lime);
}

.surface-card__body {
  font-size: var(--t-body);
  line-height: var(--lh-body);
  color: var(--ink);
  flex: 1;
  letter-spacing: var(--ls-body);
  font-weight: var(--w-regular);
}

.surface-card__body p + p {
  margin-top: 10px;
}

.surface-card__body strong {
  font-weight: 600;
  color: var(--ink);
}

.surface-card--prize .surface-card__body {
  color: rgba(244, 242, 235, 0.88);
}

.surface-card--prize .surface-card__body strong {
  color: var(--ink-on-dark);
}

.surface-card__tag {
  margin-top: 28px;
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(14, 14, 16, 0.06);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-dim);
  align-self: flex-start;
}

.surface-card--prize .surface-card__tag {
  background: var(--lime);
  color: var(--ink);
}

/* =========================================================
   NAV
   ========================================================= */
.nav {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  z-index: 100;
  font-family: var(--font-mono);
  pointer-events: none;
}

.nav__pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(14, 14, 16, 0.9);
  color: rgba(244, 242, 235, 0.9);
  padding: 6px 8px;
  border-radius: 100px;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  font-size: 12px;
  letter-spacing: 0.06em;
  border: 1px solid rgba(244, 242, 235, 0.08);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
  pointer-events: auto;
}

.nav__btn {
  background: transparent;
  border: none;
  color: inherit;
  cursor: pointer;
  font-size: 16px;
  padding: 6px 14px;
  border-radius: 100px;
  opacity: 0.75;
  transition: opacity 0.15s, background 0.15s;
  font-family: inherit;
}

.nav__btn:hover {
  opacity: 1;
  background: rgba(244, 242, 235, 0.08);
}

.nav__counter {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 8px;
  font-variant-numeric: tabular-nums;
  user-select: none;
  white-space: nowrap;
}

.nav__title {
  color: rgba(14, 14, 16, 0.85);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 11px;
  max-width: 640px;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nav__sep { opacity: 0.45; }

/* Hide nav pill + title on portrait mobile — swipe and tap-zones handle navigation.
   Keep nav on landscape mobile so the on-screen affordance stays available. */
@media (max-width: 900px) and (orientation: portrait) {
  .nav { display: none; }
}

/* =========================================================
   PRINT
   ========================================================= */
@media print {
  html, body { background: var(--bg); overflow: visible; }
  body::before { display: none; }
  .viewport { position: static; background: transparent; }
  .deck { position: static; transform: none; width: auto; height: auto; }
  .slide {
    display: block !important;
    position: relative;
    width: 1920px;
    height: 1080px;
    page-break-after: always;
    break-after: page;
  }
  .nav { display: none; }
  @page { size: 1920px 1080px; margin: 0; }
}

/* =========================================================
   SLIDE 6 · PRODUCT ARCHITECTURE — core + arms
   ========================================================= */

.product-arch {
  flex: 1;
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 24px;
  min-height: 0;
}

/* Core · Grounded profile */
.arch-core {
  padding: 30px 28px;
  background: #0d0d0e;
  border-radius: 16px;
  color: var(--ink-on-dark);
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  overflow: hidden;
}

.arch-core::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 120% 60% at 50% 0%,
    rgba(200, 241, 91, 0.12),
    transparent 70%
  );
  pointer-events: none;
}

.arch-core > * { position: relative; z-index: 1; }

.arch-core__label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lime);
  font-weight: 700;
  margin: 0;
}

.arch-core__title {
  font-size: 32px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: #f4f2eb;
  margin: 0;
}

.arch-core__ctx {
  font-size: 15px;
  line-height: 1.5;
  color: rgba(244, 242, 235, 0.75);
  margin: 0;
}

.arch-core__attrs {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.arch-core__attrs li {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.3;
  color: rgba(244, 242, 235, 0.9);
  padding-left: 20px;
  position: relative;
}

.arch-core__attrs li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 7px;
  height: 7px;
  background: var(--lime);
  border-radius: 50%;
}

.arch-core__footnote {
  font-size: 14px;
  color: #f4f2eb;
  font-weight: 600;
  padding-top: 14px;
  margin: 0;
  border-top: 1px solid rgba(244, 242, 235, 0.14);
}

.arch-core__status {
  align-self: flex-start;
  margin-top: auto;
}

/* Arms · 2x2 grid */
.arch-arms {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 16px;
}

.arch-arm {
  padding: 22px 24px 20px;
  border-radius: 14px;
  background: rgba(13, 13, 14, 0.03);
  border: 1px solid rgba(13, 13, 14, 0.12);
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.arch-arm--live {
  background: rgba(200, 241, 91, 0.14);
  border-color: rgba(200, 241, 91, 0.5);
}

.arch-arm--phase2 {
  background: rgba(13, 13, 14, 0.92);
  border-color: rgba(13, 13, 14, 0.92);
  color: #f4f2eb;
}

.arch-arm__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

.arch-arm__idx {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(13, 13, 14, 0.6);
  font-weight: 700;
}

.arch-arm--phase2 .arch-arm__idx {
  color: rgba(244, 242, 235, 0.65);
}

.arch-arm__title {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.018em;
  line-height: 1.15;
  color: var(--ink);
  margin: 0 0 12px;
}

.arch-arm--phase2 .arch-arm__title {
  color: #f4f2eb;
}

.arch-arm__ctx {
  font-size: 14px;
  line-height: 1.5;
  color: rgba(13, 13, 14, 0.72);
  margin: 0 0 14px;
  letter-spacing: -0.005em;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.arch-arm__ctx p {
  margin: 0;
}

.arch-arm--phase2 .arch-arm__ctx {
  color: rgba(244, 242, 235, 0.78);
}

.arch-arm__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}

.arch-arm__list li {
  font-size: 13.5px;
  font-weight: 500;
  line-height: 1.4;
  color: rgba(13, 13, 14, 0.85);
  padding-left: 15px;
  position: relative;
}

.arch-arm__list li strong {
  color: var(--ink);
  font-weight: 700;
}

.arch-arm--live .arch-arm__list li strong,
.arch-arm--next .arch-arm__list li strong {
  color: var(--lime-deep);
}

.arch-arm--phase2 .arch-arm__list li {
  color: rgba(244, 242, 235, 0.82);
}

.arch-arm--phase2 .arch-arm__list li strong {
  color: var(--lime);
}

.arch-arm__list li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: rgba(13, 13, 14, 0.35);
  font-family: var(--font-mono);
  font-size: 11px;
}

.arch-arm--phase2 .arch-arm__list li::before {
  color: var(--lime);
}

.arch-arm--live .arch-arm__list li::before {
  color: var(--lime-deep);
}

/* Status pills */
.arch-status {
  display: inline-flex;
  align-items: center;
  padding: 5px 10px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
  white-space: nowrap;
}

.arch-status--live {
  background: var(--lime);
  color: var(--ink);
}

.arch-status--next {
  background: rgba(13, 13, 14, 0.08);
  border: 1px solid rgba(13, 13, 14, 0.25);
  color: rgba(13, 13, 14, 0.8);
}

.arch-status--phase2 {
  background: rgba(244, 242, 235, 0.08);
  border: 1px solid rgba(244, 242, 235, 0.25);
  color: rgba(244, 242, 235, 0.78);
}

/* Core status sits on dark bg, needs specific variant */
.arch-core__status.arch-status--live {
  background: var(--lime);
  color: var(--ink);
  font-size: 11px;
  padding: 7px 12px;
}

/* =========================================================
   SLIDE 8 · uses slide-12 format with 3-segment funds bar
   ========================================================= */

.slide[data-slide="8"] .funds-bar {
  grid-template-columns: 50fr 35fr 15fr;
}

/* =========================================================
   SLIDE 10 · CREAM CARD THEME
   Category prize slide. Cream canvas, dark content blocks,
   lime-tinted Groundly layer.
   ========================================================= */

.slide[data-slide="10"] .s9-title--new,
.slide[data-slide="10"] .s9-title--new em {
  color: #0d0d0e;
}

.slide[data-slide="10"] .s9-title--new em {
  color: #0d0d0e;
  border-bottom: 4px solid var(--lime);
  padding-bottom: 2px;
}

.slide[data-slide="10"] .s9-sub--new {
  color: rgba(13, 13, 14, 0.7);
}

/* Timeline markers → dark pills on cream */
.slide[data-slide="10"] .timeline-marker {
  background: rgba(13, 13, 14, 0.06);
  border-color: rgba(13, 13, 14, 0.18);
  color: rgba(13, 13, 14, 0.72);
}

.slide[data-slide="10"] .timeline-marker__dot {
  background: rgba(13, 13, 14, 0.35);
}

.slide[data-slide="10"] .timeline-marker--then {
  background: rgba(13, 13, 14, 0.92);
  border-color: rgba(13, 13, 14, 0.92);
  color: var(--lime);
}

.slide[data-slide="10"] .timeline-marker--then .timeline-marker__dot {
  background: var(--lime);
  box-shadow: 0 0 8px rgba(200, 241, 91, 0.6);
}

/* Timeline arrow → dark on cream */
.slide[data-slide="10"] .timeline-arrow svg line {
  stroke: #0d0d0e;
}

.slide[data-slide="10"] .timeline-arrow svg marker path {
  fill: #0d0d0e;
}

/* Left rail · NOW card becomes a dark content block on cream */
.slide[data-slide="10"] .case-card--compact {
  background: #0d0d0e;
  border-color: rgba(13, 13, 14, 0.15);
  color: #f4f2eb;
  box-shadow: 0 8px 24px rgba(13, 13, 14, 0.08);
}

.slide[data-slide="10"] .case-card--compact .case-card__label,
.slide[data-slide="10"] .case-card--compact .case-card__title,
.slide[data-slide="10"] .case-card--compact .case-card__big-val,
.slide[data-slide="10"] .case-card--compact .case-card__big-key,
.slide[data-slide="10"] .case-card--compact .case-card__hint--sm,
.slide[data-slide="10"] .case-card--compact .case-card__comp {
  color: inherit;
}

.slide[data-slide="10"] .case-card--compact .case-card__title {
  color: #f4f2eb;
}

.slide[data-slide="10"] .case-card--compact .case-card__big-val {
  color: #f4f2eb;
}

.slide[data-slide="10"] .case-card--compact .case-card__big-key,
.slide[data-slide="10"] .case-card--compact .case-card__hint--sm {
  color: rgba(244, 242, 235, 0.65);
}

.slide[data-slide="10"] .case-card--compact .case-card__label {
  color: rgba(244, 242, 235, 0.6);
}

.slide[data-slide="10"] .case-card--compact .tier-list li {
  background: rgba(244, 242, 235, 0.06);
  border-color: rgba(244, 242, 235, 0.12);
  color: rgba(244, 242, 235, 0.88);
}

.slide[data-slide="10"] .case-card--compact .tier-list__name {
  color: rgba(244, 242, 235, 0.6);
}

.slide[data-slide="10"] .case-card--compact .tier-list__price {
  color: #f4f2eb;
}

.slide[data-slide="10"] .case-card--compact .case-card__big {
  border-bottom-color: rgba(244, 242, 235, 0.14);
}

.slide[data-slide="10"] .case-card--compact .case-card__comp {
  color: rgba(244, 242, 235, 0.55);
}

.slide[data-slide="10"] .case-card--compact .case-card__footer {
  border-top-color: rgba(244, 242, 235, 0.12);
}

.slide[data-slide="10"] .case-card--compact .case-card__outcome--solo {
  background: rgba(200, 241, 91, 0.14);
  border-color: rgba(200, 241, 91, 0.45);
  color: var(--lime);
}

/* Right · hero card → transparent. Content blocks float as dark rectangles on cream. */
.slide[data-slide="10"] .case-card--hero {
  background: transparent;
  border: none;
  padding: 0;
  color: #0d0d0e;
  box-shadow: none;
}

.slide[data-slide="10"] .case-card--hero::before {
  display: none;
}

.slide[data-slide="10"] .hero-topbar {
  margin-bottom: 16px;
}

.slide[data-slide="10"] .case-card__label--inline {
  color: rgba(13, 13, 14, 0.75);
  font-weight: 700;
}

/* Hero pillars: dark solid blocks on cream */
.slide[data-slide="10"] .explain-pillars--stacked .explain-pillar {
  background: #0d0d0e;
  border-color: rgba(13, 13, 14, 0.2);
}

.slide[data-slide="10"] .explain-pillars--stacked .explain-pillar__num {
  color: var(--lime);
}

.slide[data-slide="10"] .explain-pillars--stacked .explain-pillar p {
  color: rgba(244, 242, 235, 0.78);
}

/* Hero footer → dark on cream with lime outcome pill */
.slide[data-slide="10"] .case-card--hero .case-card__footer {
  border-top: 1px solid rgba(13, 13, 14, 0.18);
  padding-top: 14px;
}

.slide[data-slide="10"] .case-card--hero .case-card__comp {
  color: rgba(13, 13, 14, 0.55);
}

.slide[data-slide="10"] .case-card--hero .case-card__outcome {
  background: #0d0d0e;
  border-color: #0d0d0e;
  color: var(--lime);
}
