/* Stranger Things Quiz Room — 80s Hawkins navy + Christmas-light reds */

:root {
  --qr-bg: #0a0d1a;
  --qr-bg-elev: #131933;
  --qr-fg: #f1ecdc;
  --qr-fg-dim: #8c8aa8;
  --qr-accent: #ed1c24;            /* Christmas red */
  --qr-accent-dim: #7c1014;
  --qr-warn: #f7c548;               /* light bulb yellow */
  --qr-danger: #c1102b;
  --qr-uvg: #5b3a93;                /* Upside Down purple */
  --qr-radius: 6px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  padding: 0;
  background: var(--qr-bg);
  color: var(--qr-fg);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#qr-root {
  width: 100%;
  max-width: 480px;
  padding: 24px 16px;
}

.qr-stage { display: flex; flex-direction: column; gap: 16px; }

.qr-progress {
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  color: var(--qr-fg-dim);
  text-align: right;
  letter-spacing: 1px;
}

.qr-board {
  background: var(--qr-bg-elev);
  border: 1px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  padding: 20px 16px;
  min-height: 320px;
}

.qr-scene {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 0 16px;
  border: 1px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  background: var(--qr-bg);
  image-rendering: pixelated;
}

.qr-btn {
  appearance: none;
  background: var(--qr-accent);
  color: #fff;
  border: none;
  border-radius: var(--qr-radius);
  padding: 12px 20px;
  font-family: 'Press Start 2P', monospace;
  font-size: 12px;
  cursor: pointer;
  letter-spacing: 1px;
  width: 100%;
  margin-top: 16px;
  min-height: 44px;
  transition: filter 100ms;
}
.qr-btn:hover { filter: brightness(1.1); }
.qr-btn:disabled { opacity: 0.5; cursor: not-allowed; filter: grayscale(0.6); }
.qr-btn-sm { font-size: 10px; padding: 6px 12px; min-height: 32px; width: auto; margin-top: 0; }

.qr-hint {
  font-size: 12px;
  color: var(--qr-warn);
  font-style: italic;
  margin-top: 8px;
  opacity: 0;
  transition: opacity 400ms;
}
.qr-hint-visible { opacity: 1; }

.qr-resume-banner {
  background: var(--qr-bg-elev);
  border: 1px solid var(--qr-warn);
  border-radius: var(--qr-radius);
  padding: 12px;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  flex-wrap: wrap;
}

.qr-result { text-align: center; padding: 24px 0; }
.qr-result-sprite-wrap { margin-bottom: 16px; }
.qr-result-sprite {
  width: 192px;
  height: 192px;
  image-rendering: pixelated;
  border: 4px solid var(--qr-accent);
  border-radius: var(--qr-radius);
  background: rgba(237, 28, 36, 0.05);
}
.qr-result-eyebrow {
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  color: var(--qr-accent);
  letter-spacing: 2px;
  margin-bottom: 4px;
}
.qr-result-name {
  font-family: 'Press Start 2P', monospace;
  font-size: 20px;
  margin: 4px 0 8px;
  letter-spacing: 1px;
}
.qr-result-tagline { font-style: italic; color: var(--qr-fg-dim); font-size: 14px; margin-top: 0; }
.qr-result-desc { line-height: 1.6; padding: 0 8px; text-align: left; }
.qr-result-runner { color: var(--qr-fg-dim); font-size: 13px; margin-top: 12px; }
.qr-result-receipts {
  margin-top: 24px;
  padding: 12px 16px;
  background: var(--qr-bg-elev);
  border-radius: var(--qr-radius);
  text-align: left;
}
.qr-result-receipts h3 {
  font-family: 'Press Start 2P', monospace;
  font-size: 12px;
  color: var(--qr-accent);
  margin: 0 0 8px;
}
.qr-result-receipts ul {
  margin: 0;
  padding-left: 20px;
  color: var(--qr-fg-dim);
  font-size: 13px;
  line-height: 1.6;
}

@keyframes qrShake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-4px); }
  75% { transform: translateX(4px); }
}
@keyframes qrFlicker {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* === Puzzle 1: Christmas Lights === */
.qr-lt-prompt { margin-bottom: 12px; }
.qr-lt-counter {
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  color: var(--qr-fg-dim);
  margin-bottom: 12px;
  text-align: center;
}
.qr-lt-counter span { color: var(--qr-warn); }
.qr-lt-counter.complete span { color: var(--qr-accent); }
.qr-lt-input {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-bottom: 12px;
  font-family: 'Press Start 2P', monospace;
  font-size: 18px;
  letter-spacing: 4px;
  color: var(--qr-warn);
  min-height: 28px;
}
.qr-lt-input span {
  display: inline-block;
  width: 28px;
  text-align: center;
  border-bottom: 2px solid var(--qr-accent-dim);
  padding-bottom: 2px;
}
.qr-lt-input span.filled { color: var(--qr-warn); border-color: var(--qr-warn); }
.qr-lt-wall {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
  background: rgba(255, 255, 255, 0.04);
  padding: 8px;
  border-radius: var(--qr-radius);
  margin-bottom: 12px;
}
.qr-lt-bulb {
  appearance: none;
  position: relative;
  aspect-ratio: 1;
  min-height: 44px;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 0;
}
.qr-lt-bulb::after {
  content: attr(data-letter);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Press Start 2P', monospace;
  font-size: 13px;
  color: var(--qr-fg);
  text-shadow: 0 0 3px var(--qr-bg);
  pointer-events: none;
}
.qr-lt-bulb img {
  width: 100%;
  height: 100%;
  image-rendering: pixelated;
  display: block;
}
.qr-lt-bulb.lit img { animation: qrFlicker 1.6s infinite ease-in-out; }
.qr-lt-bulb.tapped::after { color: var(--qr-warn); }

.qr-lt-actions { display: flex; gap: 8px; margin-top: 12px; }
.qr-lt-actions .qr-btn { margin-top: 0; width: auto; flex: 1; }
.qr-lt-actions .qr-lt-clear { background: var(--qr-fg-dim); color: var(--qr-bg); }

.qr-lt-meaning {
  background: rgba(247, 197, 72, 0.06);
  border: 1px dashed var(--qr-warn);
  border-radius: var(--qr-radius);
  padding: 12px;
  margin-top: 12px;
}
.qr-lt-meaning h3 {
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  color: var(--qr-warn);
  margin: 0 0 8px;
}
.qr-lt-interpretation {
  appearance: none;
  display: block;
  width: 100%;
  background: var(--qr-bg);
  border: 2px solid var(--qr-accent-dim);
  color: var(--qr-fg);
  border-radius: var(--qr-radius);
  padding: 10px 12px;
  margin-bottom: 6px;
  font-family: inherit;
  font-size: 13px;
  text-align: left;
  cursor: pointer;
  min-height: 44px;
}
.qr-lt-interpretation:hover { border-color: var(--qr-accent); }
.qr-lt-interpretation.picked { background: rgba(237, 28, 36, 0.16); border-color: var(--qr-accent); }

/* === Puzzle 2: D&D === */
.qr-dnd-prompt { margin-bottom: 12px; }
.qr-dnd-scenario {
  background: rgba(247, 197, 72, 0.05);
  border: 1px dashed var(--qr-warn);
  border-radius: var(--qr-radius);
  padding: 12px;
  font-style: italic;
  margin-bottom: 12px;
  font-size: 13px;
  line-height: 1.5;
}
.qr-dnd-roles {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.qr-dnd-role {
  appearance: none;
  background: var(--qr-bg);
  border: 2px solid var(--qr-accent-dim);
  color: var(--qr-fg);
  border-radius: var(--qr-radius);
  padding: 12px;
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  min-height: 56px;
}
.qr-dnd-role:hover { border-color: var(--qr-accent); }
.qr-dnd-role.picked { background: rgba(237, 28, 36, 0.16); border-color: var(--qr-accent); }
.qr-dnd-role-name {
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  color: var(--qr-warn);
}
.qr-dnd-role-desc { font-size: 12px; color: var(--qr-fg-dim); margin-top: 4px; }

.qr-dnd-outcome {
  background: rgba(237, 28, 36, 0.08);
  border: 1px solid var(--qr-accent);
  border-radius: var(--qr-radius);
  padding: 12px;
  margin-top: 12px;
  font-size: 13px;
  line-height: 1.5;
}

/* === Puzzle 3: Hawkins Lab maze === */
.qr-lab-prompt { margin-bottom: 12px; }
.qr-lab-counter {
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  color: var(--qr-fg-dim);
  margin-bottom: 8px;
  text-align: center;
}
.qr-lab-counter span { color: var(--qr-warn); }
.qr-lab-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  background: rgba(255, 255, 255, 0.04);
  padding: 8px;
  border-radius: var(--qr-radius);
  margin-bottom: 12px;
  aspect-ratio: 1;
}
.qr-lab-room {
  appearance: none;
  border: 1px solid var(--qr-accent-dim);
  background: var(--qr-bg);
  border-radius: 4px;
  font-family: 'Press Start 2P', monospace;
  font-size: 9px;
  color: var(--qr-fg-dim);
  cursor: pointer;
  position: relative;
  min-height: 44px;
}
.qr-lab-room.alarm { background: rgba(193, 16, 43, 0.15); }
.qr-lab-room.start { color: var(--qr-warn); border-color: var(--qr-warn); }
.qr-lab-room.exit  { color: var(--qr-warn); border-color: var(--qr-warn); border-style: dashed; }
.qr-lab-room.path  { background: rgba(247, 197, 72, 0.18); border-color: var(--qr-warn); }
.qr-lab-room.tripped { background: var(--qr-danger); color: #fff; animation: qrShake 380ms ease; }
.qr-lab-status {
  font-size: 13px;
  text-align: center;
  margin-bottom: 8px;
  min-height: 18px;
}

/* === Puzzle 4: Russian Cipher === */
.qr-cipher-prompt { margin-bottom: 12px; }
.qr-cipher-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.qr-cipher-wheel {
  position: relative;
  width: 200px;
  height: 200px;
}
.qr-cipher-wheel-img {
  width: 100%;
  height: 100%;
  image-rendering: pixelated;
}
.qr-cipher-rotate {
  display: flex;
  gap: 8px;
  align-items: center;
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
}
.qr-cipher-rotate-btn {
  appearance: none;
  width: 44px;
  height: 44px;
  background: var(--qr-bg);
  border: 2px solid var(--qr-accent);
  color: var(--qr-fg);
  font-family: inherit;
  font-size: 18px;
  border-radius: var(--qr-radius);
  cursor: pointer;
}
.qr-cipher-shift {
  background: var(--qr-warn);
  color: #1a1408;
  padding: 4px 12px;
  border-radius: var(--qr-radius);
}
.qr-cipher-message {
  background: var(--qr-bg);
  border: 1px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  padding: 12px;
  font-family: 'Press Start 2P', monospace;
  font-size: 14px;
  letter-spacing: 4px;
  text-align: center;
  margin-bottom: 12px;
}
.qr-cipher-message .encoded { color: var(--qr-fg-dim); }
.qr-cipher-message .decoded { color: var(--qr-warn); }
.qr-cipher-input {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-bottom: 12px;
}
.qr-cipher-input input {
  width: 56px;
  height: 56px;
  text-align: center;
  background: var(--qr-bg);
  border: 2px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  font-family: 'Press Start 2P', monospace;
  font-size: 20px;
  color: var(--qr-warn);
  text-transform: uppercase;
}
.qr-cipher-input input:focus { outline: none; border-color: var(--qr-warn); }
.qr-cipher-status {
  font-size: 12px;
  text-align: center;
  min-height: 16px;
  color: var(--qr-fg-dim);
}
.qr-cipher-status.correct { color: var(--qr-warn); }
.qr-cipher-status.wrong { color: var(--qr-danger); }

/* === Puzzle 5: Mind Flayer === */
.qr-mf-prompt { margin-bottom: 12px; }
.qr-mf-objective {
  background: rgba(91, 58, 147, 0.18);
  border: 1px solid var(--qr-uvg);
  border-radius: var(--qr-radius);
  padding: 10px 12px;
  margin-bottom: 12px;
  font-size: 13px;
}
.qr-mf-objective strong { color: var(--qr-warn); }
.qr-mf-friends {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}
.qr-mf-friend {
  appearance: none;
  background: var(--qr-bg);
  border: 2px solid var(--qr-accent-dim);
  color: var(--qr-fg);
  border-radius: var(--qr-radius);
  padding: 10px;
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  min-height: 56px;
  text-align: left;
}
.qr-mf-friend:hover { border-color: var(--qr-accent); }
.qr-mf-friend.picked { background: rgba(237, 28, 36, 0.18); border-color: var(--qr-accent); }
.qr-mf-friend.linked-warn { border-style: dashed; border-color: var(--qr-warn); }
.qr-mf-counter {
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  text-align: center;
  margin-bottom: 8px;
  color: var(--qr-fg-dim);
}
.qr-mf-counter span { color: var(--qr-warn); }
.qr-mf-counter.complete span { color: var(--qr-accent); }
.qr-mf-status {
  font-size: 12px;
  text-align: center;
  min-height: 16px;
  margin-bottom: 8px;
  color: var(--qr-fg-dim);
}
.qr-mf-status.warn { color: var(--qr-warn); }
.qr-mf-status.danger { color: var(--qr-danger); }
