/* Wednesday Quiz Room - Nevermore case-file theme */

:root {
  --qr-bg: #0a090e;
  --qr-bg-elev: #17131f;
  --qr-fg: #ebe5dc;
  --qr-fg-dim: #a49aae;
  --qr-accent: #8a4fb6;
  --qr-accent-dim: #4b2a63;
  --qr-warn: #c29a52;
  --qr-danger: #b5314a;
  --qr-radius: 6px;
  --qr-bone: #ebe5dc;
  --qr-ink: #0a090e;
  --qr-slate: #323844;
  --qr-stone: #606a79;
  --qr-teal: #193940;
  --qr-rose: #cb89ab;
  --qr-wine: #67162f;
  --qr-shadow: rgba(0, 0, 0, 0.52);
  --qr-line: rgba(235, 229, 220, 0.14);
  --qr-scene-cello: #241a2d;
  --qr-scene-garden: #132f32;
  --qr-scene-vision: #20173a;
  --qr-scene-board: #2b1d18;
  --qr-scene-trust: #0f2f38;
}

/* Base room frame */
body {
  background: linear-gradient(180deg, #0a090e 0%, #100e17 52%, #08080c 100%);
  color: var(--qr-fg);
}

#qr-root { max-width: 500px; }
.qr-stage { gap: 18px; }

.qr-progress {
  color: var(--qr-fg-dim);
  text-shadow: 0 1px 0 var(--qr-ink);
}

.qr-board {
  background: linear-gradient(180deg, rgba(138, 79, 182, 0.08), rgba(25, 57, 64, 0.05)), var(--qr-bg-elev);
  border: 1px solid rgba(194, 154, 82, 0.32);
  box-shadow: 0 18px 40px var(--qr-shadow), inset 0 0 0 1px rgba(235, 229, 220, 0.04);
}

.qr-scene {
  border: 1px solid rgba(194, 154, 82, 0.45);
  background: var(--qr-bg);
  box-shadow: 0 8px 0 rgba(0, 0, 0, 0.26);
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  animation: qrWdSceneReveal 420ms ease-out both;
}

.qr-board h1, .qr-board h2, .qr-board h3,
.qr-choice-prompt h1, .qr-choice-prompt h2, .qr-choice-prompt h3 { color: var(--qr-fg); }

.qr-choice-prompt { margin-bottom: 14px; }

.qr-choice-prompt h2,
.qr-wd-poison .qr-wd-poison-prompt h2 {
  margin: 0 0 8px;
  color: var(--qr-accent);
  font-family: 'Press Start 2P', monospace;
  font-size: 14px;
  line-height: 1.45;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.qr-choice-prompt p,
.qr-wd-poison .qr-wd-poison-prompt p {
  margin: 0;
  color: var(--qr-fg-dim);
  font-size: 14px;
  line-height: 1.55;
}

.qr-btn {
  background: linear-gradient(180deg, #9b62c3 0%, var(--qr-accent) 100%);
  color: var(--qr-ink);
  border: 1px solid rgba(235, 229, 220, 0.18);
  box-shadow: 0 4px 0 #3a1e4c;
  text-shadow: none;
  transition: transform 120ms ease, filter 120ms ease, box-shadow 120ms ease;
}

.qr-btn:hover { filter: brightness(1.12); transform: translateY(-1px); }
.qr-btn:active { transform: translateY(2px); box-shadow: 0 2px 0 #3a1e4c; }
.qr-btn:disabled { opacity: 0.48; cursor: not-allowed; transform: none; filter: grayscale(0.45); }
.qr-btn-sm { min-height: 44px; padding: 8px 12px; }

.qr-actions {
  display: flex;
  gap: 10px;
  align-items: stretch;
}

.qr-actions .qr-btn {
  width: auto;
  flex: 1 1 0;
  margin-top: 0;
}

/* Shared choices, counters, status */
.qr-choice-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 14px;
}

.qr-choice {
  min-height: 64px;
  padding: 13px 14px;
  color: var(--qr-fg);
  line-height: 1.45;
  background: linear-gradient(180deg, rgba(235, 229, 220, 0.035), rgba(0, 0, 0, 0)), var(--qr-bg);
  border: 2px solid var(--qr-accent-dim);
  box-shadow: inset 0 0 0 1px rgba(235, 229, 220, 0.04);
  transition: transform 130ms ease, border-color 130ms ease, background 130ms ease;
}

.qr-choice:hover {
  border-color: var(--qr-warn);
  transform: translateY(-2px);
  animation: qrWdChoiceLift 180ms ease-out both;
}

.qr-choice:focus-visible, .qr-btn:focus-visible,
.qr-cello-string:focus-visible, .qr-wd-poison-tile:focus-visible,
.qr-wd-poison-slot:focus-visible {
  outline: 2px solid var(--qr-warn);
  outline-offset: 2px;
}

.qr-choice.picked {
  color: var(--qr-fg);
  border-color: var(--qr-accent);
  background: rgba(138, 79, 182, 0.20);
}

.qr-choice:disabled { cursor: default; }
.qr-choice-name { display: block; margin-bottom: 5px; color: var(--qr-warn); }
.qr-counter { margin: 8px 0 14px; color: var(--qr-fg-dim); }
.qr-counter span { color: var(--qr-warn); }
.qr-counter.complete, .qr-counter.complete span { color: var(--qr-accent); }
.qr-status { min-height: 28px; color: var(--qr-fg-dim); }
.qr-status.win { color: var(--qr-warn); animation: qrWdPulse 520ms ease-out; }
.qr-status.bad { color: var(--qr-danger); animation: qrShake 360ms ease; }

.qr-outcome {
  margin: 12px 0 0;
  padding: 13px 14px;
  color: var(--qr-fg);
  line-height: 1.55;
  background: rgba(25, 57, 64, 0.32);
  border: 1px solid rgba(194, 154, 82, 0.36);
  border-radius: var(--qr-radius);
}

.qr-outcome[hidden], .qr-choice-list[hidden] { display: none; }

/* Result screen */
.qr-result { padding: 18px 0 24px; }

.qr-result-sprite {
  background: linear-gradient(180deg, rgba(138, 79, 182, 0.12), rgba(25, 57, 64, 0.10)), var(--qr-bg);
  border: 4px solid var(--qr-accent);
  box-shadow: 0 10px 0 #34213f, 0 22px 34px var(--qr-shadow);
  animation: qrWdSpriteEnter 560ms steps(6, end) both;
}

.qr-result-eyebrow, .qr-result-dossier-eyebrow { color: var(--qr-warn); }
.qr-result-name, .qr-result-desc { color: var(--qr-fg); }
.qr-result-tagline, .qr-result-runner { color: var(--qr-fg-dim); }

.qr-result-receipts.qr-result-dossier {
  background: linear-gradient(180deg, rgba(235, 229, 220, 0.07), rgba(138, 79, 182, 0.07));
  border-color: rgba(194, 154, 82, 0.36);
}

/* Puzzle 1: Cello in Wednesday's dorm */
.qr-wd-cello {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.qr-wd-cello .qr-scene {
  background-color: var(--qr-scene-cello);
  border-color: rgba(194, 154, 82, 0.55);
}

.qr-cello-pattern {
  display: flex;
  justify-content: center;
  gap: 8px;
  min-height: 32px;
  margin: 2px 0 4px;
  color: var(--qr-warn);
  font-family: 'Press Start 2P', monospace;
  font-size: 18px;
  letter-spacing: 1px;
}

.qr-cello-pattern span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  background: rgba(0, 0, 0, 0.20);
  border: 1px solid rgba(194, 154, 82, 0.28);
  border-radius: 4px;
}

.qr-cello-pattern span.lit {
  color: var(--qr-ink);
  background: var(--qr-warn);
  box-shadow: 0 0 18px rgba(194, 154, 82, 0.30);
}

.qr-cello-strings {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 9px;
  margin: 0 0 4px;
}

.qr-cello-string {
  appearance: none;
  min-height: 64px;
  color: var(--qr-fg);
  cursor: pointer;
  background: linear-gradient(180deg, #17131f 0%, #0d0b11 100%);
  border: 2px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  box-shadow: inset 0 -8px 0 rgba(0, 0, 0, 0.22);
  font-family: 'Press Start 2P', monospace;
  font-size: 14px;
  transition: transform 100ms ease, border-color 100ms ease, background 100ms ease;
}

.qr-cello-string:hover { border-color: var(--qr-warn); transform: translateY(-2px); }
.qr-cello-string:active { transform: translateY(1px); }
.qr-cello-string:disabled { opacity: 0.52; cursor: not-allowed; }
.qr-wd-cello .qr-cello-replay { background: linear-gradient(180deg, #c7a15d 0%, var(--qr-warn) 100%) !important; }
.qr-wd-cello .qr-cello-walk { background: linear-gradient(180deg, #a49aae 0%, #606a79 100%) !important; color: var(--qr-ink) !important; }

/* Puzzle 2: The Poisoner's Garden */
.qr-wd-poison {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.qr-wd-poison .qr-scene {
  background-color: var(--qr-scene-garden);
  border-color: rgba(25, 57, 64, 0.95);
}

.qr-wd-poison .qr-wd-poison-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.qr-wd-poison .qr-wd-poison-tile {
  min-height: 86px;
  padding: 10px;
  color: var(--qr-fg);
  background: linear-gradient(180deg, rgba(25, 57, 64, 0.46), rgba(10, 9, 14, 0.96));
  border: 2px solid rgba(96, 106, 121, 0.72);
  box-shadow: inset 0 0 0 1px rgba(235, 229, 220, 0.04);
}

.qr-wd-poison .qr-wd-poison-tile:hover { border-color: var(--qr-warn); transform: translateY(-2px); }

.qr-wd-poison .qr-wd-poison-tile.picked {
  border-color: var(--qr-accent);
  background: linear-gradient(180deg, rgba(138, 79, 182, 0.26), rgba(10, 9, 14, 0.96));
}

.qr-wd-poison .qr-wd-poison-tile-name { color: var(--qr-bone); line-height: 1.35; }
.qr-wd-poison .qr-wd-poison-tile-blurb { color: var(--qr-fg-dim); font-size: 11px; }
.qr-wd-poison .qr-wd-poison-tile-tag { background: rgba(194, 154, 82, 0.16); color: var(--qr-warn); }

.qr-wd-poison .qr-wd-poison-kettle {
  background: linear-gradient(180deg, rgba(103, 22, 47, 0.18), rgba(25, 57, 64, 0.14)), var(--qr-bg);
  border: 2px solid rgba(194, 154, 82, 0.40);
}

.qr-wd-poison .qr-wd-poison-kettle-label { color: var(--qr-warn); }

.qr-wd-poison .qr-wd-poison-tray {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.qr-wd-poison .qr-wd-poison-slot {
  min-height: 60px;
  color: var(--qr-fg-dim);
  background: rgba(0, 0, 0, 0.24);
  border: 1px dashed rgba(235, 229, 220, 0.24);
}

.qr-wd-poison .qr-wd-poison-slot.filled {
  color: var(--qr-fg);
  background: rgba(138, 79, 182, 0.18);
  border-color: var(--qr-accent-dim);
  border-style: solid;
}

.qr-wd-poison .qr-wd-poison-status { color: var(--qr-fg-dim); }
.qr-wd-poison .qr-wd-poison-status.lethal { color: var(--qr-danger); }
.qr-wd-poison .qr-wd-poison-status.soothing { color: var(--qr-rose); }
.qr-wd-poison .qr-wd-poison-status.drowsy { color: #aeb5ff; }

.qr-wd-poison .qr-wd-poison-actions {
  display: flex;
  gap: 10px;
}

.qr-wd-poison .qr-wd-poison-actions .qr-btn { width: auto; flex: 1 1 0; }

.qr-wd-poison .qr-wd-poison-result {
  color: var(--qr-warn);
  background: rgba(10, 9, 14, 0.72);
  border: 1px solid rgba(194, 154, 82, 0.38);
}

/* Puzzle 3: The Vision */
.qr-vision {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.qr-vision .qr-scene {
  background-color: var(--qr-scene-vision);
  filter: saturate(1.08) contrast(1.05);
}

.qr-vision .qr-choice { border-color: rgba(138, 79, 182, 0.72); }
.qr-vision .qr-choice[data-id="name"] { box-shadow: inset 4px 0 0 var(--qr-danger); }
.qr-vision .qr-choice[data-id="wait"] { box-shadow: inset 4px 0 0 var(--qr-warn); }
.qr-vision .qr-choice[data-id="tell"] { box-shadow: inset 4px 0 0 var(--qr-rose); }
.qr-vision .qr-choice[data-id="investigate"] { box-shadow: inset 4px 0 0 var(--qr-teal); }
.qr-vision .qr-outcome { background: rgba(32, 23, 58, 0.68); }
.qr-vision-done { margin-top: 12px; }

/* Puzzle 4: Suspect board */
.qr-suspect {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.qr-suspect .qr-scene {
  background-color: var(--qr-scene-board);
  border-color: rgba(103, 22, 47, 0.72);
}

.qr-suspect .qr-choice-list { gap: 9px; }

.qr-suspect .qr-choice {
  position: relative;
  padding-left: 16px;
  background: linear-gradient(180deg, rgba(43, 29, 24, 0.76), rgba(10, 9, 14, 0.96));
  border-color: rgba(96, 106, 121, 0.72);
}

.qr-suspect .qr-choice::before {
  content: '';
  position: absolute;
  left: 6px;
  top: 13px;
  width: 4px;
  height: calc(100% - 26px);
  background: var(--qr-wine);
  border-radius: 2px;
}

.qr-suspect .qr-choice[data-id="tyler"]::before { background: var(--qr-danger); }
.qr-suspect .qr-choice[data-id="enid"]::before { background: var(--qr-rose); }
.qr-suspect .qr-choice[data-id="xavier"]::before { background: var(--qr-accent); }
.qr-suspect .qr-choice.picked { border-color: var(--qr-warn); }
.qr-suspect .qr-outcome { background: rgba(43, 29, 24, 0.80); }
.qr-suspect-done { background: linear-gradient(180deg, #c7a15d 0%, var(--qr-warn) 100%); }

/* Puzzle 5: Trust the Mystery */
.qr-trust {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.qr-trust .qr-scene {
  background-color: var(--qr-scene-trust);
  border-color: rgba(25, 57, 64, 0.95);
}

.qr-trust .qr-choice-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
}

.qr-trust .qr-choice {
  min-height: 92px;
  background: linear-gradient(180deg, rgba(25, 57, 64, 0.38), rgba(10, 9, 14, 0.98));
}

.qr-trust .qr-choice[data-id="alone"] { border-color: rgba(235, 229, 220, 0.34); }
.qr-trust .qr-choice[data-id="enid"] { border-color: rgba(203, 137, 171, 0.64); }
.qr-trust .qr-choice[data-id="morticia"] { border-color: rgba(194, 154, 82, 0.62); }
.qr-trust .qr-choice[data-id="bianca"] { border-color: rgba(25, 57, 64, 0.95); }
.qr-trust .qr-choice[data-id="xavier"] { border-color: rgba(138, 79, 182, 0.72); }
.qr-trust .qr-choice[data-id="eugene"] { border-color: rgba(194, 158, 92, 0.72); }
.qr-trust .qr-choice.picked { background: rgba(138, 79, 182, 0.24); }
.qr-trust .qr-outcome { background: rgba(25, 57, 64, 0.50); }
.qr-trust-done { margin-top: 12px; }

/* Motion */
@keyframes qrWdSpriteEnter {
  0% { opacity: 0; transform: translateY(12px) scale(0.96); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes qrWdSceneReveal {
  0% { opacity: 0; transform: translateY(6px); filter: brightness(0.72); }
  100% { opacity: 1; transform: translateY(0); filter: brightness(1); }
}

@keyframes qrWdPropBob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}

@keyframes qrWdChoiceLift {
  0% { box-shadow: inset 0 0 0 1px rgba(235, 229, 220, 0.04); }
  100% { box-shadow: inset 0 0 0 1px rgba(235, 229, 220, 0.06), 0 8px 16px rgba(0, 0, 0, 0.18); }
}

@keyframes qrWdPulse {
  0% { text-shadow: 0 0 0 rgba(194, 154, 82, 0); }
  50% { text-shadow: 0 0 12px rgba(194, 154, 82, 0.58); }
  100% { text-shadow: 0 0 0 rgba(194, 154, 82, 0); }
}

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

/* Responsive */
@media (max-width: 540px) {
  #qr-root { padding: 18px 12px; }
  .qr-board { padding: 16px 12px; }
  .qr-scene { width: 100%; min-height: 102px; object-fit: cover; }
  .qr-choice-prompt h2, .qr-wd-poison .qr-wd-poison-prompt h2 { font-size: 12px; }
  .qr-choice-prompt p, .qr-wd-poison .qr-wd-poison-prompt p, .qr-choice { font-size: 13px; }

  .qr-cello-strings,
  .qr-wd-poison .qr-wd-poison-grid,
  .qr-wd-poison .qr-wd-poison-tray,
  .qr-trust .qr-choice-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .qr-cello-string, .qr-choice, .qr-wd-poison .qr-wd-poison-tile,
  .qr-wd-poison .qr-wd-poison-slot, .qr-btn { min-height: 44px; }
  .qr-actions, .qr-wd-poison .qr-wd-poison-actions { flex-direction: column; }
  .qr-actions .qr-btn, .qr-wd-poison .qr-wd-poison-actions .qr-btn { width: 100%; }
}

@media (max-width: 380px) {
  .qr-cello-pattern { gap: 5px; font-size: 16px; }
  .qr-cello-pattern span { min-width: 28px; height: 28px; }
  .qr-trust .qr-choice, .qr-suspect .qr-choice { min-height: 72px; }
  .qr-result-sprite { width: 208px; height: 208px; }
}

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

  .qr-choice:hover,
  .qr-cello-string:hover,
  .qr-wd-poison .qr-wd-poison-tile:hover { transform: none; }
}
