/* DWeb Camp 2026 Mesh — CRT / terminal theme. Hand-written, no external assets.
   Fonts are bundled locally; @font-face src paths are RELATIVE to this file, so
   the stylesheet stays portable if base_url ever changes (SPEC.md D2/D4). */

@font-face {
  font-family: "Press Start 2P";
  src: url("../fonts/PressStart2P.woff2") format("woff2");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Departure Mono";
  src: url("../fonts/DepartureMono.woff2") format("woff2");
  font-weight: 400; font-style: normal; font-display: swap;
}

:root {
  --bg:     #07090a;
  --panel:  #0d1310;
  --fg:     #41ff8a;          /* phosphor green */
  --fg-dim: #1f7a44;
  --amber:  #ffb24a;          /* accent */
  --cyan:   #6fe6ff;
  --line:   #18402a;
  --glow:   0 0 4px rgba(65,255,138,0.45);
  --maxw:   72ch;
}

*, *::before, *::after { box-sizing: border-box; }

html { background: var(--bg); }
body {
  margin: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bg);
  color: var(--fg);
  font-family: "Departure Mono", ui-monospace, "DejaVu Sans Mono", monospace;
  font-size: 16px;
  line-height: 1.6;
  text-shadow: var(--glow);
}

/* CRT scanline overlay + screen vignette */
body::before {
  content: ""; position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  background: repeating-linear-gradient(
    to bottom, rgba(0,0,0,0) 0, rgba(0,0,0,0) 2px, rgba(0,0,0,0.18) 3px);
}
body::after {
  content: ""; position: fixed; inset: 0; z-index: 9998; pointer-events: none;
  background: radial-gradient(ellipse at center, rgba(0,0,0,0) 55%, rgba(0,0,0,0.45) 100%);
}

/* typography */
h1, h2, h3 {
  font-family: "Press Start 2P", "Departure Mono", monospace;
  font-weight: 400; line-height: 1.4; color: var(--amber);
  text-shadow: 0 0 6px rgba(255,178,74,0.5);
}
h1 { font-size: 1.35rem; margin: 1.4rem 0 1rem; }
h2 { font-size: 1.0rem;  margin: 2rem 0 0.8rem; color: var(--fg); text-shadow: var(--glow); }
h3 { font-size: 0.8rem;  margin: 1.4rem 0 0.6rem; color: var(--cyan);
     text-shadow: 0 0 5px rgba(111,230,255,0.4); }

p, li { max-width: var(--maxw); }
a { color: var(--fg); text-decoration: underline; text-underline-offset: 2px; }
a:hover, a:focus { background: var(--fg); color: var(--bg); text-shadow: none; outline: none; }

code, pre, kbd { font-family: "Departure Mono", ui-monospace, monospace; }
code { color: var(--amber); }
pre {
  background: var(--panel); border: 1px solid var(--line);
  padding: 0.8rem 1rem; overflow-x: auto; max-width: var(--maxw);
}
pre code { color: var(--fg); }
hr { border: none; border-top: 1px dashed var(--line); margin: 2rem 0; }

/* skip link */
.skip-link { position: absolute; left: -9999px; top: 0;
  background: var(--amber); color: var(--bg); padding: 0.4rem 0.8rem; z-index: 10000; }
.skip-link:focus { left: 0; }

/* header / nav */
.site-header {
  position: sticky; top: 0; z-index: 50; background: var(--bg);
  border-bottom: 1px solid var(--line); padding: 0.7rem 1rem;
  display: flex; flex-wrap: wrap; gap: 0.6rem 1rem; align-items: center;
}
.brand { font-family: "Press Start 2P", monospace; font-size: 0.72rem;
  color: var(--amber); text-decoration: none; text-shadow: 0 0 6px rgba(255,178,74,0.5); }
.brand:hover { background: none; color: var(--fg); }
.site-nav { display: flex; flex-wrap: wrap; gap: 0.35rem 0.8rem; }
.site-nav a { font-family: "Press Start 2P", monospace; font-size: 0.55rem;
  text-decoration: none; color: var(--fg-dim); letter-spacing: 0.05em; text-shadow: none; }
.site-nav a:hover, .site-nav a:focus { color: var(--bg); background: var(--fg); }

/* main */
.site-main { flex: 1 0 auto; width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 1.6rem 1.1rem 3rem; }

/* buttons */
.btn { display: inline-block; font-family: "Press Start 2P", monospace; font-size: 0.8rem;
  color: var(--bg); background: var(--amber); border: 2px solid var(--amber);
  padding: 0.9rem 1.2rem; text-decoration: none; text-shadow: none; }
.btn:hover, .btn:focus { background: var(--bg); color: var(--amber); }

/* splash */
.splash { text-align: center; padding: 3rem 0 1rem; }
.splash-title { font-family: "Press Start 2P", monospace;
  font-size: clamp(1.8rem, 9vw, 3.4rem); color: var(--fg); margin: 0 0 1.4rem;
  line-height: 1.2; text-shadow: 0 0 10px rgba(65,255,138,0.6); }
.splash-sub { display: inline-block; color: var(--fg-dim); letter-spacing: 0.12em; margin: 0 auto 2rem; }
.splash-cta { margin-top: 1.5rem; }

/* splash HUD / live counters (game-interface framing) */
.hud { display: flex; justify-content: center; gap: 1.2rem; flex-wrap: wrap; margin: 0 auto 0.8rem; }
.hud-item { border: 1px solid var(--line); background: var(--panel); padding: 0.7rem 1.1rem; min-width: 8.5rem; }
.hud-label { display: block; font-size: 0.8rem; color: var(--fg-dim); letter-spacing: 0.1em; }
.hud-value { display: block; font-family: "Press Start 2P", monospace; font-size: 1.4rem;
  color: var(--amber); margin-top: 0.55rem; text-shadow: 0 0 8px rgba(255,178,74,0.5); }
.hud-sync { color: var(--fg-dim); font-size: 0.82rem; margin: 0.2rem 0 2rem; }
.hud-sync #stat-updated { color: var(--fg); }

/* footer */
.site-footer { border-top: 1px solid var(--line); padding: 1.1rem 1.1rem 2rem;
  margin-top: 2rem; color: var(--fg-dim); font-size: 0.92rem; }
.site-footer a { color: var(--amber); }
.footer-primary, .footer-matrix, .footer-dash { max-width: none; margin: 0.2rem 0; }
.cursor { color: var(--fg); animation: blink 1.1s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }

/* doc components: callouts, settings card, device grid */
.doc blockquote { border-left: 3px solid var(--amber); background: var(--panel);
  margin: 1.3rem 0; padding: 0.7rem 1rem; color: var(--fg); }
.doc blockquote p { max-width: none; margin: 0.3rem 0; }
.doc blockquote a { color: var(--amber); }
.muted { color: var(--fg-dim); font-size: 0.82rem; }

.refcard { border: 2px solid var(--line); background: var(--panel); max-width: 30rem; margin: 1.3rem 0; }
.refcard-row { display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  padding: 0.65rem 0.95rem; border-bottom: 1px dashed var(--line); }
.refcard-row:last-child { border-bottom: none; }
.refcard-k { color: var(--fg-dim); letter-spacing: 0.08em; }
.tbc { color: var(--amber); border: 1px dashed var(--amber); padding: 0.05rem 0.5rem;
  letter-spacing: 0.12em; font-size: 0.85rem; }

.devices { display: grid; grid-template-columns: 1fr; gap: 1rem; margin: 1.3rem 0; max-width: none; }
@media (min-width: 760px) { .devices { grid-template-columns: repeat(3, 1fr); } }
.device { border: 1px solid var(--line); background: var(--panel); padding: 1rem;
  display: flex; flex-direction: column; }
.device h3 { margin: 0 0 0.6rem; }
.device p { max-width: none; }
.device .pick { color: var(--amber); margin: 0 0 0.6rem; }
.device .specs { color: var(--fg-dim); font-size: 0.8rem; margin: 0.4rem 0 0; }
.device .buy { margin: 0.8rem 0 0; }

/* tables (agenda, any doc table) */
.doc table { border-collapse: collapse; width: 100%; margin: 1.3rem 0; }
.doc th, .doc td { border: 1px solid var(--line); padding: 0.55rem 0.8rem;
  text-align: left; vertical-align: top; }
.doc th { background: var(--panel); color: var(--fg-dim); letter-spacing: 0.08em; font-weight: normal; }
.doc td { max-width: none; }

/* responsive / motion */
@media (max-width: 640px) {
  body { font-size: 15px; }
  .site-nav a { font-size: 0.5rem; }
}
@media (prefers-reduced-motion: reduce) { .cursor { animation: none; } }
