/* ============================================================
   KJ2294 · St Jude Charity Stream — "poster.css"
   Clean Swiss-modernist poster system. White · near-black · St Jude red.
   Futura (display/numerals) + Helvetica Neue (text). No texture, strong grid.
   ============================================================ */

:root {
  --paper:  #f5efe1;        /* warm cream paper           */
  --ink:    #14110d;        /* near-black, faintly warm   */
  --muted:  #6b665d;        /* secondary label grey       */
  --red:    #c8102e;        /* St Jude red                */
  --red-dk: #98000f;
  --line:   #ddd5c1;        /* hairline rule (on cream)   */

  --display: "Avenir Next", "Avenir", sans-serif;   /* headline + numerals, w800 */
  --sans:    "Avenir Next", "Avenir", sans-serif;   /* text                      */
}

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

.sheet {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  position: relative;
  overflow: hidden;
}

/* ---- type helpers ---- */
.eyebrow {
  font-family: var(--sans); font-weight: 700;
  text-transform: uppercase; letter-spacing: .26em;
  color: var(--red); font-size: 15px;
}
.display { font-family: var(--display); font-weight: 700; line-height: .86;
           text-transform: uppercase; letter-spacing: -.01em; }
.lede { font-family: var(--sans); font-weight: 400; color: var(--ink);
        line-height: 1.32; }
.kicker { font-family: var(--sans); font-weight: 700; text-transform: uppercase;
          letter-spacing: .14em; }
.red    { color: var(--red); }
.ink    { color: var(--ink); }
.muted  { color: var(--muted); }

/* ---- rules ---- */
.rule       { border: none; border-top: 3px solid var(--ink); width: 100%; }
.rule.red   { border-top-color: var(--red); }
.rule.thin  { border-top-width: 1px; border-top-color: var(--line); }

/* ---- milestone grid: big red numeral + label ---- */
.milestones { display: grid; }
.ms {
  display: grid; grid-template-columns: var(--ms-col, 2.6em) 1fr;
  align-items: baseline; column-gap: .7em;
  padding: var(--ms-pad, .42em) 0;
  border-bottom: 1px solid var(--line);
}
.ms:first-child { border-top: 1px solid var(--line); }
.ms .num { font-family: var(--display); font-weight: 700; color: var(--red);
           text-align: right; font-variant-numeric: tabular-nums;
           font-size: var(--ms-num, 1em); letter-spacing: -.02em; }
.ms .lab { font-family: var(--sans); font-weight: 500; line-height: 1.12; }
.ms .lab b { font-weight: 700; }

/* ---- schedule chip ---- */
.sched {
  display: inline-block; background: var(--red); color: #fff;
  font-family: var(--sans); font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; padding: .42em .8em;
}

/* ---- QR block ---- */
.qr { display: block; background: #fff; border: 2px solid var(--ink); }

/* ---- clean tear-off tabs ---- */
.tabs { display: flex; border-top: 1px dashed var(--ink); }
.tab  { flex: 1; border-left: 1px dashed var(--ink);
        display: flex; align-items: center; justify-content: center; }
.tab:first-child { border-left: none; }
.tab span {
  writing-mode: vertical-rl; transform: rotate(180deg);
  font-family: var(--sans); font-weight: 700; letter-spacing: .05em;
  white-space: nowrap; color: var(--ink);
}
.tab span i { font-style: normal; color: var(--red); }

@media print {
  @page { size: 8.5in 11in; margin: 0; }
  * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}
