/* ============================================================
   BASE — primitives shared by both registers.
   The register (soul / cockpit) controls tokens.
   This file consumes them via semantic aliases.
   ============================================================ */

@import url('tokens.css');

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; }
html, body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd, ul, ol { margin: 0; padding: 0; }
ul, ol { list-style: none; }
img, picture, svg, video { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }

html {
  font-size: var(--fs-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--fg);
  background: var(--bg);
  font-feature-settings: "kern", "liga", "calt", "ss01";
}

::selection { background: var(--accent-soft); color: var(--fg); }

/* ── Type primitives ── */
.display, .h1, .h2, .h3, .h4, .h5, .lead { text-wrap: pretty; }

.display {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(48px, 8vw, var(--fs-5xl));
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tightest);
}
.h1 { font-family: var(--font-display); font-weight: 400; font-size: var(--fs-3xl); line-height: var(--lh-tight); letter-spacing: var(--tracking-tight); }
.h2 { font-family: var(--font-display); font-weight: 500; font-size: var(--fs-2xl); line-height: var(--lh-snug); letter-spacing: var(--tracking-tight); }
.h3 { font-family: var(--font-display); font-weight: 500; font-size: var(--fs-xl); line-height: var(--lh-snug); }
.h4 { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-lg); line-height: var(--lh-snug); letter-spacing: var(--tracking-tight); }
.h5 { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-md); line-height: var(--lh-snug); }

.eyebrow {
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: var(--fs-2xs);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--fg-3);
}
.eyebrow--accent { color: var(--accent); }

.lead {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-lg);
  line-height: var(--lh-loose);
  color: var(--fg-2);
  font-style: italic;
}

.body { font-family: var(--font-body); font-size: var(--fs-base); line-height: var(--lh-loose); color: var(--fg-2); }
.small { font-size: var(--fs-sm); color: var(--fg-3); }
.caption { font-size: var(--fs-xs); color: var(--fg-3); font-style: italic; }
.mono   { font-family: var(--font-mono); font-size: 0.92em; }
.muted  { color: var(--fg-3); }
.faint  { color: var(--fg-4); }
.accent { color: var(--accent); }
.accent-2 { color: var(--accent-2); }

/* ── Layout ── */
.page { max-width: 960px; margin: 0 auto; padding: var(--space-9) var(--space-7); }
.page--wide { max-width: 1200px; }
.page--narrow { max-width: 720px; }

.prose { max-width: var(--measure); }
.prose > * + * { margin-top: var(--space-5); }
.prose h2 { margin-top: var(--space-8); }
.prose h3 { margin-top: var(--space-7); }
.prose p  { font-size: var(--fs-md); line-height: var(--lh-loose); color: var(--fg); }
.prose ul, .prose ol { padding-left: var(--space-5); }
.prose ul li { list-style: none; position: relative; padding-left: var(--space-5); }
.prose ul li::before {
  content: ""; position: absolute;
  left: 0; top: 0.85em;
  width: 10px; height: 1px;
  background: var(--accent);
}
.prose ol { list-style: none; counter-reset: ol; }
.prose ol li { counter-increment: ol; position: relative; padding-left: var(--space-7); }
.prose ol li::before {
  content: counter(ol, decimal-leading-zero);
  position: absolute; left: 0; top: 2px;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--accent);
  letter-spacing: var(--tracking-wide);
}
.prose li + li { margin-top: var(--space-2); }

/* ── Masthead / colophon ── */
.masthead {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--fg);
  margin-bottom: var(--space-7);
}
.masthead__brand {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-md);
  font-style: italic;
  letter-spacing: var(--tracking-tight);
}
.masthead__meta {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  color: var(--fg-3);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
}

.colophon {
  margin-top: var(--space-10);
  padding-top: var(--space-5);
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
}

/* ── Aside / callout ── */
.aside {
  border-left: 1px solid var(--accent);
  padding: var(--space-1) 0 var(--space-1) var(--space-5);
  margin: var(--space-6) 0;
}
.aside__label {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--accent);
  margin-bottom: var(--space-2);
}
.aside p { font-size: var(--fs-md); line-height: var(--lh-normal); color: var(--fg); }

/* ── Pull quote ── */
.pullquote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: var(--fs-2xl);
  line-height: var(--lh-snug);
  color: var(--fg);
  letter-spacing: var(--tracking-tight);
  border-top: 1px solid var(--fg);
  border-bottom: 1px solid var(--fg);
  padding: var(--space-6) 0;
  margin: var(--space-7) 0;
}
.pullquote cite {
  display: block;
  margin-top: var(--space-4);
  font-family: var(--font-mono);
  font-style: normal;
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--fg-3);
}

/* ── Code ── */
code, .code {
  font-family: var(--font-mono);
  font-size: 0.92em;
  background: var(--bg-3);
  padding: 0.1em 0.4em;
  color: var(--fg);
}
pre {
  background: var(--shou, #2A211B);
  color: var(--bone, #E8E4DA);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  line-height: 1.65;
  padding: var(--space-5) var(--space-6);
  overflow-x: auto;
  margin: var(--space-6) 0;
  border-left: 1px solid var(--accent);
}
.cockpit pre, [data-register="cockpit"] pre { background: var(--graphite); border-left-color: var(--accent); }
pre code { background: none; padding: 0; color: inherit; }
.tk-key { color: #C9A878; }
.tk-str { color: #B8C99B; }
.tk-num { color: #D8B36C; }
.tk-cmt { color: #847E72; font-style: italic; }
.tk-fn  { color: #A6C5D8; }

/* ── Tables ── */
.table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  margin: var(--space-6) 0;
}
.table th, .table td {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
}
.table th {
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--fg-3);
  border-bottom: 1px solid var(--fg);
  padding-bottom: var(--space-3);
}
.table .num { font-family: var(--font-mono); text-align: right; font-variant-numeric: tabular-nums; }

/* ── Stat ── */
.stat { border-top: 1px solid var(--fg); padding-top: var(--space-3); }
.stat__value {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-3xl);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
}
.stat__label {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--fg-3);
  margin-top: var(--space-2);
}

/* ── Tag ── */
.tag {
  display: inline-flex; align-items: center; gap: var(--space-1);
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  padding: 4px 8px;
  border: 1px solid var(--rule);
  color: var(--fg-2);
}
.tag--accent { color: var(--accent); border-color: var(--accent); }
.tag--solid  { background: var(--fg); color: var(--bg); border-color: var(--fg); }

/* ── Rules ── */
.rule { border: 0; border-top: 1px solid var(--rule); margin: var(--space-7) 0; }
.rule--strong { border-top: 1px solid var(--fg); }
.rule--ornament {
  border: 0;
  text-align: center;
  margin: var(--space-7) 0;
  color: var(--fg-3);
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-style: italic;
}
.rule--ornament::before { content: "—"; letter-spacing: 0.5em; }

/* ── Figures ── */
figure { margin: var(--space-6) 0; }
figcaption {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-sm);
  color: var(--fg-3);
  margin-top: var(--space-2);
  padding-left: var(--space-4);
  border-left: 1px solid var(--rule);
}
.placeholder-img {
  background: var(--bg-3);
  border: 1px dashed var(--fg-4);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--fg-3);
  aspect-ratio: 16 / 9;
}
.placeholder-img--plate {
  border-style: solid;
  border-color: var(--rule);
  background: var(--bg-3);
  width: 100%; height: 100%; aspect-ratio: auto;
}

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  padding: 10px 18px;
  border: 1px solid var(--fg);
  color: var(--fg);
  background: transparent;
  transition: all var(--dur-fast) var(--ease);
}
.btn:hover { background: var(--fg); color: var(--bg); }
.btn--accent { border-color: var(--accent); color: var(--accent); }
.btn--accent:hover { background: var(--accent); color: var(--bg); border-color: var(--accent); }

/* ── Grid ── */
.grid { display: grid; gap: var(--space-6); }
.grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid--sidebar   { grid-template-columns: 1fr 220px; }
.grid--sidebar-l { grid-template-columns: 220px 1fr; }
@media (max-width: 720px) {
  .grid--2, .grid--3, .grid--4, .grid--sidebar, .grid--sidebar-l { grid-template-columns: 1fr; }
}
.stack > * + * { margin-top: var(--space-4); }
.stack-lg > * + * { margin-top: var(--space-6); }
.row { display: flex; align-items: center; gap: var(--space-3); }
.row-between { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }

.center { text-align: center; }
.right  { text-align: right; }
.tabular { font-variant-numeric: tabular-nums; }
.serif  { font-family: var(--font-display); }
.sans   { font-family: var(--font-body); }

@media print {
  body { background: white; }
  .no-print { display: none !important; }
  pre, .aside, figure { page-break-inside: avoid; }
  h1, h2, h3 { page-break-after: avoid; }
}

/* ── Focus indicators ── visible ring on every interactive element. */
button:focus-visible,
a:focus-visible,
[tabindex]:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
summary:focus-visible {
  outline: var(--focus-ring-width) solid var(--accent);
  outline-offset: var(--focus-ring-offset);
}

/* ── Reduced motion ── respect the user's OS preference. */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ── Accessibility-first modifier ──
   data-a11y="strict" enforces:
     · 16px minimum body type
     · line-height 1.75 minimum
     · no italic body text
     · body uses --fg (not --fg-2)
     · animations disabled regardless of OS preference
   Apply to <html>, <body>, or any container. */
[data-a11y="strict"] {
  font-size: 16px;
  line-height: var(--lh-a11y);
}
[data-a11y="strict"] body,
[data-a11y="strict"] p,
[data-a11y="strict"] li,
[data-a11y="strict"] dd,
[data-a11y="strict"] .body,
[data-a11y="strict"] .prose p {
  font-size: 16px;
  line-height: var(--lh-a11y);
  color: var(--fg);
  font-style: normal;
}
[data-a11y="strict"] em,
[data-a11y="strict"] i,
[data-a11y="strict"] cite,
[data-a11y="strict"] .lead {
  font-style: normal;
}
[data-a11y="strict"] .lead {
  font-family: var(--font-body);
  font-weight: 400;
}
[data-a11y="strict"] *,
[data-a11y="strict"] *::before,
[data-a11y="strict"] *::after {
  animation-duration: 0.01ms !important;
  transition-duration: 0.01ms !important;
}
[data-a11y="strict"] :focus-visible {
  outline-width: 3px;
  outline-offset: 3px;
}
