/* ============================================================
   TYPOGRAPHY
   ============================================================ */

body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  font-weight: var(--fw-regular);
  color: var(--color-charcoal);
}

h1, h2, h3, h4, h5, h6,
.display, .h1, .h2, .h3, .h4 {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tight);
}

h1, .h1 { font-size: clamp(2rem, 4.5vw, var(--fs-5xl)); font-weight: var(--fw-regular); letter-spacing: -0.025em; }
h2, .h2 { font-size: clamp(1.5rem, 3vw, var(--fs-3xl)); font-weight: var(--fw-semibold); }
h3, .h3 { font-size: clamp(1.25rem, 2.2vw, var(--fs-2xl)); font-weight: var(--fw-semibold); }
h4, .h4 { font-size: var(--fs-xl); font-weight: var(--fw-semibold); }
h5      { font-size: var(--fs-lg); font-weight: var(--fw-semibold); font-family: var(--font-body); letter-spacing: 0; }
h6      { font-size: var(--fs-md); font-weight: var(--fw-semibold); font-family: var(--font-body); letter-spacing: 0; }

.display {
  font-size: clamp(2.5rem, 6vw, var(--fs-6xl));
  font-weight: var(--fw-regular);
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.display em,
h1 em, .h1 em {
  font-style: italic;
  color: var(--color-accent-deep);
  font-weight: var(--fw-regular);
}

p { line-height: var(--lh-relaxed); }

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent-deep);
}

.caption {
  font-size: var(--fs-sm);
  color: var(--color-mid-grey);
  line-height: var(--lh-normal);
}

.text-muted { color: var(--color-mid-grey); }
.text-ink   { color: var(--color-ink); }
.text-accent { color: var(--color-accent-deep); }

.serif { font-family: var(--font-display); }
.sans  { font-family: var(--font-body); }

em { font-style: italic; }
strong { font-weight: var(--fw-semibold); color: var(--color-ink); }

/* Links in content */
a.link {
  color: var(--color-accent-deep);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color var(--dur-fast) var(--ease-out);
}
a.link:hover { color: var(--color-accent); }

/* Section titles — shared pattern */
.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, var(--fs-3xl));
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-3);
}

.section-subtitle {
  font-size: var(--fs-md);
  color: var(--color-mid-grey);
  max-width: 60ch;
  line-height: var(--lh-relaxed);
}

.section-header {
  margin-bottom: var(--space-8);
}

.section-header--flex {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}
