/* ── Games Nobody Likes — Design System ──────────────────────────────────────
   Direction B: Retro Arcade / BBS
   Palette: phosphor green #2EFF44 · hot pink #FF0080 · near-black #080808
   Fonts: Space Mono (display/labels/nav) · Inter (body/descriptions)
   Author: Jeremiah Buttler
   ─────────────────────────────────────────────────────────────────────────── */

/* ═══ Tokens ═══════════════════════════════════════════════════════════════ */
:root {
  /* Surfaces */
  --color-bg:           #080808;
  --color-bg-raised:    #0D0D0D;
  --color-surface:      #131313;
  --color-surface-2:    #1A1A1A;

  /* Borders */
  --color-border:       #222222;
  --color-border-green: #2EFF44;
  --color-border-pink:  #FF00CC;

  /* Text — muted/dim raised to clear WCAG AA (4.5:1) for small text.
     muted #9E9E9E: 6.9:1 on #131313, 4.7:1 on #333 .badge-free chips.
     dim   #828282: 4.8:1 on #131313 surface, 5.2:1 on #080808 bg.
     (was #949494 / #787878 — dim failed AA on raised+surface, 4.2–4.4:1.) */
  --color-text:         #EAEAEA;
  --color-text-muted:   #9E9E9E;
  --color-text-dim:     #828282;

  /* Brand accents */
  --color-green:        #2EFF44;   /* primary CTA, active, prices */
  --color-pink:         #FF00CC;   /* featured, alerts, sub badges */
  --color-yellow:       #FFE000;   /* tier-2 badges */
  --color-blue:         #6666FF;   /* one-time purchase badges */
  --color-screen:       #040E06;   /* screen/inner backgrounds */

  /* Semantic aliases */
  --color-primary:      var(--color-green);
  --color-secondary:    var(--color-pink);
  --color-error:        var(--color-pink);
  --color-success:      var(--color-green);
  --color-warning:      var(--color-yellow);

  /* Typography */
  --font-mono:   'Space Mono', 'Courier New', monospace;
  --font-body:   'Inter', system-ui, -apple-system, sans-serif;

  /* Type scale — 1.25 ratio (Major Third), base 14px display / 15px body */
  --text-2xs:  10px;
  --text-xs:   11px;
  --text-sm:   12px;
  --text-base: 14px;
  --text-md:   15px;
  --text-lg:   18px;
  --text-xl:   22px;
  --text-2xl:  28px;
  --text-3xl:  36px;
  --text-4xl:  44px;

  /* Spacing — 8pt scale */
  --space-1:   4px;
  --space-2:   8px;
  --space-3:   12px;
  --space-4:   16px;
  --space-5:   20px;
  --space-6:   24px;
  --space-8:   32px;
  --space-10:  40px;
  --space-12:  48px;
  --space-16:  64px;

  /* Layout */
  --max-w:     1160px;
  --nav-h:     56px;

  /* Direction B: sharp corners throughout */
  --radius:    0px;
  --radius-sm: 0px;
  --radius-lg: 0px;

  /* Borders (shorthand) */
  --border:        1px solid var(--color-border);
  --border-green:  1px solid var(--color-green);
  --border-pink:   1px solid var(--color-pink);

  /* Focus ring */
  --focus-ring: 0 0 0 2px var(--color-green);
}


/* ═══ Reset ════════════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  font-size: var(--text-md);
  line-height: 1.65;
  background: var(--color-bg);
  color: var(--color-text);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}
img, svg { display: block; max-width: 100%; }
a { color: var(--color-green); text-decoration: none; }
a:hover { color: var(--color-text); }
ul, ol { list-style: none; }
input, button, select, textarea { font: inherit; }
button { cursor: pointer; }


/* ═══ Typography ══════════════════════════════════════════════════════════ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-mono);
  font-weight: 700;
  line-height: 1.15;
  color: var(--color-text);
  letter-spacing: 0.5px;
}
h1 { font-size: var(--text-4xl); }
h2 { font-size: var(--text-3xl); }
h3 { font-size: var(--text-2xl); }
h4 { font-size: var(--text-xl); }
h5 { font-size: var(--text-lg); }
h6 { font-size: var(--text-base); }

.mono { font-family: var(--font-mono); }
.text-green { color: var(--color-green); }
.text-pink   { color: var(--color-pink); }
.text-yellow { color: var(--color-yellow); }
.text-muted  { color: var(--color-text-muted); }

/* Kicker / label above a heading */
.kicker {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: 700;
  color: var(--color-pink);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}


/* ═══ Layout utilities ════════════════════════════════════════════════════ */
.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--space-6);
}
.section { padding: var(--space-12) var(--space-6); }
.section-sm { padding: var(--space-8) var(--space-6); }

.section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  border-bottom: var(--border-green);
  padding-bottom: var(--space-3);
  margin-bottom: var(--space-6);
}
.section-title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-green);
  letter-spacing: 3px;
  text-transform: uppercase;
}
.section-meta {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  letter-spacing: 1px;
}


/* ═══ Navigation ══════════════════════════════════════════════════════════ */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--color-bg-raised);
  border-bottom: var(--border-green);
  height: var(--nav-h);
}
.nav-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--space-6);
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-8);
}
.nav-logo { display: flex; align-items: center; flex-shrink: 0; }
.nav-logo img { height: 28px; width: auto; }

.nav-links {
  display: flex;
  gap: var(--space-6);
  flex: 1;
}
.nav-links a {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: 700;
  color: var(--color-text-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: var(--space-1) 0;
  border-bottom: 2px solid transparent;
  transition: color 0.15s, border-color 0.15s;
}
.nav-links a:hover,
.nav-links a.on {
  color: var(--color-green);
  border-bottom-color: var(--color-green);
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}
.nav-user {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  letter-spacing: 1px;
}

/* ── Account nav dropdown ─────────────────────────────────────────────── */
.nav-account { position: relative; }
.nav-account-btn {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-green);   /* Welcome [name] reads as the brand accent */
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 5px 10px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color 0.15s, border-color 0.15s;
}
.nav-account-btn:hover,
.nav-account-btn[aria-expanded="true"] {
  color: var(--color-green);
  border-color: var(--color-green);
}
.nav-account-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.nav-account-caret {
  font-size: 10px;
  line-height: 1;
  flex-shrink: 0;
  transition: transform 0.2s;
}
.nav-account-btn[aria-expanded="true"] .nav-account-caret { transform: rotate(180deg); }
.nav-account-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 155px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 4px;
  z-index: 200;
  display: none;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.nav-account-menu.is-open { display: block; }
.nav-account-menu a {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  padding: 9px 14px;
  border-radius: calc(var(--radius) - 2px);
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: 0.5px;
  transition: background 0.1s, color 0.1s;
}
.nav-account-menu a:hover,
.nav-account-menu a:focus { background: var(--color-bg); color: var(--color-green); outline: none; }

/* Admin gear — red so it reads as "admin/operator zone" against the green nav.
   Hover/focus reveals the full admin dropdown; direct click navigates to the
   Dashboard (so the gear's primary action stays useful on touch devices that
   never trigger :hover). */
.nav-gear-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.nav-gear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #FF3344;   /* admin-only accent: a true red distinct from brand pink */
  transition: color 0.15s, transform 0.3s ease;
}
.nav-gear:hover,
.nav-gear:focus-visible,
.nav-gear.on { color: #FF6677; }
.nav-gear:hover { transform: rotate(60deg); }
.nav-gear:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 4px; }

.nav-gear-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 175px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 4px;
  z-index: 200;
  display: none;
  box-shadow: 0 8px 24px rgba(0,0,0,0.45);
}
/* Shown via JS toggle (.is-open) — handles mouse, keyboard, and touch. */
.nav-gear-menu.is-open { display: block; }
.nav-gear-menu a {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  padding: 9px 14px;
  border-radius: calc(var(--radius) - 2px);
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: 0.5px;
  transition: background 0.1s, color 0.1s;
}
.nav-gear-menu a:hover,
.nav-gear-menu a:focus {
  background: var(--color-bg);
  color: #FF6677;   /* matches the gear's red on hover */
  outline: none;
}
.nav-gear-menu-sep {
  height: 1px;
  background: var(--color-border);
  margin: 4px 6px;
}

/* Hamburger toggle (mobile) */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: var(--space-2);
  margin-left: auto;
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-green);
  transition: transform 0.2s, opacity 0.2s;
}


/* ═══ Buttons ═════════════════════════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: var(--space-3) var(--space-5);
  border: 1px solid transparent;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  text-decoration: none;
}
.btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }

.btn-primary {
  background: var(--color-green);
  color: #000;
  border-color: var(--color-green);
}
.btn-primary:hover { background: #50FF66; border-color: #50FF66; color: #000; }

.btn-ghost {
  background: transparent;
  color: var(--color-text-muted);
  border-color: var(--color-border);
}
.btn-ghost:hover { border-color: var(--color-green); color: var(--color-green); }

.btn-pink {
  background: var(--color-pink);
  color: #fff;
  border-color: var(--color-pink);
}
.btn-pink:hover { background: #FF33A0; border-color: #FF33A0; color: #fff; }

.btn-outline-green {
  background: transparent;
  color: var(--color-green);
  border-color: var(--color-green);
}
.btn-outline-green:hover { background: var(--color-green); color: #000; }

.btn-sm  { padding: var(--space-2) var(--space-4); font-size: var(--text-2xs); }
.btn-lg  { padding: var(--space-4) var(--space-8); font-size: var(--text-xs); }
.btn-block { width: 100%; }


/* ═══ Badges ══════════════════════════════════════════════════════════════ */
.badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 2px var(--space-2);
  line-height: 1.4;
}
.badge-free    { background: #333; color: var(--color-text-muted); }
.badge-tier1   { background: var(--color-green); color: #000; }
.badge-tier2   { background: var(--color-pink);  color: #fff; }
.badge-tier3   { background: var(--color-yellow); color: #000; }
.badge-buy     { background: var(--color-blue);  color: #fff; }
.badge-new     { background: var(--color-screen); color: var(--color-green); border: 1px solid var(--color-green); }
.badge-featured { background: var(--color-pink); color: #fff; }


/* ═══ Cards ═══════════════════════════════════════════════════════════════ */
/* Game card grid — gap:1px on a colored container creates the grid line effect */
.game-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-6);            /* 24px — real separation; was a 1px hairline that fused the cards into one block */
}

.game-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);   /* each tile is now its own framed object */
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.game-card:hover {
  border-color: var(--color-green);
  transform: translateY(-3px);
  /* crisp 2px green frame + dark lift to pop the tile off the near-black ground */
  box-shadow: 0 0 0 1px var(--color-green), 0 10px 28px rgba(0,0,0,0.6);
}
.game-card:hover .game-card-title { color: var(--color-green); }

.game-card-thumb {
  aspect-ratio: 16/10;
  background: var(--color-screen);
  position: relative;
  overflow: hidden;
  border-bottom: 2px solid var(--color-green);
}

/* Real screenshot image — cover-fit, full brightness (CRT overlay provides retro effect) */
.game-card-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  image-rendering: high-quality;
  filter: saturate(1.1);
}

/* CRT scanline overlay */
.game-card-thumb::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(0,0,0,0.20) 0 1px,
    transparent 1px 2px
  );
  pointer-events: none;
  z-index: 2;
}

/* Bottom vignette — ensures title badge is always readable */
.game-card-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 35%, rgba(0,0,0,0.78) 100%);
  pointer-events: none;
  z-index: 2;
}

/* Accent top-edge bar */
.game-card-thumb-bar {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  z-index: 3;
}

/* Title + genre overlay at bottom of thumb */
.game-card-thumb-badge {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 3;
  padding: 4px 8px 6px;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.game-card-thumb-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,0.95);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.game-card-thumb-genre {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  text-shadow: 0 1px 3px rgba(0,0,0,0.9);
}

/* No-image fallback — keep the coloured panel for cards without a thumbnail */
.game-card-thumb.no-image {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: 1px;
  text-align: center;
  padding: var(--space-3);
}

/* Accent cover colors (fallback) */
.game-card-thumb.c-green  { border-bottom-color: var(--color-green); color: var(--color-green); background: #04120A; }
.game-card-thumb.c-pink   { border-bottom-color: var(--color-pink);  color: var(--color-pink);  background: #0A0012; }
.game-card-thumb.c-blue   { border-bottom-color: var(--color-blue);  color: var(--color-blue);  background: #080018; }
.game-card-thumb.c-yellow { border-bottom-color: var(--color-yellow);color: var(--color-yellow);background: #121000; }

.game-card-thumb .badge { position: absolute; top: 0; right: 0; z-index: 4; }

/* Free-to-play corner ribbon — Tier 0 (access_mode='free') only */
.game-card-free-ribbon {
  position: absolute;
  top: 14px;
  left: -36px;
  width: 130px;
  padding: 4px 0;
  text-align: center;
  background: var(--color-green);
  color: #041006;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 9px;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  transform: rotate(-45deg);
  z-index: 5;
  box-shadow: 0 2px 8px rgba(0,0,0,0.55);
  pointer-events: none;
}

/* Free-to-play corner ribbon, hero-slide scale — overlays the slideshow */
.hero-slide-free-ribbon {
  position: absolute;
  top: 30px;
  left: -65px;
  width: 230px;
  padding: 7px 0;
  text-align: center;
  background: var(--color-green);
  color: #041006;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transform: rotate(-45deg);
  z-index: 3;
  box-shadow: 0 3px 12px rgba(0,0,0,0.65);
  pointer-events: none;
}
.hero-slider--compact .hero-slide-free-ribbon {
  top: 22px;
  left: -52px;
  width: 180px;
  padding: 5px 0;
  font-size: 11px;
  letter-spacing: 0.1em;
}

.game-card-body { padding: var(--space-3) var(--space-4); flex: 1; }
.game-card-title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: var(--space-1);
  transition: color 0.15s;
}
.game-card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
}
.game-card-price { color: var(--color-green); font-weight: 700; }
.game-card-price.is-pink { color: var(--color-pink); }
.game-card-price.is-buy  { color: var(--color-blue); }


/* ═══ Dashboard (logged-in home — Direction B split) ══════════════════════ */
.dashboard {
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg-raised);
}
.dashboard-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-6);
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--space-6);
  align-items: start;
}
.dashboard-left {
  border-right: 1px solid var(--color-border);
  padding-right: var(--space-6);
}
.dashboard-shortcuts {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.dashboard-shortcut {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: var(--space-2) var(--space-3);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: border-color 0.12s;
}
.dashboard-shortcut:hover { border-color: var(--color-green); }
.dashboard-shortcut-cmd {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--color-green);
  text-transform: uppercase;
}
.dashboard-shortcut-desc {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
}
@media (max-width: 700px) {
  .dashboard-inner { grid-template-columns: 1fr; }
  .dashboard-left { border-right: none; border-bottom: 1px solid var(--color-border);
    padding-right: 0; padding-bottom: var(--space-5); }
}


/* ═══ Hero ════════════════════════════════════════════════════════════════ */
.hero {
  padding: var(--space-12) var(--space-6) var(--space-10);
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-10);
  align-items: center;
  max-width: var(--max-w);
  margin: 0 auto;
}
.hero-kicker {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-pink);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}
.hero-title {
  font-family: var(--font-mono);
  font-size: var(--text-4xl);
  font-weight: 700;
  line-height: 1.1;
  margin-bottom: var(--space-4);
}
.hero-title .g { color: var(--color-green); }
.hero-title .p { color: var(--color-pink); }
.hero-sub {
  font-family: var(--font-body);
  font-size: var(--text-md);
  color: var(--color-text-muted);
  line-height: 1.7;
  max-width: 480px;
  margin-bottom: var(--space-8);
}
.hero-actions { display: flex; gap: var(--space-4); flex-wrap: wrap; align-items: center; }

/* Terminal / featured game panel */
.terminal-panel {
  background: var(--color-screen);
  border: var(--border-green);
  padding: var(--space-6);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-green);
  line-height: 2;
}
.terminal-panel .dim  { color: var(--color-text-muted); }
.terminal-panel .pink { color: var(--color-pink); }
.terminal-panel .yellow { color: var(--color-yellow); }


/* ═══ Forum teaser block ══════════════════════════════════════════════════ */
.forum-teaser {
  border: var(--border-pink);
  padding: var(--space-6) var(--space-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}
.forum-teaser-title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-pink);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: var(--space-1);
}
.forum-teaser-sub {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}


/* ═══ Flash messages ══════════════════════════════════════════════════════ */
.flash-container { padding: var(--space-2) var(--space-6); }
.flash {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.5px;
  padding: var(--space-3) var(--space-4);
  border-left: 3px solid;
  margin-bottom: var(--space-2);
}
.flash-success { border-color: var(--color-green); color: var(--color-green); background: #041008; }
.flash-error   { border-color: var(--color-pink);  color: var(--color-pink);  background: #110008; }
.flash-info    { border-color: var(--color-blue);  color: var(--color-blue);  background: #080014; }
.flash-warning { border-color: var(--color-yellow);color: var(--color-yellow);background: #110F00; }


/* ═══ Forms ═══════════════════════════════════════════════════════════════ */
.form-group { margin-bottom: var(--space-5); }
.form-label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: 700;
  color: var(--color-text-muted);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.form-control {
  width: 100%;
  background: var(--color-surface);
  border: var(--border);
  color: var(--color-text);
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  transition: border-color 0.15s;
  appearance: none;
  min-height: 44px; /* touch target */
}
.form-control:focus {
  outline: none;
  border-color: var(--color-green);
  box-shadow: 0 0 0 1px var(--color-green);
}
.form-control::placeholder { color: var(--color-text-dim); }
.form-hint {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-dim);
  margin-top: var(--space-1);
  letter-spacing: 0.5px;
}
.form-error-msg {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-pink);
  margin-top: var(--space-1);
}
.form-control.is-invalid { border-color: var(--color-pink); }

select.form-control { background-image: none; }
textarea.form-control { min-height: 120px; resize: vertical; }


/* ═══ Tables ══════════════════════════════════════════════════════════════ */
.table-wrap { overflow-x: auto; }
.table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}
.table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  border-bottom: var(--border-green);
  color: var(--color-green);
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  white-space: nowrap;
}
.table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: var(--border);
  color: var(--color-text);
  vertical-align: middle;
}
.table tr:hover td { background: var(--color-surface); }


/* ═══ Pagination ══════════════════════════════════════════════════════════ */
.pagination {
  display: flex;
  gap: 1px;
  background: var(--color-border);
  border: var(--border);
  width: fit-content;
  margin: var(--space-8) auto 0;
}
.page-link {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: 700;
  letter-spacing: 1px;
  padding: var(--space-2) var(--space-4);
  background: var(--color-surface);
  color: var(--color-text-muted);
  min-height: 44px;
  min-width: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-link:hover,
.page-link.active { background: var(--color-screen); color: var(--color-green); }
.page-link:focus-visible { outline: none; box-shadow: var(--focus-ring); }


/* ═══ Footer ══════════════════════════════════════════════════════════════ */
.footer {
  border-top: var(--border-green);
  padding: var(--space-5) var(--space-6);
  margin-top: auto;
}
.footer-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}
.footer-brand {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text-muted);
  letter-spacing: 2px;
}
.footer-links {
  display: flex;
  gap: var(--space-5);
  flex-wrap: wrap;
}
.footer-links a {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-dim);
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: color 0.15s;
}
.footer-links a:hover { color: var(--color-green); }
.footer-copyright {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-dim);
  letter-spacing: 1px;
}


/* ═══ Accessibility ═══════════════════════════════════════════════════════ */
:focus-visible { outline: 2px solid var(--color-green); outline-offset: 2px; }
.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;
}
a:focus-visible, button:focus-visible { box-shadow: var(--focus-ring); outline: none; }

/* Skip link */
.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-4);
  background: var(--color-green);
  color: #000;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  padding: var(--space-2) var(--space-4);
  z-index: 999;
  transition: top 0.1s;
}
.skip-link:focus { top: var(--space-2); }

/* Site notice bar */
.site-notice {
  background: var(--color-surface);
  color: var(--color-warning);
  border-bottom: 1px solid var(--color-warning);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-align: center;
  padding: var(--space-2) var(--space-4);
  letter-spacing: 0.03em;
}


/* ═══ Responsive ══════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .hero {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }
  .terminal-panel { display: none; }
  h1 { font-size: var(--text-3xl); }
  h2 { font-size: var(--text-2xl); }
}

@media (max-width: 640px) {
  :root { --nav-h: 52px; }

  /* Nav collapses */
  .nav-toggle { display: flex; }
  .nav-links {
    display: none;
    position: absolute;
    top: var(--nav-h);
    left: 0;
    right: 0;
    background: var(--color-bg-raised);
    border-bottom: var(--border-green);
    flex-direction: column;
    gap: 0;
    padding: var(--space-4) var(--space-6);
  }
  .nav-links.open { display: flex; }
  .nav-links a {
    padding: var(--space-3) 0;
    border-bottom: var(--border);
    width: 100%;
  }
  .nav-links a.on { border-bottom-color: var(--color-border); color: var(--color-green); }

  .nav-actions .nav-user { display: none; }

  /* Single-column layout */
  .hero { padding: var(--space-8) var(--space-4); }
  .hero-title { font-size: var(--text-2xl); }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions .btn { min-height: 44px; }

  .section, .section-sm { padding: var(--space-8) var(--space-4); }
  .container { padding: 0 var(--space-4); }

  /* Full-width game grid on small screens — tighter gap so 2-up tiles stay dense */
  .game-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }

  /* Forum teaser stacks */
  .forum-teaser { flex-direction: column; align-items: flex-start; gap: var(--space-4); }
  .forum-teaser .btn { min-height: 44px; width: 100%; }

  /* Forms single-column */
  .form-row { flex-direction: column; }
  .form-control { min-height: 44px; }

  /* Footer stacks */
  .footer-inner { flex-direction: column; align-items: flex-start; gap: var(--space-4); }
  .footer-links { gap: var(--space-4); }

  /* Tables scroll */
  .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

@media (max-width: 380px) {
  .game-grid { grid-template-columns: 1fr; }
}


/* ═══ Section labels ══════════════════════════════════════════════════════ */
.section-label {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-green);
  margin: 0;
}
.section-link {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--color-text-muted);
  transition: color 0.15s;
}
.section-link:hover { color: var(--color-green); }


/* ═══ Carousel ════════════════════════════════════════════════════════════ */
.carousel { position: relative; }

.carousel-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-5);
}
.carousel-hd-left {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
}
.carousel-hd-btns { display: flex; gap: var(--space-2); }

/* Scrollable card row */
.carousel-track {
  display: flex;
  gap: var(--space-6);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;            /* Firefox */
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--space-2);   /* prevent clipped card shadows */
}
.carousel-track::-webkit-scrollbar { display: none; }

/* Fixed-width cards snap cleanly */
.carousel-track .game-card {
  flex: 0 0 230px;
  width: 230px;
  scroll-snap-align: start;
}

/* Compact variant — tighter cards for constrained spaces (dashboard) */
.carousel--sm .carousel-track .game-card { flex: 0 0 175px; width: 175px; }

/* Prev / next arrow buttons */
.carousel-btn {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-family: var(--font-mono);
  font-size: 12px;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: border-color 0.15s, color 0.15s;
}
.carousel-btn:hover:not(:disabled):not([aria-disabled="true"]) {
  border-color: var(--color-green);
  color: var(--color-green);
}
.carousel-btn:disabled,
.carousel-btn[aria-disabled="true"] { opacity: 0.28; cursor: default; }
.carousel-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }

/* Pager variant — video-library-style translateX pager ─────────────────── */
.carousel--pager .carousel-viewport { overflow: hidden; }
.carousel--pager .carousel-track {
  overflow: visible;
  transform: translateX(0);
  transition: transform 0.42s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
  scroll-snap-type: none;
}
@media (prefers-reduced-motion: reduce) {
  .carousel--pager .carousel-track { transition: none; }
}


/* ═══ Hero Slider ═════════════════════════════════════════════════════════ */
.hero-slider {
  position: relative;
  overflow: hidden;
  background: var(--color-screen);
  border-bottom: 1px solid var(--color-border);
}

/* Establishes the slide area height; all slides stack absolutely inside */
.hero-slider-track {
  position: relative;
  min-height: 440px;
}

/* All slides stacked at the same position; only .is-active one is visible */
.hero-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;  /* content pins to bottom */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.45s ease;
}
.hero-slide.is-active {
  opacity: 1;
  pointer-events: auto;
}
@media (prefers-reduced-motion: reduce) {
  .hero-slide { transition: none; }
}

/* Background: game screenshot, darkened + stretched to fill */
.hero-slide-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
  background: var(--color-screen);   /* solid fallback when no thumbnail */
}
.hero-slide-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  image-rendering: high-quality;
  filter: saturate(1.05);
  display: block;
}

/* Very subtle scanline — kept faint at hero scale to avoid grain */
.hero-slide-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(0,0,0,0.06) 0 1px,
    transparent 1px 3px
  );
  pointer-events: none;
}

/* Full-coverage dark frame + heavy bottom for text readability */
.hero-slide::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.42) 0%,
    rgba(0,0,0,0.55) 45%,
    rgba(0,0,0,0.92) 100%
  );
  z-index: 1;
  pointer-events: none;
}

/* Text + CTA content, anchored at the bottom of the slide */
.hero-slide-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-8) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.hero-slide-kicker {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-pink);
}
.hero-slide-title {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: 700;
  line-height: 1.1;
  color: var(--color-text);
}
.hero-slide-tags {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  align-items: center;
}
.hero-slide-tag {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.hero-slide-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  padding-top: var(--space-1);
}

/* Controls bar: [◀] [● ○ ○] [▶] — sits below the slide area */
.hero-slider-ui {
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
}
.hero-slider-ui-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-3) var(--space-6);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.hero-slider-btn {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-family: var(--font-mono);
  font-size: 11px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: border-color 0.15s, color 0.15s;
}
.hero-slider-btn:hover {
  border-color: var(--color-green);
  color: var(--color-green);
}
.hero-slider-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }

.hero-dots {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;  /* padding on each .hero-dot provides the tap-target spacing */
}
.hero-dot {
  width: 6px;
  height: 6px;
  /* padding expands tap target to ~24px without affecting visual size */
  padding: 9px;
  box-sizing: content-box;
  background-color: var(--color-border);
  background-clip: content-box;
  border: none;
  cursor: pointer;
  transition: background-color 0.2s, transform 0.2s;
}
.hero-dot.is-active {
  background-color: var(--color-green);
  transform: scale(1.6);
}
.hero-dot:focus-visible { outline: none; box-shadow: var(--focus-ring); }


/* ── Compact hero slider (logged-in dashboard, beside the options panel) ── */
/* Reuses all .hero-slide* markup; shrinks height, drops the centered max-width
 * so it fills its grid column, and trims the title + padding to card scale.  */
.hero-slider--compact {
  border: 1px solid var(--color-border);
}
.hero-slider--compact .hero-slider-track { min-height: 300px; }
.hero-slider--compact .hero-slide-content {
  max-width: none;
  padding: var(--space-5);
  gap: var(--space-2);
}
.hero-slider--compact .hero-slide-title { font-size: var(--text-xl); }
.hero-slider--compact .hero-slider-ui {
  border-bottom: none;
  border-top: 1px solid var(--color-border);
}
.hero-slider--compact .hero-slider-ui-inner {
  max-width: none;
  padding: var(--space-2) var(--space-4);
}


/* ═══ Brand strip (logged-out, below hero slider) ═════════════════════════ */
.hero-brand-strip {
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg);
}
.hero-brand-strip-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-8) var(--space-6);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-10);
  align-items: center;
}
.hero-brand-title {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.hero-brand-sub {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
  max-width: 520px;
}
.hero-brand-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  min-width: 180px;
}

/* ── Responsive: hero slider + carousels + brand strip ──────────────────── */
@media (max-width: 640px) {
  .hero-slider-track        { min-height: 320px; }
  .hero-slide-title         { font-size: var(--text-2xl); }
  .hero-slide-content       { padding: var(--space-6) var(--space-4); }
  .hero-brand-strip-inner   { grid-template-columns: 1fr; gap: var(--space-4); }
  .hero-brand-actions       { flex-direction: row; flex-wrap: wrap; }
  .carousel-track .game-card          { flex: 0 0 185px; width: 185px; }
  .carousel--sm .carousel-track .game-card { flex: 0 0 150px; width: 150px; }
}


/* ═══ Alternate Themes ════════════════════════════════════════════════════ */
/* Each block overrides only the colour tokens; layout/spacing/fonts stay.  */

/* ── AMBER PHOSPHOR — warm 1980s amber CRT monitor ──────────────────────── */
html[data-theme="amber"] {
  --color-bg:           #090600;
  --color-bg-raised:    #0E0B00;
  --color-surface:      #141000;
  --color-surface-2:    #1C1600;
  --color-border:       #2E2400;
  --color-border-green: #FFB300;
  --color-border-pink:  #FF7700;
  --color-text:         #F0CB80;
  --color-text-muted:   #B0902F;   /* was #9B7A2E (4.48:1 — fails AA); #B0902F = 5.91:1 */
  --color-text-dim:     #9E8000;   /* was #907400 (4.02:1 — fails AA); #9E8000 = 4.76:1, stays below muted */
  --color-green:        #FFB300;
  --color-pink:         #FF7700;
  --color-yellow:       #FFE500;
  --color-blue:         #D4A800;
  --color-screen:       #060400;
  --color-primary:      #FFB300;
  --color-secondary:    #FF7700;
  --color-error:        #FF7700;
  --color-success:      #FFB300;
  --color-warning:      #FFE500;
}

/* ── COMMODORE 64 — iconic blue-and-tan home computer ───────────────────── */
html[data-theme="c64"] {
  --color-bg:           #3538B0;
  --color-bg-raised:    #2E30A0;
  --color-surface:      #3F44BC;
  --color-surface-2:    #4A50C8;
  --color-border:       #6068CC;
  --color-border-green: #AAAAFF;
  --color-border-pink:  #FF9900;
  --color-text:         #C0C8FF;
  --color-text-muted:   #8890CC;
  --color-text-dim:     #5560A8;
  --color-green:        #AAAAFF;
  --color-pink:         #FF9900;
  --color-yellow:       #FFFF00;
  --color-blue:         #8888FF;
  --color-screen:       #282090;
  --color-primary:      #AAAAFF;
  --color-secondary:    #FF9900;
  --color-error:        #FF9900;
  --color-success:      #AAAAFF;
  --color-warning:      #FFFF00;
}

/* ── EGA / DOS — harsh cyan and magenta on black, EGA palette ───────────── */
html[data-theme="ega"] {
  --color-bg:           #000000;
  --color-bg-raised:    #080808;
  --color-surface:      #080830;
  --color-surface-2:    #10104A;
  --color-border:       #222266;
  --color-border-green: #00FFFF;
  --color-border-pink:  #FF00FF;
  --color-text:         #AAAAEE;
  --color-text-muted:   #8585AE;
  --color-text-dim:     #6D6DB5;
  --color-green:        #00FFFF;
  --color-pink:         #FF00FF;
  --color-yellow:       #FFFF00;
  --color-blue:         #5555FF;
  --color-screen:       #000020;
  --color-primary:      #00FFFF;
  --color-secondary:    #FF00FF;
  --color-error:        #FF00FF;
  --color-success:      #00FFFF;
  --color-warning:      #FFFF00;
}

/* ── BLOODWARE — gothic horror, blood red on near-black ─────────────────── */
html[data-theme="bloodware"] {
  --color-bg:           #050003;
  --color-bg-raised:    #090005;
  --color-surface:      #100008;
  --color-surface-2:    #180010;
  --color-border:       #2D0018;
  --color-border-green: #F0302E;
  --color-border-pink:  #FF5555;
  --color-text:         #FFCCCC;
  --color-text-muted:   #B87878;
  --color-text-dim:     #AE6C6C;   /* was #A56363 (4.36:1 — fails AA); #AE6C6C = 4.93:1, stays below muted */
  --color-green:        #F0302E;  /* was #CC0000 — 3.5:1 on dark; #F0302E clears 4.5:1 */
  --color-pink:         #FF5555;
  --color-yellow:       #FF9900;
  --color-blue:         #990099;
  --color-screen:       #040002;
  --color-primary:      #F0302E;
  --color-secondary:    #FF5555;
  --color-error:        #FF5555;
  --color-success:      #F0302E;
  --color-warning:      #FF9900;
}
/* btn-primary in bloodware: #000 text on #F0302E bg = 5.16:1 — passes AA */

/* ── GAME BOY — four shades of classic LCD green ────────────────────────── */
html[data-theme="gameboy"] {
  --color-bg:           #0F380F;
  --color-bg-raised:    #0F380F;
  --color-surface:      #306230;
  --color-surface-2:    #4A7A4A;
  --color-border:       #306230;
  --color-border-green: #9BBC0F;
  --color-border-pink:  #8BAC0F;
  --color-text:         #9BBC0F;
  --color-text-muted:   #8BAC0F;
  --color-text-dim:     #306230;
  --color-green:        #9BBC0F;
  --color-pink:         #8BAC0F;
  --color-yellow:       #9BBC0F;
  --color-blue:         #8BAC0F;
  --color-screen:       #0F380F;
  --color-primary:      #9BBC0F;
  --color-secondary:    #8BAC0F;
  --color-error:        #8BAC0F;
  --color-success:      #9BBC0F;
  --color-warning:      #9BBC0F;
}

/* Caps Lock warning — 5th Game Boy shade for visibility (#DFFF6E ≈ 8.6:1 on #0F380F) */
html[data-theme="gameboy"] .caps-warn { color: #DFFF6E; }

/* ── AMBER contrast patches ─────────────────────────────────────────────── */
/* amber: --color-pink = #FF7700 (orange). White text = 3.96:1 — fails AA.
   Near-black #1A1100 on #FF7700 = 8.1:1 ✓ */
html[data-theme="amber"] .btn-pink,
html[data-theme="amber"] .btn-pink:hover { color: #1A1100; }
html[data-theme="amber"] .badge-tier2,
html[data-theme="amber"] .badge-featured { color: #1A1100; }
/* amber: --color-blue = #D4A800 (gold). White text = 2.23:1 — fails AA.
   Near-black #1A1100 on #D4A800 = 8.4:1 ✓ */
html[data-theme="amber"] .badge-buy { color: #1A1100; }

/* ── BLOODWARE contrast patches ─────────────────────────────────────────── */
/* bloodware: --color-pink = #FF5555. White text = 3.14:1 — fails AA.
   Near-black #1A0000 on #FF5555 = 6.4:1 ✓ (and 6.0:1 on the #FF33A0 hover bg) */
html[data-theme="bloodware"] .btn-pink,
html[data-theme="bloodware"] .btn-pink:hover,
html[data-theme="bloodware"] .badge-tier2,
html[data-theme="bloodware"] .badge-featured { color: #1A0000; }

/* badge-free chip bg is #333 globally; theme muted text fails AA on it
   (amber 3.14:1, bloodware 3.61:1). Darker chip bg restores ≥4.5:1. */
html[data-theme="amber"] .badge-free,
html[data-theme="bloodware"] .badge-free { background: #1A1A1A; }


/* ═══ Dev Status Strip ════════════════════════════════════════════════════ */
/* Slim full-width bar between card thumbnail and card body.
   --ds is set per-status class; the strip inherits color + bg from it.    */
.dev-status-strip {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-left: 3px solid var(--ds, #888);
  color: var(--ds, #888);
  background: color-mix(in srgb, var(--ds, #888) 14%, var(--color-surface));
  line-height: 1;
}
.dev-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--ds, #888);
  box-shadow: 0 0 6px var(--ds, #888);
  flex-shrink: 0;
}
.dev-status-initial { --ds: #8A8A8A; }
.dev-status-alpha   { --ds: #FF8A00; }
.dev-status-beta    { --ds: #19D3E6; }
.dev-status-rc      { --ds: #B07CFF; }

/* Detail-page banner: slightly larger, full bleed */
.dev-status-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 9px 16px;
  border-left: 4px solid var(--ds, #888);
  color: var(--ds, #888);
  background: color-mix(in srgb, var(--ds, #888) 12%, var(--color-surface));
  margin-bottom: 20px;
}
.dev-status-banner .dev-status-dot {
  width: 9px;
  height: 9px;
}
.dev-status-banner .dev-status-label {
  flex: 1;
}
.dev-status-banner .dev-status-desc {
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  color: var(--color-text-muted);
  font-family: var(--font-body);
}

/* Caps Lock warning hint on password fields (standing-rules skill) */
.caps-warn{display:flex;align-items:center;gap:6px;margin-top:.5rem;
  font-size:.8rem;font-weight:600;color:var(--color-pink,#c0272d)}
.caps-warn[hidden]{display:none}

/* ── First-party analytics dashboard (analytics skill) ──────────────────── */
/* Controls row */
.analytics-controls { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.analytics-range { display: flex; align-items: center; gap: .5rem; font-size: .9rem; }
.analytics-export { display: flex; align-items: center; gap: .3rem; font-size: .82rem; }

/* KPI strip */
.analytics-kpi-strip {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: .75rem;
  margin-bottom: 1.5rem;
}
.analytics-kpi {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  background: var(--color-surface); border: 1px solid var(--color-border,#333);
  border-radius: 4px; padding: .85rem .75rem .65rem;
  position: relative;
}
.analytics-kpi--alert { border-color: transparent; }
.analytics-kpi-label {
  font-size: .68rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .04em; color: var(--color-text-muted); margin-bottom: .25rem;
  display: flex; align-items: center; gap: .25rem; flex-wrap: wrap; justify-content: center;
}
.analytics-kpi-num { font-size: 1.85rem; font-weight: 700; color: var(--color-text); line-height: 1.1; }
.analytics-kpi-delta {
  font-size: .72rem; font-weight: 600; margin-top: .2rem;
  padding: .1rem .4rem; border-radius: 999px;
}
.delta-up   { color: #22c55e; background: #22c55e15; }
.delta-down { color: #ef4444; background: #ef444415; }
.kpi-warn { color: #f59e0b; }
.kpi-ok   { color: #22c55e; }

/* Beacon stats bar */
.analytics-beacon-bar {
  display: flex; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap;
}
.beacon-stat {
  display: flex; align-items: center; gap: .4rem;
  background: var(--color-surface); border: 1px solid var(--color-border,#333);
  border-radius: 4px; padding: .45rem .85rem;
  font-size: .82rem;
}
.beacon-stat-label {
  color: var(--color-text-muted); font-size: .72rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .04em;
  display: flex; align-items: center; gap: .2rem;
}
.beacon-stat-val { font-weight: 700; color: var(--color-text); }

/* Daily trend */
.analytics-daily-panel { margin-bottom: 1.5rem; }
.analytics-bar-cell { width: 38%; }
.analytics-bar {
  display: block; height: 10px;
  background: var(--color-green); border-radius: 2px; min-width: 2px;
  width: 0; /* JS sets this from data-pct */
}

/* Breakdown panels */
.analytics-breakdown-row,
.analytics-secondary-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-bottom: 1rem;
}
.analytics-secondary-row { grid-template-columns: repeat(2, 1fr); margin-bottom: 1.5rem; }
.analytics-breakdown-panel { margin-bottom: 0; }
.analytics-breakdown-list { padding: .5rem .75rem .75rem; }
.analytics-breakdown-list--wide { display: grid; grid-template-columns: repeat(2, 1fr); gap: .1rem .5rem; }
.breakdown-item {
  display: grid;
  grid-template-columns: 6.5rem 1fr 2.5rem 2.75rem;
  align-items: center;
  gap: .4rem;
  padding: .25rem 0;
  border-bottom: 1px solid var(--color-border,#333);
  font-size: .82rem;
}
.breakdown-item:last-child { border-bottom: none; }
.breakdown-label { color: var(--color-text); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.breakdown-bar-wrap { overflow: hidden; }
.breakdown-bar { height: 8px; border-radius: 2px; }
.analytics-bar--new       { background: #22c55e; }
.analytics-bar--returning { background: #8b5cf6; }
.analytics-bar--bot       { background: #f59e0b; }
.breakdown-count { text-align: right; color: var(--color-text); font-variant-numeric: tabular-nums; }
.breakdown-pct   { text-align: right; color: var(--color-text-muted); font-size: .72rem; font-variant-numeric: tabular-nums; }

/* Two-column table panels */
.analytics-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.5rem; }
.analytics-panel { margin-bottom: 0; }
.analytics-wide-panel { margin-bottom: 1rem; }

/* Tooltip system */
.tip-wrap {
  display: inline-flex; align-items: center;
  position: relative; vertical-align: middle;
}
.tip-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1rem; height: 1rem; padding: 0;
  font-size: .68rem; font-weight: 700; line-height: 1;
  color: var(--color-text-muted); background: none; border: 1px solid var(--color-border,#333);
  border-radius: 50%; cursor: help;
  margin-left: .25rem; flex-shrink: 0;
  transition: color .15s, border-color .15s;
}
.tip-btn:hover,
.tip-btn:focus { color: var(--color-green); border-color: var(--color-green); outline: none; }
.tip-pop {
  position: absolute;
  top: calc(100% + .35rem);
  z-index: 200;
  width: 320px;
  max-width: min(320px, 90vw);
  background: var(--color-bg-secondary,#1a1a1a);
  border: 1px solid var(--color-border,#333);
  border-radius: 4px;
  padding: .6rem .75rem;
  font-size: .78rem;
  line-height: 1.55;
  color: var(--color-text);
  box-shadow: 0 4px 16px #0006;
  pointer-events: auto;
  text-align: left;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}
.tip-pop[hidden] { display: none; }

/* Deploy status badge */
.deploy-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.72rem; font-family: var(--font-mono);
  padding: 3px 8px; border-radius: 3px;
}
.deploy-badge--ok    { color: var(--color-green); }
.deploy-badge--stale { color: #f59e0b; }
.deploy-badge--dead  { color: var(--color-pink); }

/* Responsive */
@media (max-width: 900px) {
  .analytics-kpi-strip { grid-template-columns: repeat(3, 1fr); }
  .analytics-breakdown-row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .analytics-kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .analytics-breakdown-row,
  .analytics-secondary-row { grid-template-columns: 1fr; }
  .analytics-cols { grid-template-columns: 1fr; }
  .analytics-breakdown-list--wide { grid-template-columns: 1fr; }
  .breakdown-item { grid-template-columns: 5.5rem 1fr 2.2rem 2.5rem; }
}
