/* ========================================================================
   tomlew — personal projects template
   shared design system
   ======================================================================== */

:root {
  /* type scale (modular, slightly editorial) */
  --t-display: clamp(48px, 7vw, 96px);
  --t-h1: clamp(36px, 4.5vw, 56px);
  --t-h2: clamp(26px, 2.6vw, 34px);
  --t-h3: 22px;
  --t-body: 18px;
  --t-small: 15px;
  --t-mono: 13px;

  /* spacing */
  --space-xs: 8px;
  --space-s: 16px;
  --space-m: 28px;
  --space-l: 56px;
  --space-xl: 96px;
  --space-2xl: 144px;

  --rule: 1px;
  --radius: 0px;

  /* warm paper palette */
  --bg: oklch(0.972 0.008 78);
  --bg-soft: oklch(0.945 0.010 78);
  --ink: oklch(0.205 0.012 60);
  --ink-soft: oklch(0.42 0.013 60);
  --ink-faint: oklch(0.62 0.012 60);
  --rule-c: oklch(0.86 0.012 70);
  --rule-soft: oklch(0.92 0.010 75);

  /* accents */
  --accent: oklch(0.52 0.13 38);          /* terracotta */
  --accent-2: oklch(0.46 0.11 245);       /* ink blue */
  --accent-soft: oklch(0.92 0.04 38);
  --accent-legible: var(--accent);        /* accent, lightened for text on dark */

  /* density */
  --density: 1;

  /* type families (role-based) */
  --font-display: "Instrument Serif", "Newsreader", Georgia, serif;
  --font-body: "Newsreader", Georgia, serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;

  /* motion */
  --ease-out: cubic-bezier(0.22, 0.61, 0.36, 1);
  --dur-fast: 140ms;
  --dur-base: 240ms;
}

:root[data-theme="dark"] {
  --bg: oklch(0.18 0.010 70);
  --bg-soft: oklch(0.22 0.012 70);
  --ink: oklch(0.94 0.010 80);
  --ink-soft: oklch(0.72 0.012 75);
  --ink-faint: oklch(0.52 0.012 70);
  --rule-c: oklch(0.32 0.013 70);
  --rule-soft: oklch(0.26 0.012 70);
  --accent-soft: oklch(0.32 0.06 38);
  --accent-legible: color-mix(in srgb, var(--accent) 56%, white);
}

/* density modifier */
:root[data-density="compact"] {
  --space-l: 40px;
  --space-xl: 64px;
  --space-2xl: 96px;
  --t-body: 17px;
}
:root[data-density="airy"] {
  --space-l: 72px;
  --space-xl: 128px;
  --space-2xl: 192px;
}

/* ---- base ---- */
* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body), "Newsreader", Georgia, serif;
  font-size: var(--t-body);
  line-height: 1.55;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body {
  min-height: 100vh;
  font-feature-settings: "kern", "liga", "onum";
}

a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid var(--rule-c);
  transition: border-color 0.2s, color 0.2s;
}
a:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* ---- typography primitives ---- */
.display {
  font-family: var(--font-display), "Instrument Serif", Georgia, serif;
  font-size: var(--t-display);
  font-weight: 400;
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin: 0;
}
h1, .h1 {
  font-family: var(--font-display), "Instrument Serif", Georgia, serif;
  font-size: var(--t-h1);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0;
}
h2, .h2 {
  font-family: var(--font-display), "Instrument Serif", Georgia, serif;
  font-size: var(--t-h2);
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0;
}
h3, .h3 {
  font-family: var(--font-body), "Newsreader", Georgia, serif;
  font-size: var(--t-h3);
  font-weight: 500;
  line-height: 1.25;
  margin: 0;
}
.mono, code, kbd, .kicker {
  font-family: var(--font-mono), "JetBrains Mono", ui-monospace, monospace;
  font-size: var(--t-mono);
  letter-spacing: 0.04em;
}
.kicker {
  text-transform: uppercase;
  color: var(--ink-faint);
  font-weight: 500;
}

.lead {
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.45;
  color: var(--ink-soft);
  font-weight: 400;
  font-style: italic;
}

.small { font-size: var(--t-small); color: var(--ink-soft); }
.faint { color: var(--ink-faint); }

/* ---- layout primitives ---- */
.page {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 clamp(24px, 5vw, 80px);
}

.rule {
  border: 0;
  border-top: var(--rule) solid var(--rule-c);
  margin: var(--space-l) 0;
}
.rule-soft {
  border: 0;
  border-top: var(--rule) solid var(--rule-soft);
  margin: var(--space-m) 0;
}

/* ---- top bar ---- */
.topbar {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-m);
  padding: var(--space-m) 0 var(--space-s);
  border-bottom: var(--rule) solid var(--rule-c);
}
.topbar .brand {
  font-family: var(--font-display), "Instrument Serif", serif;
  font-size: 26px;
  letter-spacing: -0.005em;
}
.topbar .brand a { border-bottom: none; }
.topbar nav {
  display: flex;
  gap: var(--space-m);
  align-items: baseline;
}
.topbar nav a {
  border-bottom: none;
  font-family: var(--font-mono), "JetBrains Mono", monospace;
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
}
.topbar nav a:hover { color: var(--accent); }
.topbar nav a.current { color: var(--ink); }

/* ---- footer ---- */
.footer {
  margin-top: var(--space-2xl);
  padding: var(--space-l) 0 var(--space-m);
  border-top: var(--rule) solid var(--rule-c);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-m);
  font-family: var(--font-mono), "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--ink-faint);
  flex-wrap: wrap;
}
.footer a { border-bottom: none; color: var(--ink-soft); }
.footer a:hover { color: var(--accent); }

/* ---- focus ---- */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

/* ---- selection ---- */
::selection {
  background: var(--accent-soft);
  color: var(--ink);
}
