/* ============================================================
   TITAN DOSSIER — Newsroom / saga aesthetic
   ============================================================ */

:root {
  --maroon:      #5C0F0A;
  --maroon-deep: #3B0805;
  --ink:         #1A0605;
  --ink-soft:    #2A100C;
  --gold:        #E8C46A;
  --gold-deep:   #B8902F;
  --parchment:   #F5EDDA;
  --parchment-2: #ECE2C8;
  --paper:       #FBF6E7;
  --rule:        rgba(26, 6, 5, 0.18);
  --rule-light:  rgba(245, 237, 218, 0.22);

  --font-display: "Anton", "Bebas Neue", Impact, sans-serif;
  --font-serif:   "Newsreader", "Source Serif Pro", Georgia, serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--parchment);
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: 19px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

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

::selection { background: var(--gold); color: var(--ink); }

/* ------------------------------------------------------------
   Reusable atoms
   ------------------------------------------------------------ */

.wrap { max-width: 1340px; margin: 0 auto; padding: 0 36px; }

.hairline { border-top: 1px solid var(--rule); }
.hairline-light { border-top: 1px solid var(--rule-light); }
.hairline-thick { border-top: 4px solid var(--ink); }
.hairline-double {
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  height: 6px;
  border-image: none;
}
.hairline-double::after {
  content: "";
  display: block;
  height: 2px;
  border-top: 1px solid var(--ink);
  margin-top: 2px;
}

.label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
}

.label-gold { color: var(--gold); }
.label-maroon { color: var(--maroon); }

.stamp {
  display: inline-block;
  border: 2px solid currentColor;
  padding: 4px 10px 3px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 700;
  transform: rotate(-3deg);
  color: var(--maroon);
}
.stamp.red { color: var(--maroon); border-color: var(--maroon); }
.stamp.gold { color: var(--gold); border-color: var(--gold); }
.stamp.ink { color: var(--ink); border-color: var(--ink); }

.kicker {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--maroon);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.kicker::before {
  content: "";
  width: 32px;
  height: 1px;
  background: currentColor;
}

.display {
  font-family: var(--font-display);
  font-weight: 400;
  text-transform: uppercase;
  line-height: 0.86;
  letter-spacing: -0.005em;
}

.serif-headline {
  font-family: var(--font-serif);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.015em;
  font-style: italic;
}

.pull {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  line-height: 1.18;
  letter-spacing: -0.01em;
}

.byline {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: 0.72;
}

.cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px 12px;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  border: 2px solid var(--ink);
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease, transform 120ms ease;
}
.cta:hover { background: var(--gold); color: var(--ink); border-color: var(--gold); }
.cta.ghost { background: transparent; color: var(--ink); }
.cta.ghost:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.cta.gold { background: var(--gold); color: var(--ink); border-color: var(--gold); }
.cta.gold:hover { background: var(--ink); color: var(--gold); border-color: var(--ink); }
.cta .arrow { font-size: 16px; transform: translateY(-1px); }

/* ------------------------------------------------------------
   Topbar
   ------------------------------------------------------------ */

.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--paper);
  border-bottom: 1px solid var(--ink);
}
.topbar-strip {
  background: var(--ink);
  color: var(--parchment);
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 6px 36px;
  display: flex;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.topbar-strip span { opacity: 0.8; }
.topbar-strip .live {
  color: var(--gold);
  display: inline-flex; align-items: center; gap: 8px;
}
.topbar-strip .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--gold);
  animation: pulse 1.6s infinite;
}
@keyframes pulse { 0%,100% { opacity: 1 } 50% { opacity: 0.25 } }

.topbar-main {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 14px 36px;
  gap: 24px;
}
.topbar-nav {
  display: flex;
  gap: 26px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.topbar-nav a { padding: 6px 0; border-bottom: 2px solid transparent; }
.topbar-nav a:hover { border-color: var(--maroon); color: var(--maroon); }

.topbar-mast {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.topbar-mast img { width: 34px; height: 34px; }
.mast-wordmark {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  line-height: 0.9;
}
.mast-titan {
  font-size: 30px;
  color: var(--ink);
}
.mast-mid {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  color: var(--maroon);
  transform: translateY(-2px);
}
.mast-doge {
  font-size: 30px;
  color: var(--maroon);
  border-bottom: 3px solid var(--gold);
  padding-bottom: 1px;
}
@media (max-width: 640px) {
  .mast-mid { display: none; }
  .mast-titan, .mast-doge { font-size: 24px; }
  /* Free up room so the Buy CTA fits; socials still live in the footer */
  .topbar-actions .icon-link { display: none; }
}

.topbar-actions {
  display: flex; gap: 10px; justify-content: flex-end; align-items: center;
}
.icon-link {
  width: 36px; height: 36px;
  border: 1px solid var(--ink);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink);
  transition: background 120ms, color 120ms;
}
.icon-link:hover { background: var(--ink); color: var(--paper); }
.icon-link svg { width: 16px; height: 16px; }
.topbar-actions .cta {
  height: 36px;
  padding: 0 16px;
  border-width: 1px;
  font-size: 11px;
}

/* ------------------------------------------------------------
   Front page (hero)
   ------------------------------------------------------------ */

.front {
  background: var(--paper);
  padding: 40px 0 72px;
  position: relative;
}
.front-meta {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 16px;
  padding: 12px 0;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.front-meta .c { text-align: center; }
.front-meta .r { text-align: right; }

.front-headline {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
.front-kicker {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--maroon);
}
.front-headline h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(80px, 16vw, 260px);
  line-height: 0.82;
  text-transform: uppercase;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.front-headline h1 .strike {
  position: relative;
  display: inline-block;
  color: var(--ink);
  opacity: 0.45;
}
.front-headline h1 .strike::after {
  content: "";
  position: absolute;
  left: -2%;
  right: -2%;
  top: 50%;
  height: 8px;
  background: var(--maroon);
  transform: rotate(-2deg);
}
.front-headline h1 em {
  color: var(--maroon);
  font-style: normal;
}

.front-deck {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 36px;
  padding-top: 28px;
  margin-top: 18px;
  border-top: 1px solid var(--ink);
}
.front-deck .lede {
  font-family: var(--font-serif);
  font-size: 22px;
  line-height: 1.35;
  font-weight: 500;
}
.front-deck .lede .dropcap {
  float: left;
  font-family: var(--font-display);
  font-size: 86px;
  line-height: 0.82;
  margin: 6px 10px 0 0;
  color: var(--maroon);
}
.front-deck .col h3 {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin: 0 0 10px;
  color: var(--maroon);
}
.front-deck .col p { margin: 0 0 10px; font-size: 16px; line-height: 1.45; }

.front-plate {
  margin-top: 56px;
  border: 1px solid var(--ink);
  background: var(--maroon);
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  display: grid;
  place-items: center;
}
.front-plate img {
  width: 100%; height: 100%; object-fit: cover;
  filter: contrast(1.02) saturate(1.05);
}
.front-plate .corner {
  position: absolute;
  top: 14px; left: 14px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  background: rgba(0,0,0,0.55);
  padding: 6px 10px;
  border: 1px solid var(--gold);
}
.front-plate .corner.tr { left: auto; right: 14px; }
.front-plate .caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,0.78));
  color: var(--parchment);
  padding: 40px 22px 18px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* Hero plate auto-cycle progress bar */
.hero-progress {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: rgba(0,0,0,0.35);
  opacity: 0;
  transition: opacity 200ms ease;
  z-index: 2;
}
.hero-progress span {
  display: block;
  height: 100%;
  width: 0%;
  background: var(--gold);
  box-shadow: 0 0 8px rgba(232, 196, 106, 0.5);
}
.front-plate[data-auto="1"] .hero-progress { opacity: 1; }
.front-plate[data-auto="1"] .hero-progress span {
  animation: heroProgress 5s linear infinite;
}
@keyframes heroProgress {
  from { width: 0%; }
  to   { width: 100%; }
}

/* Plate variants */
.front-plate[data-variant="maga"] { background: #b32a1a; }
.front-plate[data-variant="elon"] { background: #0e0e10; }
.front-plate[data-variant="risen"] { background: #1a3654; }
.front-plate img { transition: opacity 320ms ease; }

/* Ticker */
.ticker {
  background: var(--ink);
  color: var(--parchment);
  border-top: 1px solid var(--gold);
  border-bottom: 1px solid var(--gold);
  overflow: hidden;
  position: relative;
}
.ticker-track {
  display: flex;
  gap: 64px;
  white-space: nowrap;
  padding: 14px 0;
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  animation: ticker 60s linear infinite;
  width: max-content;
}
.ticker-track span.g { color: var(--gold); }
.ticker-track span.dim { opacity: 0.5; }
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ------------------------------------------------------------
   Section scaffolding
   ------------------------------------------------------------ */

section { padding: 90px 0; position: relative; }
.section-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: baseline;
  margin-bottom: 48px;
  padding-bottom: 22px;
  border-bottom: 2px solid currentColor;
}
.section-head .num {
  font-family: var(--font-display);
  font-size: 96px;
  line-height: 0.82;
}
.section-head .title {
  font-family: var(--font-display);
  font-size: clamp(48px, 8vw, 120px);
  line-height: 0.86;
  text-transform: uppercase;
  letter-spacing: -0.01em;
}
.section-head .meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-align: right;
  line-height: 1.5;
}

/* Color modes */
.bg-paper     { background: var(--paper); color: var(--ink); }
.bg-parchment { background: var(--parchment); color: var(--ink); }
.bg-maroon    { background: var(--maroon); color: var(--parchment); }
.bg-ink       { background: var(--ink); color: var(--parchment); }
.bg-maroon .label, .bg-maroon .kicker, .bg-maroon .stamp,
.bg-ink    .label, .bg-ink    .kicker { color: var(--gold); }
.bg-maroon .kicker::before, .bg-ink .kicker::before { background: var(--gold); }
.bg-maroon a, .bg-ink a { color: var(--gold); }

/* ------------------------------------------------------------
   The Vow
   ------------------------------------------------------------ */

.vow {
  padding: 110px 0 120px;
  text-align: center;
  background:
    radial-gradient(ellipse at center, rgba(232,196,106,0.08), transparent 60%),
    var(--ink);
  color: var(--parchment);
  border-top: 1px solid var(--gold);
  border-bottom: 1px solid var(--gold);
}
.vow .creed {
  font-family: var(--font-display);
  font-size: clamp(56px, 10vw, 160px);
  line-height: 0.86;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--parchment);
  margin: 18px 0 24px;
}
.vow .creed em {
  color: var(--gold);
  font-style: normal;
}
.vow .creed .small {
  display: block;
  font-size: 0.42em;
  color: var(--gold);
  letter-spacing: 0.08em;
  margin-top: 18px;
  font-family: var(--font-display);
}
.vow .pull {
  max-width: 880px;
  margin: 36px auto 0;
  font-size: 26px;
  color: var(--parchment);
  opacity: 0.92;
}
.vow .signature {
  margin-top: 40px;
  display: inline-flex;
  gap: 20px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
}

/* ------------------------------------------------------------
   Saga (chapters)
   ------------------------------------------------------------ */

.chapter {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 56px;
  align-items: start;
  padding: 72px 0;
  border-top: 1px solid var(--rule);
}
.chapter:first-of-type { border-top: 0; padding-top: 24px; }
.chapter.flip { grid-template-columns: 1.15fr 1fr; }
.chapter.flip .ch-art { order: -1; }

.ch-meta {
  display: flex; gap: 16px; align-items: baseline; margin-bottom: 18px;
}
.ch-meta .num {
  font-family: var(--font-display);
  font-size: 78px;
  line-height: 0.82;
  color: var(--maroon);
}
.ch-meta .lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.ch-meta .lbl .date {
  display: block;
  color: var(--ink);
  opacity: 0.7;
  margin-top: 4px;
}

.chapter h3 {
  font-family: var(--font-display);
  font-size: clamp(48px, 6vw, 88px);
  line-height: 0.88;
  text-transform: uppercase;
  margin: 0 0 18px;
  letter-spacing: -0.01em;
}
.chapter h3 em { color: var(--maroon); font-style: normal; }
.chapter p {
  font-size: 18px;
  line-height: 1.55;
  margin: 0 0 14px;
}
.chapter .pq {
  border-left: 3px solid var(--maroon);
  padding: 6px 0 6px 20px;
  margin: 18px 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.25;
  color: var(--ink);
}
.chapter .pq cite {
  display: block;
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-top: 8px;
  color: var(--maroon);
}

.ch-art {
  border: 1px solid var(--ink);
  background: var(--ink);
  padding: 0;
  position: relative;
  overflow: hidden;
}
.ch-art img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ch-art.shrink-70 { max-width: 49%; margin: 0 auto; }
.ch-art figcaption {
  background: var(--ink);
  color: var(--parchment);
  padding: 12px 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* Stack of multiple exhibits in a single chapter column */
.ch-art-stack {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.ch-art-stack .ch-art img {
  height: auto;
  width: 100%;
  object-fit: contain;
  background: var(--paper);
}

.ch-headlines {
  margin-top: 20px;
  display: grid; gap: 0;
}
.ch-headlines li {
  list-style: none;
  display: grid;
  grid-template-columns: 110px 1fr auto;
  gap: 18px;
  padding: 12px 0;
  border-top: 1px solid var(--rule);
  font-size: 15px;
  align-items: baseline;
}
.ch-headlines li:last-child { border-bottom: 1px solid var(--rule); }
.ch-headlines .src {
  font-family: var(--font-display);
  font-size: 18px;
  text-transform: uppercase;
  color: var(--maroon);
  letter-spacing: 0.02em;
}
.ch-headlines .hl {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 600;
  line-height: 1.25;
  font-size: 17px;
}
.ch-headlines .dt {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.7;
}

/* Saga marquee */
.saga-marquee {
  background: var(--maroon);
  color: var(--parchment);
  padding: 22px 0;
  margin: 56px 0;
  overflow: hidden;
  border-top: 1px solid var(--gold);
  border-bottom: 1px solid var(--gold);
  position: relative;
}
.saga-marquee .track {
  display: flex; gap: 64px; white-space: nowrap; width: max-content;
  animation: ticker 80s linear infinite;
  font-family: var(--font-display);
  font-size: 46px;
  text-transform: uppercase;
  line-height: 1;
}
.saga-marquee .track .g { color: var(--gold); }
.saga-marquee .track .dot {
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--gold);
  display: inline-block;
  align-self: center;
}

/* ------------------------------------------------------------
   The Cuban Files
   ------------------------------------------------------------ */

.cuban {
  background: var(--paper);
}
.cuban-intro {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 56px;
  align-items: end;
  margin-bottom: 56px;
}
.cuban-intro p {
  font-size: 19px; line-height: 1.5; margin: 0 0 12px;
}
.cuban-quote {
  background: var(--ink);
  color: var(--parchment);
  padding: 32px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 24px;
  line-height: 1.25;
  position: relative;
}
.cuban-quote .qm {
  font-family: var(--font-display);
  font-size: 110px;
  color: var(--gold);
  line-height: 0.6;
  position: absolute;
  top: 14px; left: 18px;
  opacity: 0.85;
}
.cuban-quote blockquote {
  margin: 0 0 12px;
  padding-left: 56px;
}
.cuban-quote cite {
  display: block;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  padding-left: 56px;
  margin-top: 14px;
}

.cuban-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.cuban-card {
  position: relative;
  border: 1px solid var(--ink);
  background: var(--paper);
  display: flex;
  flex-direction: column;
  margin: 0;
}
.cuban-media {
  position: relative;
  overflow: hidden;
  background: var(--maroon);
  border-bottom: 1px solid var(--ink);
}
.cuban-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cuban-card figcaption {
  background: var(--paper);
  color: var(--ink);
  padding: 12px 14px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  line-height: 1.35;
  text-transform: none;
}
.cuban-card figcaption .exh {
  display: inline-block;
  background: var(--ink);
  color: var(--gold);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 3px 7px 2px;
  margin-right: 8px;
  vertical-align: 2px;
  font-weight: 600;
}

.cuban-card.w12 { grid-column: span 12; }
.cuban-card.w8  { grid-column: span 8; }
.cuban-card.w7  { grid-column: span 7; }
.cuban-card.w6  { grid-column: span 6; }
.cuban-card.w5  { grid-column: span 5; }
.cuban-card.w4  { grid-column: span 4; }
.cuban-card.w3  { grid-column: span 3; }

/* Tweet & contain variants — preserve full image (no crop) */
.cuban-card.tweet .cuban-media,
.cuban-card.contain .cuban-media {
  background: var(--paper);
}
.cuban-card.tweet .cuban-media img,
.cuban-card.contain .cuban-media img {
  object-fit: contain;
  padding: 14px;
}

/* I'M OUT button */
.imout {
  margin-top: 64px;
  background: var(--ink);
  color: var(--parchment);
  padding: 56px 48px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
  border: 1px solid var(--gold);
  position: relative;
  overflow: hidden;
}
.imout h4 {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 72px);
  line-height: 0.9;
  text-transform: uppercase;
  margin: 0 0 10px;
  color: var(--parchment);
}
.imout h4 em { color: var(--gold); font-style: normal; }
.imout p {
  font-size: 16px; opacity: 0.85; margin: 0 0 14px; max-width: 56ch;
}
.imout .count {
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gold);
}
.imout button {
  background: var(--maroon);
  color: var(--parchment);
  border: 2px solid var(--gold);
  padding: 28px 36px 24px;
  font-family: var(--font-display);
  font-size: 44px;
  text-transform: uppercase;
  line-height: 0.92;
  cursor: pointer;
  letter-spacing: 0.01em;
  transition: transform 80ms ease, background 80ms ease;
}
.imout button:hover { background: var(--gold); color: var(--ink); }
.imout button:active { transform: scale(0.97); }

/* Cuban exit overlay */
.cuban-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  pointer-events: none;
  display: none;
}
.cuban-overlay.show { display: block; }
.cuban-overlay::before {
  content: "";
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.55);
  animation: flash 600ms ease both;
}
@keyframes flash {
  0% { background: rgba(0,0,0,0); }
  20% { background: rgba(0,0,0,0.7); }
  100% { background: rgba(0,0,0,0); }
}
.cuban-overlay .runaway {
  position: absolute;
  top: 30%;
  left: -30%;
  width: 360px;
  height: 360px;
  background-image: url("media/punkz/cuban-strike.gif");
  background-size: cover;
  background-position: center;
  border: 6px solid var(--gold);
  animation: runaway 1.4s cubic-bezier(.6,.04,.45,1) forwards;
  box-shadow: 0 30px 80px rgba(0,0,0,0.5);
}
@keyframes runaway {
  0%   { left: -40%; transform: rotate(-8deg) scale(0.7); opacity: 0; }
  20%  { opacity: 1; }
  100% { left: 140%; transform: rotate(28deg) scale(1.1); opacity: 1; }
}
.cuban-overlay .yell {
  position: absolute;
  top: 22%;
  left: 50%;
  transform: translateX(-50%) rotate(-2deg);
  font-family: var(--font-display);
  font-size: clamp(80px, 16vw, 240px);
  color: var(--gold);
  -webkit-text-stroke: 3px var(--ink);
  text-shadow: 6px 6px 0 var(--ink);
  letter-spacing: -0.01em;
  animation: yellPop 1.2s ease forwards;
  white-space: nowrap;
}
@keyframes yellPop {
  0% { transform: translateX(-50%) rotate(-2deg) scale(0.4); opacity: 0; }
  18% { transform: translateX(-50%) rotate(-2deg) scale(1.08); opacity: 1; }
  80% { opacity: 1; }
  100% { transform: translateX(-50%) rotate(-2deg) scale(1); opacity: 0; }
}

/* ------------------------------------------------------------
   The Elon Prophecy
   ------------------------------------------------------------ */

.elon {
  background: var(--ink);
  color: var(--parchment);
  position: relative;
  overflow: hidden;
}
.elon::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 10%, rgba(232,196,106,0.08), transparent 40%),
    radial-gradient(circle at 80% 90%, rgba(92,15,10,0.5), transparent 50%);
  pointer-events: none;
}
.elon .section-head { color: var(--gold); border-color: var(--gold); }
.elon .section-head .num, .elon .section-head .title { color: var(--parchment); }
.elon .section-head .title em { color: var(--gold); font-style: normal; }

.prophecy {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 56px;
  align-items: center;
}
.prophecy-tweet {
  background: var(--parchment);
  color: var(--ink);
  padding: 36px;
  border: 1px solid var(--gold);
  position: relative;
}
.prophecy-tweet img { width: 100%; height: auto; }
.prophecy-tweet .meta {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--maroon);
  border-bottom: 1px solid var(--rule);
  padding-bottom: 12px; margin-bottom: 18px;
}
.prophecy-tweet .quote {
  font-family: var(--font-display);
  font-size: clamp(60px, 8vw, 120px);
  line-height: 0.9;
  text-transform: uppercase;
}
.prophecy-tweet .quote em { color: var(--maroon); font-style: normal; }
.prophecy-tweet .src {
  margin-top: 22px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--maroon);
}

.prophecy-body h3 {
  font-family: var(--font-display);
  font-size: clamp(48px, 6vw, 96px);
  line-height: 0.86;
  text-transform: uppercase;
  margin: 0 0 20px;
}
.prophecy-body h3 em { color: var(--gold); font-style: normal; }
.prophecy-body p { font-size: 18px; line-height: 1.55; margin: 0 0 12px; opacity: 0.92; }
.prophecy-body .pq {
  margin-top: 26px;
  border-left: 3px solid var(--gold);
  padding: 4px 0 4px 18px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--parchment);
}

.prophecy-strip {
  margin-top: 60px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
}
.prophecy-strip figure {
  margin: 0;
  border: 1px solid var(--gold);
  background: var(--ink-soft);
  overflow: hidden;
  position: relative;
}
.prophecy-strip figure img {
  width: 100%; height: 320px; object-fit: cover;
}
.prophecy-strip figcaption {
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  border-top: 1px solid var(--gold);
  background: var(--ink);
}

/* ------------------------------------------------------------
   Punkz Codex
   ------------------------------------------------------------ */

.punkz {
  background: var(--parchment);
}
.punkz-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  margin-bottom: 56px;
  align-items: end;
}
.punkz-intro p { font-size: 19px; line-height: 1.5; margin: 0 0 12px; }
.punkz-intro .stat {
  display: flex;
  justify-content: space-between;
  gap: 32px;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  padding: 20px 0;
}
.punkz-intro .stat > div:nth-child(2) { text-align: center; }
.punkz-intro .stat > div:last-child { text-align: right; }
.punkz-intro .stat .n {
  font-family: var(--font-display);
  font-size: 60px;
  line-height: 0.9;
}
.punkz-intro .stat .l {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--maroon);
  margin-top: 4px;
}

.punkz-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.punk-card {
  background: var(--maroon);
  border: 1px solid var(--ink);
  position: relative;
  overflow: hidden;
  aspect-ratio: 1/1;
}
.punk-card .media {
  position: absolute;
  inset: 0;
}
.punk-card img,
.punk-card video {
  width: 100%; height: 100%; object-fit: cover;
  image-rendering: pixelated;
  transition: transform 220ms ease;
  display: block;
}
.punk-card:hover img,
.punk-card:hover video { transform: scale(1.05); }
.punk-card .id {
  position: absolute; top: 8px; left: 8px;
  background: var(--gold);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  padding: 3px 7px;
}
.punk-card .name {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: var(--ink);
  color: var(--parchment);
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: 0.04em;
  padding: 8px 12px 6px;
  text-transform: uppercase;
  border-top: 1px solid var(--gold);
}

/* ------------------------------------------------------------
   Burn Ledger
   ------------------------------------------------------------ */

.burn {
  background: var(--maroon);
  color: var(--parchment);
  position: relative;
  overflow: hidden;
}
.burn::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 0%, rgba(232,196,106,0.16), transparent 50%);
  pointer-events: none;
}
.burn .section-head { color: var(--parchment); border-color: var(--gold); }
.burn .section-head .num { color: var(--gold); }
.burn .section-head .title em { color: var(--gold); font-style: normal; }

.burn-stage {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.burn-num {
  font-family: var(--font-display);
  font-size: clamp(110px, 18vw, 280px);
  line-height: 0.82;
  letter-spacing: -0.01em;
  color: var(--gold);
}
.burn-num .b {
  display: block;
  color: var(--parchment);
  font-size: 0.32em;
  letter-spacing: 0.04em;
  margin-top: 14px;
}
.burn-copy h3 {
  font-family: var(--font-display);
  font-size: clamp(44px, 5vw, 72px);
  line-height: 0.92;
  text-transform: uppercase;
  margin: 0 0 18px;
}
.burn-copy h3 em { color: var(--gold); font-style: normal; }
.burn-copy p { font-size: 17px; line-height: 1.55; margin: 0 0 12px; opacity: 0.92; }

.burn-table {
  margin-top: 56px;
  border-top: 1px solid var(--gold);
  border-bottom: 1px solid var(--gold);
}
.burn-table .row {
  display: grid;
  grid-template-columns: 90px 1fr auto auto;
  gap: 24px;
  align-items: center;
  padding: 18px 0;
  border-top: 1px solid var(--rule-light);
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.burn-table .row:first-child { border-top: 0; color: var(--gold); }
.burn-table .row .addr { word-break: break-all; letter-spacing: 0.06em; }
.burn-table .row .amt {
  font-family: var(--font-display);
  font-size: 28px;
  letter-spacing: 0.02em;
  color: var(--gold);
}
.burn-table .row a { text-decoration: underline; text-underline-offset: 4px; }

/* ------------------------------------------------------------
   Federal Reserve File
   ------------------------------------------------------------ */

.fedfile {
  background: var(--parchment);
  color: var(--ink);
  position: relative;
  overflow: hidden;
}
.fedfile::before {
  content: "";
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(20, 14, 8, 0.05) 1px, transparent 1px);
  background-size: 100% 26px;
  pointer-events: none;
  opacity: 0.7;
}
.fedfile > .wrap { position: relative; }
.fedfile .section-head { color: var(--ink); border-color: var(--ink); }
.fedfile .section-head .num { color: var(--maroon); }
.fedfile .section-head .title em { color: var(--maroon); font-style: italic; }

.ff-stage {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 56px;
  align-items: stretch;
}

.ff-paper {
  background: #fbf6e8;
  border: 1px solid var(--ink);
  padding: 36px 36px 32px;
  position: relative;
  box-shadow: 8px 8px 0 0 var(--maroon);
}
.ff-rubric {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding-bottom: 12px;
  border-bottom: 1.5px solid var(--ink);
  margin-bottom: 28px;
}
.ff-stamp {
  position: absolute;
  top: 32px; right: -14px;
  transform: rotate(7deg);
  border: 2px solid var(--maroon);
  color: var(--maroon);
  padding: 8px 14px 7px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  text-align: center;
  background: rgba(251, 246, 232, 0.85);
  line-height: 1.3;
}
.ff-stamp strong {
  display: block;
  font-size: 12px;
  letter-spacing: 0.18em;
  margin-top: 2px;
}
.ff-doctype {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--maroon);
  margin-bottom: 14px;
}
.ff-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 2.8vw, 42px);
  line-height: 1.06;
  margin: 0 0 22px;
  letter-spacing: -0.01em;
  max-width: 92%;
}
.ff-title em { color: var(--maroon); font-style: italic; }
.ff-authors {
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.65;
  font-style: italic;
  margin-bottom: 22px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(20, 14, 8, 0.25);
}
.ff-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 26px;
}
.ff-meta > div {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  line-height: 1.4;
}
.ff-meta span {
  display: block;
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--maroon);
  margin-bottom: 5px;
}
.ff-abstract {
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.6;
  margin: 0 0 28px;
}
.ff-abstract strong { color: var(--maroon); }
.ff-cta {
  display: inline-flex;
  align-items: baseline;
  gap: 16px;
  background: var(--ink);
  color: var(--parchment);
  padding: 14px 22px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--ink);
  transition: 200ms;
}
.ff-cta:hover {
  background: var(--maroon);
  border-color: var(--maroon);
}
.ff-cta-url {
  color: var(--gold);
  letter-spacing: 0.14em;
  text-transform: lowercase;
  font-style: italic;
}

.ff-commentary {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 8px 0;
}
.ff-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.36em;
  text-transform: uppercase;
  color: var(--maroon);
  margin-bottom: 22px;
}
.ff-commentary h4 {
  font-family: var(--font-display);
  font-size: clamp(36px, 4.2vw, 58px);
  line-height: 1.04;
  margin: 0 0 22px;
  letter-spacing: -0.01em;
}
.ff-commentary h4 em {
  color: var(--maroon);
  font-style: italic;
}
.ff-commentary p {
  font-size: 17px;
  line-height: 1.55;
  margin: 0 0 14px;
}
.ff-pull {
  background: var(--ink);
  color: var(--parchment);
  padding: 28px 32px 26px;
  position: relative;
  margin: 22px 0 18px;
}
.ff-pull .qm {
  font-family: var(--font-display);
  font-size: 92px;
  color: var(--gold);
  line-height: 0.6;
  position: absolute;
  top: 22px;
  left: 18px;
  opacity: 0.85;
}
.ff-pull blockquote {
  margin: 0 0 12px;
  padding-left: 50px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 20px;
  line-height: 1.32;
}
.ff-pull blockquote em { color: var(--gold); font-style: italic; }
.ff-pull blockquote strong {
  display: block;
  margin-top: 10px;
  color: var(--gold);
  font-style: normal;
  font-weight: 600;
}
.ff-tag {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink);
  border-top: 1px solid var(--ink);
  padding-top: 14px;
}

/* ------------------------------------------------------------
   Something Stirs (teaser)
   ------------------------------------------------------------ */

.stirs {
  background: var(--paper);
  text-align: center;
  padding: 140px 0 130px;
  position: relative;
  overflow: hidden;
}
.stirs::before, .stirs::after {
  content: "";
  position: absolute; left: 0; right: 0; height: 1px;
  background: var(--ink);
}
.stirs::before { top: 0; }
.stirs::after { bottom: 0; }

.stirs .small {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--maroon);
  margin-bottom: 28px;
}
.stirs h2 {
  font-family: var(--font-display);
  font-size: clamp(80px, 14vw, 220px);
  line-height: 0.86;
  text-transform: uppercase;
  margin: 0;
  letter-spacing: -0.01em;
  position: relative;
  display: inline-block;
}
.stirs h2 em { color: var(--maroon); font-style: normal; }
.stirs h2 .glitch {
  position: absolute;
  inset: 0;
  color: var(--gold);
  mix-blend-mode: multiply;
  opacity: 0.55;
  animation: glitch 4s infinite;
  pointer-events: none;
}
@keyframes glitch {
  0%, 95%, 100% { transform: translate(0,0); }
  96% { transform: translate(-3px, 1px); }
  97% { transform: translate(3px, -1px); }
  98% { transform: translate(-2px, 2px); }
  99% { transform: translate(2px, -2px); }
}
.stirs .blurb {
  max-width: 740px;
  margin: 36px auto 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.4;
  color: var(--ink);
}
.stirs-exhibit {
  margin: 56px auto 0;
  max-width: 440px;
  border: 1px solid var(--gold);
  background: var(--ink-soft);
  overflow: hidden;
  position: relative;
  text-align: left;
}
.stirs-exhibit a { display: block; }
.stirs-exhibit img {
  display: block;
  width: 100%;
  height: 320px;
  object-fit: cover;
  object-position: center top;
}
.stirs-exhibit figcaption {
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  border-top: 1px solid var(--gold);
  background: var(--ink);
  line-height: 1.4;
}
.stirs .seal {
  margin-top: 48px;
  display: inline-flex; gap: 28px; align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink);
}
.stirs .seal .glyph {
  width: 56px; height: 56px;
  border: 1px solid var(--ink);
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 30px;
  color: var(--maroon);
}

/* ------------------------------------------------------------
   The $100M Question — quiz
   ------------------------------------------------------------ */

.quiz {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(232,196,106,0.10), transparent 55%),
    var(--ink);
  color: var(--parchment);
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--gold);
}
.quiz .section-head {
  color: var(--gold);
  border-color: var(--gold);
  grid-template-columns: 1fr auto;
}
.quiz .section-head .num,
.quiz .section-head .title { color: var(--parchment); }
.quiz .section-head .title em { color: var(--gold); font-style: normal; }

.quiz-stage { position: relative; }

/* Question card */
.quiz-card {
  max-width: 1080px;
  margin: 0 auto;
  text-align: center;
}
.quiz-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 22px;
}
.quiz-q {
  font-family: var(--font-display);
  font-size: clamp(30px, 4.4vw, 54px);
  line-height: 1.04;
  letter-spacing: -0.01em;
  margin: 0 auto 44px;
  max-width: 16ch;
  text-wrap: balance;
}
.quiz-q em { color: var(--gold); font-style: italic; }

.quiz-options {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px;
  margin-bottom: 26px;
}
.quiz-opt {
  display: grid;
  grid-template-columns: 48px 1fr 28px;
  align-items: center;
  gap: 18px;
  text-align: left;
  padding: 26px 26px;
  background: rgba(245, 237, 218, 0.03);
  border: 1.5px solid rgba(232, 196, 106, 0.4);
  color: var(--parchment);
  font: inherit;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: border-color 180ms ease, background 180ms ease, transform 120ms ease;
}
.quiz-opt::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--gold);
  transform: translateY(101%);
  transition: transform 320ms cubic-bezier(.4,.1,.2,1);
  z-index: 0;
}
.quiz-opt > * { position: relative; z-index: 1; }
.quiz-opt:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
}
.quiz-opt:hover:not(.is-correct):not(.is-wrong)::before { transform: translateY(82%); }
.quiz-opt .opt-key {
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-display);
  font-size: 26px;
  line-height: 1;
  transition: 180ms;
}
.quiz-opt .opt-body { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.quiz-opt .opt-name {
  font-family: var(--font-display);
  font-size: 30px;
  letter-spacing: 0.02em;
  line-height: 1;
}
.quiz-opt .opt-sub {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.7;
}
.quiz-opt .opt-mark {
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 24px;
  opacity: 0;
  transition: opacity 180ms;
}

/* states */
.quiz-opt.is-correct {
  border-color: var(--gold);
  background: var(--gold);
  color: var(--ink);
  transform: translateY(-2px);
}
.quiz-opt.is-correct::before { transform: translateY(0); }
.quiz-opt.is-correct .opt-key { border-color: var(--ink); color: var(--ink); }
.quiz-opt.is-correct .opt-mark { opacity: 1; color: var(--maroon); }
.quiz-opt.is-correct .opt-mark::after { content: "✓"; }

.quiz-opt.is-wrong {
  border-color: var(--maroon);
  background: rgba(92, 15, 10, 0.55);
  color: var(--parchment);
  animation: quizShake 420ms cubic-bezier(.36,.07,.19,.97);
}
.quiz-opt.is-wrong .opt-key { border-color: var(--maroon); color: #E8857A; }
.quiz-opt.is-wrong .opt-mark { opacity: 1; color: #E8857A; }
.quiz-opt.is-wrong .opt-mark::after { content: "✕"; }

.quiz-stage.answered .quiz-opt { cursor: default; pointer-events: none; }
.quiz-stage.answered .quiz-opt:not(.is-correct):not(.is-wrong) { opacity: 0.4; }

@keyframes quizShake {
  10%, 90% { transform: translateX(-2px); }
  20%, 80% { transform: translateX(4px); }
  30%, 50%, 70% { transform: translateX(-8px); }
  40%, 60% { transform: translateX(8px); }
}

.quiz-feedback {
  min-height: 22px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 8px;
  opacity: 0;
  transition: opacity 200ms;
}
.quiz-feedback.show { opacity: 1; }
.quiz-feedback.ok { color: var(--gold); }
.quiz-feedback.no { color: #E8857A; }
.quiz-hint {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  opacity: 0.55;
}

/* Proof */
.quiz-proof {
  margin-top: 12px;
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
  grid-template-areas:
    "head  head"
    "chart math";
  gap: 28px 36px;
  align-items: start;
}
.quiz-proof[hidden] { display: none; }
.quiz-proof.reveal { animation: quizReveal 560ms cubic-bezier(.2,.7,.2,1) both; }
@keyframes quizReveal {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

.proof-head {
  grid-area: head;
  position: relative;
  border-top: 1.5px solid var(--gold);
  padding-top: 26px;
  max-width: 760px;
}
.proof-stamp {
  position: absolute;
  top: 22px; right: 0;
  transform: rotate(7deg);
  border: 2px solid var(--gold);
  color: var(--gold);
  padding: 9px 16px 7px;
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}
.proof-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}
.proof-head h3 {
  font-family: var(--font-display);
  font-size: clamp(32px, 3.8vw, 50px);
  line-height: 1.02;
  margin: 0 0 16px;
  letter-spacing: -0.01em;
}
.proof-head h3 em { color: var(--gold); font-style: italic; }
.proof-head p {
  font-size: 17px;
  line-height: 1.55;
  margin: 0;
  opacity: 0.9;
  max-width: 62ch;
}

.proof-chart {
  grid-area: chart;
  margin: 0;
  border: 1px solid var(--gold);
  background: #0d1018;
  overflow: hidden;
}
.proof-chart img {
  display: block;
  width: 100%;
  height: auto;
}
.proof-chart figcaption {
  padding: 11px 16px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  border-top: 1px solid var(--gold);
  background: var(--ink);
}

.proof-math {
  grid-area: math;
  border: 1px solid rgba(232, 196, 106, 0.4);
  background: rgba(245, 237, 218, 0.03);
  padding: 28px 28px 24px;
  align-self: stretch;
}
.pm-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
}
.pm-grid { display: grid; gap: 12px; }
.pm-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-bottom: 1px dashed rgba(232, 196, 106, 0.25);
  padding-bottom: 12px;
}
.pm-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  opacity: 0.7;
}
.pm-val {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: 0.01em;
  line-height: 1;
}
.pm-op {
  font-family: var(--font-display);
  font-size: 24px;
  color: var(--gold);
  text-align: center;
  line-height: 0.6;
}
.pm-result { border-bottom: none; padding-bottom: 0; }
.pm-result .pm-label { color: var(--gold); opacity: 1; }
.pm-result .pm-val { color: var(--gold); font-size: clamp(28px, 3.2vw, 40px); }
.pm-note {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(232, 196, 106, 0.3);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.5;
  opacity: 0.88;
}
.pm-note strong { color: var(--gold); font-style: normal; }

.quiz-reset {
  margin-top: 22px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: transparent;
  color: var(--gold);
  border: 1.5px solid var(--gold);
  padding: 13px 22px 11px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  transition: 160ms;
}
.quiz-reset:hover { background: var(--gold); color: var(--ink); }
.quiz-reset .arrow { font-size: 16px; }

/* celebratory overlay */
.quiz-overlay {
  position: fixed;
  inset: 0;
  z-index: 9998;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(26, 6, 5, 0.86);
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}
.quiz-overlay.show { opacity: 1; }
.quiz-yell {
  font-family: var(--font-display);
  font-size: clamp(56px, 11vw, 168px);
  line-height: 0.9;
  color: var(--parchment);
  text-align: center;
  letter-spacing: -0.01em;
  -webkit-text-stroke: 2px var(--ink);
  text-shadow: 6px 6px 0 var(--maroon);
  transform: scale(0.7);
  opacity: 0;
}
.quiz-overlay.show .quiz-yell { animation: quizPop 1.3s cubic-bezier(.2,.8,.2,1) forwards; }
.quiz-yell em { color: var(--gold); font-style: normal; display: block; }
@keyframes quizPop {
  0%   { transform: scale(0.7) rotate(-3deg); opacity: 0; }
  18%  { transform: scale(1.06) rotate(-1deg); opacity: 1; }
  30%  { transform: scale(1) rotate(0deg); }
  82%  { transform: scale(1); opacity: 1; }
  100% { transform: scale(1.04); opacity: 0; }
}
.quiz-confetti { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.quiz-confetti i {
  position: absolute;
  top: -8%;
  width: 11px; height: 18px;
  background: var(--gold);
  opacity: 0.95;
  animation: confettiFall linear forwards;
}
.quiz-confetti i:nth-child(3n)   { background: var(--parchment); }
.quiz-confetti i:nth-child(4n)   { background: var(--maroon); }
.quiz-confetti i:nth-child(5n)   { width: 8px; height: 8px; border-radius: 50%; }
@keyframes confettiFall {
  0%   { transform: translateY(0) rotate(0deg); opacity: 1; }
  100% { transform: translateY(112vh) rotate(720deg); opacity: 0.9; }
}

@media (prefers-reduced-motion: reduce) {
  .quiz-opt.is-wrong { animation: none; }
  .quiz-overlay.show .quiz-yell { animation: none; opacity: 1; transform: scale(1); }
  .quiz-confetti i { display: none; }
  .quiz-proof.reveal { animation: none; }
}

/* ------------------------------------------------------------
   Footer
   ------------------------------------------------------------ */

footer {
  background: var(--ink);
  color: var(--parchment);
  padding: 72px 0 36px;
  border-top: 1px solid var(--gold);
}
footer .grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 36px;
}
footer h5 {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin: 0 0 16px;
  color: var(--gold);
}
footer .mast {
  font-family: var(--font-display);
  font-size: 40px;
  line-height: 0.9;
  text-transform: uppercase;
  margin-bottom: 14px;
}
footer .mast em { color: var(--gold); font-style: normal; }

/* Footer masthead — matches topbar treatment, tuned for dark bg */
.footer-mast {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 10px;
  line-height: 0.9;
}
.footer-mast .fm-titan {
  color: var(--parchment);
}
.footer-mast .fm-mid {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  color: var(--gold);
  transform: translateY(-3px);
}
.footer-mast .fm-doge {
  color: var(--gold);
  border-bottom: 3px solid var(--maroon);
  padding-bottom: 2px;
}
footer p { margin: 0 0 8px; font-size: 14px; opacity: 0.78; line-height: 1.5; }
footer ul { list-style: none; margin: 0; padding: 0; }
footer ul li { margin-bottom: 8px; font-size: 14px; }
footer ul li a { border-bottom: 1px solid transparent; padding-bottom: 1px; }
footer ul li a:hover { border-color: var(--gold); color: var(--gold); }
footer .colophon {
  margin-top: 56px;
  padding-top: 18px;
  border-top: 1px solid rgba(245,237,218,0.18);
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  opacity: 0.7;
  flex-wrap: wrap;
  gap: 16px;
}

/* ------------------------------------------------------------
   Tweaks panel
   ------------------------------------------------------------ */

.tweaks-toggle-wrap {
  position: fixed;
  bottom: 22px; right: 22px;
  z-index: 90;
}
.tweaks-panel {
  position: fixed;
  bottom: 22px; right: 22px;
  z-index: 100;
  width: 320px;
  background: var(--paper);
  border: 1px solid var(--ink);
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
  font-family: var(--font-mono);
  color: var(--ink);
  display: none;
}
.tweaks-panel.open { display: block; }
.tweaks-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px;
  background: var(--ink);
  color: var(--parchment);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.tweaks-head button {
  background: transparent; border: 0; color: var(--parchment);
  font: inherit; cursor: pointer;
}
.tweaks-body { padding: 16px; }
.tweak-row { margin-bottom: 16px; }
.tweak-row:last-child { margin-bottom: 0; }
.tweak-row label {
  display: block;
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--maroon);
  margin-bottom: 8px;
}
.tweak-segment {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  border: 1px solid var(--ink);
}
.tweak-segment.seg-4 {
  grid-template-columns: 1fr 1fr 1fr 1fr;
}
.tweak-segment button {
  background: var(--paper);
  color: var(--ink);
  border: 0;
  border-right: 1px solid var(--ink);
  padding: 10px 6px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
}
.tweak-segment button:last-child { border-right: 0; }
.tweak-segment button.active {
  background: var(--ink); color: var(--gold);
}

/* ------------------------------------------------------------
   Responsive
   ------------------------------------------------------------ */

@media (max-width: 980px) {
  .wrap { padding: 0 22px; }
  .topbar-main { grid-template-columns: 1fr auto; padding: 12px 22px; }
  .topbar-nav { display: none; }
  .front-deck { grid-template-columns: 1fr; gap: 22px; }
  .chapter, .chapter.flip { grid-template-columns: 1fr; gap: 28px; }
  .chapter.flip .ch-art { order: 0; }
  .cuban-intro { grid-template-columns: 1fr; }
  .cuban-grid { grid-template-columns: repeat(6, 1fr); }
  .cuban-card.w12, .cuban-card.w8, .cuban-card.w7, .cuban-card.w6, .cuban-card.w5, .cuban-card.w4, .cuban-card.w3 { grid-column: span 6; }
  .imout { grid-template-columns: 1fr; }
  .prophecy { grid-template-columns: 1fr; }
  .prophecy-strip { grid-template-columns: 1fr; }
  .punkz-grid { grid-template-columns: repeat(2, 1fr); }
  .punkz-intro { grid-template-columns: 1fr; }
  .burn-stage { grid-template-columns: 1fr; }
  .burn-table .row { grid-template-columns: 60px 1fr; row-gap: 6px; }
  .burn-table .row .addr { grid-column: 1 / -1; }
  .burn-table .row .amt { grid-column: 1 / -1; }
  footer .grid { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
  footer .grid > div { overflow-wrap: anywhere; }
  .section-head { grid-template-columns: 1fr; gap: 8px; }
  .section-head .meta { text-align: left; }
  .ff-meta { grid-template-columns: 1fr 1fr; }
  /* Federal Reserve File: stack the paper + commentary */
  .ff-stage { grid-template-columns: 1fr; gap: 32px; }
  .ff-stamp { right: 0; }
  /* Quiz: stack everything into one column on narrow screens */
  .quiz .section-head { grid-template-columns: 1fr; }
  .quiz-options { grid-template-columns: minmax(0, 1fr); }
  .quiz-proof {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "head"
      "chart"
      "math";
  }
}
