/* ============================================================
   BASE
   ============================================================ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html,body { height:100%; overflow:hidden; }
body { background:#000; color:var(--ink); font-family:var(--font-crt);
  user-select:none; -webkit-tap-highlight-color:transparent;
  display:flex; align-items:center; justify-content:center; }
button { font-family:inherit; cursor:pointer; border:0; background:none; }
button:focus { outline:none; }

.device { width:100vw; height:100vh; height:100dvh; position:relative; }
.gb-shell { display:none; }

body.auto .gb-shell { display:flex; }
body.auto { background:#15101a; }

@media (min-width:720px) {
  .device { display:flex; align-items:center; justify-content:center; }
  body.auto { background:#100c1a; }
  body.auto .gb-shell {
    --gb-shell-height: min(96dvh, 1180px);
    height: var(--gb-shell-height);
    width: min(92vw, calc(var(--gb-shell-height) * 0.62));
  }
  .gb-dpad-wrap { width:clamp(96px,11dvh,132px); height:clamp(96px,11dvh,132px); }
  .gb-btn-ab { width:clamp(48px,5.8dvh,72px); height:clamp(48px,5.8dvh,72px); }
  .gb-btn-pill { width:clamp(38px,4.5dvh,54px); height:clamp(11px,1.3dvh,16px); }
  .gb-deck { gap:clamp(14px,2dvh,24px); }
  .gb-bezel { padding:clamp(10px,2dvh,20px) clamp(8px,1.5dvh,16px) clamp(16px,3dvh,32px); }
}

.screen-inner { width:100%; height:100%; background:var(--bg-screen); position:relative; overflow:hidden; }
.screen-inner::before { content:""; position:absolute; inset:0;
  background:repeating-linear-gradient(to bottom,transparent 0px,transparent 2px,rgba(255,255,255,.025) 2px,rgba(255,255,255,.025) 3px);
  pointer-events:none; z-index:50; }
.screen-inner::after { content:""; position:absolute; inset:0;
  background:radial-gradient(ellipse at center,transparent 0%,transparent 55%,rgba(0,0,0,.55) 100%);
  pointer-events:none; z-index:49; }

/* ============================================================
   GAME BOY SHELL
   ============================================================ */
.gb-shell { width:100%; height:100%; flex-direction:column; align-items:center;
  background:radial-gradient(ellipse at center,var(--gb-shell-hi) 0%,var(--gb-shell) 50%,var(--gb-shell-dark) 100%);
  padding:14px 16px 16px; position:relative; }
.gb-shell::before { content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.15),transparent 30%),radial-gradient(circle at 80% 90%,rgba(0,0,0,.08),transparent 40%);
  pointer-events:none; }
.gb-top { width:100%; display:flex; justify-content:space-between; align-items:center;
  padding:4px 6px 8px; font-family:var(--font-pixel); font-size:.45rem;
  color:var(--gb-shell-dark); letter-spacing:.1em; text-transform:uppercase; z-index:1; }
.gb-top .left { color:#555; }
.gb-top .right { color:var(--gb-btn-purple); font-weight:bold; }
.gb-bezel { width:100%; flex:0 0 auto; aspect-ratio:1/1; background:var(--gb-screen-bezel);
  border-radius:12px 12px 36px 12px; padding:16px 14px 28px; position:relative;
  box-shadow:inset 0 3px 6px rgba(0,0,0,.6),inset 0 -1px 0 rgba(255,255,255,.05); z-index:1; }
.gb-led-row { position:absolute; top:24px; left:22px; display:flex; align-items:center; gap:6px;
  font-family:var(--font-pixel); font-size:.35rem; color:#888; letter-spacing:.08em; }
.gb-led { width:6px; height:6px; background:var(--gb-led-red); border-radius:50%; box-shadow:0 0 6px var(--gb-led-red); }
.gb-brand { position:absolute; top:22px; right:22px; font-family:var(--font-pixel); font-size:.4rem;
  color:#999; letter-spacing:.15em; font-style:italic; }
.gb-brand span { color:var(--gb-btn-purple); font-style:normal; }
.gb-screen { width:100%; height:100%; margin-top:18px; position:relative;
  background:#000; border:1px solid #1a1620; overflow:hidden; }
.gb-undertext { position:absolute; bottom:6px; left:0; right:0; text-align:center;
  font-family:var(--font-pixel); font-size:.35rem; color:#777; letter-spacing:.15em; }
.gb-deck { width:100%; display:grid; grid-template-columns:1fr 1fr; align-items:center;
  align-content:center; flex:1 1 auto;
  padding:14px 4px 0; gap:14px; z-index:1; }
.gb-dpad-wrap { width:96px; height:96px; position:relative; justify-self:start; margin-left:8px; }
.gb-dpad-cross { position:absolute; background:var(--gb-dpad);
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.4),inset 0 2px 0 rgba(255,255,255,.05),0 2px 4px rgba(0,0,0,.3); }
.gb-dpad-cross.h { top:36px; left:6px; width:84px; height:24px; border-radius:4px; }
.gb-dpad-cross.v { top:6px; left:36px; width:24px; height:84px; border-radius:4px; }
.gb-dpad-btn { position:absolute; width:32px; height:32px; background:transparent;
  color:rgba(255,255,255,.15); font-size:11px; z-index:2; transition:color 80ms; }
.gb-dpad-btn:active { color:rgba(255,255,255,.5); }
.gb-dpad-btn.up { top:0; left:32px; } .gb-dpad-btn.down { bottom:0; left:32px; }
.gb-dpad-btn.left { top:32px; left:0; } .gb-dpad-btn.right { top:32px; right:0; }
.gb-ab { display:flex; align-items:center; gap:12px; justify-self:end; transform:rotate(-22deg); margin-right:14px; }
.gb-btn-ab { width:48px; height:48px; border-radius:50%; background:var(--gb-btn-red);
  font-family:var(--font-pixel); font-size:.85rem; color:white;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.4),inset 0 2px 0 rgba(255,255,255,.15),0 3px 5px rgba(0,0,0,.3);
  transition:transform 80ms; }
.gb-btn-ab:active { transform:translateY(2px); }
.gb-btn-label { font-family:var(--font-pixel); font-size:.4rem; color:var(--gb-shell-dark);
  text-align:center; margin-top:4px; letter-spacing:.1em; transform:rotate(0deg); }
.gb-ab-col { display:flex; flex-direction:column; align-items:center; transform:rotate(22deg); }
.gb-startsel { grid-column:1/-1; display:flex; justify-content:center; gap:24px; margin-top:6px; transform:rotate(-22deg); }
.gb-startsel-col { display:flex; flex-direction:column; align-items:center; transform:rotate(22deg); }
.gb-btn-pill { width:38px; height:11px; border-radius:6px; background:var(--gb-dpad);
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.05),0 2px 3px rgba(0,0,0,.25); }
.gb-btn-pill:active { transform:translateY(1px); }
.gb-speaker { position:absolute; bottom:18px; right:18px;
  display:grid; grid-template-columns:repeat(6,4px); gap:6px; transform:rotate(-22deg); pointer-events:none; }
.gb-speaker span { display:block; width:4px; height:22px; background:var(--gb-shell-dark); border-radius:2px;
  box-shadow:inset 0 1px 1px rgba(0,0,0,.4); }

/* ============================================================
   VIEWS (shared — rendered inside the screen mount point)
   ============================================================ */
.view { position:absolute; inset:0; display:flex; flex-direction:column; opacity:0;
  pointer-events:none; transition:opacity 200ms ease-out; }
.view.active { opacity:1; pointer-events:auto; }
#view-boot { align-items:center; justify-content:center; padding:16px; text-align:center; }
.boot-logo { font-family:var(--font-metalslug); font-size:clamp(1.6rem,5.5vw,3.4rem); line-height:1.1;
  color:#E8352A; paint-order:stroke fill;
  -webkit-text-stroke:4px #000;
  text-shadow:
    2px 2px 0 #000,
    3px 3px 0 #000,
    4px 4px 0 rgba(0,0,0,.7),
    0 0 28px rgba(232,53,42,.45);
  transform:skew(-4deg); margin-bottom:22px; letter-spacing:.03em; }
.boot-msgs { font-family:var(--font-crt); font-size:clamp(.9rem,2.3vw,1.25rem); color:var(--neon-green);
  text-align:left; max-width:460px; width:100%; margin-bottom:22px; letter-spacing:.05em; }
.boot-msg { opacity:0; transition:opacity 100ms; }
.boot-msg.shown { opacity:1; }
.boot-msg .ok { color:var(--ms-yellow); }
.loading-bar { width:min(380px,80%); height:16px; border:2px solid var(--ink-dim); background:var(--bg-darker); margin-bottom:22px; }
.loading-fill { height:100%; background:repeating-linear-gradient(90deg,var(--ms-red-bright) 0px,var(--ms-red-bright) 8px,var(--ms-yellow) 8px,var(--ms-yellow) 16px); width:0%; transition:width 80ms linear; }
.press-start { font-family:var(--font-metalslug); font-size:clamp(1rem,2.8vw,1.5rem); color:#E8352A;
  paint-order:stroke fill; -webkit-text-stroke:2px #000;
  opacity:0; animation:blinkFast .9s steps(2,jump-none) infinite; letter-spacing:.06em; }
.press-start.shown { opacity:1; }
@keyframes blinkFast { 50% { opacity:.2; } }

#view-menu { padding:14px 16px; }
.menu-head { display:flex; align-items:center; justify-content:space-between; padding-bottom:8px;
  border-bottom:2px solid var(--ms-red-bright); margin-bottom:14px; gap:10px; flex-wrap:wrap; }
.menu-title { font-family:var(--font-pixel); font-size:clamp(.6rem,2vw,.95rem);
  color:var(--ms-yellow); text-shadow:2px 2px 0 var(--ms-red-deep); letter-spacing:.05em; }
.menu-hud { font-family:var(--font-crt); font-size:1rem; color:var(--ink-dim);
  letter-spacing:.1em; text-transform:uppercase; display:flex; gap:10px; flex-wrap:wrap; }
.menu-hud .val { color:var(--ms-yellow); }
.menu-hud .credit-blink { color:var(--ms-red-bright); animation:blinkFast 1.1s infinite; }
.menu-body { display:grid; grid-template-columns:1fr; gap:14px; height:calc(100% - 50px); min-height:0; }
@media (min-width:900px) { .menu-body { grid-template-columns:1.4fr 1fr; } }
.cart-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px;
  align-content:start; overflow-y:auto; padding:4px 4px 4px 0; }
@media (min-width:480px) { .cart-grid { grid-template-columns:repeat(3,1fr); } }
.cart { background:var(--bg-panel); border:2px solid var(--ink-faint); padding:8px 6px 10px;
  position:relative; text-align:center; transition:transform 120ms,border-color 120ms,box-shadow 120ms;
  cursor:pointer; min-height:150px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:6px; }
.cart-art { width:78px; height:92px; display:flex; align-items:center; justify-content:center; }
.cart-art svg { display:block; max-width:100%; max-height:100%; }
@media (min-width:720px) { .cart-art { width:92px; height:108px; } }
.cart-label { font-family:var(--font-pixel); font-size:.5rem; color:var(--ink-dim);
  line-height:1.4; letter-spacing:.04em; text-transform:uppercase; }
@media (min-width:480px) { .cart-label { font-size:.55rem; } }
.cart.selected { border-color:var(--ms-yellow); background:var(--bg-panel-hi);
  transform:scale(1.05); box-shadow:0 0 0 1px var(--ms-yellow),0 0 22px rgba(255,210,58,.4); }
.cart.selected .cart-label { color:var(--ms-yellow); }
.cart.selected::before,.cart.selected::after { content:""; position:absolute;
  width:11px; height:11px; border:3px solid var(--ms-yellow); }
.cart.selected::before { top:-3px; left:-3px; border-right:none; border-bottom:none; }
.cart.selected::after { bottom:-3px; right:-3px; border-left:none; border-top:none; }
.preview { background:var(--bg-darker); border:2px solid var(--ms-yellow); padding:14px 16px;
  display:flex; flex-direction:column; position:relative; min-height:180px; }
.preview::before { content:"// EQUIP"; position:absolute; top:-10px; left:12px;
  background:var(--bg-screen); padding:0 6px; font-family:var(--font-pixel);
  font-size:.5rem; color:var(--ms-yellow); letter-spacing:.1em; }
.preview-title { font-family:var(--font-pixel); font-size:.75rem; color:var(--ms-yellow);
  line-height:1.4; margin-bottom:10px; text-shadow:2px 2px 0 var(--ms-red-deep); letter-spacing:.04em; }
.preview-desc { font-family:var(--font-crt); font-size:1.05rem; color:var(--ink-dim); line-height:1.45; margin-bottom:10px; }
.preview-meta { margin-top:auto; display:flex; flex-direction:column; gap:3px;
  font-family:var(--font-crt); font-size:1rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); }
.preview-meta b { color:var(--ms-yellow); font-weight:normal; }
.preview-press { margin-top:12px; font-family:var(--font-pixel); font-size:.5rem;
  color:var(--neon-green); letter-spacing:.1em; text-align:center;
  padding:7px 10px; border:2px dashed var(--neon-green); animation:blinkFast 1.2s infinite; }
#view-detail { padding:14px 16px; }
.detail-head { display:flex; align-items:center; gap:12px; padding-bottom:10px;
  border-bottom:2px solid var(--ms-red-bright); margin-bottom:14px; }
.back-btn { background:var(--bg-panel); border:2px solid var(--ms-red-bright); color:var(--ms-red-bright);
  font-family:var(--font-pixel); font-size:.55rem; padding:6px 10px; letter-spacing:.08em; }
.back-btn:hover,.back-btn:active { background:var(--ms-red-bright); color:var(--ms-cream); }
.detail-title { font-family:var(--font-pixel); font-size:clamp(.7rem,2vw,1rem);
  color:var(--ms-yellow); letter-spacing:.05em; text-shadow:2px 2px 0 var(--ms-red-deep); }
.detail-body { height:calc(100% - 50px); overflow-y:auto; padding-right:4px;
  font-family:var(--font-mono); font-size:.88rem; color:var(--ink-dim); line-height:1.6; }
.detail-body h3 { font-family:var(--font-pixel); font-size:.7rem; color:var(--neon-cyan);
  margin:18px 0 10px; letter-spacing:.05em; }
.post-row, a.post-row {
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  background:var(--bg-panel); border:1px solid var(--ink-faint); margin-bottom:7px;
  font-family:var(--font-crt); font-size:1.05rem;
}
a.post-row {
  text-decoration:none; color:inherit; transition:border-color 100ms;
}
a.post-row:hover { border-color:var(--ms-yellow); }
.post-row .num { font-family:var(--font-pixel); font-size:.55rem; color:var(--ms-red-bright); }
.post-row .title { color:var(--ink); flex:1; }
.post-row .date { color:var(--ink-faint); font-size:.9rem; }
.detail-open-all {
  display:block; margin-top:14px; text-align:center;
  font-family:var(--font-pixel); font-size:.5rem; color:var(--neon-green);
  padding:7px 10px; border:2px dashed var(--neon-green); text-decoration:none;
  transition:background 100ms;
}
.detail-open-all:hover { background:var(--neon-green); color:#000; }
.flash { position:absolute; inset:0; background:var(--ms-cream); opacity:0; pointer-events:none; z-index:80; }
.flash.fire { animation:flash 220ms ease-out; }
@keyframes flash { 0% { opacity:.55; } 100% { opacity:0; } }
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--bg-darker); }
::-webkit-scrollbar-thumb { background:var(--ink-faint); }
::-webkit-scrollbar-thumb:hover { background:var(--ms-red-bright); }

/* ============================================================
   READABLE CONTENT PAGES (layout: default / post / section / archive)
   ============================================================ */
body.page {
  background:var(--gbc-page-bg);
  color:var(--ink);
  font-family:var(--font-mono);
  overflow:auto;
  display:flex;
  flex-direction:column;
  align-items:stretch; /* override base body's align-items:center, which sized .page-content to content width and overflowed mobile */
  min-height:100vh;
  user-select:auto;
}
.page-header {
  padding:14px 24px;
  border-bottom:2px solid var(--gbc-page-border);
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
  position:sticky; top:0; background:rgba(11,18,8,.96); z-index:10;
}
.back-home {
  font-family:var(--font-pixel); font-size:.55rem; color:var(--gbc-lcd);
  text-decoration:none; letter-spacing:.06em;
}
.back-home:hover { color:var(--gbc-lcd-bright); }
.page-content {
  width:100%; max-width:760px; margin:40px auto; padding:0 24px 60px;
  line-height:1.7; font-size:.875rem;
  flex:1;
}
.page-content h1 { font-family:var(--font-pixel); color:var(--gbc-lcd-bright); font-size:clamp(.8rem, 3.2vw, 1.15rem); margin:0 0 24px; line-height:1.7; letter-spacing:.01em; text-shadow:0 0 14px rgba(182,223,90,.3); overflow-wrap:break-word; }
.page-content h2 { font-family:var(--font-crt); color:var(--gbc-lcd-bright); font-size:1.65rem; margin:40px 0 12px; line-height:1.25; letter-spacing:.04em; }
.page-content h3 { font-family:var(--font-crt); color:var(--gbc-lcd); font-size:1.3rem; margin:28px 0 10px; line-height:1.3; letter-spacing:.03em; }
.page-content p { margin-bottom:16px; }
.page-content a { color:var(--gbc-lcd); }
.page-content a:hover { color:var(--gbc-lcd-bright); }
.page-content code {
  font-family:var(--font-mono); background:var(--gbc-page-panel); color:var(--ink);
  padding:2px 5px; font-size:.85rem; border-radius:3px;
}
.page-content pre {
  font-family:var(--font-mono); background:var(--gbc-page-panel); color:var(--ink);
  padding:16px; overflow-x:auto; margin:16px 0; border-left:3px solid var(--gbc-page-border);
  border-radius:0 3px 3px 0;
}
.page-content pre code { background:none; padding:0; }
.page-content ul, .page-content ol { margin:0 0 16px 24px; }
.page-content li { margin-bottom:6px; }
.page-content blockquote {
  border-left:3px solid var(--gbc-lcd); margin:16px 0;
  padding:8px 16px; color:var(--ink-dim);
}
.page-content img {
  max-width:100%; height:auto; display:block;
}
.page-content figure { margin:24px 0; }
.page-content figcaption {
  font-family:var(--font-mono); font-size:.78rem; color:var(--ink-faint);
  margin-top:8px; line-height:1.5;
}
.post-screenshot {
  margin:28px 0;
  background:var(--gbc-page-panel);
  border:3px solid var(--gbc-page-border);
  box-shadow:
    inset 0 0 0 1px rgba(138,180,58,.12),
    0 6px 0 var(--gbc-page-bg);
}
.post-screenshot-frame {
  padding:10px;
  background:
    repeating-linear-gradient(0deg, transparent 0 2px, rgba(138,180,58,.03) 2px 3px),
    var(--gbc-page-panel-hi);
  border-bottom:2px solid var(--gbc-page-border);
}
.post-screenshot-frame img {
  width:100%; height:auto; display:block;
  border:2px solid var(--gbc-page-border);
  border-radius:2px;
  image-rendering:auto;
}
.post-screenshot figcaption {
  padding:10px 12px 12px;
  font-family:var(--font-mono); font-size:.78rem;
  color:var(--ink-dim); line-height:1.5;
  border-top:1px dashed rgba(138,180,58,.2);
}
/* Scoped under .page-content so the auto side-margins win over the generic
   `.page-content figure { margin:24px 0 }` rule (higher specificity) — otherwise
   the capped-width figure pins left instead of centering in the column. */
.page-content .post-pixel-art {
  max-width:min(100%, 520px);
  margin:28px auto;
  background:var(--gbc-dmg);
  border:4px solid var(--gbc-page-border);
  box-shadow:
    inset 0 0 0 3px var(--gbc-dmg-mid),
    0 6px 0 var(--gbc-page-bg);
}
.post-pixel-art-frame {
  padding:14px;
  display:flex; align-items:center; justify-content:center;
  background:
    repeating-linear-gradient(to bottom, transparent 0 2px, rgba(15,56,15,.08) 2px 3px),
    var(--gbc-dmg);
}
.post-pixel-art-frame img {
  width:auto; max-width:100%; height:auto;
  image-rendering:pixelated;
  filter:drop-shadow(2px 2px 0 rgba(48,98,48,.35));
}
.post-pixel-art figcaption {
  margin:0;
  padding:10px 12px 12px;
  background:var(--gbc-page-panel);
  border-top:3px solid var(--gbc-page-border);
  color:var(--ink-dim);
}
/* Rule-tier badge icons inline in post tables (research/hunt/analyst). */
.tier-badge {
  width:18px; height:18px;
  image-rendering:pixelated;
  vertical-align:-4px; margin-right:6px;
}
.page-content table {
  display:block; overflow-x:auto; -webkit-overflow-scrolling:touch;
  width:max-content; max-width:100%;
  border-collapse:collapse; margin:20px 0;
  font-size:.82rem; table-layout:auto;
}
.page-content th {
  font-family:var(--font-pixel); font-size:.46rem; color:var(--gbc-lcd);
  background:var(--gbc-page-panel); border:1px solid var(--gbc-page-border);
  padding:8px 10px; text-align:left; letter-spacing:.04em; white-space:nowrap;
}
.page-content td {
  border:1px solid var(--gbc-page-border); padding:7px 10px;
  vertical-align:top; color:var(--ink-dim); line-height:1.5;
}
.page-content tr:nth-child(even) td { background:var(--gbc-page-panel); }
.page-tags { display:flex; gap:8px; flex-wrap:wrap; }
.tag {
  font-family:var(--font-pixel); font-size:.4rem; color:var(--gbc-lcd-dim);
  border:1px solid var(--gbc-lcd-dim); padding:3px 6px; text-decoration:none;
}
.tag:hover { border-color:var(--gbc-lcd); color:var(--gbc-lcd); }
.post-meta {
  font-family:var(--font-crt); font-size:1rem; color:var(--ink-faint);
  margin-bottom:28px; letter-spacing:.05em;
}
.post-meta .post-date { color:var(--gbc-lcd-bright); }
.archive-notice {
  font-family:var(--font-crt); font-size:1rem;
  border:1px solid var(--gbc-page-border); padding:8px 12px; margin-bottom:24px;
  color:var(--ink-dim);
}
.archive-notice a { color:var(--gbc-lcd); }
.page-footer {
  text-align:center; padding:16px; border-top:1px solid var(--gbc-page-panel);
  font-family:var(--font-crt); font-size:.95rem; color:var(--ink-faint);
}
.page-footer a { color:var(--ink-dim); text-decoration:none; }
.page-footer a:hover { color:var(--gbc-lcd); }
/* Section / archive landing list */
.section-list { margin-top:28px; }
.section-post-row {
  display:flex; align-items:center; gap:12px; padding:12px 16px;
  background:var(--gbc-page-panel); border:1px solid var(--gbc-page-border); margin-bottom:8px;
  font-family:var(--font-crt); font-size:1.05rem;
  text-decoration:none; color:inherit; transition:border-color 100ms;
}
.section-post-row:hover { border-color:var(--gbc-lcd); }
.section-intro {
  font-family:var(--font-crt); font-size:1.05rem; color:var(--ink-dim);
  margin:-8px 0 24px; line-height:1.5;
}
.section-empty {
  color:var(--ink-faint); font-family:var(--font-crt);
}
.section-post-row .num { font-family:var(--font-pixel); font-size:.5rem; color:var(--gbc-lcd-dim); min-width:30px; flex-shrink:0; }
.section-post-body { display:flex; flex-direction:column; gap:4px; flex:1; min-width:0; }
.section-post-row .title { color:var(--ink); }
.section-post-row .excerpt {
  font-family:var(--font-crt); font-size:.95rem; color:var(--ink-faint); line-height:1.4;
}
.section-post-row .date { color:var(--ink-faint); font-size:.9rem; white-space:nowrap; flex-shrink:0; }
/* Accessibility */
@media (max-width:600px) {
  .page-header { padding:10px 16px; gap:4px; }
  .page-content { padding:0 16px 48px; }
  .tag { font-size:.35rem; padding:2px 4px; }
  .section-post-row { align-items:flex-start; }
  .section-post-row .date { padding-top:3px; }
}
.skip-arcade {
  position:absolute; top:-50px; left:0; z-index:9999;
  background:var(--gbc-lcd); color:#000;
  font-family:var(--font-pixel); font-size:.5rem; padding:8px 12px;
  text-decoration:none; transition:top 100ms;
}
.skip-arcade:focus { top:0; }
.sr-only {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ============================================================
   GAME BOY SCREEN — LCD THEME + BOOT + MENU OVERRIDES
   ============================================================ */

/* LCD feel: dark green tint, softer scanlines + vignette */
.gb-shell .screen-inner { background:#0c1008; }
.gb-shell .screen-inner::before {
  background:repeating-linear-gradient(to bottom,transparent 0px,transparent 2px,rgba(80,160,80,.012) 2px,rgba(80,160,80,.012) 3px);
}
.gb-shell .screen-inner::after {
  background:radial-gradient(ellipse at center,transparent 0%,transparent 65%,rgba(0,0,0,.28) 100%);
}

/* Boot — Game Boy mode */
.gb-shell #view-boot .loading-bar { display:none; }
.gb-shell #view-boot {
  background:#9bbc0f;
  color:#0f380f;
}
.gb-shell #view-boot .boot-msgs {
  margin-bottom:14px; text-align:center;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  width:100%;
}
.gb-boot-stack {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  opacity:0; filter:brightness(.35) contrast(1.1);
  transition:opacity 280ms ease, filter 420ms ease;
}
.gb-boot-stack.power-on { opacity:1; filter:brightness(1) contrast(1); }
.gb-boot-stack.ready { opacity:1; filter:none; }
.gb-boot-logo {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  margin:6px 0 6px;
  opacity:0; transform:translateY(-26px);
  transition:opacity 300ms ease, transform 480ms cubic-bezier(.18,.89,.32,1.18);
}
.gb-boot-logo.shown { opacity:1; transform:translateY(0); }
.gb-boot-word {
  display:block;
  font-family:var(--font-pixel);
  font-size:clamp(1rem,5vw,1.6rem);
  color:#0f380f; letter-spacing:.1em; line-height:1.3;
  text-shadow:2px 2px 0 rgba(48,98,48,.3);
}
.gb-boot-tagline {
  font-family:var(--font-pixel);
  font-size:clamp(.28rem,1vw,.4rem);
  color:#306230; letter-spacing:.18em;
  opacity:0; transform:translateY(6px);
  transition:opacity 340ms ease, transform 380ms ease;
}
.gb-boot-tagline.shown { opacity:1; transform:translateY(0); }
.gb-boot-load {
  display:flex; flex-direction:column; align-items:center; gap:6px; margin-top:12px;
  opacity:0; transition:opacity 240ms ease;
}
.gb-boot-load.shown { opacity:1; }
.gb-boot-loadbar {
  width:clamp(110px,46vw,170px); height:10px;
  border:2px solid #0f380f; background:rgba(15,56,15,.1); padding:1px;
}
.gb-boot-loadfill {
  display:block; height:100%; width:0; background:#0f380f;
  transition:width 900ms steps(14,end);
}
.gb-boot-load.shown .gb-boot-loadfill { width:100%; }
.gb-boot-loadtext {
  font-family:var(--font-pixel);
  font-size:clamp(.3rem,1.5vw,.44rem);
  color:#306230; letter-spacing:.2em;
  animation:gbLoadBlink 650ms steps(2,jump-none) infinite;
}
.gb-boot-load.done .gb-boot-loadtext { animation:none; opacity:.45; }
@keyframes gbLoadBlink { 50% { opacity:.2; } }
@media (prefers-reduced-motion:reduce) { .gb-boot-loadfill { transition:none; } }

/* PRESS START — GB palette */
.gb-shell .press-start {
  font-family:var(--font-pixel);
  color:#0f380f; -webkit-text-stroke:0;
  text-shadow:1px 1px 0 rgba(48,98,48,.35);
  font-size:clamp(.55rem,2.2vw,.78rem);
  letter-spacing:.12em;
}

/* Menu header + preview — green accent */
.gb-shell .menu-head { border-bottom-color:#3a6018; }
.gb-shell .menu-title { color:var(--neon-green); text-shadow:none; }
.gb-shell .preview { border-color:#3a6018; }
.gb-shell .preview::before { content:"// CART INFO"; color:var(--neon-green); background:#0c1008; }
.gb-shell .preview-title { color:var(--neon-green); text-shadow:none; }
.gb-shell .preview-meta b { color:var(--neon-green); }
.gb-shell .preview-press { color:var(--neon-green); border-color:var(--neon-green); }

/* Back btn + detail */
.gb-shell .back-btn { border-color:#3a6018; color:var(--neon-green); }
.gb-shell .back-btn:hover,.gb-shell .back-btn:active { background:#3a6018; color:#0c1008; }
.gb-shell .detail-head { border-bottom-color:#3a6018; }
.gb-shell .detail-title { color:var(--neon-green); text-shadow:none; }
.gb-shell .detail-body h3 { color:var(--neon-green); }
.gb-shell .detail-open-all { color:var(--neon-green); border-color:var(--neon-green); }
.gb-shell .detail-open-all:hover { background:var(--neon-green); color:#0c1008; }
.gb-shell a.post-row:hover { border-color:var(--neon-green); }
.gb-shell .post-row .num { color:#4a7a20; }

/* Cartridge cards — dark green theme */
.gb-shell .cart { background:#111810; border-color:#2a3820; }
.gb-shell .cart.selected {
  border-color:var(--neon-green); background:#182015;
  box-shadow:0 0 0 1px var(--neon-green),0 0 16px rgba(138,180,58,.28);
}
.gb-shell .cart.selected .cart-label { color:var(--neon-green); }
.gb-shell .cart.selected::before,.gb-shell .cart.selected::after { border-color:var(--neon-green); }
.gb-shell .cart-label { color:#3a5828; }

/* ============================================================
   DESKTOP SCREEN CONTENT — must come last to override earlier
   per-breakpoint rules (e.g. cart-art at 720px)
   ============================================================ */
@media (min-width:720px) {
  .gb-boot-word { font-size:clamp(1.3rem,5.2dvh,2.3rem); }
  .gb-shell .press-start { font-size:clamp(.55rem,2.4dvh,1rem); }
  #view-menu { padding:clamp(8px,1.8dvh,20px) clamp(10px,2dvh,22px); }
  .menu-head { padding-bottom:clamp(8px,1.5dvh,14px); margin-bottom:clamp(10px,2dvh,18px); }
  .menu-title { font-size:clamp(.6rem,2.5dvh,1.4rem); }
  .menu-hud { font-size:clamp(1rem,2.2dvh,1.6rem); }
  .menu-body { gap:clamp(12px,2dvh,22px); }
  .cart-art { width:clamp(92px,12dvh,148px); height:clamp(108px,14.5dvh,180px); }
  .cart { padding:clamp(6px,1.2dvh,12px) clamp(4px,1dvh,8px) clamp(8px,1.5dvh,14px); gap:clamp(4px,.8dvh,8px); min-height:clamp(150px,20dvh,240px); }
  .cart-label { font-size:clamp(.5rem,1.5dvh,.85rem); }
  .preview { padding:clamp(10px,2dvh,22px) clamp(12px,2dvh,20px); min-height:clamp(180px,28dvh,320px); }
  .preview-title { font-size:clamp(.75rem,2.2dvh,1.3rem); margin-bottom:clamp(6px,1.2dvh,14px); }
  .preview-desc { font-size:clamp(1.05rem,2.4dvh,1.6rem); }
  .preview-meta { font-size:clamp(1rem,2.2dvh,1.5rem); }
  .preview-press { font-size:clamp(.5rem,1.4dvh,.8rem); padding:clamp(5px,1.2dvh,10px) clamp(8px,1.5dvh,14px); margin-top:clamp(8px,1.5dvh,16px); }
  #view-detail { padding:clamp(8px,1.8dvh,20px) clamp(10px,2dvh,22px); }
  .detail-head { padding-bottom:clamp(8px,1.5dvh,14px); margin-bottom:clamp(10px,2dvh,18px); }
  .back-btn { font-size:clamp(.55rem,1.5dvh,.85rem); padding:clamp(4px,1dvh,8px) clamp(8px,1.5dvh,14px); }
  .detail-title { font-size:clamp(.7rem,2.2dvh,1.3rem); }
  .detail-body { font-size:clamp(.88rem,2dvh,1.3rem); }
  .detail-body h3 { font-size:clamp(.7rem,1.8dvh,1rem); margin:clamp(12px,2dvh,22px) 0 clamp(6px,1.2dvh,12px); }
  .post-row, a.post-row { font-size:clamp(1.05rem,2.3dvh,1.5rem); padding:clamp(7px,1.5dvh,14px) clamp(10px,1.8dvh,16px); margin-bottom:clamp(4px,1dvh,9px); }
  .post-row .num { font-size:clamp(.55rem,1.5dvh,.85rem); }
  .detail-open-all { font-size:clamp(.5rem,1.4dvh,.8rem); margin-top:clamp(10px,2dvh,18px); padding:clamp(5px,1.2dvh,10px) clamp(8px,1.5dvh,14px); }
}

/* ============================================================
   BOOT ZOOM TRANSITION
   ============================================================ */
@keyframes deviceZoom {
  0%   { transform:scale(1);  opacity:1; }
  60%  { transform:scale(6);  opacity:.7; }
  100% { transform:scale(14); opacity:0; }
}

body.boot-zooming .device {
  animation:deviceZoom 640ms cubic-bezier(.3,.55,.4,1) forwards;
  pointer-events:none;
}

/* ============================================================
   CARTRIDGE STAGE — full-page section selector
   ============================================================ */
#cartridge-stage {
  position:fixed; inset:0; z-index:20;
  background:
    radial-gradient(ellipse at center, #142010 0%, #0c1008 55%, #060804 100%);
  overflow-y:auto; -webkit-overflow-scrolling:touch;
  display:flex; flex-direction:column; align-items:center;
  padding:clamp(24px,4vh,56px) clamp(16px,4vw,80px) clamp(32px,5vh,64px);
  opacity:0; transition:opacity 360ms ease-in;
}
#cartridge-stage[hidden] { display:none; }
#cartridge-stage.visible { opacity:1; }

.stage-shell {
  width:100%; max-width:1100px;
  display:flex; flex-direction:column; align-items:center;
}

.stage-header {
  width:100%;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
  margin-bottom:clamp(20px,4vh,44px);
  padding-bottom:12px;
  border-bottom:2px solid var(--gbc-page-border);
}
.stage-title {
  font-family:var(--font-pixel); font-size:clamp(.5rem,2vw,.85rem);
  color:var(--gbc-lcd); letter-spacing:.16em;
  text-shadow:0 0 14px rgba(138,180,58,.4);
}
.stage-hud {
  font-family:var(--font-crt); font-size:clamp(1rem,2vw,1.2rem);
  color:var(--ink-faint); letter-spacing:.1em; text-transform:uppercase;
}
.stage-hud-val { color:var(--gbc-lcd); }
/* Right side of the menu header: GAMES count + the REBOOT button (replays the
   boot/loading screen). In the header so it stays visible at the top on mobile,
   where the footer sits below the cartridge stack. */
.stage-header-right { display:flex; align-items:center; gap:clamp(10px,2.4vw,18px); }
.stage-reboot {
  font-family:var(--font-pixel); font-size:clamp(.4rem,1.2vw,.52rem);
  color:var(--gbc-lcd); letter-spacing:.1em; text-transform:uppercase;
  background:transparent; border:2px solid var(--gbc-lcd-dim);
  padding:7px 11px; border-radius:2px; cursor:pointer;
  transition:background 110ms, color 110ms, border-color 110ms;
}
.stage-reboot:hover, .stage-reboot:focus-visible {
  color:#0c1008; background:var(--gbc-lcd); border-color:var(--gbc-lcd); outline:none;
}

.stage-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(min(170px,44vw), 230px));
  gap:clamp(16px,3vw,32px);
  justify-content:center;
  width:100%;
}

.stage-cart {
  display:flex; flex-direction:column; align-items:center;
  text-decoration:none; color:inherit;
  padding:clamp(16px,2.5vw,24px) clamp(12px,2vw,18px);
  background:var(--gbc-page-panel);
  border:2px solid var(--gbc-page-border);
  gap:clamp(6px,1.2vh,10px);
  transition:border-color 140ms, transform 140ms, box-shadow 140ms, background 140ms;
  position:relative;
}
.stage-cart::before,
.stage-cart::after {
  content:""; position:absolute; width:10px; height:10px;
  border:2px solid transparent; opacity:0;
  transition:opacity 140ms, border-color 140ms;
}
.stage-cart::before { top:-2px; left:-2px; border-right:none; border-bottom:none; }
.stage-cart::after { bottom:-2px; right:-2px; border-left:none; border-top:none; }
.stage-cart:hover,
.stage-cart:focus,
.stage-cart.focused {
  border-color:var(--gbc-lcd);
  background:var(--gbc-page-panel-hi);
  transform:translateY(-4px);
  box-shadow:0 8px 28px rgba(138,180,58,.22);
  outline:none;
}
.stage-cart.focused::before,
.stage-cart.focused::after { opacity:1; border-color:var(--gbc-lcd); }

.stage-cart-art {
  display:flex; align-items:center; justify-content:center;
  width:140px; height:170px;
}
.stage-cart-art svg,
.stage-cart-art .pixel-cartridge-svg {
  display:block;
  width:140px; height:170px;
  image-rendering:pixelated;
  image-rendering:crisp-edges;
  shape-rendering:crispEdges;
}
.stage-cart-art img.pixel-cartridge-img {
  display:block;
  width:100%; height:100%;
  object-fit:contain;
  image-rendering:pixelated;
  image-rendering:crisp-edges;
}
@media (min-width:720px) {
  .stage-cart-art { width:168px; height:204px; }
  .stage-cart-art svg,
  .stage-cart-art .pixel-cartridge-svg { width:168px; height:204px; }
}

.stage-cart-name {
  font-family:var(--font-pixel); font-size:clamp(.42rem,1.4vw,.62rem);
  color:var(--gbc-lcd-dim); letter-spacing:.07em;
  text-align:center; line-height:1.5; text-transform:uppercase;
}
.stage-cart-meta {
  font-family:var(--font-crt); font-size:clamp(.85rem,1.6vw,1rem);
  color:var(--gbc-lcd); letter-spacing:.12em; text-transform:uppercase;
}
.stage-cart:hover .stage-cart-name,
.stage-cart:focus .stage-cart-name,
.stage-cart.focused .stage-cart-name { color:var(--gbc-lcd-bright); }

.stage-cart-desc {
  font-family:var(--font-crt); font-size:clamp(.85rem,1.6vw,1rem);
  color:var(--ink-faint); text-align:center; line-height:1.4;
}

.stage-footer {
  width:100%;
  display:flex; justify-content:center; align-items:center;
  gap:clamp(16px,4vw,40px); flex-wrap:wrap;
  margin-top:clamp(24px,4vh,48px);
  padding-top:14px;
  border-top:2px dashed rgba(138,180,58,.22);
}
.stage-hint {
  font-family:var(--font-pixel); font-size:clamp(.38rem,1.2vw,.5rem);
  color:var(--gbc-lcd-dim); letter-spacing:.08em;
}
.stage-hint-select { color:var(--gbc-lcd); }

/* Reduced-motion: skip zoom, instant crossfade */
@media (prefers-reduced-motion: reduce) {
  body.boot-zooming .device { animation:none; opacity:0; }
  #cartridge-stage { transition:none; }
}

