/* ============================================================================
   typography.css — základ písma, nadpisy, významové textové třídy
   ============================================================================ */

/* Scrollbar-gutter: vždy rezervuj místo pro vertikální scrollbar, i když
   není potřeba. Tím se předejde horizontálnímu posunu obsahu (včetně horní
   navigace) při přepínání mezi stránkami s různě dlouhým obsahem.
   `stable both-edges` zachovává symetrii (mezera vlevo i vpravo). */
html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  scrollbar-gutter: stable;
}

body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Nadpisy */
h1, h2, h3 {
  font-family: var(--font-editorial);
  font-weight: 400;
  color: var(--ink);
}
h1 { font-size: 36px; line-height: 1.15; margin-bottom: var(--space-md); }
h2 { font-size: 24px; line-height: 1.25; margin: var(--space-xl) 0 var(--space-md); }
h3 {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 18px;
  margin: var(--space-lg) 0 var(--space-sm);
}

/* Odstavce a odkazy */
p { margin: 0 0 var(--space-md); }
a {
  color: var(--blue);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}
a:hover { text-decoration-thickness: 2px; }

/* Významové třídy (pro čísla, hero, narativ) */
.text-hero {
  font-family: var(--font-hero);
  font-weight: 100;
  font-feature-settings: "tnum";
  letter-spacing: -0.04em;
}
.text-data {
  font-family: var(--font-body);
  font-feature-settings: "tnum";
  font-weight: 500;
}
.text-narrative {
  font-family: var(--font-editorial);
  font-style: italic;
}
.text-muted { color: var(--ink-muted); }
.text-soft  { color: var(--ink-soft);  }
