/* Avengers Quiz Room - reactor cyan, shield navy, armor red and gold */

/* 1. Room variables */
:root {
  --qr-bg: #08111c;
  --qr-bg-elev: #122034;
  --qr-fg: #f0f2e5;
  --qr-fg-dim: #b8c0ca;
  --qr-accent: #6fd5ff;
  --qr-accent-dim: #255482;
  --qr-warn: #d9aa44;
  --qr-danger: #d8412f;
  --qr-radius: 6px;
  --qr-avengers-space: #08111c;
  --qr-avengers-deck: #122034;
  --qr-avengers-shield: #255482;
  --qr-avengers-reactor: #6fd5ff;
  --qr-avengers-white: #f0f2e5;
  --qr-avengers-crimson: #9f1f28;
  --qr-avengers-red: #d8412f;
  --qr-avengers-gold: #d9aa44;
  --qr-avengers-silver: #b8c0ca;
  --qr-avengers-green: #216742;
  --qr-scene-recruit: url('objects/scene_recruit.png');
  --qr-scene-newyork: url('objects/scene_newyork.png');
  --qr-scene-civilwar: url('objects/scene_civilwar.png');
  --qr-scene-heist: url('objects/scene_heist.png');
  --qr-scene-snap: url('objects/scene_snap.png');
  --qr-prop-reactor: url('objects/arc_reactor.png');
  --qr-prop-shield: url('objects/shield.png');
  --qr-prop-mjolnir: url('objects/mjolnir.png');
  --qr-prop-scepter: url('objects/scepter.png');
  --qr-prop-gauntlet: url('objects/infinity_gauntlet.png');
  --qr-prop-timegps: url('objects/time_gps.png');
  --qr-prop-web: url('objects/web_shooter.png');
  --qr-prop-cap: url('objects/captain_helmet.png');
  --qr-prop-loki: url('objects/loki_horn_helmet.png');
  --qr-prop-spider: url('objects/spider_emblem.png');
  --qr-prop-accords: url('objects/accords_doc.png');
  --qr-prop-tesseract: url('objects/tesseract.png');
}

/* 2. Base room frame */
* { box-sizing: border-box; }

body {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  color: var(--qr-fg);
  background:
    linear-gradient(180deg, rgba(37, 84, 130, .34) 0%, rgba(8, 17, 28, 0) 42%),
    repeating-linear-gradient(90deg, rgba(111, 213, 255, .035) 0 1px, transparent 1px 48px),
    var(--qr-bg);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  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 {
  color: var(--qr-fg-dim);
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  letter-spacing: 1px;
  text-align: right;
  text-shadow: 0 0 8px rgba(111, 213, 255, .28);
}

.qr-board {
  min-height: 320px;
  padding: 18px 16px 20px;
  background:
    linear-gradient(180deg, rgba(111, 213, 255, .08), rgba(111, 213, 255, 0) 34%),
    linear-gradient(180deg, var(--qr-bg-elev), var(--qr-bg));
  border: 1px solid color-mix(in srgb, var(--qr-accent-dim) 78%, var(--qr-accent));
  border-radius: var(--qr-radius);
  box-shadow: 0 18px 38px rgba(0, 0, 0, .36), inset 0 0 0 1px rgba(240, 242, 229, .04);
}

.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-board h2,
.qr-choice-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;
}

.qr-choice-prompt {
  position: relative;
  margin-bottom: 14px;
  color: var(--qr-fg-dim);
}

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

.qr-scene {
  display: block;
  width: 100%;
  max-height: 170px;
  object-fit: cover;
  margin: 0 0 16px;
  border: 1px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  background: var(--qr-bg);
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  box-shadow: 0 0 0 1px rgba(240, 242, 229, .06), 0 10px 24px rgba(0, 0, 0, .32);
  animation: qrAvengersSceneFade 260ms ease-out both;
}

/* 3. Shared controls */
.qr-choice-list { display: grid; grid-template-columns: 1fr; gap: 10px; margin-bottom: 12px; }

.qr-choice {
  --qr-choice-icon: var(--qr-prop-shield);
  appearance: none;
  position: relative;
  width: 100%;
  min-height: 58px;
  padding: 12px 13px 12px 58px;
  color: var(--qr-fg);
  background:
    linear-gradient(180deg, rgba(240, 242, 229, .055), rgba(0, 0, 0, 0)),
    var(--qr-bg);
  border: 2px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  font-family: inherit;
  font-size: 13px;
  line-height: 1.45;
  text-align: left;
  cursor: pointer;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease, box-shadow 120ms ease;
}

.qr-choice::before {
  content: '';
  position: absolute;
  left: 12px;
  top: 50%;
  width: 34px;
  height: 34px;
  background: var(--qr-choice-icon) center / contain no-repeat;
  image-rendering: pixelated;
  transform: translateY(-50%);
  filter: drop-shadow(0 2px 0 rgba(0, 0, 0, .55));
}

.qr-choice::after {
  content: '';
  position: absolute;
  left: 50px;
  top: 11px;
  bottom: 11px;
  width: 1px;
  background: rgba(184, 192, 202, .22);
}

.qr-choice:hover {
  border-color: var(--qr-accent);
  transform: translateY(-1px);
  box-shadow: 0 4px 0 rgba(8, 17, 28, .88), 0 0 14px rgba(111, 213, 255, .12);
}

.qr-choice:disabled {
  cursor: not-allowed;
  opacity: .64;
  transform: none;
}

.qr-choice.picked {
  color: var(--qr-fg);
  background:
    linear-gradient(180deg, rgba(111, 213, 255, .18), rgba(216, 65, 47, .08)),
    var(--qr-bg);
  border-color: var(--qr-accent);
  opacity: 1;
  animation: qrAvengersChoiceLift 180ms ease-out;
}

.qr-choice-name {
  display: block;
  margin-bottom: 5px;
  color: var(--qr-warn);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  line-height: 1.45;
  letter-spacing: 1px;
}

.qr-btn {
  appearance: none;
  width: 100%;
  min-height: 44px;
  margin-top: 16px;
  padding: 12px 18px;
  color: var(--qr-bg);
  background: var(--qr-accent);
  border: 1px solid rgba(240, 242, 229, .18);
  border-radius: var(--qr-radius);
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  line-height: 1.35;
  letter-spacing: 1px;
  cursor: pointer;
  transition: transform 100ms ease, filter 100ms ease, background 100ms ease;
}

.qr-btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.qr-btn:disabled { opacity: .48; cursor: not-allowed; filter: grayscale(.35); transform: none; }
.qr-btn-sm { width: auto; min-height: 36px; margin-top: 0; padding: 8px 12px; font-size: 10px; }

.qr-counter,
.qr-status {
  border-radius: var(--qr-radius);
  background: rgba(18, 32, 52, .84);
  border: 1px solid rgba(111, 213, 255, .24);
}

.qr-counter {
  margin: 0 0 12px;
  padding: 9px 10px;
  color: var(--qr-fg-dim);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  line-height: 1.5;
  text-align: center;
}

.qr-counter span { color: var(--qr-warn); }
.qr-counter.complete span { color: var(--qr-accent); }
.qr-status { min-height: 34px; margin-bottom: 10px; padding: 9px 10px; color: var(--qr-fg-dim); font-size: 12px; line-height: 1.35; text-align: center; }
.qr-status.warn { color: var(--qr-warn); }
.qr-status.win { color: var(--qr-accent); }
.qr-status.bad { color: var(--qr-danger); }

.qr-outcome {
  margin-top: 12px;
  padding: 13px 14px;
  color: var(--qr-fg);
  background: rgba(37, 84, 130, .22);
  border: 1px solid var(--qr-accent);
  border-radius: var(--qr-radius);
  font-size: 13px;
  line-height: 1.55;
  box-shadow: inset 0 0 0 1px rgba(240, 242, 229, .05);
}

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

/* 4. Scene and prompt treatment */
body:has(.qr-avg-rec-done) .qr-scene { content: var(--qr-scene-recruit); border-color: var(--qr-accent); }
body:has(.qr-avg-ny-done) .qr-scene { content: var(--qr-scene-newyork); border-color: var(--qr-warn); }
body:has(.qr-avg-cw-done) .qr-scene { content: var(--qr-scene-civilwar); border-color: var(--qr-danger); }
body:has(.qr-avg-heist) .qr-scene { content: var(--qr-scene-heist); border-color: var(--qr-accent); }
body:has(.qr-avg-snap-done) .qr-scene { content: var(--qr-scene-snap); border-color: var(--qr-warn); }

body:has(.qr-avg-rec-done) .qr-choice-prompt,
body:has(.qr-avg-ny-done) .qr-choice-prompt,
body:has(.qr-avg-cw-done) .qr-choice-prompt,
body:has(.qr-avg-snap-done) .qr-choice-prompt {
  padding: 12px 58px 12px 13px;
  background: rgba(18, 32, 52, .72);
  border: 1px solid rgba(111, 213, 255, .24);
  border-radius: var(--qr-radius);
}

body:has(.qr-avg-rec-done) .qr-choice-prompt::after,
body:has(.qr-avg-ny-done) .qr-choice-prompt::after,
body:has(.qr-avg-cw-done) .qr-choice-prompt::after,
body:has(.qr-avg-snap-done) .qr-choice-prompt::after {
  content: '';
  position: absolute;
  right: 10px;
  top: 50%;
  width: 38px;
  height: 38px;
  background: var(--qr-prompt-prop) center / contain no-repeat;
  image-rendering: pixelated;
  transform: translateY(-50%);
  filter: drop-shadow(0 3px 0 rgba(0, 0, 0, .55));
  animation: qrAvengersPropBob 2.7s ease-in-out infinite;
}

body:has(.qr-avg-rec-done) .qr-choice-prompt { --qr-prompt-prop: var(--qr-prop-tesseract); }
body:has(.qr-avg-ny-done) .qr-choice-prompt { --qr-prompt-prop: var(--qr-prop-scepter); }
body:has(.qr-avg-cw-done) .qr-choice-prompt { --qr-prompt-prop: var(--qr-prop-accords); }
body:has(.qr-avg-snap-done) .qr-choice-prompt { --qr-prompt-prop: var(--qr-prop-gauntlet); }

/* 5. Puzzle 1 - Recruitment */
body:has(.qr-avg-rec-done) .qr-choice-list { gap: 9px; }
body:has(.qr-avg-rec-done) .qr-choice[data-id="tech"] { --qr-choice-icon: var(--qr-prop-reactor); border-color: color-mix(in srgb, var(--qr-avengers-reactor) 70%, var(--qr-accent-dim)); }
body:has(.qr-avg-rec-done) .qr-choice[data-id="soldier"] { --qr-choice-icon: var(--qr-prop-shield); border-color: color-mix(in srgb, var(--qr-avengers-shield) 72%, var(--qr-accent)); }
body:has(.qr-avg-rec-done) .qr-choice[data-id="spy"] { --qr-choice-icon: var(--qr-prop-accords); border-color: color-mix(in srgb, var(--qr-avengers-silver) 58%, var(--qr-accent-dim)); }
body:has(.qr-avg-rec-done) .qr-choice[data-id="monster"] { --qr-choice-icon: var(--qr-prop-mjolnir); border-color: color-mix(in srgb, var(--qr-avengers-gold) 70%, var(--qr-accent-dim)); }
body:has(.qr-avg-rec-done) .qr-choice[data-id="trick"] { --qr-choice-icon: var(--qr-prop-loki); border-color: color-mix(in srgb, var(--qr-avengers-green) 70%, var(--qr-accent)); }
body:has(.qr-avg-rec-done) .qr-choice[data-id="kid"] { --qr-choice-icon: var(--qr-prop-web); border-color: color-mix(in srgb, var(--qr-avengers-red) 62%, var(--qr-accent)); }
.qr-avg-rec-done { background: var(--qr-avengers-reactor); color: var(--qr-bg); }

/* 6. Puzzle 2 - Battle of New York */
body:has(.qr-avg-ny-done) .qr-board { box-shadow: 0 18px 38px rgba(0, 0, 0, .38), inset 0 0 22px rgba(217, 170, 68, .08); }
body:has(.qr-avg-ny-done) .qr-choice[data-id="portal"] { --qr-choice-icon: var(--qr-prop-tesseract); border-color: var(--qr-accent); }
body:has(.qr-avg-ny-done) .qr-choice[data-id="nuke"] { --qr-choice-icon: var(--qr-prop-reactor); border-color: var(--qr-avengers-red); }
body:has(.qr-avg-ny-done) .qr-choice[data-id="civ"] { --qr-choice-icon: var(--qr-prop-shield); border-color: var(--qr-avengers-shield); }
body:has(.qr-avg-ny-done) .qr-choice[data-id="sceptre"] { --qr-choice-icon: var(--qr-prop-scepter); border-color: var(--qr-warn); }
body:has(.qr-avg-ny-done) .qr-choice[data-id="sky"] { --qr-choice-icon: var(--qr-prop-mjolnir); border-color: color-mix(in srgb, var(--qr-accent) 70%, var(--qr-warn)); }
body:has(.qr-avg-ny-done) .qr-choice[data-id="hulk"] { --qr-choice-icon: var(--qr-prop-mjolnir); border-color: var(--qr-avengers-green); }
body:has(.qr-avg-ny-done) .qr-choice:hover { box-shadow: 0 4px 0 rgba(8, 17, 28, .9), 0 0 16px rgba(217, 170, 68, .16); }
.qr-avg-ny-done { background: var(--qr-warn); color: var(--qr-bg); }

/* 7. Puzzle 3 - Sokovia Accords */
body:has(.qr-avg-cw-done) .qr-choice-prompt { border-color: rgba(216, 65, 47, .38); }
body:has(.qr-avg-cw-done) .qr-choice[data-id="sign"] { --qr-choice-icon: var(--qr-prop-accords); border-color: var(--qr-avengers-red); }
body:has(.qr-avg-cw-done) .qr-choice[data-id="refuse"] { --qr-choice-icon: var(--qr-prop-shield); border-color: var(--qr-accent); }
body:has(.qr-avg-cw-done) .qr-choice[data-id="bucky"] { --qr-choice-icon: var(--qr-prop-cap); border-color: color-mix(in srgb, var(--qr-avengers-shield) 68%, var(--qr-warn)); }
body:has(.qr-avg-cw-done) .qr-choice[data-id="broker"] { --qr-choice-icon: var(--qr-prop-accords); border-color: var(--qr-avengers-silver); }
body:has(.qr-avg-cw-done) .qr-choice[data-id="leave"] { --qr-choice-icon: var(--qr-prop-mjolnir); border-color: var(--qr-warn); }
body:has(.qr-avg-cw-done) .qr-choice[data-id="kid_no"] { --qr-choice-icon: var(--qr-prop-web); border-color: var(--qr-danger); }
body:has(.qr-avg-cw-done) .qr-choice.picked { background: linear-gradient(90deg, rgba(216, 65, 47, .18), rgba(37, 84, 130, .18)), var(--qr-bg); }
.qr-avg-cw-done { background: var(--qr-danger); color: #fff; }

/* 8. Puzzle 4 - Time Heist */
body:has(.qr-avg-heist) .qr-avg-heist { gap: 14px; }
body:has(.qr-avg-heist) .qr-avg-heist-prompt {
  padding: 12px;
  background: rgba(18, 32, 52, .72);
  border: 1px solid rgba(111, 213, 255, .24);
  border-radius: var(--qr-radius);
}
body:has(.qr-avg-heist) .qr-avg-heist-prompt h2 { color: var(--qr-accent); font-size: 14px; line-height: 1.45; }
body:has(.qr-avg-heist) .qr-avg-heist-prompt p { color: var(--qr-fg-dim); font-size: 13px; line-height: 1.55; }
body:has(.qr-avg-heist) .qr-avg-heist-tls { gap: 8px; }
body:has(.qr-avg-heist) .qr-avg-heist-tl {
  min-height: 62px;
  padding: 10px 12px;
  background: linear-gradient(90deg, rgba(111, 213, 255, .08), rgba(0, 0, 0, 0)), var(--qr-bg);
  border: 1.5px solid var(--qr-accent-dim);
  box-shadow: inset 4px 0 0 rgba(111, 213, 255, .22);
}
body:has(.qr-avg-heist) .qr-avg-heist-tl:hover { border-color: var(--qr-accent); filter: brightness(1.12); }
body:has(.qr-avg-heist) .qr-avg-heist-tl.selected { border-color: var(--qr-warn); box-shadow: inset 4px 0 0 var(--qr-warn), 0 0 0 2px rgba(217, 170, 68, .26); }
body:has(.qr-avg-heist) .qr-avg-heist-tl-label { color: var(--qr-warn); font-size: 10px; letter-spacing: 1px; }
body:has(.qr-avg-heist) .qr-avg-heist-tl-hint { color: var(--qr-fg-dim); font-size: 12px; line-height: 1.35; }
body:has(.qr-avg-heist) .qr-avg-heist-tl-assigned { background: var(--qr-accent); color: var(--qr-bg); border-radius: 3px; }
body:has(.qr-avg-heist) .qr-avg-heist-tl-assigned.invalid { background: var(--qr-danger); color: #fff; }
body:has(.qr-avg-heist) .qr-avg-heist-tl-assigned.open { border-color: var(--qr-accent-dim); color: var(--qr-fg-dim); background: transparent; }
body:has(.qr-avg-heist) .qr-avg-heist-bench-label { color: var(--qr-fg-dim); }
body:has(.qr-avg-heist) .qr-avg-heist-bench { gap: 7px; }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn {
  min-height: 66px;
  background: var(--qr-bg);
  border: 1.5px solid var(--qr-accent-dim);
  color: var(--qr-fg);
}
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn:nth-child(1) { border-color: var(--qr-avengers-red); }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn:nth-child(2) { border-color: var(--qr-avengers-shield); }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn:nth-child(3) { border-color: var(--qr-warn); }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn:nth-child(4) { border-color: var(--qr-avengers-silver); }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn:nth-child(5) { border-color: var(--qr-avengers-green); }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn:nth-child(6) { border-color: var(--qr-danger); }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn:hover:not(:disabled) { border-color: var(--qr-accent); filter: brightness(1.14); }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn.assigned { opacity: .42; }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn-name { color: var(--qr-accent); font-size: 10px; }
body:has(.qr-avg-heist) .qr-avg-heist-avgbtn-desc { color: var(--qr-fg-dim); }
body:has(.qr-avg-heist) .qr-avg-heist-feedback { min-height: 28px; color: var(--qr-fg-dim); }
body:has(.qr-avg-heist) .qr-avg-heist-feedback.warn { color: var(--qr-danger); }
body:has(.qr-avg-heist) .qr-avg-heist-feedback.good { color: var(--qr-accent); }
body:has(.qr-avg-heist) .qr-avg-heist-actions { gap: 8px; }
body:has(.qr-avg-heist) .qr-avg-heist-skip { background: var(--qr-bg); color: var(--qr-fg-dim); border-color: var(--qr-accent-dim); }
body:has(.qr-avg-heist) .qr-avg-heist-run { background: var(--qr-warn); color: var(--qr-bg); }
body:has(.qr-avg-heist) .qr-avg-heist-result { background: rgba(18, 32, 52, .88); color: var(--qr-warn); border: 1px solid rgba(217, 170, 68, .36); }
.qr-avg-heist-done { background: var(--qr-accent); color: var(--qr-bg); }

/* 9. Puzzle 5 - The Snap */
body:has(.qr-avg-snap-done) .qr-board { box-shadow: 0 18px 38px rgba(0, 0, 0, .44), inset 0 0 28px rgba(217, 170, 68, .10); }
body:has(.qr-avg-snap-done) .qr-choice[data-id="iron"] { --qr-choice-icon: var(--qr-prop-reactor); border-color: var(--qr-avengers-red); }
body:has(.qr-avg-snap-done) .qr-choice[data-id="cap"] { --qr-choice-icon: var(--qr-prop-shield); border-color: var(--qr-avengers-shield); }
body:has(.qr-avg-snap-done) .qr-choice[data-id="thor"] { --qr-choice-icon: var(--qr-prop-mjolnir); border-color: var(--qr-warn); }
body:has(.qr-avg-snap-done) .qr-choice[data-id="hulk"] { --qr-choice-icon: var(--qr-prop-gauntlet); border-color: var(--qr-avengers-green); }
body:has(.qr-avg-snap-done) .qr-choice[data-id="wait"] { --qr-choice-icon: var(--qr-prop-timegps); border-color: var(--qr-accent); }
body:has(.qr-avg-snap-done) .qr-choice[data-id="kid"] { --qr-choice-icon: var(--qr-prop-spider); border-color: var(--qr-danger); }
body:has(.qr-avg-snap-done) .qr-choice.picked { box-shadow: 0 0 0 2px rgba(217, 170, 68, .28), 0 6px 0 rgba(8, 17, 28, .92); }
.qr-avg-snap-done { background: var(--qr-warn); color: var(--qr-bg); }

/* 10. Result screen and animations */
.qr-result { text-align: center; padding: 24px 0; }
.qr-result-sprite-wrap { display: flex; justify-content: center; margin-bottom: 16px; }

.qr-result-sprite {
  width: 224px;
  height: 224px;
  display: block;
  object-fit: contain;
  object-position: center;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  background: linear-gradient(180deg, rgba(111, 213, 255, .18), rgba(159, 31, 40, .16)), var(--qr-bg-elev);
  border: 4px solid var(--qr-accent);
  border-radius: var(--qr-radius);
  box-shadow: 0 8px 0 var(--qr-accent-dim), 0 0 0 1px rgba(240, 242, 229, .16);
  animation: qrAvengersSpriteEntrance 420ms cubic-bezier(.22, 1.12, .36, 1) both;
}

.qr-result-eyebrow,
.qr-result-dossier-eyebrow {
  color: var(--qr-accent);
  font-family: 'Press Start 2P', monospace;
  letter-spacing: 2px;
}

.qr-result-eyebrow { margin-bottom: 4px; font-size: 11px; }
.qr-result-name { margin: 4px 0 8px; color: var(--qr-fg) !important; font-family: 'Press Start 2P', monospace; font-size: 20px; line-height: 1.35; }
.qr-result-tagline { margin-top: 0; color: var(--qr-fg-dim); font-size: 14px; font-style: italic; }
.qr-result-desc { padding: 0 8px; line-height: 1.6; text-align: left; }
.qr-result-runner { color: var(--qr-fg-dim); font-size: 13px; margin-top: 12px; }
.qr-result-receipts.qr-result-dossier { background: rgba(18, 32, 52, .84); border-color: rgba(111, 213, 255, .28); }

@keyframes qrAvengersSpriteEntrance {
  from { opacity: 0; transform: translateY(10px) scale(.95); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes qrAvengersSceneFade {
  from { opacity: 0; transform: translateY(-5px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes qrAvengersPropBob {
  0%, 100% { transform: translateY(-50%); }
  50% { transform: translateY(calc(-50% - 4px)); }
}

@keyframes qrAvengersChoiceLift {
  0% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
  100% { transform: translateY(0); }
}

/* 11. Mobile */
@media (max-width: 520px) {
  #qr-root { padding: 16px 12px; }
  .qr-board { padding: 16px 12px 18px; }
  .qr-board h2,
  .qr-choice-prompt h2,
  body:has(.qr-avg-heist) .qr-avg-heist-prompt h2 { font-size: 12px; line-height: 1.5; }
  .qr-choice-prompt p,
  .qr-outcome,
  body:has(.qr-avg-heist) .qr-avg-heist-prompt p { font-size: 12px; }
  .qr-scene { max-height: 150px; }
  .qr-choice { min-height: 54px; padding: 11px 11px 11px 52px; }
  .qr-choice::before { left: 11px; width: 30px; height: 30px; }
  .qr-choice::after { left: 45px; }
  .qr-btn,
  .qr-choice,
  body:has(.qr-avg-heist) .qr-avg-heist-tl,
  body:has(.qr-avg-heist) .qr-avg-heist-avgbtn { min-height: 44px; }
  body:has(.qr-avg-heist) .qr-avg-heist-bench { grid-template-columns: repeat(3, 1fr); }
  body:has(.qr-avg-heist) .qr-avg-heist-actions { flex-direction: column; }
  body:has(.qr-avg-heist) .qr-avg-heist-actions .qr-btn { width: 100%; }
  .qr-result-sprite { width: 192px; height: 192px; }
}

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