/* ============================================================
   Rhodes Design System — cjarhodes.com
   Foundations + shared layout. Dark-first, light mirror.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400&display=swap');

/* --------------------------------------------------
   PALETTE — raw tokens
   -------------------------------------------------- */
:root {
  --umber-1000: #0c0907;
  --umber-975:  #18110c;
  --umber-950:  #221913;
  --umber-900:  #2d221a;
  --umber-850:  #382a20;
  --umber-800:  #433326;
  --umber-700:  #553f2f;
  --umber-600:  #514237;
  --umber-500:  #6b594b;
  --umber-400:  #8b7868;
  --umber-300:  #ab9a8a;
  --umber-200:  #ccbfb1;
  --umber-100:  #e6dcd0;
  --umber-50:   #f1ebe0;

  --parchment-50:  #fff8f0;
  --parchment-100: #fbf3e7;
  --parchment-200: #f5ead8;
  --parchment-300: #ecdcc3;

  --claret-900: #3d0e17;
  --claret-800: #5a1621;
  --claret-700: #78202d;
  --claret-600: #8e2837;
  --claret-500: #a23346;
  --claret-400: #b84b5b;
  --claret-300: #cf6d7b;
  --claret-200: #e3a4ad;
  --claret-100: #f3d5da;

  --brass-700: #5a4a1f;
  --brass-600: #7a6430;
  --brass-500: #9a8247;
  --brass-400: #b8a06a;
  --brass-300: #d4c093;

  --sage-700: #3a4a3a;
  --sage-500: #6b8268;
  --sage-300: #a3b8a0;

  --signal-red: #a03a3a;
}

/* --------------------------------------------------
   SEMANTIC TOKENS — DARK (default)
   -------------------------------------------------- */
:root,
[data-theme="dark"] {
  --bg-page:    var(--umber-1000);
  --bg-sunken:  var(--umber-975);
  --bg-surface: var(--umber-900);
  --bg-raised:  var(--umber-800);
  --bg-overlay: rgba(12, 9, 7, 0.72);

  --fg-1: #f1ebe0;
  --fg-2: #ccbfb1;
  --fg-3: #8b7868;
  --fg-4: #6b594b;
  --fg-on-accent: #fff8f0;

  --rule-1: #241d18;
  --rule-2: #3d3129;
  --rule-3: #514237;

  --accent:       var(--claret-500);
  --accent-hover: var(--claret-400);
  --accent-press: var(--claret-600);
  --accent-bg:    rgba(162, 51, 70, 0.14);
  --accent-soft:  var(--claret-300);

  --highlight: var(--brass-400);
  --success:   var(--sage-300);
  --danger:    var(--signal-red);

  --shadow-sm: 0 1px 2px rgba(20, 10, 4, 0.28);
  --shadow-md: 0 4px 12px rgba(20, 10, 4, 0.32), 0 1px 2px rgba(20, 10, 4, 0.22);
  --shadow-lg: 0 12px 32px rgba(20, 10, 4, 0.4), 0 2px 6px rgba(20, 10, 4, 0.26);

  --selection-bg: var(--claret-700);
  --selection-fg: var(--parchment-50);
}

[data-theme="light"] {
  --bg-page:    var(--parchment-50);
  --bg-surface: #ffffff;
  --bg-raised:  var(--parchment-100);
  --bg-sunken:  var(--parchment-200);
  --bg-overlay: rgba(255, 248, 240, 0.85);

  --fg-1: #1c1612;
  --fg-2: #3d3129;
  --fg-3: #6b594b;
  --fg-4: #8b7868;
  --fg-on-accent: #fff8f0;

  --rule-1: #ecdcc3;
  --rule-2: #ccbfb1;
  --rule-3: #ab9a8a;

  --accent:       var(--claret-600);
  --accent-hover: var(--claret-700);
  --accent-press: var(--claret-800);
  --accent-bg:    rgba(142, 40, 55, 0.09);
  --accent-soft:  var(--claret-700);

  --highlight: var(--brass-600);
  --success:   var(--sage-700);
  --danger:    var(--claret-800);

  --shadow-sm: 0 1px 2px rgba(60, 38, 20, 0.06);
  --shadow-md: 0 4px 12px rgba(60, 38, 20, 0.08), 0 1px 2px rgba(60, 38, 20, 0.04);
  --shadow-lg: 0 12px 32px rgba(60, 38, 20, 0.12), 0 2px 6px rgba(60, 38, 20, 0.06);

  --selection-bg: var(--claret-200);
  --selection-fg: var(--claret-900);
}

/* --------------------------------------------------
   TYPE + SPACING TOKENS
   -------------------------------------------------- */
:root {
  --font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  --font-reading: 'Newsreader', 'Iowan Old Style', Palatino, Georgia, serif;

  --fs-xs:   0.75rem;
  --fs-sm:   0.8125rem;
  --fs-base: 0.9375rem;
  --fs-md:   1.0625rem;
  --fs-lg:   1.25rem;
  --fs-xl:   1.5rem;
  --fs-2xl:  2rem;
  --fs-3xl:  2.75rem;
  --fs-4xl:  4rem;
  --fs-5xl:  6rem;

  --lh-tight:   1.05;
  --lh-snug:    1.2;
  --lh-normal:  1.5;
  --lh-relaxed: 1.65;
  --lh-reading: 1.7;

  --tr-tight: -0.04em;
  --tr-snug:  -0.02em;
  --tr-wide:   0.02em;
  --tr-caps:   0.08em;

  --fw-regular: 400;
  --fw-medium:  500;
  --fw-semi:    600;
  --fw-bold:    700;

  --sp-1:  4px;
  --sp-2:  8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  24px;
  --sp-6:  32px;
  --sp-7:  48px;
  --sp-8:  64px;
  --sp-9:  96px;
  --sp-10: 128px;

  --measure-narrow: 56ch;
  --measure-normal: 68ch;
  --measure-wide:   80ch;

  --radius-1: 2px;
  --radius-2: 4px;
  --radius-3: 8px;
  --radius-full: 9999px;

  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast: 120ms;
  --dur-base: 180ms;
  --dur-slow: 320ms;
}

/* --------------------------------------------------
   RESET + ELEMENT DEFAULTS
   -------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  font-family: var(--font-mono);
  font-size: 16px;
  color: var(--fg-1);
  background: var(--bg-page);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
  transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out);
}

body {
  font-family: var(--font-mono);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--fg-1);
  background: var(--bg-page);
}

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

h1, .h1 { font-family: var(--font-mono); font-size: var(--fs-3xl); font-weight: var(--fw-medium); line-height: var(--lh-tight); letter-spacing: var(--tr-tight); color: var(--fg-1); }
h2, .h2 { font-family: var(--font-mono); font-size: var(--fs-2xl); font-weight: var(--fw-medium); line-height: var(--lh-snug);  letter-spacing: var(--tr-snug);  color: var(--fg-1); }
h3, .h3 { font-family: var(--font-mono); font-size: var(--fs-xl);  font-weight: var(--fw-semi);   line-height: var(--lh-snug);  letter-spacing: var(--tr-snug);  color: var(--fg-1); }
h4, .h4 { font-family: var(--font-mono); font-size: var(--fs-lg);  font-weight: var(--fw-semi);   line-height: var(--lh-snug);  color: var(--fg-1); }

.display { font-family: var(--font-mono); font-size: var(--fs-4xl); font-weight: var(--fw-medium); line-height: 0.98; letter-spacing: var(--tr-tight); }

p { font-size: var(--fs-base); line-height: var(--lh-relaxed); color: var(--fg-2); text-wrap: pretty; }

.lead { font-size: var(--fs-md); line-height: var(--lh-relaxed); color: var(--fg-1); }

.prose {
  font-family: var(--font-reading);
  font-size: 1.0625rem;
  line-height: var(--lh-reading);
  color: var(--fg-1);
  max-width: var(--measure-normal);
}
.prose p { color: var(--fg-1); font-family: inherit; font-size: inherit; line-height: inherit; }
.prose p + p { margin-top: 1.1em; }
.prose em { font-style: italic; }
.prose strong { font-weight: 600; color: var(--fg-1); }

.eyebrow,
.label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-caps);
  text-transform: uppercase;
  color: var(--fg-3);
}

code, kbd, pre, samp { font-family: var(--font-mono); font-size: 0.92em; }
code {
  background: var(--bg-sunken);
  padding: 0.1em 0.35em;
  border-radius: var(--radius-1);
  color: var(--accent-soft);
  border: 1px solid var(--rule-1);
}

a {
  color: var(--fg-1);
  text-decoration: underline;
  text-decoration-color: var(--fg-4);
  text-underline-offset: 0.22em;
  text-decoration-thickness: 1px;
  transition: color var(--dur-fast) var(--ease-out),
              text-decoration-color var(--dur-fast) var(--ease-out);
}
a:hover { color: var(--accent); text-decoration-color: var(--accent); }

hr { border: 0; border-top: 1px solid var(--rule-2); }

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

.muted { color: var(--fg-3); }
.accent-text { color: var(--accent); }
.mono { font-family: var(--font-mono); }
.serif { font-family: var(--font-reading); }

/* --------------------------------------------------
   LAYOUT
   -------------------------------------------------- */
.wrap {
  max-width: 1040px;
  margin: 0 auto;
  padding: 0 var(--sp-6);
}
.wrap--narrow { max-width: 760px; }
.wrap--reading { max-width: 820px; }

/* --------------------------------------------------
   STICKY HEADER
   -------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  background: var(--bg-overlay);
  border-bottom: 1px solid var(--rule-2);
}
.site-header .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
  padding-top: 14px;
  padding-bottom: 14px;
}

.wordmark {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: var(--fw-medium);
  letter-spacing: -0.03em;
  color: var(--fg-1);
  text-decoration: none;
}
.wordmark:hover { color: var(--fg-1); }
.wordmark::after {
  content: '';
  width: 5px;
  height: 5px;
  background: var(--accent);
  border-radius: 50%;
  margin-left: 3px;
  transform: translateY(-1px);
}

.site-nav {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  flex-wrap: wrap;
}
.site-nav a {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg-3);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.site-nav a:hover,
.site-nav a.is-active {
  color: var(--fg-1);
}
.site-nav a.is-active { border-bottom-color: var(--accent); }

.theme-toggle {
  background: transparent;
  border: 1px solid var(--rule-3);
  color: var(--fg-2);
  padding: 4px 10px;
  border-radius: var(--radius-1);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.theme-toggle:hover { color: var(--fg-1); border-color: var(--fg-3); }

/* --------------------------------------------------
   BUTTONS
   -------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: var(--fw-medium);
  letter-spacing: -0.01em;
  padding: 10px 18px;
  border-radius: var(--radius-1);
  border: 1px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
  white-space: nowrap;
}
.btn svg { width: 14px; height: 14px; flex-shrink: 0; }

.btn--primary {
  background: var(--accent);
  color: var(--fg-on-accent);
}
.btn--primary:hover { background: var(--accent-hover); color: var(--fg-on-accent); }
.btn--primary:active { background: var(--accent-press); }

.btn--secondary {
  background: transparent;
  color: var(--fg-1);
  border-color: var(--rule-3);
}
.btn--secondary:hover {
  color: var(--fg-1);
  border-color: var(--fg-3);
  background: var(--bg-surface);
}

.btn--ghost {
  background: transparent;
  color: var(--fg-2);
  padding: 10px 0;
}
.btn--ghost:hover { color: var(--accent); }

/* --------------------------------------------------
   BADGES
   -------------------------------------------------- */
.badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  letter-spacing: 0.04em;
  color: var(--fg-3);
  border: 1px solid var(--rule-3);
}
.badge--accent {
  color: var(--accent);
  border-color: var(--accent);
  background: var(--accent-bg);
}

/* --------------------------------------------------
   SECTIONS
   -------------------------------------------------- */
.section {
  padding: var(--sp-8) 0;
}
.section + .section {
  border-top: 1px solid var(--rule-1);
}
.section__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-5);
  margin-bottom: var(--sp-5);
  flex-wrap: wrap;
}
.section__head-link {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg-2);
  text-decoration: none;
}
.section__head-link:hover { color: var(--accent); }

/* --------------------------------------------------
   FOOTER
   -------------------------------------------------- */
.site-footer {
  border-top: 1px solid var(--rule-2);
  margin-top: var(--sp-9);
  padding: var(--sp-6) 0;
  color: var(--fg-3);
  font-size: 13px;
}
.site-footer .wrap {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--sp-4);
}
.site-footer__mark {
  font-family: var(--font-mono);
}
.site-footer__mark .bracket { color: var(--fg-2); }
.site-footer__links {
  display: flex;
  gap: var(--sp-5);
  font-family: var(--font-mono);
}
.site-footer__links a {
  color: var(--fg-3);
  text-decoration: none;
}
.site-footer__links a:hover { color: var(--accent); }

/* --------------------------------------------------
   RESPONSIVE
   -------------------------------------------------- */
@media (max-width: 640px) {
  .wrap { padding: 0 var(--sp-5); }
  .site-header .wrap { gap: var(--sp-3); padding-top: var(--sp-3); padding-bottom: var(--sp-3); }
  .site-nav { gap: var(--sp-4); }
  .section { padding: var(--sp-7) 0; }
  .site-footer { margin-top: var(--sp-8); }
}

@media (max-width: 480px) {
  .site-nav .nav-minor { display: none; }
}
