/* Shared legal document styles. Tokens from colors_and_type.css. */
*, *::before, *::after { box-sizing: border-box; }
body { min-height: 100vh; overflow-x: hidden; }

.grid-bg {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(to right, rgba(232,232,232,0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(232,232,232,0.06) 1px, transparent 1px);
  background-size: 128px 128px;
  mask-image: radial-gradient(ellipse 90% 70% at 50% 30%, #000 60%, transparent 100%);
}

.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  height: 72px; background: var(--surface-bg);
  border-bottom: var(--border-hairline);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--space-7);
}
.nav__brand { display: flex; align-items: center; text-decoration: none; color: var(--text-primary); }
.nav__brand img.wordmark { height: 28px; width: auto; display: block; }
.nav__links { display: flex; gap: var(--space-7); align-items: center; }
.nav__link {
  font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: var(--tracking-wider);
  color: var(--text-tertiary); text-decoration: none;
  padding: var(--space-2) 0; border-bottom: 1px solid transparent;
  transition: color 80ms linear, border-color 80ms linear;
}
.nav__link:hover { color: var(--text-primary); }
.nav__right { display: flex; align-items: center; gap: var(--space-5); }
.lang-switch {
  display: inline-flex; border: var(--border-hairline);
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
}
.lang-switch button {
  appearance: none; background: transparent; color: var(--text-tertiary);
  border: 0; padding: 6px 10px; cursor: pointer; font: inherit;
  text-transform: uppercase;
  transition: background 80ms linear, color 80ms linear;
}
.lang-switch button + button { border-left: var(--border-hairline); }
.lang-switch button[aria-pressed="true"] {
  background: var(--text-primary); color: var(--surface-bg);
}
.lang-switch button:hover:not([aria-pressed="true"]) { color: var(--text-primary); }

.btn {
  appearance: none; background: transparent; border: var(--border-thin);
  color: var(--text-primary); padding: 10px var(--space-5);
  font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: var(--tracking-wider);
  text-decoration: none; cursor: pointer; display: inline-flex;
  align-items: center; gap: var(--space-3);
  transition: background 80ms linear, color 80ms linear;
}
.btn:hover { background: var(--text-primary); color: var(--surface-bg); }

main { position: relative; z-index: 1; padding-top: 72px; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 var(--space-7); }
.eyebrow {
  font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: var(--tracking-wider);
  color: var(--text-tertiary);
}
.eyebrow-row { display: flex; align-items: center; gap: var(--space-3); }
.dot { width: 8px; height: 8px; background: var(--text-primary); display: inline-block; }

/* ── Hero ──────────────────────────────────────────── */
.page-hero {
  padding: var(--space-10) 0 var(--space-9);
  border-bottom: var(--border-hairline);
}
.page-hero__crumb {
  display: flex; gap: var(--space-3); align-items: center;
  margin-bottom: var(--space-7);
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: var(--text-tertiary);
}
.page-hero__crumb a { color: var(--text-tertiary); text-decoration: none; }
.page-hero__crumb a:hover { color: var(--text-primary); }
.page-hero__crumb .sep { color: var(--text-disabled); }
.page-hero__crumb .here { color: var(--text-primary); }

.page-hero__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(48px, 6vw, 88px);
  line-height: 0.96;
  letter-spacing: var(--tracking-tighter);
  text-transform: uppercase;
  margin: var(--space-7) 0 var(--space-7);
}
.page-hero__lead {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1.45;
  color: var(--text-secondary);
  max-width: 60ch;
}
.page-hero__meta {
  display: flex; gap: var(--space-7);
  margin-top: var(--space-7);
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  color: var(--text-tertiary);
}
.page-hero__meta strong { color: var(--text-primary); font-weight: 500; margin-left: var(--space-3); }

/* ── Document body ─────────────────────────────────── */
.doc {
  padding: var(--space-10) 0;
  display: grid; grid-template-columns: 220px 1fr;
  gap: var(--space-9);
  border-bottom: var(--border-hairline);
}
.toc {
  position: sticky; top: 96px; align-self: start;
  display: flex; flex-direction: column; gap: var(--space-3);
  padding-right: var(--space-5);
  border-right: var(--border-hairline);
}
.toc__h {
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  color: var(--text-tertiary);
  margin: 0 0 var(--space-3);
}
.toc a {
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: var(--text-tertiary); text-decoration: none;
  padding: 6px 0;
  border-bottom: var(--border-hairline);
  transition: color 80ms linear;
}
.toc a:hover { color: var(--text-primary); }

.body { display: flex; flex-direction: column; gap: var(--space-9); max-width: 76ch; }
.body section { display: flex; flex-direction: column; gap: var(--space-5); scroll-margin-top: 96px; }
.body h2 {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(28px, 2.4vw, 40px); line-height: 1.05;
  letter-spacing: var(--tracking-tight); text-transform: uppercase;
  margin: 0; padding-bottom: var(--space-5);
  border-bottom: var(--border-hairline);
}
.body h2 .num {
  font-family: var(--font-mono); font-size: 0.5em;
  color: var(--text-tertiary); margin-right: var(--space-5);
  letter-spacing: var(--tracking-wider);
  vertical-align: 0.4em;
}
.body h3 {
  font-family: var(--font-display); font-weight: 600;
  font-size: var(--text-lg); line-height: 1.2;
  text-transform: uppercase; letter-spacing: var(--tracking-tight);
  color: var(--text-primary);
  margin: 0;
}
.body p, .body li {
  font-family: var(--font-display); font-weight: 400;
  font-size: var(--text-base); line-height: 1.6;
  color: var(--text-secondary);
  margin: 0; text-wrap: pretty;
}
.body ul, .body ol { margin: 0; padding-left: 1.4em; display: flex; flex-direction: column; gap: var(--space-3); }
.body a { color: var(--text-primary); text-decoration: underline; text-underline-offset: 3px; }
.body a:hover { text-decoration: none; }

.kv {
  display: grid; grid-template-columns: 180px 1fr;
  gap: var(--space-5);
  padding: var(--space-5) 0;
  border-bottom: var(--border-hairline);
  align-items: baseline;
}
.kv:last-child { border-bottom: 0; }
.kv .k {
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  color: var(--text-tertiary);
}
.kv .v {
  font-family: var(--font-mono); font-size: var(--text-sm);
  color: var(--text-primary); line-height: 1.5;
}
.kv .v a { color: inherit; }

footer {
  background: var(--surface-bg);
  border-top: var(--border-hairline);
  padding: var(--space-7) 0;
  position: relative; z-index: 1;
}
footer .container {
  display: grid; grid-template-columns: 1fr auto;
  gap: var(--space-7); align-items: center;
}
.foot__brand {
  display: flex; gap: var(--space-7);
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  color: var(--text-tertiary);
}
.foot__version { color: var(--text-primary); }
.foot__links {
  display: flex; gap: var(--space-5);
  font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
}
.foot__links a {
  color: var(--text-tertiary); text-decoration: none;
  transition: color 80ms linear;
}
.foot__links a:hover { color: var(--text-primary); }

/* Responsive */
@media (max-width: 960px) {
  .doc { grid-template-columns: 1fr; }
  .toc { position: static; border-right: 0; padding-right: 0; padding-bottom: var(--space-5); border-bottom: var(--border-hairline); }
  .kv { grid-template-columns: 1fr; gap: var(--space-3); }
  footer .container { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .nav { padding: 0 var(--space-5); height: 64px; }
  main { padding-top: 64px; }
  .nav__links { display: none; }
  .container { padding: 0 var(--space-5); }
  .page-hero__meta { flex-direction: column; gap: var(--space-3); }
}
