/* === Typography · editorial hierarchy ===
   Display serif for gravitas (Instrument Serif), body sans (Inter), mono for data. */

body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  letter-spacing: var(--ls-body);
  color: var(--color-ink);
  background: var(--color-bg);
}

.display {
  font-family: var(--font-display);
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  font-weight: 400;
  font-style: normal;
}

.display em {
  font-style: italic;
  color: var(--color-ink-muted);
}

h1, .h1 {
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-display);
  font-weight: 400;
}

h2, .h2 {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
  font-weight: 400;
}

h3, .h3 {
  font-family: var(--font-body);
  font-size: var(--fs-h3);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-heading);
  font-weight: 500;
}

h4, .h4 {
  font-family: var(--font-body);
  font-size: var(--fs-h4);
  line-height: var(--lh-tight);
  font-weight: 600;
  letter-spacing: -0.005em;
}

.kicker {
  font-family: var(--font-mono);
  font-size: var(--fs-micro);
  letter-spacing: var(--ls-kicker);
  text-transform: uppercase;
  color: var(--color-ink-muted);
  font-weight: 500;
}

.lede {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  line-height: 1.55;
  color: var(--color-ink-muted);
  max-width: 64ch;
}

.body-lg { font-size: var(--fs-body-lg); }
.body-sm { font-size: var(--fs-small); }
.muted   { color: var(--color-ink-muted); }
.subtle  { color: var(--color-ink-subtle); }
.signal  { color: var(--color-signal); }
.warm    { color: var(--color-warm); }

.mono {
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  letter-spacing: var(--ls-mono);
}

.mono-micro {
  font-family: var(--font-mono);
  font-size: var(--fs-micro);
  letter-spacing: var(--ls-mono);
  text-transform: uppercase;
}

.serif-em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
}

/* Prose — paragraphs inside editorial sections */
.prose p + p { margin-top: var(--space-4); }
.prose a {
  color: var(--color-signal);
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
  transition: opacity var(--dur-1) var(--ease-out);
}
.prose a:hover { opacity: 0.7; }

/* Editorial drop-cap-ish first paragraph */
.first-graf::first-letter {
  font-family: var(--font-display);
  float: left;
  font-size: 3.6em;
  line-height: 0.86;
  padding: 0.12em 0.1em 0 0;
  font-weight: 400;
  color: var(--color-ink);
}
