/* ======================================================
   Mini-Game shared styles (matches portfolio themes)
   ====================================================== */
*, *::before, *::after { box-sizing: border-box; }

:root, [data-theme="cyber"] {
  --bg:#050d1a; --bg2:#080f1f; --bg3:#0a1628;
  --panel:#0d1f38; --panel2:#0f2540;
  --accent:#00e5ff; --accent2:#00ff9d; --accent3:#ff6b35;
  --text:#c8d8e8; --text-dim:#6a8099;
  --border:rgba(0,229,255,0.18); --border-bright:rgba(0,229,255,0.45);
  --grid-line:rgba(0,229,255,0.08);
  --sky-1:#0a1628; --sky-2:#050d1a;
}
[data-theme="gold"] {
  --bg:#0c0a08; --bg2:#100e0b; --bg3:#14110d;
  --panel:#1a1510; --panel2:#201a12;
  --accent:#c9a84c; --accent2:#f0c060; --accent3:#cd8040;
  --text:#ccc8c0; --text-dim:#706860;
  --border:rgba(201,168,76,0.18); --border-bright:rgba(201,168,76,0.45);
  --grid-line:rgba(201,168,76,0.08);
  --sky-1:#1a1510; --sky-2:#0c0a08;
}
[data-theme="aurora"] {
  --bg:#0a0612; --bg2:#0d0918; --bg3:#0f0b1e;
  --panel:#160d28; --panel2:#1c1132;
  --accent:#a855f7; --accent2:#22d3ee; --accent3:#f472b6;
  --text:#d4c8f0; --text-dim:#7060a0;
  --border:rgba(168,85,247,0.2); --border-bright:rgba(168,85,247,0.5);
  --grid-line:rgba(168,85,247,0.08);
  --sky-1:#160d28; --sky-2:#0a0612;
}

html, body { margin: 0; padding: 0; min-height: 100%; }
body.game-body {
  font-family: 'Share Tech Mono', monospace;
  color: var(--text);
  background:
    radial-gradient(ellipse at 20% 0%, rgba(255,255,255,0.04) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 100%, var(--border) 0%, transparent 55%),
    var(--bg);
  background-attachment: fixed;
  overflow-x: hidden;
}

/* ===== LOADER ===== */
.game-loader {
  position: fixed; inset: 0;
  z-index: 1000;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 18px;
  background: var(--bg);
  transition: opacity 0.45s ease;
}
.game-loader.fade-out { opacity: 0; pointer-events: none; }
.loader-logo {
  font-family: 'Orbitron', sans-serif;
  font-size: 1rem; letter-spacing: 4px;
  color: var(--accent);
  opacity: 0.8;
}
.loader-title {
  font-family: 'Orbitron', sans-serif;
  font-size: clamp(1.6rem, 5vw, 2.6rem);
  font-weight: 800; letter-spacing: 4px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: loaderGlow 2s ease-in-out infinite;
}
@keyframes loaderGlow {
  0%, 100% { filter: drop-shadow(0 0 8px var(--accent)); }
  50%      { filter: drop-shadow(0 0 22px var(--accent)); }
}
.loader-bar {
  width: min(380px, 75vw);
  height: 6px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.loader-fill {
  width: 0%; height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  box-shadow: 0 0 14px var(--accent);
  transition: width 0.18s linear;
}
.loader-status {
  font-size: 0.78rem; color: var(--text-dim); letter-spacing: 2px;
}

/* ===== TOPBAR ===== */
.game-topbar {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--border);
  background: rgba(5,8,18,0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 50;
}
.game-back-row { display: flex; gap: 6px; flex-shrink: 0; }
.game-back {
  font-family: 'Share Tech Mono', monospace;
  text-decoration: none;
  color: var(--text);
  background: var(--panel);
  border: 1px solid var(--border-bright);
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 0.82rem;
  letter-spacing: 1px;
  transition: all 0.2s;
  white-space: nowrap;
}
.game-back:hover {
  background: var(--accent); color: var(--bg);
  box-shadow: 0 0 16px var(--accent);
}
.game-back.ghost {
  background: transparent; color: var(--text-dim);
}
.game-back.ghost:hover {
  background: var(--bg3); color: var(--accent);
  border-color: var(--accent);
}
.game-title-wrap { flex: 1; text-align: center; }
.game-tag {
  font-size: 0.7rem; letter-spacing: 3px; color: var(--accent); opacity: 0.8;
}
.game-title {
  margin: 2px 0 0; font-family: 'Orbitron', sans-serif;
  font-size: clamp(1rem, 2.6vw, 1.4rem);
  letter-spacing: 3px; font-weight: 800;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.game-theme-switch { display: flex; gap: 6px; }
.gts-btn {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--panel); border: 1px solid var(--border);
  cursor: pointer; padding: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.gts-btn:hover { transform: scale(1.1); }
.gts-btn.active { border-color: var(--accent); box-shadow: 0 0 10px var(--border-bright); }
.gts-btn span { display: block; width: 12px; height: 12px; border-radius: 50%; }

/* ===== HUD ===== */
.game-hud {
  display: flex; gap: 10px;
  padding: 16px 22px 4px;
  justify-content: center; flex-wrap: wrap;
}
.hud-block {
  display: flex; flex-direction: column; align-items: center;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 8px 18px;
  min-width: 90px;
}
.hud-label { font-size: 0.65rem; letter-spacing: 2px; color: var(--text-dim); }
.hud-val   {
  font-family: 'Orbitron', sans-serif; font-size: 1.4rem; font-weight: 800;
  color: var(--accent); text-shadow: 0 0 10px var(--border-bright);
}

/* ===== STAGE ===== */
.game-stage {
  position: relative;
  display: flex; flex-direction: column; align-items: center;
  padding: 16px;
}
#gameCanvas {
  display: block;
  max-width: 96vw;
  width: auto;
  height: auto;
  border: 1px solid var(--border-bright);
  border-radius: 14px;
  box-shadow: 0 16px 40px rgba(0,0,0,0.45), 0 0 30px var(--border);
  background: linear-gradient(180deg, var(--sky-1), var(--sky-2));
  cursor: pointer;
  touch-action: manipulation;
}
/* Wide canvases (runner-like) */
.canvas-wide #gameCanvas { width: min(900px, 96vw); aspect-ratio: 900 / 320; height: auto; }
/* Wide-tall (pong) */
.canvas-pong #gameCanvas { width: min(900px, 96vw); aspect-ratio: 9 / 5; height: auto; }
/* Tall canvases */
.canvas-tall #gameCanvas { width: min(540px, 90vw); aspect-ratio: 540 / 640; height: auto; }
/* Square canvases */
.canvas-square #gameCanvas { width: min(600px, 92vw); aspect-ratio: 1 / 1; height: auto; }

/* ===== OVERLAY ===== */
.game-overlay {
  position: absolute;
  inset: 16px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 12px;
  background: rgba(5,8,18,0.65);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border-radius: 14px;
  text-align: center; padding: 20px;
}
.game-overlay.hidden { display: none; }
.overlay-title {
  margin: 0;
  font-family: 'Orbitron', sans-serif;
  font-size: clamp(1.6rem, 5vw, 2.4rem);
  font-weight: 800; letter-spacing: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.overlay-title.overlay-over {
  background: linear-gradient(90deg, var(--accent3), var(--accent));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.overlay-sub {
  margin: 0; color: var(--text-dim);
  font-size: 0.92rem; letter-spacing: 1px;
  max-width: 480px;
}
.overlay-sub kbd {
  background: var(--panel); border: 1px solid var(--border);
  padding: 2px 8px; border-radius: 4px;
  font-family: 'Share Tech Mono', monospace; color: var(--accent);
  font-size: 0.78rem;
}
.overlay-btn {
  margin-top: 8px;
  font-family: 'Orbitron', sans-serif; font-weight: 800;
  font-size: 0.95rem; letter-spacing: 2px;
  padding: 12px 26px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: var(--bg);
  border: 0; border-radius: 10px;
  cursor: pointer;
  box-shadow: 0 0 20px var(--border-bright);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.overlay-btn.small { padding: 10px 18px; font-size: 0.8rem; letter-spacing: 1.5px; }
.overlay-btn.ghost {
  background: transparent; color: var(--accent);
  border: 1px solid var(--border-bright); box-shadow: none;
}
.overlay-btn:hover { transform: translateY(-2px); box-shadow: 0 0 30px var(--accent); }
.overlay-link {
  display: inline-block; margin-top: 6px;
  color: var(--text-dim); text-decoration: none;
  font-size: 0.78rem; letter-spacing: 1.5px;
}
.overlay-link:hover { color: var(--accent); }

/* ===== FOOTER ===== */
.game-footer {
  text-align: center; padding: 26px 16px 18px;
  font-size: 0.72rem; letter-spacing: 2px; color: var(--text-dim);
  opacity: 0.7;
}

/* ===========================================================
   TIC TAC TOE
   =========================================================== */
.ttt-stage { padding-top: 6px; }

.ttt-diff {
  display: flex; gap: 8px; align-items: center;
  justify-content: center;
  padding: 6px 16px 0; flex-wrap: wrap;
}
.ttt-diff-label {
  font-size: 0.7rem; letter-spacing: 2px; color: var(--text-dim);
  margin-right: 4px;
}
.diff-btn {
  font-family: 'Share Tech Mono', monospace; font-size: 0.78rem;
  letter-spacing: 1px;
  background: var(--panel); color: var(--text);
  border: 1px solid var(--border); border-radius: 8px;
  padding: 6px 14px; cursor: pointer;
  transition: all 0.2s;
}
.diff-btn:hover { border-color: var(--border-bright); }
.diff-btn.active {
  background: var(--accent); color: var(--bg);
  border-color: var(--accent); box-shadow: 0 0 12px var(--border-bright);
}

.ttt-status {
  margin-top: 14px;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.95rem; letter-spacing: 1.5px;
  color: var(--text);
  min-height: 1.4em;
}

.ttt-board {
  --cell: clamp(72px, 22vw, 120px);
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, var(--cell));
  grid-template-rows: repeat(3, var(--cell));
  gap: 8px;
  margin: 16px auto;
  padding: 12px;
  background: var(--panel);
  border: 1px solid var(--border-bright);
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(0,0,0,0.45), 0 0 30px var(--border);
}
.ttt-cell {
  position: relative;
  width: var(--cell); height: var(--cell);
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  font-family: 'Orbitron', sans-serif;
  font-size: calc(var(--cell) * 0.55);
  font-weight: 800;
  color: var(--text);
  display: flex; align-items: center; justify-content: center;
  transition: transform 0.15s ease, border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}
.ttt-cell:hover:not(:disabled) {
  transform: translateY(-2px);
  border-color: var(--accent);
  box-shadow: 0 0 18px var(--border-bright);
}
.ttt-cell.x { color: var(--accent); text-shadow: 0 0 14px var(--accent); }
.ttt-cell.o { color: var(--accent3); text-shadow: 0 0 14px var(--accent3); }
.ttt-cell.win { background: var(--bg2); border-color: var(--accent2); box-shadow: 0 0 22px var(--accent2); }
.ttt-cell.placed { animation: cellPop 0.32s cubic-bezier(0.34, 1.56, 0.64, 1); }
@keyframes cellPop {
  from { transform: scale(0.4); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}
.ttt-cell:disabled { cursor: default; }

.ttt-line {
  position: absolute; inset: 12px;
  pointer-events: none;
  width: calc(100% - 24px); height: calc(100% - 24px);
  color: var(--accent2);
  filter: drop-shadow(0 0 8px var(--accent2));
  opacity: 0;
  transition: opacity 0.3s;
}
.ttt-line.show { opacity: 1; }
.ttt-line line {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  transition: stroke-dashoffset 0.5s ease-out;
}
.ttt-line.show line { stroke-dashoffset: 0; }

.ttt-actions {
  display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
  align-items: center;
  margin-top: 4px;
}
.hud-block.ttt-you  .hud-val { color: var(--accent);  text-shadow: 0 0 10px var(--accent); }
.hud-block.ttt-ai   .hud-val { color: var(--accent3); text-shadow: 0 0 10px var(--accent3); }
.hud-block.ttt-draw .hud-val { color: var(--accent2); text-shadow: 0 0 10px var(--accent2); }

@media (max-width: 600px) {
  .game-topbar { padding: 10px 12px; gap: 8px; }
  .game-back { padding: 6px 10px; font-size: 0.78rem; }
  .game-title { font-size: 0.95rem; letter-spacing: 2px; }
  .gts-btn { width: 24px; height: 24px; }
  .gts-btn span { width: 10px; height: 10px; }
  .hud-block { padding: 6px 12px; min-width: 70px; }
  .hud-val { font-size: 1.1rem; }
}


/* ===========================================================
   GAME ZONE HUB
   =========================================================== */
.zone-wrap {
  max-width: 920px;
  margin: 0 auto;
  padding: 24px 18px 40px;
}
.zone-header {
  text-align: center;
  margin-bottom: 24px;
}
.zone-tag {
  display: inline-block;
  font-size: 0.72rem; letter-spacing: 3px; color: var(--accent);
  opacity: 0.85;
}
.zone-title {
  margin: 4px 0 6px;
  font-family: 'Orbitron', sans-serif;
  font-size: clamp(1.8rem, 5vw, 2.6rem);
  font-weight: 800; letter-spacing: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.zone-sub {
  color: var(--text-dim);
  font-size: 0.9rem;
  margin: 0;
}
.zone-list {
  display: flex; flex-direction: column;
  gap: 10px;
  margin-top: 12px;
}
/* Reuse the game-row from main popup — replicate styles for hub */
.zone-row {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 14px;
  padding: 13px 18px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  text-decoration: none;
  color: var(--text);
  overflow: hidden;
  transition: transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1),
              border-color 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
  isolation: isolate;
  will-change: transform;
}
.zone-row::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, var(--border-bright), transparent);
  transform: translateX(-100%);
  transition: transform 0.55s ease;
  pointer-events: none;
  opacity: 0.4;
  z-index: -1;
}
.zone-row:hover {
  border-color: var(--border-bright);
  background: var(--panel2);
  box-shadow: 0 8px 22px rgba(0,0,0,0.35), 0 0 18px var(--border-bright);
}
.zone-row:hover::before { transform: translateX(100%); }
.zone-row-icon {
  font-size: 1.9rem; line-height: 1;
  filter: drop-shadow(0 0 8px var(--accent));
  transition: transform 0.25s ease;
}
.zone-row:hover .zone-row-icon { transform: scale(1.18) rotate(-8deg); }
.zone-row-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.zone-row-title {
  font-family: 'Orbitron', sans-serif;
  font-size: 1.05rem; letter-spacing: 0.5px; color: var(--text);
}
.zone-row-desc {
  font-size: 0.8rem; color: var(--text-dim); line-height: 1.4;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.zone-row-meta { display: flex; gap: 5px; flex-shrink: 0; }
.zone-row-chip {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.66rem; letter-spacing: 0.5px;
  padding: 3px 8px; border-radius: 30px;
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--accent);
}
.zone-row-cta {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.84rem; letter-spacing: 1px;
  color: var(--accent); white-space: nowrap;
  transition: text-shadow 0.2s, transform 0.2s;
}
.zone-row:hover .zone-row-cta {
  text-shadow: 0 0 10px var(--accent); transform: translateX(3px);
}
@media (max-width: 600px) {
  .zone-row { grid-template-columns: auto 1fr auto; padding: 11px 14px; gap: 10px; }
  .zone-row-meta { display: none; }
  .zone-row-icon { font-size: 1.6rem; }
  .zone-row-title { font-size: 0.95rem; }
  .zone-row-desc { font-size: 0.72rem; }
  .zone-row-cta { font-size: 0.76rem; }
}

/* RPS / Guess simple game pages */
.simple-game-stage {
  max-width: 640px;
  margin: 0 auto;
  padding: 20px 18px 30px;
  text-align: center;
}
.rps-buttons {
  display: flex; gap: 14px; flex-wrap: wrap;
  justify-content: center;
  margin: 22px 0 14px;
}
.rps-btn {
  width: 110px; height: 110px;
  font-size: 3rem;
  background: var(--panel);
  border: 1px solid var(--border-bright);
  border-radius: 18px;
  cursor: pointer;
  transition: all 0.2s;
  display: flex; align-items: center; justify-content: center;
}
.rps-btn:hover {
  transform: translateY(-4px) scale(1.05);
  background: var(--panel2);
  box-shadow: 0 10px 26px rgba(0,0,0,0.35), 0 0 22px var(--border-bright);
}
.rps-arena {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 14px;
  margin: 26px 0 14px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 22px 14px;
}
.rps-side { text-align: center; }
.rps-side-label { font-size: 0.72rem; letter-spacing: 2px; color: var(--text-dim); display: block; margin-bottom: 8px; }
.rps-emoji {
  font-size: 3.4rem;
  display: inline-block;
  filter: drop-shadow(0 0 14px var(--accent));
  min-height: 4rem;
}
.rps-emoji.shake { animation: rpsShake 0.5s ease-in-out; }
@keyframes rpsShake {
  0%,100% { transform: rotate(0); }
  20% { transform: rotate(-15deg) translateY(-4px); }
  40% { transform: rotate(15deg) translateY(-4px); }
  60% { transform: rotate(-10deg); }
  80% { transform: rotate(10deg); }
}
.rps-vs {
  font-family: 'Orbitron', sans-serif; font-size: 1.2rem;
  font-weight: 800; color: var(--accent);
  text-shadow: 0 0 12px var(--accent);
}
.rps-result {
  font-family: 'Orbitron', sans-serif;
  font-size: 1.2rem; letter-spacing: 1.5px;
  margin: 8px 0 4px;
  min-height: 1.4em;
}
.rps-result.win  { color: var(--accent2); text-shadow: 0 0 10px var(--accent2); }
.rps-result.lose { color: var(--accent3); text-shadow: 0 0 10px var(--accent3); }
.rps-result.draw { color: var(--text-dim); }

.guess-input-wrap {
  display: flex; gap: 10px; justify-content: center;
  margin: 18px 0;
}
.guess-input {
  font-family: 'Share Tech Mono', monospace;
  font-size: 1.4rem;
  width: 140px;
  padding: 10px 14px;
  text-align: center;
  background: var(--bg3);
  border: 1px solid var(--border-bright);
  border-radius: 10px;
  color: var(--accent);
  letter-spacing: 2px;
}
.guess-input:focus { outline: none; box-shadow: 0 0 16px var(--border-bright); }
.guess-feedback {
  font-family: 'Orbitron', sans-serif;
  font-size: 1.4rem; letter-spacing: 1px;
  min-height: 1.6em; margin: 8px 0;
  color: var(--text);
}
.guess-feedback.too-low  { color: var(--accent2); text-shadow: 0 0 10px var(--accent2); }
.guess-feedback.too-high { color: var(--accent3); text-shadow: 0 0 10px var(--accent3); }
.guess-feedback.win      { color: var(--accent); text-shadow: 0 0 14px var(--accent); }
.guess-history {
  display: flex; gap: 6px; flex-wrap: wrap;
  justify-content: center;
  margin: 14px 0;
  min-height: 32px;
}
.guess-pill {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.85rem;
  padding: 4px 10px;
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 30px;
  color: var(--text-dim);
}


/* ===========================================================
   MOBILE ON-SCREEN CONTROLS (touch devices only)
   =========================================================== */
.mobile-controls {
  display: none; /* hidden on desktop */
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 100;
  padding: 10px 16px max(12px, env(safe-area-inset-bottom));
  background: linear-gradient(to top, rgba(5,8,18,0.92) 0%, transparent 100%);
  pointer-events: none; /* children handle their own events */
  user-select: none;
  -webkit-user-select: none;
}
@media (hover: none) and (pointer: coarse) {
  .mobile-controls { display: flex; }
}

/* ---- Layout variants ---- */
.mc-lr {
  /* Left / Right only (runner, brick, shooter, pong, asteroid, pixel drop) */
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
}
.mc-dpad {
  /* Full D-pad (snake) */
  justify-content: center;
  align-items: flex-end;
}
.mc-tap {
  /* Single big tap area (flappy) */
  justify-content: center;
  align-items: flex-end;
}

/* ---- Base button ---- */
.mc-btn {
  pointer-events: all;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.08);
  border: 1.5px solid var(--border-bright);
  border-radius: 14px;
  color: var(--accent);
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.1s, transform 0.1s;
  touch-action: manipulation;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.mc-btn:active, .mc-btn.pressed {
  background: rgba(var(--accent-rgb, 0,229,255), 0.22);
  transform: scale(0.93);
  box-shadow: 0 0 14px var(--border-bright);
}

/* Size variants */
.mc-btn-lg  { width: 72px; height: 72px; font-size: 2rem; border-radius: 18px; }
.mc-btn-md  { width: 60px; height: 60px; }
.mc-btn-sm  { width: 50px; height: 50px; font-size: 1.3rem; border-radius: 12px; }
.mc-btn-xl  { width: 160px; height: 64px; font-size: 1.4rem; border-radius: 20px; letter-spacing: 2px; font-family: 'Orbitron', sans-serif; }

/* ---- D-pad layout ---- */
.mc-dpad-grid {
  display: grid;
  grid-template-columns: 50px 50px 50px;
  grid-template-rows: 50px 50px 50px;
  gap: 4px;
}
.mc-dpad-grid .mc-up    { grid-column: 2; grid-row: 1; }
.mc-dpad-grid .mc-left  { grid-column: 1; grid-row: 2; }
.mc-dpad-grid .mc-center{ grid-column: 2; grid-row: 2; opacity: 0.3; pointer-events: none; }
.mc-dpad-grid .mc-right { grid-column: 3; grid-row: 2; }
.mc-dpad-grid .mc-down  { grid-column: 2; grid-row: 3; }

/* ---- Runner: left side = duck, right side = jump ---- */
.mc-runner {
  justify-content: space-between;
  align-items: flex-end;
}
.mc-runner .mc-duck { align-self: flex-end; }
.mc-runner .mc-jump { align-self: flex-end; }

/* ---- Pong: vertical buttons ---- */
.mc-pong {
  justify-content: flex-start;
  align-items: flex-end;
  gap: 10px;
}
.mc-pong-col {
  display: flex;
  flex-direction: column;
  gap: 8px;
}


/* ===========================================================
   LEVEL SELECTOR (shared across all games)
   =========================================================== */
.game-level-wrap {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  padding: 6px 16px 0;
  flex-wrap: wrap;
}
.game-level-label {
  font-size: 0.7rem;
  letter-spacing: 2px;
  color: var(--text-dim);
  margin-right: 4px;
}
.level-btn {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.78rem;
  letter-spacing: 1px;
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 6px 14px;
  cursor: pointer;
  transition: all 0.2s;
}
.level-btn:hover { border-color: var(--border-bright); }
.level-btn.active {
  background: var(--accent);
  color: var(--bg);
  border-color: var(--accent);
  box-shadow: 0 0 12px var(--border-bright);
}
.level-btn[data-level="easy"].active   { background: var(--accent2); border-color: var(--accent2); box-shadow: 0 0 12px var(--accent2); }
.level-btn[data-level="medium"].active { background: var(--accent);  border-color: var(--accent); }
.level-btn[data-level="hard"].active   { background: var(--accent3); border-color: var(--accent3); box-shadow: 0 0 12px var(--accent3); }


