/*
 * ink.css — NOIR / CHALK-ON-VOID overhaul
 * Loaded last. Black-dominant, editorial-brutalist reskin with creative layout.
 *
 * Design rules:
 *   1. Pure void black dominates. Elevated surfaces are near-black, not gray.
 *   2. Two chalk values (bone #f4f1e8 and dust #c9c5b6). Grays only via alpha.
 *   3. Hard offset shadows use chalk — a stamp in reverse (dark card, light shadow).
 *   4. SVG marginalia/underlines now in chalk strokes on the black paper.
 *   5. Typography is maximal: split-weight titles, massive display type, stencil caps.
 *   6. Layout is asymmetric — off-center slabs, rotated ornaments, numbered scenes.
 *   7. No color gradients, no blur, no GL canvas. Cheap and loud.
 */

/* ─────────────────────────────────────────────────────────────────────────
   0. PALETTE — chalk on void
   ───────────────────────────────────────────────────────────────────────── */
:root,
body,
body[data-theme="default"],
body[data-theme="cosmic"],
body[data-theme="cyberpunk"],
body[data-theme="brutalist"],
body[data-theme="synthwave"],
body[data-theme="experimental"] {
  color-scheme: dark;

  --void:         #050505;            /* deepest black — the page               */
  --void-warm:    #0b0b0c;            /* near-black card base                   */
  --void-edge:    #131314;            /* slightly elevated recess               */
  --chalk:        #f4f1e8;            /* main ink — bone white, warm            */
  --chalk-dust:   #c9c5b6;            /* softer secondary                        */
  --chalk-90:     rgba(244, 241, 232, 0.90);
  --chalk-64:     rgba(244, 241, 232, 0.64);
  --chalk-42:     rgba(244, 241, 232, 0.42);
  --chalk-22:     rgba(244, 241, 232, 0.22);
  --chalk-12:     rgba(244, 241, 232, 0.12);
  --chalk-08:     rgba(244, 241, 232, 0.08);
  --chalk-04:     rgba(244, 241, 232, 0.04);

  /* One restrained warm accent — used sparingly for live / hot states */
  --ember:        #ff3d00;
  --ember-dim:    rgba(255, 61, 0, 0.55);

  /* Hard overrides of upstream tokens */
  --color-bg-primary:    var(--void);
  --color-bg-secondary:  var(--void-warm);
  --color-bg-tertiary:   var(--void-edge);
  --color-bg-card:       var(--void-warm);

  --color-text-primary:   var(--chalk);
  --color-text-secondary: var(--chalk-64);
  --color-text-tertiary:  var(--chalk-42);

  --color-accent-1:      var(--chalk);
  --color-accent-2:      var(--chalk);
  --color-accent-3:      var(--chalk);
  --color-accent-4:      var(--chalk);
  --color-accent-1-rgb:  244, 241, 232;
  --color-accent-2-rgb:  244, 241, 232;
  --color-accent-3-rgb:  244, 241, 232;
  --color-accent-4-rgb:  244, 241, 232;

  --color-glow-1: transparent;
  --color-glow-2: transparent;
  --color-glow-3: transparent;

  --color-border:  var(--chalk-12);
  --color-shadow:  rgba(0, 0, 0, 0.75);
  --color-overlay: rgba(5, 5, 5, 0.96);

  --color-success: var(--chalk);
  --color-error:   #ff5a3d;
  --color-warning: var(--chalk);
  --color-info:    var(--chalk);

  --gradient-primary:   none;
  --gradient-secondary: none;
  --gradient-tertiary:  none;

  /* Cinematic tokens (defined in cinematic.css) */
  --cine-label:    var(--chalk-42);
  --cine-body:     var(--chalk-64);
  --cine-value:    var(--chalk);
  --cine-border:   var(--chalk-12);
  --cine-border-h: var(--chalk-22);
  --cine-surface:  rgba(244, 241, 232, 0.02);

  /* Type stack */
  --font-pen:      'Caveat', 'Bradley Hand', cursive;
  --font-hand:     'Architects Daughter', 'Caveat', cursive;
  --font-stamp:    'Special Elite', 'Courier New', monospace;
  --font-mono:     'Fira Code', 'Courier New', monospace;
  --font-display:  'Syne', 'Space Grotesk', serif;
}

/* Match mobile browser chrome color to the void */
html { background: var(--void); }

/* ─────────────────────────────────────────────────────────────────────────
   1. VOID — body + subtle chalk-dust grain
   ───────────────────────────────────────────────────────────────────────── */
html, body {
  background: var(--void);
  color: var(--chalk);
}

body {
  font-family: 'Space Grotesk', system-ui, sans-serif;
  /* Faint chalk-dust grain + very faint ruled lines (blackboard feel) */
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.96  0 0 0 0 0.95  0 0 0 0 0.91  0 0 0 0.05 0'/></filter><rect width='100%25' height='100%25' filter='url(%23g)'/></svg>"),
    repeating-linear-gradient(to bottom, transparent 0, transparent 31px, rgba(244,241,232,0.025) 31px, rgba(244,241,232,0.025) 32px);
  background-size: 220px 220px, 100% 32px;
  background-attachment: fixed, fixed;
}

/* Keep noise overlay — quieten it so the grain above stays primary */
.noise-overlay {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23g)' opacity='0.5'/></svg>") !important;
  opacity: 0.10 !important;
  mix-blend-mode: screen !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   2. KILL THE LAG — hide every expensive canvas / GL surface
   ───────────────────────────────────────────────────────────────────────── */
#gallery-3d,
#gallery-3d canvas,
canvas[data-bg="dotted-surface"],
canvas#dotted-surface,
.dotted-surface,
canvas#bg-canvas,
.morph-bg,
canvas.morph-bg-canvas {
  display: none !important;
}

* {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.navigation,
.nav-bar,
.hud {
  mix-blend-mode: normal !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   3. HERO — brutal split-weight title + chalk marginalia on the void
   ───────────────────────────────────────────────────────────────────────── */
.hero-section {
  background:
    radial-gradient(ellipse at 18% 28%, rgba(244,241,232,0.05), transparent 55%),
    radial-gradient(ellipse at 82% 82%, rgba(244,241,232,0.035), transparent 60%),
    var(--void);
  position: relative;
  overflow: hidden;
}

/* Large hand-drawn celestial diagram — chalk strokes, offset asymmetrically */
.hero-section::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 800' fill='none' stroke='%23f4f1e8' stroke-width='1' stroke-linecap='round'><defs><filter id='w' x='-5%25' y='-5%25' width='110%25' height='110%25'><feTurbulence type='fractalNoise' baseFrequency='0.018' numOctaves='2' seed='5'/><feDisplacementMap in='SourceGraphic' scale='5'/></filter></defs><g filter='url(%23w)' opacity='0.35'><circle cx='400' cy='400' r='320'/><circle cx='400' cy='400' r='240'/><circle cx='400' cy='400' r='160'/><circle cx='400' cy='400' r='80'/><line x1='80' y1='400' x2='720' y2='400'/><line x1='400' y1='80' x2='400' y2='720'/><line x1='180' y1='180' x2='620' y2='620'/><line x1='620' y1='180' x2='180' y2='620'/><circle cx='400' cy='400' r='6' fill='%23f4f1e8'/><circle cx='560' cy='320' r='4' fill='%23f4f1e8'/><circle cx='280' cy='540' r='3' fill='%23f4f1e8'/><circle cx='620' cy='460' r='3' fill='%23f4f1e8'/></g></svg>");
  background-position: 82% 58%;
  background-repeat: no-repeat;
  background-size: min(74vmin, 680px) min(74vmin, 680px);
  opacity: 0.9;
}

/* Marginalia — tiny chalk doodles */
.hero-section::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='110' fill='none' stroke='%23f4f1e8' stroke-width='1.2' stroke-linecap='round'><path d='M10 60 Q 30 10, 60 50 T 110 30 T 150 70'/><circle cx='130' cy='80' r='3' fill='%23f4f1e8'/><path d='M118 92 l 8 -4 M120 100 l 12 -2'/></svg>"),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='140' fill='none' stroke='%23f4f1e8' stroke-width='1.2' stroke-linecap='round'><path d='M20 80 l -10 -10 M20 80 l 10 -10 M20 80 l 0 -50'/><path d='M50 100 q 30 -40 70 -20 q 40 20 40 -10'/><text x='130' y='25' font-family='Caveat,cursive' font-size='24' fill='%23f4f1e8' stroke='none' opacity='0.9'>scroll</text></svg>");
  background-position: 5% 14%, 93% 86%;
  background-repeat: no-repeat;
  background-size: 160px 110px, 200px 140px;
  opacity: 0.75;
}

/* Asymmetric content — pull title slightly left of center for editorial weight */
.cine-hero-content {
  position: relative;
  z-index: 2;
  align-items: flex-start !important;
  text-align: left !important;
  padding-left: clamp(1rem, 6vw, 6rem);
  max-width: min(1200px, 94vw);
}

/* Giant monogram watermark behind the hero — rotated chalk initials */
.cine-hero-content::before {
  content: 'ND';
  position: absolute;
  right: clamp(-2rem, -4vw, -0.5rem);
  top: -0.4em;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(8rem, 22vw, 22rem);
  line-height: 0.8;
  letter-spacing: -0.06em;
  color: transparent;
  -webkit-text-stroke: 1px var(--chalk-08);
          text-stroke: 1px var(--chalk-08);
  pointer-events: none;
  z-index: -1;
  transform: rotate(-6deg);
  user-select: none;
}

.cine-title {
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: -0.035em;
  font-size: clamp(3.2rem, 12vw, 11rem) !important;
  line-height: 0.92 !important;
  color: var(--chalk);
  text-shadow: none;
  position: relative;
  text-align: left !important;
  margin: 0 !important;
}

/* Split treatment: "The" becomes outline, "Quazar" stays solid. JS-free — use
   ::first-word equivalent via a nested span. Fallback: a single-word title still
   renders fine since we only style the first line via a gradient background
   clip that renders as solid on the second word. */
.cine-title {
  background: linear-gradient(
    to right,
    transparent 0,
    transparent 30%,
    var(--chalk) 30%,
    var(--chalk) 100%
  );
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 1.5px var(--chalk);
}

/* Hand-drawn chalk underline under the title */
.cine-title::after {
  content: '';
  display: block;
  margin: 0.25em 0 0 0;
  width: min(380px, 62%);
  height: 18px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='380' height='18' fill='none' stroke='%23f4f1e8' stroke-width='2' stroke-linecap='round'><path d='M4 12 Q 50 4, 100 10 T 200 8 T 300 12 T 376 6'/></svg>") no-repeat left center/contain;
  -webkit-text-fill-color: initial;
}

.cine-rule {
  background: var(--chalk) !important;
  height: 1px !important;
  opacity: 0.35;
  align-self: flex-start !important;
  margin-left: 0 !important;
}

.cine-sub {
  font-family: var(--font-stamp);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-size: 0.78rem;
  color: var(--chalk-64) !important;
  text-align: left !important;
  margin-left: 0 !important;
}

/* Add a numbered "00 / HERO" scene tag above the title */
.cine-hero-content > *:first-child {
  position: relative;
}
.cine-hero-content::after {
  content: '00 — THE QUAZAR / v4';
  position: absolute;
  top: 0.5rem;
  left: clamp(1rem, 6vw, 6rem);
  font-family: var(--font-mono);
  font-size: 0.64rem;
  letter-spacing: 0.42em;
  color: var(--chalk-42);
  text-transform: uppercase;
  pointer-events: none;
}

.cine-cta {
  gap: 1.4rem;
  justify-content: flex-start !important;
  margin-left: 0 !important;
}

.cine-link {
  position: relative;
  font-family: var(--font-stamp);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 0.8rem;
  color: var(--chalk) !important;
  padding: 6px 2px 8px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='10' fill='none' stroke='%23f4f1e8' stroke-width='1.4' stroke-linecap='round'><path d='M2 6 Q 25 2, 50 6 T 98 4'/></svg>");
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 100% 8px;
  transition: color 160ms ease, transform 160ms ease, opacity 160ms ease;
}

.cine-link:hover {
  transform: translateY(-1px);
  opacity: 0.85;
}

.cine-sep {
  color: var(--chalk-42) !important;
  font-family: var(--font-pen);
  font-size: 1.5rem;
}

.cine-scroll-line {
  width: 1px !important;
  background: var(--chalk) !important;
  opacity: 0.55;
}

/* ─────────────────────────────────────────────────────────────────────────
   4. HUD / NAV — dark bar with chalk pen-strokes
   ───────────────────────────────────────────────────────────────────────── */
.hud {
  background: linear-gradient(to bottom, rgba(5,5,5,0.92), rgba(5,5,5,0.55) 70%, transparent) !important;
  border: none !important;
}

.hud-logo {
  font-family: var(--font-pen);
  font-weight: 700;
  font-size: 1.7rem;
  color: var(--chalk) !important;
  letter-spacing: -0.005em;
}

.logo-cursor { color: var(--chalk) !important; }

.hud-nav {
  background: rgba(244, 241, 232, 0.03) !important;
  border: 1px solid var(--chalk) !important;
  box-shadow: 3px 3px 0 var(--chalk-22) !important;
  border-radius: 2px !important;
}

.hud-nav-link {
  color: var(--chalk-64) !important;
  font-family: var(--font-stamp);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.hud-nav-link:hover { color: var(--chalk) !important; }

.hud-nav-link.active {
  background: var(--chalk) !important;
  color: var(--void) !important;
}

.page-indicator .pi-dot,
.page-indicator span {
  background: var(--chalk-22) !important;
  border: 1px solid var(--chalk-42);
}

.page-indicator .pi-dot.active,
.page-indicator span.active {
  background: var(--chalk) !important;
  border-color: var(--chalk);
}

/* ─────────────────────────────────────────────────────────────────────────
   5. SECTION HEADERS — chalk marginalia over void
   ───────────────────────────────────────────────────────────────────────── */
.section-header {
  position: relative;
}

.section-title {
  font-family: var(--font-stamp);
  font-weight: 400;
  font-size: 1.05rem;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--chalk) !important;
  position: relative;
  padding-left: 0;
  display: inline-block;
}

.section-line {
  height: 14px !important;
  max-width: 22rem;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='320' height='14' fill='none' stroke='%23f4f1e8' stroke-width='1.4' stroke-linecap='round'><path d='M4 9 Q 40 3, 80 8 T 160 6 T 240 10 T 316 5'/></svg>") no-repeat left center/100% 12px !important;
  clip-path: none !important;
  margin-top: 0.4rem !important;
  opacity: 0.85;
}

/* Asterisk marginalia — now in chalk */
.section-header::before {
  content: '✱';
  position: absolute;
  left: -2.4rem;
  top: -0.6rem;
  font-family: var(--font-pen);
  font-size: 2.4rem;
  color: var(--chalk);
  transform: rotate(-12deg);
  opacity: 0.9;
}

/* Give every non-hero section a warm chalk-seam divider at its top edge,
   replacing the inset light-seam from cinematic.css */
section:not(.hero-section) {
  box-shadow: inset 0 1px 0 var(--chalk-12) !important;
  position: relative;
}

/* Big ghosted scene numeral floating behind each section heading */
section:not(.hero-section) .section-header {
  position: relative;
}

section:not(.hero-section) .section-header::after {
  content: '';
  position: absolute;
  right: -0.5rem;
  top: -1.2rem;
  width: 60px;
  height: 1px;
  background: var(--chalk-22);
}

@media (max-width: 900px) {
  .section-header::before { display: none; }
  .cine-hero-content::before { display: none; }
  .cine-hero-content::after {
    left: 1rem;
    font-size: 0.58rem;
    letter-spacing: 0.32em;
  }
  .cine-hero-content {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  /* Revert split-weight title to solid fill on mobile — reads better small */
  .cine-title {
    background: none !important;
    -webkit-text-fill-color: var(--chalk) !important;
    -webkit-text-stroke: 0 !important;
    white-space: normal !important;
  }
}

/* ─────────────────────────────────────────────────────────────────────────
   6. CARD FRAMING — slab on the void, chalk stamp shadow
   ───────────────────────────────────────────────────────────────────────── */
.dc-card,
.dc-panel,
.contact-info,
.about-sig-card,
.terminal-block,
.terminal-signature,
.contrib-graph-wrap,
.analyzer-card,
.pc-card,
.project-card,
.fun-quote {
  background: var(--void-warm) !important;
  border: 1px solid var(--chalk) !important;
  border-left: 1px solid var(--chalk) !important;
  border-radius: 2px !important;
  box-shadow: 4px 4px 0 var(--chalk) !important;   /* chalk offset stamp */
  clip-path: none !important;
  position: relative;
  color: var(--chalk) !important;
}

.dc-card:hover,
.dc-panel:hover,
.pc-card:hover,
.project-card:hover,
.analyzer-card:hover,
.contact-hub-card:hover {
  background: var(--void-edge) !important;
  border-color: var(--chalk) !important;
  transform: translate(-2px, -2px) !important;
  box-shadow: 6px 6px 0 var(--chalk) !important;
}

/* Crosshatch hover wash for project cards — chalk strokes */
.pc-card::before,
.project-card::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  transition: opacity 200ms ease;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'><path d='M-1 1 l 12 -12 M-1 11 l 12 -12 M-1 21 l 12 -12' stroke='%23f4f1e8' stroke-width='0.6' opacity='0.18'/></svg>");
}

.pc-card:hover::before,
.project-card:hover::before { opacity: 1; }

/* ─────────────────────────────────────────────────────────────────────────
   7. TYPOGRAPHY — chalk on void
   ───────────────────────────────────────────────────────────────────────── */
.cine-title,
.sig-name,
.project-title,
.pc-title,
h1, h2, h3 {
  color: var(--chalk);
  text-shadow: none;
}

.sig-name {
  font-family: var(--font-pen);
  font-size: 3.4rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.005em !important;
  color: var(--chalk) !important;
  line-height: 1 !important;
}

.sig-title {
  font-family: var(--font-stamp);
  font-size: 0.7rem !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase;
  color: var(--chalk-64) !important;
}

.title-separator { color: var(--chalk-42) !important; }
.title-rotating, .title-static { color: var(--chalk-64) !important; }

/* ─────────────────────────────────────────────────────────────────────────
   8. BUTTONS — chalk-stamped
   ───────────────────────────────────────────────────────────────────────── */
.btn,
.pc-btn,
button.btn-primary,
button.btn-secondary {
  background: var(--void-warm) !important;
  color: var(--chalk) !important;
  border: 1.5px solid var(--chalk) !important;
  border-radius: 2px !important;
  box-shadow: 3px 3px 0 var(--chalk) !important;
  font-family: var(--font-stamp);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 0.72rem;
  padding: 0.75rem 1.5rem !important;
  transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease, color 120ms ease;
  clip-path: none !important;
  position: relative;
}

.btn::before,
.pc-btn::before { display: none !important; }

.btn:hover,
.pc-btn:hover {
  transform: translate(-2px, -2px) !important;
  box-shadow: 5px 5px 0 var(--chalk) !important;
}

.btn:active,
.pc-btn:active {
  transform: translate(1px, 1px) !important;
  box-shadow: 1px 1px 0 var(--chalk) !important;
}

.btn-primary,
.pc-btn-demo {
  background: var(--chalk) !important;
  color: var(--void) !important;
  border-color: var(--chalk) !important;
}

.btn-primary:hover,
.pc-btn-demo:hover {
  background: var(--void-warm) !important;
  color: var(--chalk) !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   9. FORMS / INPUTS — fillable slabs on the void
   ───────────────────────────────────────────────────────────────────────── */
.pf-input,
input[type="email"],
input[type="text"],
input[type="number"],
input[type="tel"],
textarea,
select {
  background: var(--void-warm) !important;
  color: var(--chalk) !important;
  border: 1.5px solid var(--chalk) !important;
  border-radius: 2px !important;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  padding: 0.75rem 0.95rem;
  box-shadow: inset 0 -2px 0 var(--chalk-08);
  transition: box-shadow 160ms ease;
}

.pf-input:focus,
input:focus,
textarea:focus,
select:focus {
  outline: none !important;
  box-shadow: 3px 3px 0 var(--chalk) !important;
  border-color: var(--chalk) !important;
}

.pf-input::placeholder,
input::placeholder,
textarea::placeholder { color: var(--chalk-42); }

.input-border, .input-border::after { background: var(--chalk) !important; }

.input-container input:focus ~ label,
.input-container input:valid ~ label,
.input-container textarea:focus ~ label,
.input-container textarea:valid ~ label {
  color: var(--chalk) !important;
}

.pf-error { color: var(--ember) !important; font-family: var(--font-pen); font-size: 1.1rem !important; }
.pf-success { color: var(--chalk); font-family: var(--font-pen); font-size: 1.15rem; }

/* ─────────────────────────────────────────────────────────────────────────
   10. TERMINAL / CODE BLOCKS — pasted printout, dark edition
   ───────────────────────────────────────────────────────────────────────── */
.terminal-block,
.terminal-signature {
  clip-path: none !important;
  border-radius: 2px !important;
  background: var(--void-warm) !important;
}

.terminal-header {
  background: var(--void-edge) !important;
  border-bottom: 1px solid var(--chalk) !important;
}

.terminal-body {
  background: transparent !important;
  color: var(--chalk) !important;
  font-family: var(--font-mono);
}

.terminal-prompt { color: var(--chalk) !important; font-weight: 700; }
.terminal-title  { color: var(--chalk-42) !important; font-family: var(--font-mono); }

.terminal-dot.red,
.terminal-dot.yellow,
.terminal-dot.green {
  background: transparent !important;
  border: 1px solid var(--chalk) !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   11. ABOUT — handwritten signal lines
   ───────────────────────────────────────────────────────────────────────── */
.about-sig-card { border-left: 1px solid var(--chalk) !important; }

.sig-avatar-inline .avatar-glitch {
  background: var(--chalk) !important;
  border: 1.5px solid var(--chalk) !important;
  border-radius: 50% !important;
}

.sig-avatar-inline .avatar-text {
  color: var(--void) !important;
  font-family: var(--font-stamp);
  font-weight: 700;
}

.connection-item { border-bottom: 1px dashed var(--chalk-22) !important; }
.conn-icon { color: var(--chalk) !important; opacity: 1; }
.conn-icon i { color: var(--chalk) !important; }
.conn-label { color: var(--chalk-42) !important; font-family: var(--font-mono); }
.conn-value { color: var(--chalk) !important; font-family: var(--font-mono); }

.status-dot {
  background: var(--chalk) !important;
  box-shadow: 0 0 0 3px var(--void), 0 0 0 4px var(--chalk) !important;
}

.status-text { color: var(--chalk) !important; font-family: var(--font-mono); }

.signal-about-block {
  font-family: var(--font-pen);
  line-height: 1.25;
  font-size: 1.7rem;
}

.signal-about-line {
  color: var(--chalk);
  font-family: var(--font-pen);
  font-size: 1.8rem;
  position: relative;
  padding-left: 1.3rem;
}

.signal-about-line::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--chalk-42);
}

.signal-about-line.accent {
  color: var(--chalk) !important;
  font-weight: 600;
  font-style: italic;
}

/* ─────────────────────────────────────────────────────────────────────────
   12. PROJECTS — slab grid with chalk stamp shadow
   ───────────────────────────────────────────────────────────────────────── */
.pc-card {
  border-left: 1px solid var(--chalk) !important;
  padding: 1.8rem !important;
}

.pc-card:hover { border-left-color: var(--chalk) !important; }

.pc-card--featured {
  border: 2px solid var(--chalk) !important;
  background: var(--void-edge) !important;
}

.pc-icon { color: var(--chalk) !important; }

.pc-title {
  color: var(--chalk) !important;
  font-family: var(--font-mono);
  font-size: 1.4rem !important;
  font-weight: 600 !important;
}

.pc-title--featured {
  font-family: var(--font-pen) !important;
  font-size: 2.6rem !important;
  font-weight: 700 !important;
  text-transform: none !important;
  letter-spacing: -0.005em !important;
  color: var(--chalk) !important;
}

.pc-desc { color: var(--chalk-64) !important; font-family: 'Space Grotesk', sans-serif; }

.pc-meta, .pc-lang-name { color: var(--chalk-42) !important; font-family: var(--font-mono); }
.pc-stars { color: var(--chalk) !important; }
.pc-stars i { color: var(--chalk) !important; }

.pc-lang-dot {
  background: var(--chalk) !important;
  border: 1px solid var(--chalk);
  box-shadow: none !important;
}

.pc-tag {
  background: var(--void-warm) !important;
  border: 1px solid var(--chalk) !important;
  color: var(--chalk) !important;
  font-family: var(--font-mono);
  border-radius: 2px !important;
}

.pc-featured-badge,
.pc-featured-badge--live {
  background: var(--chalk) !important;
  border: 1px solid var(--chalk) !important;
  color: var(--void) !important;
  font-family: var(--font-stamp);
  border-radius: 2px !important;
}

.pc-featured-badge--live {
  background: var(--ember) !important;
  color: var(--void) !important;
  border-color: var(--ember) !important;
}
.pc-featured-badge--live i { color: var(--void) !important; }

.pc-private-notice {
  color: var(--chalk-64) !important;
  border-top: 1px dashed var(--chalk-22) !important;
  font-family: var(--font-mono);
}

/* Project images become negative-print B&W */
.project-image img,
.project-card img {
  filter: grayscale(100%) contrast(1.2) brightness(0.85);
}
.project-card:hover .project-image img {
  filter: grayscale(100%) contrast(1.35) brightness(0.95);
}

.project-tag {
  background: var(--void-warm) !important;
  border: 1px solid var(--chalk) !important;
  color: var(--chalk) !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   13. GITHUB ANALYZER — chalk-on-void panels
   ───────────────────────────────────────────────────────────────────────── */
.analyzer-card {
  background: var(--void-warm) !important;
  border: 1.5px solid var(--chalk) !important;
  box-shadow: 4px 4px 0 var(--chalk) !important;
  border-radius: 2px !important;
}

.card-icon {
  color: var(--chalk) !important;
  font-size: 1.7rem !important;
}

.card-value {
  color: var(--chalk) !important;
  font-family: var(--font-pen);
  font-size: 3.4rem !important;
  font-weight: 700;
  line-height: 1;
}

.card-label {
  color: var(--chalk-64) !important;
  font-family: var(--font-stamp);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.analyzer-sub-title {
  color: var(--chalk) !important;
  font-family: var(--font-pen) !important;
  font-size: 1.9rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.analyzer-sub-title i { color: var(--chalk) !important; margin-right: 0.5rem; }

.analyzer-badge {
  background: var(--void-warm) !important;
  border: 1px solid var(--chalk) !important;
  color: var(--chalk) !important;
  font-family: var(--font-mono);
  border-radius: 2px !important;
}

.lang-bar {
  background: var(--chalk-08) !important;
  border: 1px solid var(--chalk-22) !important;
  border-radius: 0 !important;
  height: 14px !important;
}

.lang-bar-fill {
  background: var(--chalk) !important;
  background-image: repeating-linear-gradient(45deg, var(--chalk) 0 2px, transparent 2px 5px) !important;
}

.contrib-graph-img {
  /* Invert heatmap so it lives on the dark page */
  filter: grayscale(100%) invert(1) brightness(1.15) contrast(2.2) !important;
  opacity: 0.85;
  mix-blend-mode: screen;
}

.contrib-graph-header i { color: var(--chalk) !important; }
.contrib-graph-header { color: var(--chalk) !important; font-family: var(--font-mono); }

/* ─────────────────────────────────────────────────────────────────────────
   14. DISCORD PRESENCE — slab card
   ───────────────────────────────────────────────────────────────────────── */
.dc-card,
.dc-panel { background: var(--void-warm) !important; }

.dc-avatar {
  border: 1.5px solid var(--chalk) !important;
  filter: grayscale(100%) contrast(1.15) brightness(0.95);
  background: var(--void) !important;
}

.dc-status-badge {
  background: var(--void-warm) !important;
  border: 1px solid var(--chalk) !important;
}

.dc-dot { background: var(--chalk-42) !important; }

.dc-tag {
  color: var(--chalk) !important;
  font-family: var(--font-mono);
}

.dc-status-label {
  color: var(--chalk-64) !important;
  font-family: var(--font-stamp);
}

.dc-custom-status {
  color: var(--chalk) !important;
  font-family: var(--font-pen);
  font-size: 1.4rem;
  font-style: normal;
}

.dc-id-badge {
  background: var(--void-warm) !important;
  border: 1px dashed var(--chalk) !important;
  border-radius: 2px;
}

.dc-id-label { color: var(--chalk) !important; font-family: var(--font-stamp); }
.dc-id-val   { color: var(--chalk-64) !important; font-family: var(--font-mono); }

.dc-panel-header {
  color: var(--chalk) !important;
  font-family: var(--font-stamp);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.dc-panel-header i { color: var(--chalk) !important; }

.dc-spotify-panel .dc-panel-header i { color: var(--chalk) !important; }

.dc-spotify-bar {
  background-image: repeating-linear-gradient(45deg, var(--chalk) 0 2px, transparent 2px 4px) !important;
  background-color: var(--chalk) !important;
}

.dc-spotify-track { background: var(--chalk-12) !important; }

.eq-bar { background: var(--chalk) !important; }

.dc-spotify-art,
.dc-activity-img {
  filter: grayscale(100%) contrast(1.1) brightness(0.95);
  border: 1px solid var(--chalk);
  border-radius: 2px !important;
}

.dc-spotify-title { color: var(--chalk) !important; }
.dc-spotify-artist { color: var(--chalk-64) !important; }
.dc-spotify-time { color: var(--chalk-42) !important; font-family: var(--font-mono); }

.dc-spotify-title-link:hover .dc-spotify-title {
  color: var(--chalk) !important;
  text-decoration-color: var(--chalk) !important;
}

.dc-activity-name { color: var(--chalk) !important; }
.dc-activity-detail, .dc-activity-state { color: var(--chalk-64) !important; }
.dc-activity-elapsed { color: var(--chalk-42) !important; font-family: var(--font-mono); }

.dc-idle-text {
  color: var(--chalk-64) !important;
  font-family: var(--font-pen) !important;
  font-size: 1.6rem !important;
  font-style: normal !important;
}

/* Contact hub */
.contact-hub-card {
  background: var(--void-warm) !important;
  border: 1.5px dashed var(--chalk) !important;
  border-radius: 2px;
  padding: 1.3rem !important;
  box-shadow: 3px 3px 0 var(--chalk-22) !important;
}

.contact-hub-card:hover {
  border-style: solid !important;
  box-shadow: 4px 4px 0 var(--chalk) !important;
}

.contact-hub-label {
  color: var(--chalk-64) !important;
  font-family: var(--font-stamp);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.contact-link {
  color: var(--chalk) !important;
  border-left: 2px solid transparent !important;
  font-family: var(--font-mono);
}

.contact-link:hover {
  color: var(--chalk) !important;
  border-left-color: var(--chalk) !important;
  background: var(--chalk-08) !important;
  transform: translateX(4px);
}

.social-link {
  border: 1.5px solid var(--chalk) !important;
  color: var(--chalk) !important;
  background: var(--void-warm) !important;
  border-radius: 2px !important;
  box-shadow: 2px 2px 0 var(--chalk) !important;
}

.social-link::before { display: none !important; }

.social-link:hover {
  border-color: var(--chalk) !important;
  color: var(--void) !important;
  background: var(--chalk) !important;
  transform: translate(-1px, -1px) !important;
  box-shadow: 3px 3px 0 var(--chalk) !important;
}

.github-link:hover,
.linkedin-link:hover,
.twitter-link:hover,
.instagram-link:hover,
.orcid-link:hover {
  color: var(--void) !important;
  border-color: var(--chalk) !important;
  background: var(--chalk) !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   15. INSTAGRAM REQUEST MODAL — dark sheet
   ───────────────────────────────────────────────────────────────────────── */
#ig-modal-overlay {
  background: rgba(0, 0, 0, 0.78) !important;
  backdrop-filter: none !important;
}

#ig-modal-overlay > div {
  background: var(--void-warm) !important;
  border: 1.5px solid var(--chalk) !important;
  border-radius: 2px !important;
  box-shadow: 6px 6px 0 var(--chalk) !important;
  color: var(--chalk) !important;
}

#ig-modal-overlay h3 { color: var(--chalk); font-family: var(--font-pen); font-size: 2rem !important; }
#ig-modal-overlay p  { color: var(--chalk-64); }
#ig-modal-close      { color: var(--chalk) !important; }

/* ─────────────────────────────────────────────────────────────────────────
   16. CROSSHAIR / CURSOR DOT
   ───────────────────────────────────────────────────────────────────────── */
.ch-line, .ch-dot { background: var(--chalk) !important; }
.crosshair.ch-hover .ch-line,
.crosshair.ch-hover .ch-dot { background: var(--chalk) !important; opacity: 0.7; }

/* ─────────────────────────────────────────────────────────────────────────
   17. LOADERS / DOTS / MISC
   ───────────────────────────────────────────────────────────────────────── */
.loader {
  border-color: var(--chalk-12) !important;
  border-top-color: var(--chalk) !important;
}

.typing-cursor,
.cursor-blink { background-color: var(--chalk) !important; }

.skip-link {
  background: var(--chalk) !important;
  color: var(--void) !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   18. MOTION DIET — one ease, short, predictable
   ───────────────────────────────────────────────────────────────────────── */
a, button, .btn, .pc-btn, .nav-links a, .logo-text,
.section-line, .skill-tag, .project-card, .pc-card,
.social-link, .input-border, .contact-link, .dc-panel, .dc-card,
.connection-item, .hud-nav-link {
  transition: background-color 160ms ease, color 160ms ease,
              border-color 160ms ease, transform 160ms ease,
              box-shadow 160ms ease, opacity 160ms ease !important;
}

.skill-category h3,
.skill-category:nth-child(even) h3,
.project-card:nth-child(3n),
.philosophy-block,
.philosophy-title,
.philosophy-visual {
  transform: none !important;
}

.skill-tag:hover,
.project-link:hover,
.social-link:nth-child(odd):hover,
.social-link:nth-child(even):hover {
  transform: translateY(-2px) !important;
}

.philosophy-line {
  clip-path: none !important;
  height: 12px !important;
  width: 8rem !important;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='12' fill='none' stroke='%23f4f1e8' stroke-width='1.4' stroke-linecap='round'><path d='M2 8 Q 14 2, 28 6 T 56 5 T 78 9'/></svg>") no-repeat left center/100% 12px !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   19. LINKS — handwritten underline on hover
   ───────────────────────────────────────────────────────────────────────── */
a { color: var(--chalk); }

.dc-spotify-title-link,
.contact-link,
.cine-link,
.pc-btn,
.btn,
.hud-nav-link,
.skip-link { text-decoration: none !important; }

/* ─────────────────────────────────────────────────────────────────────────
   20. PALETTE / SOUND TOGGLE
   ───────────────────────────────────────────────────────────────────────── */
.palette-toggle,
.sound-toggle {
  background: var(--void-warm) !important;
  border: 1.5px solid var(--chalk) !important;
  color: var(--chalk) !important;
  box-shadow: 2px 2px 0 var(--chalk) !important;
  border-radius: 50% !important;
}

.palette-toggle:hover,
.sound-toggle:hover {
  background: var(--chalk) !important;
  color: var(--void) !important;
  transform: translate(-1px, -1px) !important;
  box-shadow: 3px 3px 0 var(--chalk) !important;
}

.palette-panel {
  background: var(--void-warm) !important;
  border: 1.5px solid var(--chalk) !important;
  box-shadow: 4px 4px 0 var(--chalk) !important;
  border-radius: 2px !important;
  color: var(--chalk) !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   21. SELECTION + SCROLLBAR
   ───────────────────────────────────────────────────────────────────────── */
::selection { background: var(--chalk); color: var(--void); }

/* Subtle chalk scrollbar on the void */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--void); }
::-webkit-scrollbar-thumb {
  background: var(--chalk-22);
  border: 2px solid var(--void);
  border-radius: 0;
}
::-webkit-scrollbar-thumb:hover { background: var(--chalk-42); }

/* ─────────────────────────────────────────────────────────────────────────
   22. REDUCED MOTION
   ───────────────────────────────────────────────────────────────────────── */
@media not all and (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* ─────────────────────────────────────────────────────────────────────────
   23. FOOTER / FONTAWESOME FALLBACK
   ───────────────────────────────────────────────────────────────────────── */
.fas, .fab, .far, .fa { color: inherit; }
.fab.fa-spotify, .fab.fa-discord, .fab.fa-github, .fab.fa-instagram,
.fab.fa-orcid, .fab.fa-python {
  color: var(--chalk) !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   24. AI TERMINAL BUTTON (the blue bubble in screenshot) — chalk coin
   ───────────────────────────────────────────────────────────────────────── */
.ai-terminal-toggle,
button.ai-terminal-toggle,
.ai-btn,
button[class*="ai-term"],
button[aria-label*="AI" i] {
  background: var(--chalk) !important;
  color: var(--void) !important;
  border: 1.5px solid var(--chalk) !important;
  box-shadow: 3px 3px 0 var(--void), 3px 3px 0 1.5px var(--chalk) !important;
}

/* ─────────────────────────────────────────────────────────────────────────
   25. META TAG FOR BROWSER CHROME — handled here because themes may override
   ───────────────────────────────────────────────────────────────────────── */
/* nothing — handled via <meta name="theme-color"> in HTML */
