/* The Arcade — shared look & components (v3, unified with the site's design language).
   The Wasteland's "dead-channel" dark: charcoal ground, phosphor-amber system accent, a cold
   cyan, editorial Fraunces + Martian Mono labels — adapted for game-feel (tactile controls with a
   real press, per-game accent hues that glow on the dark). Self-hosted fonts only (no CDN).
   Class names AND custom-property names are a stable API: games + hub depend on them. */

/* The site voice, self-hosted (mirrors src/styles + public/fonts). Fraunces for the things a mind
   wrote; Martian Mono for the instrument labels. */
@font-face{font-family:'Fraunces';src:url('/fonts/fraunces-normal-latin.woff2') format('woff2');font-weight:100 900;font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Fraunces';src:url('/fonts/fraunces-italic-latin.woff2') format('woff2');font-weight:100 900;font-style:italic;font-display:swap}
@font-face{font-family:'Martian Mono';src:url('/fonts/martian-mono-normal-latin.woff2') format('woff2');font-weight:300 700;font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

:root{
  /* canvas — the site's dead-channel dark (mirrors src/styles/global.css) */
  --void:#06070a; --bg:#0a0c11; --bg-2:#06070a; --surface:#11141c; --surface-2:#161a24;
  --ink:#e7eaf2; --ink-soft:#98a1b4; --muted:#7c8698; --line:#20252f; --line-strong:#2e3645;
  /* per-game accent hues, tuned to glow on the dark ground (kept so each game keeps its identity) */
  --violet:#8b7bff; --coral:#ff6b70; --mint:#3fd8b8; --gold:#ffc94a; --sky:#58d6e0; --grape:#b07bff; --rose:#ff6ba0;
  --phosphor:#ffc94a; --cyan:#58d6e0;
  --accent:var(--phosphor); --accent-ink:#06070a;   /* default = amber phosphor; text on a filled accent is the dark ground */
  --good:#3fd8b8; --bad:#ff6b70;
  /* form */
  --r:14px; --r-sm:9px; --r-lg:16px; --pad:clamp(16px,4vw,30px);
  --shadow-1:0 1px 2px rgba(0,0,0,.5), 0 14px 34px -20px rgba(0,0,0,.85);
  --shadow-2:0 2px 6px rgba(0,0,0,.55), 0 40px 90px -34px rgba(0,0,0,.9);
  --press:0 4px 0 0 rgba(0,0,0,.55);
  --glow:0 0 12px;
  --font-display:'Fraunces','Iowan Old Style',Palatino,Georgia,Cambria,serif;
  --font-ui:'Fraunces','Iowan Old Style',Palatino,Georgia,serif;          /* body/prose — the site reads in serif */
  --font-mono:'Martian Mono',ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;  /* labels, controls, receipts */
  --ease:cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; min-height:100svh; color:var(--ink); font-family:var(--font-ui); font-size:17px; line-height:1.55;
  background:
    radial-gradient(60% 44% at 84% -6%, color-mix(in srgb,var(--accent) 13%, transparent), transparent 70%),
    radial-gradient(48% 40% at -6% 4%, color-mix(in srgb,var(--cyan) 8%, transparent), transparent 72%),
    var(--bg);
  background-attachment:fixed; -webkit-font-smoothing:antialiased; position:relative;
}
/* atmosphere — the site's scanlines + vignette, CSS-only (no request, no JS) */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;mix-blend-mode:overlay;opacity:.5;
  background:repeating-linear-gradient(to bottom,rgba(255,255,255,.014) 0,rgba(255,255,255,.014) 1px,transparent 2px,transparent 3px)}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 10%,transparent 55%,rgba(0,0,0,.5) 100%)}
body>*{position:relative;z-index:1}
h1,h2,h3{line-height:1.04;margin:0;font-family:var(--font-display);font-weight:600;letter-spacing:-.01em}
a{color:inherit}
::selection{background:rgba(255,201,74,.22);color:#fff}

/* layout shell */
.aw-wrap{max-width:760px;margin:0 auto;padding:0 var(--pad) 64px}
.aw-stage{max-width:940px}

/* top bar — back to the arcade + game title (mono, like the site chrome) */
.aw-bar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px;margin:0 auto;max-width:760px;padding:11px var(--pad);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:color-mix(in srgb,var(--bg) 80%, transparent);border-bottom:1px solid var(--line)}
.aw-back{display:inline-flex;align-items:center;gap:7px;text-decoration:none;font-family:var(--font-mono);font-weight:500;font-size:12px;letter-spacing:.06em;color:var(--ink-soft);
  padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:color-mix(in srgb,var(--surface) 70%,transparent);transition:color .15s var(--ease),border-color .15s var(--ease)}
.aw-back:hover{color:var(--ink);border-color:var(--line-strong)}
.aw-bar .aw-title{font-family:var(--font-display);font-weight:600;font-size:22px;letter-spacing:-.01em;color:var(--accent);margin-left:2px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:52vw}
.aw-bar .aw-spacer{flex:1}

/* hero / titles */
.aw-kicker{font-family:var(--font-mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500}
.aw-h1{font-family:var(--font-display);font-weight:600;font-size:clamp(42px,11vw,80px);letter-spacing:-.02em;line-height:.98}
.aw-dek{color:var(--ink-soft);font-size:clamp(16px,2.6vw,19px);max-width:48ch;line-height:1.5}

/* cards */
.aw-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-1);padding:var(--pad)}
.aw-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px}

/* buttons — tactile, mono labels, a real press; primary glows like the phosphor */
.aw-btn{appearance:none;cursor:pointer;font-family:var(--font-mono);font-weight:500;font-size:14px;letter-spacing:.03em;
  color:var(--ink);background:var(--surface-2);border:1px solid var(--line-strong);padding:12px 19px;border-radius:12px;box-shadow:var(--press);
  transition:transform .08s var(--ease), box-shadow .08s var(--ease), background .15s var(--ease), border-color .15s var(--ease), color .15s var(--ease);
  user-select:none;-webkit-tap-highlight-color:transparent}
.aw-btn:hover{border-color:var(--accent);color:#fff}
.aw-btn:active{transform:translateY(4px);box-shadow:0 0 0 0 rgba(0,0,0,.55)}
.aw-btn--primary{background:var(--accent);color:var(--accent-ink);border-color:transparent;font-weight:600;
  box-shadow:0 4px 0 0 color-mix(in srgb,var(--accent) 55%, #000), var(--glow) color-mix(in srgb,var(--accent) 35%, transparent)}
.aw-btn--primary:hover{filter:brightness(1.06);color:var(--accent-ink)}
.aw-btn--primary:active{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 55%, #000)}
.aw-btn--ghost{background:transparent;box-shadow:none;border-color:var(--line)}
.aw-btn--ghost:active{transform:translateY(2px);box-shadow:none}
.aw-btn--lg{font-size:16px;padding:15px 28px;border-radius:14px}
.aw-btn[disabled]{opacity:.4;cursor:not-allowed;transform:none}
.aw-row{display:flex;gap:10px;flex-wrap:wrap}

/* chips / pills */
.aw-chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;padding:5px 11px;border-radius:999px;
  background:color-mix(in srgb,var(--accent) 14%,transparent);color:color-mix(in srgb,var(--accent) 75%, var(--ink));
  border:1px solid color-mix(in srgb,var(--accent) 28%,transparent)}

/* the "show the working" panel — receipts, in mono */
.aw-check{margin-top:18px;border:1px solid color-mix(in srgb,var(--accent) 26%,var(--line));border-radius:var(--r-sm);overflow:hidden;
  background:color-mix(in srgb,var(--accent) 6%,var(--surface))}
.aw-check>summary{cursor:pointer;list-style:none;padding:13px 16px;font-family:var(--font-mono);font-weight:500;font-size:13px;letter-spacing:.04em;color:var(--ink);display:flex;align-items:center;gap:9px}
.aw-check>summary::-webkit-details-marker{display:none}
.aw-check>summary::before{content:"✓";display:grid;place-items:center;width:21px;height:21px;border-radius:6px;background:var(--accent);color:var(--accent-ink);font-size:12px;flex:none}
.aw-check[open]>summary{border-bottom:1px solid var(--line)}
.aw-check .aw-check-body{padding:14px 16px;font-family:var(--font-mono);font-size:12.5px;line-height:1.7;color:var(--ink-soft)}
.aw-check .aw-check-body table{border-collapse:collapse;font-size:12px}
.aw-check .aw-check-body td,.aw-check .aw-check-body th{padding:3px 10px 3px 0;text-align:left}
.aw-check .aw-check-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* share / result card */
.aw-share{margin-top:18px;text-align:center}
.aw-grid{font-family:var(--font-mono);font-size:22px;line-height:1.2;letter-spacing:.06em;white-space:pre;margin:6px 0 14px}
.aw-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);opacity:0;background:var(--ink);color:var(--void);
  padding:11px 18px;border-radius:999px;font-family:var(--font-mono);font-weight:500;font-size:13px;transition:transform .22s var(--ease),opacity .22s var(--ease);z-index:60;pointer-events:none}
.aw-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* small print + footer link home */
.aw-fine{color:var(--muted);font-size:13px}
.aw-home{display:block;text-align:center;margin-top:40px;color:var(--muted);font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;text-decoration:none}
.aw-home:hover{color:var(--ink)}
.aw-home b{color:var(--accent)}

/* ---------- the games navigator (a right-side rail on wide screens; a menu on the bar otherwise) ---------- */
.aw-nav{position:fixed;top:0;right:0;height:100vh;width:14.5rem;z-index:25;display:none;flex-direction:column;
  padding:5rem 0.9rem 1.2rem;gap:2px;overflow-y:auto;
  background:linear-gradient(to left, color-mix(in srgb,var(--void) 62%, transparent), transparent);
  border-left:1px solid var(--line)}
.aw-nav__label{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);padding:0 .6rem .5rem}
.aw-nav a{display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;border-radius:8px;text-decoration:none;
  color:var(--ink-soft);border:1px solid transparent;transition:background .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease)}
.aw-nav a:hover{background:color-mix(in srgb,var(--surface) 70%,transparent);color:var(--ink);border-color:var(--line)}
.aw-nav a .ic{width:1.05rem;height:1.05rem;flex:none;color:var(--ga,var(--muted))}
.aw-nav a .nm{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aw-nav a.is-current{background:color-mix(in srgb,var(--ga,var(--accent)) 14%, var(--surface));border-color:color-mix(in srgb,var(--ga,var(--accent)) 45%, transparent);color:var(--ink)}
.aw-nav a.is-current .ic{color:var(--ga,var(--accent))}
.aw-nav a.is-current .nm{color:var(--ink)}
/* the toggle sits in the top bar; hidden on wide screens where the rail is always open */
.aw-navbtn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;
  color:var(--ink-soft);background:color-mix(in srgb,var(--surface) 70%,transparent);border:1px solid var(--line);border-radius:999px;padding:8px 13px}
.aw-navbtn:hover{color:var(--ink);border-color:var(--line-strong)}
.aw-navbtn svg{width:14px;height:14px}
@media (max-width:30rem){.aw-navbtn{padding:8px 10px}.aw-navbtn__t{display:none}}
@media (min-width:1180px){
  .aw-nav{display:flex}
  .aw-navbtn{display:none}
  .aw-bar,.aw-wrap,.hero,.wrap,.top{padding-right:calc(var(--pad) + 14.5rem)}
}
/* narrow: the rail becomes a drop panel toggled from the bar */
@media (max-width:1179px){
  .aw-nav{position:fixed;top:.6rem;right:.6rem;left:auto;height:auto;max-height:80vh;width:min(15rem,84vw);padding:.6rem;border:1px solid var(--line);border-radius:12px;
    background:color-mix(in srgb,var(--surface) 96%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-2)}
  .aw-nav[hidden]{display:none}
  .aw-nav:not([hidden]){display:flex}
  .aw-nav__label{padding-top:.2rem}
}

/* accessibility — site law */
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion: reduce){*{animation:none !important;transition:none !important;scroll-behavior:auto !important}}
