/* ============================================================
   tokens.css - Design Lock v1, Film Noir Investigative
   Cache version: v=20
   Locked: 2026-05-19
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;0,800;0,900;1,400;1,500;1,600;1,700;1,800;1,900&family=Inter+Tight:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  /* ---- Surfaces ---- */
  --ink-plum: #15101a;
  --deep-graphite: #1c1622;
  --light-ash: #2a2330;
  --ink-black: #0a070d;

  /* ---- Text ---- */
  --bone: #f4f0e8;
  --silver-mist: #d8d3c8;
  --faded-steel: #8a8378;

  /* ---- Accent (single primary) ---- */
  --plum: #7a4d6f;
  --plum-bright: #a96b97;
  --plum-glow: #c89bb8;

  /* ---- Reserved accents ---- */
  --oxblood: #8a1818;
  --verified-green: #3a6b4a;
  --ink-blue: #a8c5e8;

  /* ---- Rules ---- */
  --rule-hairline: #2a2330;
  --rule-strong: #4a3f50;
  --rule-bone: #f4f0e8;

  /* ---- Type families ---- */
  --font-display: 'Playfair Display', 'GT Sectra Display', Georgia, serif;
  --font-body: 'Inter Tight', 'Söhne', 'ABC Diatype', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', 'IBM Plex Mono', ui-monospace, monospace;

  /* ---- Type scale ---- */
  --text-hero: clamp(3rem, 8vw, 6rem);
  --text-section-display: clamp(2.25rem, 5vw, 4rem);
  --text-card-display: clamp(1.75rem, 3.5vw, 2.75rem);
  --text-subheading: 1.5rem;
  --text-dek: 1.25rem;
  --text-body-lg: 1.125rem;
  --text-body: 1rem;
  --text-body-sm: 0.9375rem;
  --text-kicker: 0.75rem;
  --text-micro: 0.6875rem;

  /* ---- Containers ---- */
  --container-narrow: 680px;
  --container-text: 780px;
  --container-wide: 1180px;
  --container-full: 1400px;

  /* ---- Spacing (8pt) ---- */
  --space-1: 0.5rem;
  --space-2: 1rem;
  --space-3: 1.5rem;
  --space-4: 2rem;
  --space-5: 3rem;
  --space-6: 4.5rem;
  --space-7: 6rem;
  --space-8: 9rem;
  --space-9: 12rem;

  /* ---- Radius ---- */
  --radius-none: 0;
  --radius-image: 3px;
  --radius-button: 24px;
  --radius-pill: 9999px;
}

/* ============================================================
   Reset / normalize
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  padding: 0;
  background: var(--ink-plum);
  color: var(--bone);
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: 1.6;
  letter-spacing: -0.003em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "kern" 1, "liga" 1;
}

img, svg, video { max-width: 100%; display: block; }

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 900;
  color: var(--bone);
  letter-spacing: -0.025em;
  line-height: 0.95;
}

p { margin: 0 0 var(--space-2) 0; }
p:last-child { margin-bottom: 0; }

a {
  color: var(--plum-bright);
  text-decoration: none;
  transition: color 160ms ease;
}
a:hover { color: var(--plum-glow); }

strong { font-weight: 600; color: var(--bone); }
em { font-style: italic; color: var(--plum-glow); }

::selection {
  background: var(--plum);
  color: var(--bone);
}

/* ============================================================
   Utility classes - typography
   ============================================================ */
.kicker, .eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-kicker);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--faded-steel);
}

.micro {
  font-family: var(--font-mono);
  font-size: var(--text-micro);
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--faded-steel);
}

.dek {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: var(--text-dek);
  line-height: 1.4;
  letter-spacing: -0.01em;
  color: var(--ink-blue);
}

.tabular { font-variant-numeric: tabular-nums; }

/* Inline highlights */
.hl-plum { color: var(--plum-glow); font-weight: 600; }
.hl-oxblood {
  color: var(--bone);
  font-weight: 600;
  background: var(--oxblood);
  padding: 0.05em 0.35em;
  border-radius: 2px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

/* ============================================================
   Containers
   ============================================================ */
.wrap-narrow {
  max-width: var(--container-narrow);
  margin: 0 auto;
  padding: 0 var(--space-3);
}
.wrap-text {
  max-width: var(--container-text);
  margin: 0 auto;
  padding: 0 var(--space-3);
}
.wrap {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--space-3);
}
.wrap-full {
  max-width: var(--container-full);
  margin: 0 auto;
  padding: 0 var(--space-3);
}

@media (max-width: 640px) {
  .wrap, .wrap-text, .wrap-narrow, .wrap-full { padding: 0 var(--space-2); }
}

/* ============================================================
   Buttons - pill (the only soft moment)
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 1.75rem;
  font-family: var(--font-mono);
  font-size: var(--text-kicker);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bone);
  background: var(--plum);
  border: 1px solid var(--plum);
  border-radius: var(--radius-button);
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease, transform 160ms ease;
}
.btn:hover {
  background: var(--plum-bright);
  border-color: var(--plum-bright);
  color: var(--bone);
}

.btn-oxblood {
  background: var(--oxblood);
  border-color: var(--oxblood);
  color: var(--bone);
}
.btn-oxblood:hover {
  background: #a51e1e;
  border-color: #a51e1e;
  color: var(--bone);
}

.btn-blue {
  background: #1e3c5e;
  border-color: #1e3c5e;
  color: var(--bone);
}
.btn-blue:hover {
  background: #2a527e;
  border-color: #2a527e;
  color: var(--bone);
}

.btn-ghost {
  background: transparent;
  color: var(--bone);
  border: 1px solid var(--bone);
}
.btn-ghost:hover {
  background: var(--bone);
  color: var(--ink-plum);
}

/* Text button - bone underline */
.btn-text {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono);
  font-size: var(--text-kicker);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bone);
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--bone);
  padding: 0.25rem 0 0.4rem 0;
  cursor: pointer;
  transition: color 160ms ease, border-color 160ms ease;
}
.btn-text:hover {
  color: var(--plum-glow);
  border-bottom-color: var(--plum-glow);
}

/* ============================================================
   Skip link
   ============================================================ */
.skip-link {
  position: absolute;
  left: -10000px;
  top: 0;
  padding: var(--space-2);
  background: var(--bone);
  color: var(--ink-plum);
  font-family: var(--font-mono);
  font-size: var(--text-kicker);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  z-index: 999;
}
.skip-link:focus {
  left: var(--space-3);
  top: var(--space-3);
}
