  /* ───── PART 5 — Polymarket live ───── */
  .pm-stage {
    margin-top: 60px;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: stretch;
  }
  .pm-card {
    border: 1px solid var(--rule);
    background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
    padding: 48px 48px 44px;
    border-radius: 2px;
    display: flex;
    flex-direction: column;
    min-height: 420px;
  }
  :root[data-theme="light"] .pm-card {
    background: linear-gradient(180deg, rgba(21,19,15,0.035), rgba(21,19,15,0));
  }
  .pm-live {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-family: var(--f-mono);
    font-size: 24px;
    letter-spacing: 0.18em;
    color: var(--ink-mute);
    text-transform: uppercase;
  }
  .pm-live .dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--crimson);
    box-shadow: 0 0 0 0 oklch(0.62 0.17 28 / 0.6);
    animation: pulse 1.6s ease-in-out infinite;
  }
  @keyframes pulse {
    0%, 100% { box-shadow: 0 0 0 0 oklch(0.62 0.17 28 / 0.6); }
    50%      { box-shadow: 0 0 0 8px oklch(0.62 0.17 28 / 0); }
  }
  .pm-question {
    font-size: 30px;
    margin-top: 28px;
    line-height: 1.35;
    color: var(--ink);
    font-weight: 500;
    min-height: 82px;
  }
  .pm-price-row {
    margin-top: auto;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
  }
  .pm-price {
    font-family: var(--f-mono);
    font-size: 140px;
    font-weight: 600;
    color: var(--gold);
    letter-spacing: -0.04em;
    line-height: 1;
    font-variant-numeric: tabular-nums;
    transition: color 300ms ease;
  }
  .pm-price.up   { color: var(--green); }
  .pm-price.down { color: var(--crimson); }
  .pm-delta {
    font-family: var(--f-mono);
    font-size: 24px;
    color: var(--ink-mute);
  }
  .pm-delta.up   { color: var(--green); }
  .pm-delta.down { color: var(--crimson); }
  .pm-footer {
    margin-top: 22px;
    display: flex;
    justify-content: space-between;
    font-family: var(--f-mono);
    font-size: 24px;
    color: var(--ink-mute);
  }
  .pm-legend {
    display: flex;
    gap: 16px;
  }

  /* sparkline */
  .pm-spark {
    height: 90px;
    margin-top: 28px;
    position: relative;
  }
  .pm-spark svg { width: 100%; height: 100%; overflow: visible; }
  .pm-spark path.line { fill: none; stroke: var(--gold); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
  .pm-spark path.fill { fill: url(#spark-grad); stroke: none; opacity: 0.22; }

  #hr-verb.cursor-blink {
    animation: hr-caret-blink 0.9s steps(1, end) infinite;
  }
  @keyframes hr-caret-blink {
    0%, 49% { border-right-color: var(--gold); }
    50%, 100% { border-right-color: transparent; }
  }

  /* ───── PART 6 — Theo big number ───── */
  .big-num {
    font-family: var(--f-mono);
    font-size: 340px;
    font-weight: 700;
    line-height: 0.9;
    letter-spacing: -0.06em;
    color: var(--ink);
    margin: 0;
  }
  .big-num .unit { font-size: 120px; color: var(--gold-dim); margin-left: 12px; letter-spacing: -0.02em; }
  .big-caption {
    margin-top: 36px;
    font-size: 34px;
    color: var(--ink-dim);
    font-family: var(--f-sans);
  }
  .big-caption b { color: var(--ink); font-weight: 500; }

  .method-card {
    margin-top: 80px;
    border-left: 2px solid var(--gold);
    padding: 20px 0 20px 48px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-width: 1400px;
  }
  .method-q {
    font-family: var(--f-serif);
    font-style: italic;
    font-size: 52px;
    line-height: 1.2;
    color: var(--ink);
    letter-spacing: -0.01em;
  }
  .method-q del { color: var(--ink-mute); text-decoration-thickness: 1px; }
  .method-q b { color: var(--gold); font-weight: 400; font-style: italic; }

  /* ───── PART 7 — close ───── */
  .theo-prob-chart {
    position: absolute;
    top: 124px;
    right: 42px;
    width: 690px;
    height: 375px;
    pointer-events: none;
    opacity: 0;
    transform: translateY(10px);
    z-index: 4;
  }
  #slide-neighbor[data-deck-active] .theo-prob-chart {
    animation: theo-chart-in 700ms ease forwards 450ms;
  }
  .theo-chart-label {
    font-family: var(--f-mono);
    font-size: 17px;
    letter-spacing: 0.12em;
    fill: var(--ink-mute);
  }
  .theo-chart-value {
    font-family: var(--f-mono);
    font-size: 32px;
    font-weight: 700;
    fill: var(--gold);
  }
  .theo-chart-grid {
    stroke: var(--rule);
    stroke-width: 1;
  }
  .theo-chart-axis {
    stroke: var(--ink-mute);
    stroke-width: 1;
    opacity: 0.45;
  }
  .theo-chart-before {
    fill: none;
    stroke: var(--ink-mute);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
    opacity: 0.55;
  }
  .theo-chart-after {
    fill: none;
    stroke: var(--gold);
    stroke-width: 5;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 620;
    stroke-dashoffset: 620;
  }
  .theo-chart-marker {
    stroke: var(--crimson);
    stroke-width: 2;
    stroke-dasharray: 6 7;
    opacity: 0;
  }
  .theo-chart-dot {
    fill: var(--crimson);
    opacity: 0;
    filter: drop-shadow(0 0 7px rgba(213, 75, 62, 0.72));
    transform-box: fill-box;
    transform-origin: center;
  }
  .theo-chart-pulse {
    fill: none;
    stroke: var(--crimson);
    stroke-width: 2;
    opacity: 0;
    transform-box: fill-box;
    transform-origin: center;
  }
  .theo-chart-note {
    font-family: var(--f-mono);
    font-size: 15px;
    letter-spacing: 0.08em;
    fill: var(--crimson);
    opacity: 0;
  }
  #slide-neighbor[data-deck-active] .theo-chart-after {
    animation: theo-line-draw 6000ms cubic-bezier(.2,.8,.2,1) forwards 1200ms;
  }
  #slide-neighbor[data-deck-active] .theo-chart-marker,
  #slide-neighbor[data-deck-active] .theo-chart-note {
    animation: theo-marker-in 520ms ease forwards 900ms;
  }
  #slide-neighbor[data-deck-active] .theo-chart-dot {
    animation:
      theo-marker-in 520ms ease forwards 900ms,
      theo-dot-live 1600ms ease-in-out infinite 1500ms;
  }
  #slide-neighbor[data-deck-active] .theo-chart-pulse {
    animation: theo-dot-pulse 1800ms ease-out infinite 1200ms;
  }
  @keyframes theo-chart-in {
    to { opacity: 0.76; transform: translateY(0); }
  }
  @keyframes theo-line-draw {
    to { stroke-dashoffset: 0; }
  }
  @keyframes theo-marker-in {
    to { opacity: 1; }
  }
  @keyframes theo-dot-live {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.28); }
  }
  @keyframes theo-dot-pulse {
    0% { opacity: 0.58; transform: scale(0.55); }
    72%, 100% { opacity: 0; transform: scale(2.8); }
  }

  .lineage {
    margin-top: 72px;
    display: flex;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
    font-family: var(--f-mono);
    font-size: 30px;
    color: var(--ink-dim);
    letter-spacing: 0.04em;
  }
  .lineage span { padding: 12px 24px; border: 1px solid var(--rule); border-radius: 2px; }
  .lineage span.current { border-color: var(--gold); color: var(--gold); }
  .lineage em { color: var(--ink-mute); font-style: normal; }

  .inequality {
    margin-top: 60px;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 60px;
    align-items: center;
    width: 100%;
  }
  .ineq-col {
    border: 1px solid var(--rule);
    padding: 56px 48px;
    text-align: center;
    min-height: 280px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 16px;
  }
  .ineq-col .tag {
    font-family: var(--f-mono);
    font-size: 26px;
    color: var(--gold);
    letter-spacing: 0.18em;
    text-transform: uppercase;
  }
  .ineq-col .what { font-size: 52px; font-weight: 500; letter-spacing: -0.02em; }
  .ineq-col .who  { font-size: 26px; color: var(--ink-dim); margin-top: 8px; }
  .ineq-arrow {
    font-family: var(--f-mono);
    font-size: 80px;
    color: var(--ink-mute);
  }
