/* ============================================================
   CHALKLINE · DESIGN TOKENS
   brutalist-editorial system for sohaib.gg
   ============================================================ */

/* ------------------ FONTS ------------------ */
/* Loaded via <link> in each HTML file — listed here for reference:
   Archivo Black (display)
   Archivo 400/500/600/700/900 (body + strong)
   JetBrains Mono 400/500/700 (meta, code)
*/

:root {
  /* --- COLOR · LIGHT (default) --- */
  --cl-paper:      #f0efe8;   /* page background */
  --cl-paper-2:    #e7e6de;   /* sunken panels / code blocks */
  --cl-ink:        #0a0a0a;   /* foreground */
  --cl-ink-soft:   #0a0a0acc;
  --cl-ink-mute:   #0a0a0a99;
  --cl-ink-faint:  #0a0a0a55;
  --cl-rule:       #0a0a0a;   /* all rules are full ink */
  --cl-hairline:   #0a0a0a33;

  /* accents */
  --cl-lime:       #d2f24a;   /* highlight / primary affirmative */
  --cl-lime-ink:   #0a0a0a;   /* text on lime */
  --cl-alert:      #ff3b2e;   /* destructive / warning */
  --cl-alert-ink:  #ffffff;

  /* --- TYPE --- */
  --cl-font-display: "Archivo Black", "Archivo", ui-sans-serif, system-ui, sans-serif;
  --cl-font-body:    "Archivo", ui-sans-serif, system-ui, sans-serif;
  --cl-font-mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  /* weights */
  --cl-w-regular: 400;
  --cl-w-medium:  500;
  --cl-w-semi:    600;
  --cl-w-bold:    700;
  --cl-w-black:   900;

  /* sizes · fluid where it matters */
  --cl-t-hero:     clamp(48px, 7vw, 104px);
  --cl-t-display:  clamp(40px, 5.2vw, 72px);
  --cl-t-h1:       clamp(32px, 3.6vw, 48px);
  --cl-t-h2:       clamp(26px, 2.6vw, 36px);
  --cl-t-h3:       22px;
  --cl-t-h4:       18px;
  --cl-t-body:     16px;
  --cl-t-body-lg:  18px;
  --cl-t-small:    14px;
  --cl-t-meta:     11px;
  --cl-t-micro:    10px;

  --cl-lh-tight:   0.88;
  --cl-lh-head:    1.05;
  --cl-lh-body:    1.55;
  --cl-lh-reading: 1.65;

  --cl-ls-tight:   -0.045em;
  --cl-ls-snug:    -0.02em;
  --cl-ls-flat:    0em;
  --cl-ls-wide:    0.08em;
  --cl-ls-wider:   0.14em;

  /* --- SPACE · 4pt base --- */
  --cl-s-0:   0;
  --cl-s-1:   4px;
  --cl-s-2:   8px;
  --cl-s-3:   12px;
  --cl-s-4:   16px;
  --cl-s-5:   20px;
  --cl-s-6:   24px;
  --cl-s-8:   32px;
  --cl-s-10:  40px;
  --cl-s-12:  48px;
  --cl-s-16:  64px;
  --cl-s-20:  80px;
  --cl-s-24:  96px;
  --cl-s-32:  128px;

  /* container */
  --cl-container: 1240px;
  --cl-reading:   68ch;

  /* --- RULES · BORDERS --- */
  --cl-border-hair: 1px solid var(--cl-rule);
  --cl-border:      2px solid var(--cl-rule);
  --cl-border-thick:3px solid var(--cl-rule);

  --cl-radius-0: 0;          /* Chalkline is square — radii reserved for edge cases */
  --cl-radius-1: 2px;
  --cl-radius-pill: 999px;   /* tags only, never buttons */

  /* --- ELEVATION · flat offset shadow, never blur --- */
  --cl-shadow-0: none;
  --cl-shadow-1: 4px 4px 0 0 var(--cl-ink);
  --cl-shadow-2: 6px 6px 0 0 var(--cl-ink);

  /* --- MOTION --- */
  --cl-dur-1: 80ms;
  --cl-dur-2: 160ms;
  --cl-dur-3: 260ms;
  --cl-ease:  cubic-bezier(0.2, 0.7, 0.2, 1);
  --cl-ease-snap: cubic-bezier(0.8, 0, 0.2, 1);
}

/* ------------------ DARK MODE · auto ------------------ */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --cl-paper:      #0e0e0d;
    --cl-paper-2:    #17171500;
    --cl-ink:        #f0efe8;
    --cl-ink-soft:   #f0efe8cc;
    --cl-ink-mute:   #f0efe899;
    --cl-ink-faint:  #f0efe855;
    --cl-rule:       #f0efe8;
    --cl-hairline:   #f0efe833;
    --cl-paper-2:    #1a1a18;
    --cl-lime:       #d2f24a;
    --cl-lime-ink:   #0a0a0a;
    --cl-alert:      #ff4e42;
    --cl-shadow-1: 4px 4px 0 0 var(--cl-ink);
    --cl-shadow-2: 6px 6px 0 0 var(--cl-ink);
  }
}

/* Manual overrides (for toggle) */
:root[data-theme="dark"] {
  --cl-paper:      #0e0e0d;
  --cl-paper-2:    #1a1a18;
  --cl-ink:        #f0efe8;
  --cl-ink-soft:   #f0efe8cc;
  --cl-ink-mute:   #f0efe899;
  --cl-ink-faint:  #f0efe855;
  --cl-rule:       #f0efe8;
  --cl-hairline:   #f0efe833;
  --cl-alert:      #ff4e42;
}
:root[data-theme="light"] {
  --cl-paper:      #f0efe8;
  --cl-paper-2:    #e7e6de;
  --cl-ink:        #0a0a0a;
  --cl-ink-soft:   #0a0a0acc;
  --cl-ink-mute:   #0a0a0a99;
  --cl-ink-faint:  #0a0a0a55;
  --cl-rule:       #0a0a0a;
  --cl-hairline:   #0a0a0a33;
  --cl-alert:      #ff3b2e;
}

/* ------------------ RESET + BASE ------------------ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  background: var(--cl-paper);
  color: var(--cl-ink);
  font-family: var(--cl-font-body);
  font-size: 16px;
  line-height: var(--cl-lh-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  -webkit-text-size-adjust: 100%;
}
body { background: var(--cl-paper); color: var(--cl-ink); }

::selection { background: var(--cl-lime); color: var(--cl-lime-ink); }

img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-underline-offset: 3px; text-decoration-thickness: 1.5px; }
a:hover { text-decoration-thickness: 3px; }

/* ------------------ TYPE UTILITIES ------------------ */
.cl-hero {
  font-family: var(--cl-font-display);
  font-size: var(--cl-t-hero);
  line-height: var(--cl-lh-tight);
  letter-spacing: var(--cl-ls-tight);
  text-transform: uppercase;
  margin: 0;
  text-wrap: balance;
}
.cl-display {
  font-family: var(--cl-font-display);
  font-size: var(--cl-t-display);
  line-height: 0.92;
  letter-spacing: var(--cl-ls-tight);
  text-transform: uppercase;
  margin: 0;
}
.cl-h1 {
  font-family: var(--cl-font-display);
  font-size: var(--cl-t-h1);
  line-height: 1;
  letter-spacing: var(--cl-ls-tight);
  text-transform: uppercase;
  margin: 0;
}
.cl-h2 {
  font-family: var(--cl-font-display);
  font-size: var(--cl-t-h2);
  line-height: 1;
  letter-spacing: -0.035em;
  text-transform: uppercase;
  margin: 0;
}
.cl-h3 {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-black);
  font-size: var(--cl-t-h3);
  line-height: 1.1;
  letter-spacing: var(--cl-ls-snug);
  margin: 0;
}
.cl-h4 {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-semi);
  font-size: var(--cl-t-h4);
  line-height: 1.2;
  letter-spacing: var(--cl-ls-snug);
  margin: 0;
}
.cl-lead {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-medium);
  font-size: var(--cl-t-body-lg);
  line-height: var(--cl-lh-reading);
}
.cl-body { font-size: var(--cl-t-body); line-height: var(--cl-lh-reading); }
.cl-small { font-size: var(--cl-t-small); line-height: 1.5; }
.cl-meta {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cl-ink-mute);
}
.cl-micro {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-micro);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cl-ink-mute);
}

/* lime highlight — scalpel, not a hose */
.cl-hl {
  background: var(--cl-lime);
  color: var(--cl-lime-ink);
  padding: 0 4px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.cl-hl-alert {
  background: var(--cl-alert);
  color: var(--cl-alert-ink);
  padding: 0 4px;
}

/* ------------------ LAYOUT ------------------ */
.cl-container { max-width: var(--cl-container); margin: 0 auto; padding: 0 var(--cl-s-8); }
.cl-reading   { max-width: var(--cl-reading);   margin: 0 auto; }
.cl-stack > * + * { margin-top: var(--cl-s-4); }
.cl-row { display: flex; gap: var(--cl-s-3); align-items: center; flex-wrap: wrap; }
.cl-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--cl-s-6); }
.cl-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--cl-s-6); }
.cl-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--cl-s-4); }

@media (max-width: 900px) {
  .cl-grid-2, .cl-grid-3, .cl-grid-4 { grid-template-columns: 1fr; }
}

/* ------------------ DIVIDERS ------------------ */
.cl-hr {
  border: 0;
  border-top: var(--cl-border);
  margin: var(--cl-s-8) 0;
}
.cl-hr-thin { border-top: var(--cl-border-hair); }
/* ============================================================
   CHALKLINE · COMPONENTS
   requires tokens.css
   ============================================================ */

/* ------------------ APP SHELL / NAV ------------------ */
.cl-topbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--cl-s-3) var(--cl-s-8);
  background: var(--cl-ink);
  color: var(--cl-paper);
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-bottom: var(--cl-border);
}
.cl-topbar a { color: var(--cl-paper); text-decoration: none; }
.cl-topbar .cl-topbar-dot { width: 8px; height: 8px; background: var(--cl-lime); display: inline-block; margin-right: var(--cl-s-2); }

.cl-nav {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--cl-s-5) var(--cl-s-8);
  border-bottom: var(--cl-border);
  background: var(--cl-paper);
  position: sticky; top: 0; z-index: 40;
}
.cl-nav .cl-brand {
  font-family: var(--cl-font-display);
  font-size: 22px;
  letter-spacing: var(--cl-ls-tight);
  text-transform: uppercase;
  text-decoration: none;
  color: var(--cl-ink);
}
.cl-nav .cl-brand .cl-dot { color: var(--cl-ink); background: var(--cl-lime); padding: 0 4px; }
.cl-nav ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; gap: var(--cl-s-6);
}
.cl-nav ul a {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-bold);
  font-size: var(--cl-t-small);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--cl-ink);
  text-decoration: none;
  padding: var(--cl-s-1) var(--cl-s-2);
}
.cl-nav ul a:hover, .cl-nav ul a.is-active { background: var(--cl-lime); }

/* ------------------ BUTTONS ------------------ */
.cl-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--cl-s-2);
  font-family: var(--cl-font-display);
  font-size: 13px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding: 12px 18px;
  background: var(--cl-ink);
  color: var(--cl-paper);
  border: var(--cl-border);
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--cl-dur-1) var(--cl-ease-snap),
              box-shadow var(--cl-dur-1) var(--cl-ease-snap),
              background var(--cl-dur-1) var(--cl-ease);
}
.cl-btn:hover { transform: translate(-2px, -2px); box-shadow: var(--cl-shadow-1); }
.cl-btn:active { transform: translate(0, 0); box-shadow: none; }
.cl-btn:focus-visible { outline: 3px solid var(--cl-lime); outline-offset: 2px; }

.cl-btn--lime  { background: var(--cl-lime); color: var(--cl-lime-ink); }
.cl-btn--ghost { background: transparent; color: var(--cl-ink); }
.cl-btn--alert { background: var(--cl-alert); color: var(--cl-alert-ink); border-color: var(--cl-alert); }
.cl-btn--sm    { padding: 8px 12px; font-size: 11px; }
.cl-btn--lg    { padding: 16px 22px; font-size: 15px; }
.cl-btn--block { width: 100%; }

/* ------------------ FORMS ------------------ */
.cl-field { display: block; margin-bottom: var(--cl-s-5); }
.cl-label {
  display: block;
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: var(--cl-s-2);
  color: var(--cl-ink);
}
.cl-label .cl-req { color: var(--cl-alert); }

.cl-input, .cl-textarea, .cl-select {
  width: 100%;
  font-family: var(--cl-font-body);
  font-size: var(--cl-t-body);
  padding: 12px 14px;
  background: var(--cl-paper);
  color: var(--cl-ink);
  border: var(--cl-border);
  border-radius: var(--cl-radius-0);
  transition: background var(--cl-dur-1) var(--cl-ease);
}
.cl-input:focus, .cl-textarea:focus, .cl-select:focus {
  outline: 3px solid var(--cl-lime);
  outline-offset: -3px;
  background: var(--cl-paper);
}
.cl-textarea { min-height: 120px; font-family: var(--cl-font-body); resize: vertical; }

.cl-input[aria-invalid="true"] { outline: 3px solid var(--cl-alert); outline-offset: -3px; }
.cl-help  { font-family: var(--cl-font-mono); font-size: var(--cl-t-micro); letter-spacing: 0.1em; text-transform: uppercase; color: var(--cl-ink-mute); margin-top: var(--cl-s-2); }
.cl-error { font-family: var(--cl-font-mono); font-size: var(--cl-t-micro); letter-spacing: 0.1em; text-transform: uppercase; color: var(--cl-alert); margin-top: var(--cl-s-2); }

/* checkbox / radio */
.cl-check { display: inline-flex; gap: var(--cl-s-2); align-items: center; cursor: pointer; font-size: var(--cl-t-small); }
.cl-check input { appearance: none; width: 20px; height: 20px; border: var(--cl-border); background: var(--cl-paper); margin: 0; cursor: pointer; position: relative; }
.cl-check input:checked { background: var(--cl-lime); }
.cl-check input:checked::after {
  content: "✓"; position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--cl-font-display); font-size: 14px; color: var(--cl-ink);
}
.cl-check input[type="radio"] { border-radius: 50%; }
.cl-check input[type="radio"]:checked::after { content: ""; width: 10px; height: 10px; background: var(--cl-ink); border-radius: 50%; left: 50%; top: 50%; transform: translate(-50%, -50%); }

/* toggle */
.cl-toggle { position: relative; display: inline-block; width: 48px; height: 26px; }
.cl-toggle input { opacity: 0; width: 0; height: 0; }
.cl-toggle .track { position: absolute; inset: 0; background: var(--cl-paper); border: var(--cl-border); cursor: pointer; }
.cl-toggle .track::before { content: ""; position: absolute; width: 16px; height: 16px; background: var(--cl-ink); top: 3px; left: 3px; transition: transform var(--cl-dur-2) var(--cl-ease-snap); }
.cl-toggle input:checked + .track { background: var(--cl-lime); }
.cl-toggle input:checked + .track::before { transform: translateX(22px); }

/* ------------------ TAGS / BADGES ------------------ */
.cl-tag {
  display: inline-block;
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-micro);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 8px;
  background: transparent;
  color: var(--cl-ink);
  border: var(--cl-border-hair);
}
.cl-tag--solid { background: var(--cl-ink); color: var(--cl-paper); border-color: var(--cl-ink); }
.cl-tag--lime  { background: var(--cl-lime); color: var(--cl-lime-ink); border-color: var(--cl-lime); }
.cl-tag--alert { background: var(--cl-alert); color: var(--cl-alert-ink); border-color: var(--cl-alert); }

/* ------------------ CARDS ------------------ */
.cl-card {
  background: var(--cl-paper);
  border: var(--cl-border);
  padding: var(--cl-s-6);
}
.cl-card--solid { background: var(--cl-ink); color: var(--cl-paper); }
.cl-card--solid a { color: var(--cl-paper); }
.cl-card--lime { background: var(--cl-lime); color: var(--cl-lime-ink); border-color: var(--cl-ink); }

.cl-card-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px var(--cl-s-4);
  margin: calc(-1 * var(--cl-s-6)) calc(-1 * var(--cl-s-6)) var(--cl-s-5);
  background: var(--cl-ink); color: var(--cl-paper);
  font-family: var(--cl-font-mono); font-size: var(--cl-t-meta);
  letter-spacing: 0.1em; text-transform: uppercase;
  border-bottom: var(--cl-border);
}
.cl-card--solid .cl-card-head { background: var(--cl-lime); color: var(--cl-lime-ink); border-bottom-color: var(--cl-lime); }

/* ------------------ MODAL ------------------ */
.cl-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(10,10,10,0.55);
  display: grid; place-items: center;
  padding: var(--cl-s-8);
  z-index: 100;
}
.cl-modal {
  background: var(--cl-paper);
  border: var(--cl-border-thick);
  max-width: 560px; width: 100%;
  box-shadow: var(--cl-shadow-2);
}
.cl-modal-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--cl-s-3) var(--cl-s-5);
  background: var(--cl-ink); color: var(--cl-paper);
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.cl-modal-head button {
  background: transparent; color: var(--cl-paper);
  border: 0; cursor: pointer; font-family: var(--cl-font-display); font-size: 18px;
  line-height: 1;
}
.cl-modal-body { padding: var(--cl-s-6); }
.cl-modal-foot { padding: var(--cl-s-4) var(--cl-s-6); border-top: var(--cl-border); display: flex; justify-content: flex-end; gap: var(--cl-s-2); }

/* ------------------ TABLE ------------------ */
.cl-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--cl-t-small);
  border: var(--cl-border);
}
.cl-table th, .cl-table td {
  padding: var(--cl-s-3) var(--cl-s-4);
  border-bottom: var(--cl-border-hair);
  text-align: left;
  vertical-align: top;
}
.cl-table thead th {
  background: var(--cl-ink);
  color: var(--cl-paper);
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: var(--cl-w-medium);
}
.cl-table tbody tr:hover { background: var(--cl-lime); color: var(--cl-lime-ink); }
.cl-table tbody tr:last-child td { border-bottom: 0; }

/* ------------------ POST LIST (homepage/index) ------------------ */
.cl-post-list { border-top: var(--cl-border); }
.cl-post-row {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: var(--cl-s-5);
  padding: var(--cl-s-5) var(--cl-s-4);
  border-bottom: var(--cl-border-hair);
  align-items: center;
  text-decoration: none;
  color: inherit;
  transition: background var(--cl-dur-1) var(--cl-ease);
}
.cl-post-row:hover { background: var(--cl-lime); color: var(--cl-lime-ink); }
.cl-post-row .cl-post-n {
  font-family: var(--cl-font-display);
  font-size: 36px;
  line-height: 1;
  letter-spacing: var(--cl-ls-tight);
}
.cl-post-row h3 {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-black);
  font-size: 20px;
  line-height: 1.15;
  letter-spacing: var(--cl-ls-snug);
  text-transform: uppercase;
  margin: 0 0 6px;
}
.cl-post-row .meta {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-micro);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cl-ink-mute);
  display: flex; gap: var(--cl-s-3); flex-wrap: wrap;
}
.cl-post-row:hover .meta { color: var(--cl-ink); }
.cl-post-row .cl-post-arrow { font-family: var(--cl-font-display); font-size: 28px; line-height: 1; }

/* ------------------ BREADCRUMB ------------------ */
.cl-crumb {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cl-ink-mute);
}
.cl-crumb a { color: inherit; text-decoration: none; }
.cl-crumb a:hover { color: var(--cl-ink); text-decoration: underline; }
.cl-crumb .sep { margin: 0 var(--cl-s-2); color: var(--cl-ink-faint); }

/* ------------------ THEME TOGGLE (floating) ------------------ */
.cl-theme-toggle {
  position: fixed; right: 20px; bottom: 20px;
  z-index: 50;
  display: inline-flex; gap: 0;
  background: var(--cl-paper);
  border: var(--cl-border);
  box-shadow: var(--cl-shadow-1);
}
.cl-theme-toggle button {
  appearance: none; border: 0; background: transparent;
  padding: 8px 12px; cursor: pointer;
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-micro);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cl-ink);
}
.cl-theme-toggle button + button { border-left: var(--cl-border-hair); }
.cl-theme-toggle button.is-active { background: var(--cl-lime); color: var(--cl-lime-ink); }

/* ------------------ DESIGN TOGGLE (floating, above theme toggle) ------------------ */
.cl-design-toggle {
  position: fixed; right: 20px; bottom: 68px;
  z-index: 50;
  display: inline-flex; gap: 0;
  background: var(--cl-paper);
  border: var(--cl-border);
  box-shadow: var(--cl-shadow-1);
}
.cl-design-toggle button {
  appearance: none; border: 0; background: transparent;
  padding: 8px 12px; cursor: pointer;
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-micro);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cl-ink);
}
.cl-design-toggle button + button { border-left: var(--cl-border-hair); }
.cl-design-toggle button.is-active { background: var(--cl-lime); color: var(--cl-lime-ink); }

/* ------------------ CALLOUTS ------------------ */
.cl-callout {
  border-left: 6px solid var(--cl-lime);
  padding: var(--cl-s-4) var(--cl-s-5);
  background: var(--cl-paper-2);
  font-size: var(--cl-t-body);
  line-height: var(--cl-lh-reading);
}
.cl-callout--alert { border-left-color: var(--cl-alert); }
.cl-callout-label {
  display: block;
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-micro);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: var(--cl-s-2);
  color: var(--cl-ink-mute);
}

/* ------------------ FOOTER ------------------ */
.cl-footer {
  border-top: var(--cl-border);
  padding: var(--cl-s-12) var(--cl-s-8) var(--cl-s-8);
  margin-top: var(--cl-s-20);
}
.cl-footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--cl-s-8);
  max-width: var(--cl-container);
  margin: 0 auto var(--cl-s-10);
}
.cl-footer h4 {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0 0 var(--cl-s-3);
  color: var(--cl-ink-mute);
}
.cl-footer ul { list-style: none; padding: 0; margin: 0; }
.cl-footer li { margin-bottom: var(--cl-s-2); font-size: var(--cl-t-small); }
.cl-footer a { text-decoration: none; }
.cl-footer a:hover { background: var(--cl-lime); color: var(--cl-lime-ink); }
.cl-footer-rule {
  max-width: var(--cl-container);
  margin: 0 auto; border-top: var(--cl-border);
  padding-top: var(--cl-s-5);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--cl-ink-mute);
}

@media (max-width: 900px) {
  .cl-nav ul { display: none; }
  .cl-footer-grid { grid-template-columns: 1fr 1fr; }
  .cl-post-row { grid-template-columns: 40px 1fr 20px; gap: var(--cl-s-3); }
  .cl-post-row .cl-post-n { font-size: 26px; }
  .cl-post-row h3 { font-size: 16px; }
}

/* ============================================================
   CHALKLINE · ARTICLE BODY EXTENSIONS
   styles for blog post body, captions, interactive resume
   ============================================================ */

/* article prose */
.cl-prose p { margin: 0 0 var(--cl-s-5); font-size: var(--cl-t-body); line-height: var(--cl-lh-reading); }
.cl-prose p.lead, .cl-prose .lead {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-medium);
  font-size: var(--cl-t-body-lg);
  line-height: var(--cl-lh-reading);
  margin: 0 0 var(--cl-s-6);
}
.cl-prose h2 {
  font-family: var(--cl-font-display);
  font-size: var(--cl-t-h2);
  line-height: 1;
  letter-spacing: -0.035em;
  text-transform: uppercase;
  margin: var(--cl-s-10) 0 var(--cl-s-3);
}
.cl-prose h3 {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-black);
  font-size: var(--cl-t-h3);
  line-height: 1.1;
  letter-spacing: var(--cl-ls-snug);
  margin: var(--cl-s-8) 0 var(--cl-s-3);
  text-transform: none;
}
.cl-prose h4 {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-bold);
  font-size: var(--cl-t-h4);
  line-height: 1.2;
  margin: var(--cl-s-6) 0 var(--cl-s-2);
}
.cl-prose ul, .cl-prose ol { margin: 0 0 var(--cl-s-5); padding-left: 22px; line-height: var(--cl-lh-reading); }
.cl-prose ul li, .cl-prose ol li { margin-bottom: var(--cl-s-2); }
.cl-prose strong { font-weight: var(--cl-w-bold); }
.cl-prose a { color: var(--cl-ink); text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 3px; }
.cl-prose a:hover { background: var(--cl-lime); text-decoration: none; }

.cl-prose blockquote {
  border-left: 6px solid var(--cl-ink);
  padding: var(--cl-s-4) var(--cl-s-5);
  margin: var(--cl-s-8) 0;
  font-family: var(--cl-font-display);
  font-size: 24px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

/* highlight-box · legacy class -> chalkline callout */
.cl-prose .highlight-box, .highlight-box {
  border: var(--cl-border);
  background: var(--cl-paper-2);
  padding: var(--cl-s-5) var(--cl-s-6);
  margin: var(--cl-s-8) 0;
}
.cl-prose .highlight-box h3, .highlight-box h3 {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cl-ink-mute);
  margin: 0 0 var(--cl-s-2);
}
.cl-prose .highlight-box p, .highlight-box p {
  margin: 0;
  font-size: var(--cl-t-body);
  line-height: var(--cl-lh-reading);
}

/* ------------------ HERO IMAGE / CAPTION ------------------ */
.cl-hero-image {
  border: var(--cl-border);
  padding: 0;
  background: var(--cl-paper-2);
  margin: 0 auto;
}
.cl-hero-image img { display: block; width: 100%; height: auto; }
.cl-image-caption {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-micro);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cl-ink-mute);
  margin-top: var(--cl-s-3);
  text-align: center;
}

/* ------------------ HOME · QUOTES + INTERESTS GRIDS ------------------ */
.cl-quote-card {
  border: var(--cl-border);
  background: var(--cl-paper);
  padding: var(--cl-s-6);
}
.cl-quote-card blockquote {
  font-family: var(--cl-font-display);
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  margin: 0 0 var(--cl-s-4);
}
.cl-quote-card cite {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cl-ink-mute);
  font-style: normal;
}

/* ------------------ PROFILE CARD ------------------ */
.cl-profile {
  border: var(--cl-border);
  background: var(--cl-paper);
  padding: 0;
  overflow: hidden;
}
.cl-profile-img {
  display: block;
  width: 100%;
  height: auto;
  border-bottom: var(--cl-border);
  background: var(--cl-paper-2);
}
.cl-profile-body { padding: var(--cl-s-5) var(--cl-s-6) var(--cl-s-6); }

/* ------------------ INTERACTIVE RESUME (carousel) ------------------ */
.cl-carousel {
  border: var(--cl-border);
  background: var(--cl-paper);
  position: relative;
}
.cl-carousel-track {
  display: flex;
  overflow: hidden;
  scroll-behavior: smooth;
}
.cl-carousel-card {
  flex: 0 0 100%;
  padding: var(--cl-s-8);
  min-height: 520px;
  display: none;
}
.cl-carousel-card.is-active { display: block; }
.cl-carousel-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: var(--cl-border);
  padding: var(--cl-s-3) var(--cl-s-5);
  background: var(--cl-paper-2);
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.cl-carousel-nav button {
  appearance: none; border: 0; background: transparent;
  font-family: var(--cl-font-display); font-size: 22px; cursor: pointer;
  padding: 4px 10px; color: var(--cl-ink);
}
.cl-carousel-nav button:hover { background: var(--cl-lime); }
.cl-carousel-dots { display: flex; gap: var(--cl-s-2); }
.cl-carousel-dot {
  appearance: none; border: var(--cl-border); background: var(--cl-paper);
  width: 14px; height: 14px; cursor: pointer; padding: 0;
}
.cl-carousel-dot.is-active { background: var(--cl-lime); }

.cl-timeline-item {
  display: grid;
  grid-template-columns: 110px 1fr auto;
  gap: var(--cl-s-4);
  padding: var(--cl-s-4) var(--cl-s-3);
  border-bottom: var(--cl-border-hair);
  align-items: start;
  cursor: pointer;
  transition: background var(--cl-dur-1) var(--cl-ease);
}
.cl-timeline-item:hover { background: var(--cl-lime); color: var(--cl-lime-ink); }
.cl-timeline-item:last-child { border-bottom: 0; }
.cl-timeline-item .cl-timeline-year {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-meta);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.cl-timeline-item h3 {
  font-family: var(--cl-font-body);
  font-weight: var(--cl-w-black);
  font-size: 17px;
  line-height: 1.15;
  letter-spacing: var(--cl-ls-snug);
  text-transform: uppercase;
  margin: 0 0 4px;
}
.cl-timeline-item .cl-timeline-co {
  font-family: var(--cl-font-mono);
  font-size: var(--cl-t-micro);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cl-ink-mute);
}
.cl-timeline-item:hover .cl-timeline-co { color: var(--cl-ink); }
.cl-timeline-item .cl-timeline-arrow {
  font-family: var(--cl-font-display);
  font-size: 22px;
  align-self: center;
}

/* job detail modal */
.cl-modal-backdrop[hidden] { display: none; }

/* mobile tweaks */
@media (max-width: 720px) {
  .cl-carousel-card { padding: var(--cl-s-5); min-height: 0; }
  .cl-timeline-item { grid-template-columns: 1fr auto; }
  .cl-timeline-item .cl-timeline-year { grid-column: 1 / -1; margin-bottom: 4px; }
}

/* resume two-column grid */
.cl-resume-grid {
  display: grid;
  grid-template-columns: 1fr 2.2fr;
  gap: var(--cl-s-12);
}
@media (max-width: 900px) {
  .cl-resume-grid { grid-template-columns: 1fr; gap: var(--cl-s-8); }
}

/* interactive resume timeline list */
.cl-timeline {
  border-top: var(--cl-border);
  border-bottom: var(--cl-border);
}
.cl-timeline .cl-timeline-item {
  width: 100%;
  background: var(--cl-paper);
  border-left: 0; border-right: 0; border-top: 0;
  text-align: left;
  font: inherit; color: inherit;
}

/* simple inline modal for the interactive resume */
.cl-modal {
  position: relative;
  padding: var(--cl-s-7) var(--cl-s-7) var(--cl-s-7);
  max-width: 720px;
  max-height: 90vh;
  overflow: auto;
}
.cl-modal-close {
  position: absolute;
  top: var(--cl-s-3); right: var(--cl-s-3);
  background: var(--cl-ink); color: var(--cl-paper);
  border: 0; cursor: pointer;
  width: 36px; height: 36px;
  font-family: var(--cl-font-display);
  font-size: 22px; line-height: 1;
  display: grid; place-items: center;
}
.cl-modal-close:hover { background: var(--cl-lime); color: var(--cl-lime-ink); }

/* 404 two-column grid */
.cl-404-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--cl-s-12);
}
@media (max-width: 900px) {
  .cl-404-grid { grid-template-columns: 1fr; gap: var(--cl-s-8); }
}
