/* ============================================================
   SAM·MALIK — Design System stylesheet
   Terminal-meets-gothic. Void + bone, phosphor + oxblood.
   All tokens per "Sam Malik Design System.md".
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,300..700;1,400..600&family=Space+Grotesk:wght@300..700&family=IBM+Plex+Mono:ital,wght@0,400..600;1,400..500&display=swap');

/* ---------- Tokens ---------- */
:root {
  /* Ground / voids */
  --pitch: #060608;
  --void: #0b0b0f;
  --slab: #131318;
  --slab-2: #1b1b22;
  --hairline: #26262e;
  --hairline-2: #34343e;

  /* Bone / neutrals */
  --bone: #ece7d8;
  --bone-dim: #b6b1a4;
  --ash: #847f74;
  --ash-dim: #555049;

  /* Phosphor (cybernetic) */
  --phosphor: #c8f24a;
  --phosphor-dim: #9bbd38;
  --phosphor-deep: #2c360f;
  --phosphor-glow: rgba(200, 242, 74, .32);

  /* Oxblood (gothic) */
  --oxblood: #8e1c24;
  --oxblood-lift: #b3303a;
  --oxblood-deep: #2a0c0f;

  /* Signals */
  --signal-good: #c8f24a;
  --signal-warn: #e0a838;
  --signal-bad: #b3303a;
  --signal-info: #6f8fb8;

  /* Semantic aliases */
  --bg-page: var(--void);
  --bg-sunk: var(--pitch);
  --surface-card: var(--slab);
  --border-default: var(--hairline);
  --text-display: var(--bone);
  --text-body: var(--bone-dim);
  --text-meta: var(--ash);
  --text-accent: var(--phosphor);
  --accent: var(--phosphor);
  --accent-2: var(--oxblood);

  /* Fonts */
  --font-display: 'Cormorant', serif;
  --font-ui: 'Space Grotesk', sans-serif;
  --font-mono: 'IBM Plex Mono', monospace;

  /* Type scale */
  --t-mega: 7rem;
  --t-display: 4rem;
  --t-h1: 2.25rem;
  --t-h2: 1.625rem;
  --t-h3: 1.25rem;
  --t-lg: 1.125rem;
  --t-body: 1rem;
  --t-sm: .875rem;
  --t-xs: .75rem;
  --t-micro: .6875rem;

  /* Spacing (8px grid) */
  --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;

  /* Radii */
  --r-none: 0; --r-sm: 2px; --r-md: 3px; --r-pill: 999px;

  /* Borders */
  --bw-hair: 1px; --bw-thick: 2px;

  /* Effects */
  --shadow-lift: 0 8px 24px rgba(0, 0, 0, .45);
  --shadow-deep: 0 18px 50px rgba(0, 0, 0, .6);
  --glow-sm: 0 0 8px var(--phosphor-glow);
  --glow-md: 0 0 18px var(--phosphor-glow);
  --glow-text: 0 0 12px var(--phosphor-glow);

  /* Motion */
  --ease: cubic-bezier(.22, .61, .36, 1);
  --ease-out: cubic-bezier(.16, 1, .3, 1);
  --dur-fast: 120ms; --dur: 180ms; --dur-slow: 320ms;

  --maxw: 1180px;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--void);
  color: var(--bone-dim);
  font-family: var(--font-ui);
  font-size: var(--t-body);
  line-height: 1.6;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: var(--phosphor); text-decoration: none; }
::selection { background: var(--phosphor-deep); color: var(--bone); }

/* ---------- Texture: grain + scanlines ---------- */
.sm-grain {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  opacity: .035; mix-blend-mode: screen;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.sm-scan {
  position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: .35;
  background: repeating-linear-gradient(to bottom, transparent 0, transparent 2px, rgba(0,0,0,.18) 3px, transparent 4px);
}

/* ---------- Layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--sp-6); position: relative; z-index: 2; }
.section { padding: var(--sp-9) 0; }
.section--tight { padding: var(--sp-7) 0; }

/* ---------- Mono label / eyebrow ---------- */
.sm-label, .eyebrow {
  font-family: var(--font-mono);
  font-size: var(--t-micro);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ash);
  font-weight: 500;
}
.eyebrow .idx { color: var(--phosphor); }

/* ---------- Typography helpers ---------- */
h1, h2, h3 { color: var(--bone); font-family: var(--font-display); font-weight: 500; line-height: 1.02; letter-spacing: -.02em; margin: 0; }
h1 { font-size: var(--t-display); }
h2 { font-size: var(--t-h1); }
h3 { font-size: var(--t-h2); }
.italic { font-style: italic; }
.display { font-family: var(--font-display); }
.mono { font-family: var(--font-mono); }
p { margin: 0 0 var(--sp-4); }
.lead { font-size: var(--t-lg); color: var(--bone-dim); max-width: 62ch; }
.dim { color: var(--ash); }
.middot { color: var(--phosphor); padding: 0 .35em; }

/* ---------- Nav (sticky HUD) ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(11, 11, 15, .82);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: var(--bw-hair) solid var(--hairline);
}
.nav__inner { max-width: var(--maxw); margin: 0 auto; padding: var(--sp-3) var(--sp-6);
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); }
.brand { font-family: var(--font-display); font-size: var(--t-h3); color: var(--bone); letter-spacing: .02em; }
.brand .middot { font-weight: 600; }
.nav__links { display: flex; gap: var(--sp-5); align-items: center; }
.nav__links a {
  font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: .12em;
  text-transform: uppercase; color: var(--ash); position: relative; padding: var(--sp-1) 0;
  transition: color var(--dur) var(--ease);
}
.nav__links a:hover { color: var(--bone); }
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; height: 1px; width: 0;
  background: var(--phosphor); box-shadow: var(--glow-sm); transition: width var(--dur) var(--ease);
}
.nav__links a:hover::after, .nav__links a.active::after { width: 100%; }
.nav__links a.active { color: var(--bone); }
.nav__toggle { display: none; background: none; border: var(--bw-hair) solid var(--hairline);
  color: var(--bone); font-family: var(--font-mono); font-size: var(--t-xs); padding: var(--sp-2) var(--sp-3);
  cursor: pointer; letter-spacing: .12em; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: .12em; text-transform: uppercase;
  padding: var(--sp-3) var(--sp-5); border: var(--bw-hair) solid var(--hairline-2);
  color: var(--bone); background: var(--slab); cursor: pointer; border-radius: var(--r-sm);
  transition: transform var(--dur-fast) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.btn:hover { border-color: var(--phosphor-dim); background: var(--slab-2); }
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--phosphor-deep); border-color: var(--phosphor-dim); color: var(--phosphor); box-shadow: var(--glow-sm); }
.btn--primary:hover { box-shadow: var(--glow-md); border-color: var(--phosphor); }
.btn--ghost { background: transparent; }
.btn--danger { border-color: var(--oxblood); color: var(--oxblood-lift); }
.btn--danger:hover { background: var(--oxblood-deep); border-color: var(--oxblood-lift); }

/* ---------- Tag ---------- */
.tag {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: .1em; text-transform: uppercase;
  padding: 3px var(--sp-2); border: var(--bw-hair) solid var(--hairline);
  color: var(--bone-dim); border-radius: var(--r-sm); background: var(--void);
}
.tag--phosphor { color: var(--phosphor); border-color: var(--phosphor-dim); }
.tag--oxblood { color: var(--oxblood-lift); border-color: var(--oxblood); }
.tag--outline { background: transparent; }
.tag .dot { width: 6px; height: 6px; border-radius: var(--r-pill); background: var(--phosphor); box-shadow: var(--glow-sm); }
.tag--oxblood .dot { background: var(--oxblood-lift); box-shadow: none; }

.taglist { display: flex; flex-wrap: wrap; gap: var(--sp-2); }

/* ---------- Card ---------- */
.card {
  position: relative; background: var(--slab); border: var(--bw-hair) solid var(--hairline);
  padding: var(--sp-6); border-radius: var(--r-sm);
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.card--interactive:hover { border-color: var(--hairline-2); background: var(--slab-2); transform: translateY(-2px); }
.card--accent::before { content: ""; position: absolute; left: 0; top: 0; height: 2px; width: 100%; background: var(--phosphor); box-shadow: var(--glow-sm); }
.card__index { position: absolute; top: var(--sp-4); right: var(--sp-5); font-family: var(--font-mono); font-size: var(--t-xs); color: var(--ash-dim); letter-spacing: .1em; }

/* ---------- DataField ---------- */
.datafield { display: flex; flex-direction: column; gap: var(--sp-1); }
.datafield .df-label { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: .14em; text-transform: uppercase; color: var(--ash); }
.datafield .df-value { font-family: var(--font-mono); font-size: var(--t-lg); color: var(--bone); }
.datafield .df-value .unit { color: var(--ash); font-size: var(--t-sm); }
.datafield .df-value .trend-up { color: var(--phosphor); }
.datafield .df-value .trend-down { color: var(--oxblood-lift); }

/* ---------- Rule (divider) ---------- */
.rule { display: flex; align-items: center; gap: var(--sp-4); margin: var(--sp-7) 0; }
.rule::before, .rule::after { content: ""; height: 1px; background: var(--hairline); flex: 1; }
.rule__label { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: .14em; text-transform: uppercase; color: var(--ash); white-space: nowrap; }
.rule__label .idx { color: var(--phosphor); }
.rule--accent::before, .rule--accent::after { background: linear-gradient(90deg, transparent, var(--phosphor-dim)); }

/* ---------- Marquee ---------- */
.marquee { overflow: hidden; border-top: var(--bw-hair) solid var(--hairline); border-bottom: var(--bw-hair) solid var(--hairline); background: var(--pitch); }
.marquee__track { display: inline-flex; white-space: nowrap; gap: var(--sp-6); padding: var(--sp-3) 0; animation: marquee 38s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: .12em; text-transform: uppercase; color: var(--ash); }
.marquee__item .sep { color: var(--phosphor); padding: 0 var(--sp-4); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ---------- Hero ---------- */
.hero { padding: var(--sp-10) 0 var(--sp-9); position: relative; }
.hero__name { font-size: var(--t-mega); line-height: .92; }
.hero__name .middot { font-size: .7em; }
.hero__cred { color: var(--phosphor); }

/* ---------- Page intro ---------- */
.page-head { padding: var(--sp-9) 0 var(--sp-6); border-bottom: var(--bw-hair) solid var(--hairline); }
.page-head h1 { font-size: var(--t-display); margin-top: var(--sp-3); }

/* ---------- Grids ---------- */
.grid { display: grid; gap: var(--sp-5); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }

/* ---------- Experience timeline ---------- */
.xp { border-left: var(--bw-hair) solid var(--hairline); padding-left: var(--sp-6); margin-left: var(--sp-2); }
.xp__item { position: relative; padding-bottom: var(--sp-8); }
.xp__item::before { content: ""; position: absolute; left: calc(-1 * var(--sp-6) - 4px); top: 6px; width: 7px; height: 7px; border-radius: var(--r-pill); background: var(--phosphor); box-shadow: var(--glow-sm); }
.xp__item--past::before { background: var(--ash); box-shadow: none; }
.xp__meta { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: .1em; color: var(--ash); text-transform: uppercase; }
.xp__role { font-family: var(--font-display); font-size: var(--t-h2); color: var(--bone); margin: var(--sp-1) 0 2px; }
.xp__org { color: var(--phosphor); font-family: var(--font-mono); font-size: var(--t-sm); }

/* ---------- Project visual placeholder ---------- */
.visref { aspect-ratio: 16/10; border: var(--bw-hair) solid var(--hairline); background:
  linear-gradient(135deg, var(--slab-2), var(--pitch));
  display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.visref::after { content: attr(data-label); font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: .14em; text-transform: uppercase; color: var(--ash-dim); }
.visref--grid { background-image: linear-gradient(var(--hairline) 1px, transparent 1px), linear-gradient(90deg, var(--hairline) 1px, transparent 1px); background-size: 28px 28px; background-color: var(--pitch); }

/* ---------- Exhibit (framed real artifact / screenshot) ---------- */
.exhibit { border: var(--bw-hair) solid var(--hairline); background: var(--pitch); }
.exhibit__bar { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); padding: var(--sp-2) var(--sp-3); border-bottom: var(--bw-hair) solid var(--hairline); }
.exhibit__bar .dots { display: flex; gap: 6px; }
.exhibit__bar .dots i { width: 7px; height: 7px; border-radius: var(--r-pill); display: inline-block; background: var(--hairline-2); }
.exhibit__bar .dots i.live { background: var(--phosphor); box-shadow: var(--glow-sm); }
.exhibit__bar .cap { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: .12em; text-transform: uppercase; color: var(--ash); }
.exhibit__plate { padding: var(--sp-4); background: #f4f1e9; }
.exhibit__plate img { width: 100%; height: auto; display: block; }
.exhibit__plate--dark { background: var(--pitch); }

/* ---------- Code plate ---------- */
.codeplate { border: var(--bw-hair) solid var(--hairline); background: var(--pitch); border-radius: var(--r-sm); overflow: hidden; }
.codeplate pre { margin: 0; padding: var(--sp-4); overflow-x: auto; font-family: var(--font-mono); font-size: var(--t-xs); line-height: 1.7; color: var(--bone-dim); }
.codeplate .kw { color: var(--phosphor); }
.codeplate .cm { color: var(--ash-dim); }
.codeplate .st { color: var(--oxblood-lift); }

/* ---------- Architecture stack (TensorFlow) ---------- */
.stack { display: flex; flex-direction: column; gap: 6px; }
.stack__layer { border: var(--bw-hair) solid var(--hairline); background: var(--slab); padding: var(--sp-3) var(--sp-4); display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-3); }
.stack__layer .lt { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--bone); letter-spacing: .04em; }
.stack__layer .ld { font-family: var(--font-mono); font-size: var(--t-micro); color: var(--ash); }
.stack__layer.top { border-color: var(--phosphor-dim); box-shadow: inset 0 0 0 1px var(--phosphor-deep); }
.stack__layer.top .lt { color: var(--phosphor); }
.stack__arrow { text-align: center; color: var(--ash-dim); font-family: var(--font-mono); font-size: var(--t-xs); }

/* ---------- Blog list ---------- */
.post-list { list-style: none; padding: 0; margin: 0; }
.post-list li { border-top: var(--bw-hair) solid var(--hairline); }
.post-list li:last-child { border-bottom: var(--bw-hair) solid var(--hairline); }
.post-link { display: grid; grid-template-columns: 120px 1fr auto; gap: var(--sp-5); align-items: baseline; padding: var(--sp-5) 0; transition: background var(--dur) var(--ease); }
.post-link:hover { background: var(--slab); }
.post-link .p-date { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--ash); letter-spacing: .08em; }
.post-link .p-title { font-family: var(--font-display); font-size: var(--t-h3); color: var(--bone); }
.post-link .p-arrow { color: var(--phosphor); font-family: var(--font-mono); }

/* ---------- Markdown body ---------- */
.md { max-width: 70ch; }
.md h1, .md h2, .md h3 { margin: var(--sp-7) 0 var(--sp-3); }
.md h1 { font-size: var(--t-h1); }
.md h2 { font-size: var(--t-h2); }
.md h3 { font-size: var(--t-h3); }
.md p { color: var(--bone-dim); }
.md a { border-bottom: 1px solid var(--phosphor-dim); }
.md blockquote { border-left: 2px solid var(--oxblood); margin: var(--sp-5) 0; padding: var(--sp-1) var(--sp-5); color: var(--bone); font-family: var(--font-display); font-style: italic; font-size: var(--t-lg); }
.md code { font-family: var(--font-mono); font-size: .9em; background: var(--pitch); border: 1px solid var(--hairline); padding: 1px 6px; border-radius: var(--r-sm); color: var(--phosphor); }
.md pre { background: var(--pitch); border: 1px solid var(--hairline); padding: var(--sp-4); overflow-x: auto; border-radius: var(--r-sm); }
.md pre code { background: none; border: none; padding: 0; color: var(--bone-dim); }
.md ul, .md ol { color: var(--bone-dim); padding-left: var(--sp-5); }
.md li { margin-bottom: var(--sp-2); }
.md hr { border: none; border-top: 1px solid var(--hairline); margin: var(--sp-7) 0; }

/* ---------- Reading shelf ---------- */
.shelf { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); }
.shelf--flow { display: flex; align-items: flex-start; gap: var(--sp-3); }
.shelf--flow .book { flex: 1 1 0; min-width: 0; }
.shelf-arrow { flex: 0 0 auto; align-self: flex-start; margin-top: 80px; color: var(--phosphor); font-family: var(--font-mono); font-size: var(--t-h2); text-shadow: var(--glow-text); }
.book { display: flex; flex-direction: column; gap: var(--sp-4); }
.book__cover { aspect-ratio: 2/3; border: var(--bw-hair) solid var(--hairline); background: linear-gradient(160deg, var(--slab-2), var(--pitch)); position: relative; display: flex; align-items: flex-end; padding: var(--sp-4); }
.book__cover .spine { position: absolute; left: 0; top: 0; bottom: 0; width: 6px; background: var(--oxblood); }
.book__cover--current .spine { background: var(--phosphor); box-shadow: var(--glow-sm); }
.book__cover .ct { font-family: var(--font-display); font-style: italic; color: var(--bone); font-size: var(--t-h3); line-height: 1.05; }
.book__status { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: .14em; text-transform: uppercase; }
.book__status.now { color: var(--phosphor); }
.book__status.last { color: var(--ash); }
.book__status.next { color: var(--oxblood-lift); }
.book__author { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--ash); letter-spacing: .06em; }

/* ---------- Connect ---------- */
.connect-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.connect-card { display: flex; flex-direction: column; gap: var(--sp-2); padding: var(--sp-5); border: var(--bw-hair) solid var(--hairline); background: var(--slab); transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease); }
.connect-card:hover { border-color: var(--phosphor-dim); background: var(--slab-2); }
.connect-card .cc-label { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: .14em; text-transform: uppercase; color: var(--ash); }
.connect-card .cc-value { color: var(--bone); font-family: var(--font-mono); font-size: var(--t-sm); word-break: break-all; }

/* ---------- Footer ---------- */
.footer { border-top: var(--bw-hair) solid var(--hairline); background: var(--pitch); margin-top: var(--sp-9); }
.footer__inner { max-width: var(--maxw); margin: 0 auto; padding: var(--sp-8) var(--sp-6); }
.footer__base { display: flex; justify-content: space-between; align-items: center; gap: var(--sp-4); margin-top: var(--sp-7); padding-top: var(--sp-5); border-top: var(--bw-hair) solid var(--hairline); }
.footer__base .mono { font-size: var(--t-xs); color: var(--ash); letter-spacing: .08em; }

/* ---------- Page rise transition ---------- */
.page-rise { animation: rise var(--dur-slow) var(--ease-out) both; }
@keyframes rise { from { transform: translateY(6px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

/* ---------- Status / loading ---------- */
.loading { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--ash); letter-spacing: .12em; text-transform: uppercase; }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  :root { --t-mega: 3.6rem; --t-display: 2.6rem; --t-h1: 1.9rem; }
  .nav__toggle { display: inline-block; }
  .nav__links { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column;
    gap: 0; background: rgba(11,11,15,.97); border-bottom: var(--bw-hair) solid var(--hairline); padding: var(--sp-2) var(--sp-6) var(--sp-5); }
  .nav__links.open { display: flex; }
  .nav__links a { padding: var(--sp-3) 0; border-bottom: 1px solid var(--hairline); }
  .grid--2, .grid--3, .shelf, .connect-grid { grid-template-columns: 1fr; }
  .shelf--flow { flex-direction: column; }
  .shelf--flow .book { width: 100%; }
  .shelf-arrow { align-self: center; margin: 0; transform: rotate(90deg); }
  .post-link { grid-template-columns: 1fr; gap: var(--sp-1); }
  .post-link .p-arrow { display: none; }
  .wrap { padding: 0 var(--sp-4); }
}
