/* The Manufactured Healthcare Crisis — animated explainer */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;0,6..72,700;0,6..72,800;1,6..72,400;1,6..72,600;1,6..72,700;1,6..72,800&family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,500;1,700&family=JetBrains+Mono:wght@400;500;700&display=swap');

* { box-sizing: border-box; }
html, body, #root {
  margin: 0; padding: 0;
  width: 100%; height: 100%;
  background: #0a0a0a;
  color: #f6f4ef;
  font-family: 'DM Sans', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
}

/* Scene helpers — most layout is in JSX, these are just utility */
.serif { font-family: 'Newsreader', Georgia, serif; }
.sans  { font-family: 'DM Sans', system-ui, sans-serif; }
.mono  { font-family: 'JetBrains Mono', ui-monospace, monospace; }
.tnum  { font-variant-numeric: tabular-nums; }
.italic { font-style: italic; }

/* Document grain — reusable */
.grain::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(0deg, rgba(0,0,0,0.025) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(0,0,0,0.018) 0 1px, transparent 1px 4px);
  pointer-events: none;
  mix-blend-mode: multiply;
  opacity: 0.6;
}

/* Stamp ink texture */
.stamp {
  display: inline-block;
  border: 3px solid currentColor;
  padding: 6px 14px 5px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  position: relative;
  /* roughed edges via clip-path noise */
  filter: contrast(1.05);
}
.stamp::after {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,0.18) 0 2px, transparent 3px),
    radial-gradient(circle at 70% 70%, rgba(255,255,255,0.15) 0 1px, transparent 3px),
    radial-gradient(circle at 40% 80%, rgba(255,255,255,0.2) 0 2px, transparent 4px),
    radial-gradient(circle at 85% 25%, rgba(255,255,255,0.14) 0 1px, transparent 3px);
  mix-blend-mode: screen;
  pointer-events: none;
}

/* Strikethrough animation — uses CSS var for progress */
.strike { position: relative; display: inline-block; }
.strike::after {
  content: '';
  position: absolute;
  left: -2%;
  top: 55%;
  height: 6px;
  width: calc(104% * var(--strike, 0));
  background: currentColor;
  transform: skewY(-2deg);
  transform-origin: left center;
}
