/* Greek Gods Quiz Room - Olympus audit theme */

/* 1. Room variables */
:root,
body[data-room="greek-gods"],
.qr-room-greek-gods {
  --qr-bg: #0d0a10;
  --qr-bg-elev: #1d1820;
  --qr-fg: #f4ead5;
  --qr-fg-dim: rgba(244, 234, 213, 0.72);
  --qr-accent: #f2ca54;
  --qr-accent-dim: #8b6b2a;
  --qr-warn: #d9953f;
  --qr-danger: #a83f47;
  --qr-radius: 6px;
  --qr-gg-ink: #151019;
  --qr-gg-void: #09070c;
  --qr-gg-marble: #ebe8da;
  --qr-gg-marble-warm: #f6e2c4;
  --qr-gg-gold: #f2ca54;
  --qr-gg-bronze: #c7ae6f;
  --qr-gg-olive: #486953;
  --qr-gg-storm: #7091a8;
  --qr-gg-wine: #903c40;
  --qr-gg-moon: #a8aab2;
  --qr-gg-line: rgba(242, 202, 84, 0.34);
  --qr-gg-line-soft: rgba(244, 234, 213, 0.15);
  --qr-gg-shadow: rgba(0, 0, 0, 0.68);
  --qr-gg-glow: rgba(242, 202, 84, 0.32);
}

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

body[data-room="greek-gods"] {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  color: var(--qr-fg);
  background: linear-gradient(180deg, rgba(112, 145, 168, 0.18), rgba(13, 10, 16, 0) 30%), linear-gradient(160deg, #211823 0%, var(--qr-bg) 52%, #050407 100%);
  font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  display: flex;
  flex-direction: column;
  align-items: center;
}

body[data-room="greek-gods"] #qr-root { width: 100%; max-width: 500px; padding: 24px 16px 32px; }
body[data-room="greek-gods"] .qr-stage { display: flex; flex-direction: column; gap: 14px; }

body[data-room="greek-gods"] .qr-progress {
  color: var(--qr-gg-bronze);
  font-family: "Press Start 2P", monospace;
  font-size: 10px;
  letter-spacing: 0;
  text-align: right;
  text-shadow: 0 2px 0 #000;
}

body[data-room="greek-gods"] .qr-board {
  position: relative;
  min-height: 340px;
  padding: 18px 16px 20px;
  overflow: hidden;
  color: var(--qr-fg);
  background: linear-gradient(180deg, rgba(235, 232, 218, 0.06), transparent 38%), linear-gradient(135deg, rgba(144, 60, 64, 0.14), rgba(72, 105, 83, 0.08)), var(--qr-bg-elev);
  border: 1px solid var(--qr-gg-line);
  border-radius: var(--qr-radius);
  box-shadow: 0 12px 0 rgba(0, 0, 0, 0.24), 0 18px 38px rgba(0, 0, 0, 0.32), inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

body[data-room="greek-gods"] .qr-board::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 20px), repeating-linear-gradient(0deg, rgba(0, 0, 0, 0.16) 0 1px, transparent 1px 18px);
  mix-blend-mode: soft-light;
  opacity: 0.45;
}

body[data-room="greek-gods"] .qr-board > * { position: relative; z-index: 1; }

body[data-room="greek-gods"] .qr-board h1,
body[data-room="greek-gods"] .qr-board h2,
body[data-room="greek-gods"] .qr-board h3,
body[data-room="greek-gods"] .qr-choice-prompt h1,
body[data-room="greek-gods"] .qr-choice-prompt h2,
body[data-room="greek-gods"] .qr-choice-prompt h3 {
  color: var(--qr-accent);
  font-family: "Press Start 2P", monospace;
  letter-spacing: 0;
  line-height: 1.45;
  text-transform: uppercase;
  text-shadow: 0 2px 0 #000;
}

body[data-room="greek-gods"] .qr-choice-prompt { margin: 0 0 14px; color: var(--qr-fg-dim); }
body[data-room="greek-gods"] .qr-choice-prompt h2 { margin: 0 0 8px; font-size: 14px; }
body[data-room="greek-gods"] .qr-choice-prompt p,
body[data-room="greek-gods"] .qr-board p { color: var(--qr-fg-dim); font-size: 14px; line-height: 1.55; }

body[data-room="greek-gods"] .qr-scene {
  display: block;
  width: 100%;
  height: auto;
  max-height: 172px;
  object-fit: cover;
  margin: 0 0 16px;
  background: var(--qr-bg);
  border: 1px solid var(--qr-gg-line);
  border-radius: var(--qr-radius);
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28);
  animation: qr-gg-scene-in 360ms ease-out both;
}

/* 3. Shared controls, choice cards, counters, status */
body[data-room="greek-gods"] .qr-btn {
  appearance: none;
  width: 100%;
  min-height: 44px;
  margin-top: 16px;
  padding: 12px 18px;
  color: #130d0a;
  background: linear-gradient(180deg, var(--qr-gg-gold), #c7ae6f);
  border: 1px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  box-shadow: 0 5px 0 #5f4618, 0 0 16px rgba(242, 202, 84, 0.16);
  font-family: "Press Start 2P", monospace;
  font-size: 11px;
  letter-spacing: 0;
  line-height: 1.25;
  text-transform: uppercase;
  cursor: pointer;
  touch-action: manipulation;
  transition: filter 120ms, transform 90ms, box-shadow 120ms;
}

body[data-room="greek-gods"] .qr-btn:hover:not(:disabled),
body[data-room="greek-gods"] .qr-btn:focus-visible { filter: brightness(1.08); transform: translateY(-1px); box-shadow: 0 6px 0 #5f4618, 0 0 20px rgba(242, 202, 84, 0.28); }
body[data-room="greek-gods"] .qr-btn:active:not(:disabled) { transform: translateY(2px); box-shadow: 0 2px 0 #5f4618; }
body[data-room="greek-gods"] .qr-btn:disabled { opacity: 0.52; cursor: not-allowed; filter: grayscale(0.35); transform: none; box-shadow: none; }
body[data-room="greek-gods"] .qr-btn-sm { width: auto; min-height: 36px; margin-top: 0; padding: 8px 12px; font-size: 10px; }

body[data-room="greek-gods"] .qr-choice-list,
body[data-room="greek-gods"] .qr-choice-grid { display: grid; grid-template-columns: 1fr; gap: 9px; margin: 0 0 12px; }
body[data-room="greek-gods"] .qr-choice-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }

body[data-room="greek-gods"] .qr-choice {
  position: relative;
  min-height: 64px;
  padding: 12px 12px 12px 50px;
  overflow: hidden;
  color: var(--qr-fg);
  background: linear-gradient(135deg, rgba(242, 202, 84, 0.10), rgba(112, 145, 168, 0.06)), var(--qr-gg-ink);
  border: 1px solid rgba(242, 202, 84, 0.30);
  border-radius: var(--qr-radius);
  font-size: 13px;
  line-height: 1.42;
  text-align: left;
  cursor: pointer;
  touch-action: manipulation;
  transition: border-color 120ms, transform 120ms, background 120ms, box-shadow 120ms;
}

body[data-room="greek-gods"] .qr-choice::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 50%;
  width: 26px;
  height: 26px;
  background: linear-gradient(135deg, var(--qr-gg-gold), var(--qr-gg-bronze));
  clip-path: polygon(50% 0, 62% 36%, 100% 38%, 70% 58%, 82% 100%, 50% 75%, 18% 100%, 30% 58%, 0 38%, 38% 36%);
  transform: translateY(-50%);
}

body[data-room="greek-gods"] .qr-choice::after { content: ""; position: absolute; left: 44px; top: 10px; bottom: 10px; width: 1px; background: rgba(242, 202, 84, 0.22); }
body[data-room="greek-gods"] .qr-choice:hover:not(:disabled),
body[data-room="greek-gods"] .qr-choice:focus-visible { border-color: var(--qr-accent); transform: translateY(-2px); box-shadow: 0 6px 0 rgba(0, 0, 0, 0.22), 0 0 0 2px rgba(242, 202, 84, 0.16); animation: qr-gg-choice-lift 180ms ease-out both; }
body[data-room="greek-gods"] .qr-choice:hover:not(:disabled)::before { animation: qr-gg-choice-icon-bob 900ms ease-in-out infinite; }
body[data-room="greek-gods"] .qr-choice.picked { color: #130d0a; background: linear-gradient(180deg, #f6e2c4, #c7ae6f); border-color: var(--qr-accent); box-shadow: 0 0 0 2px rgba(242, 202, 84, 0.22); }
body[data-room="greek-gods"] .qr-choice.picked::before { background: var(--qr-gg-wine); }
body[data-room="greek-gods"] .qr-choice:disabled:not(.picked) { opacity: 0.56; cursor: not-allowed; }
body[data-room="greek-gods"] .qr-choice-name { display: block; margin-bottom: 4px; color: var(--qr-accent); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 0; line-height: 1.35; }

body[data-room="greek-gods"] .qr-counter,
body[data-room="greek-gods"] .qr-status { min-height: 18px; margin: 8px 0 12px; color: var(--qr-fg-dim); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 0; line-height: 1.55; }
body[data-room="greek-gods"] .qr-counter span,
body[data-room="greek-gods"] .qr-status span,
body[data-room="greek-gods"] .qr-status.win { color: var(--qr-accent); }
body[data-room="greek-gods"] .qr-status.warn { color: var(--qr-warn); }
body[data-room="greek-gods"] .qr-status.bad { color: var(--qr-danger); }
body[data-room="greek-gods"] .qr-hint { padding: 10px 12px; color: var(--qr-warn); background: rgba(217, 149, 63, 0.08); border-left: 3px solid var(--qr-warn); border-radius: var(--qr-radius); font-size: 12px; line-height: 1.45; }
body[data-room="greek-gods"] .qr-actions { display: flex; gap: 10px; }
body[data-room="greek-gods"] .qr-actions .qr-btn { flex: 1; width: auto; margin-top: 0; }

/* 4. Results, sprites, resume, and placeholder surface */
body[data-room="greek-gods"] .qr-result { padding: 22px 0 4px; text-align: center; }
body[data-room="greek-gods"] .qr-result-sprite-wrap { margin-bottom: 14px; }

body[data-room="greek-gods"] .qr-result-sprite {
  width: 192px;
  height: 192px;
  image-rendering: pixelated;
  background: linear-gradient(180deg, rgba(242, 202, 84, 0.12), rgba(112, 145, 168, 0.08));
  border: 4px solid var(--qr-accent);
  border-radius: var(--qr-radius);
  box-shadow: 0 10px 0 rgba(0, 0, 0, 0.22), 0 0 28px rgba(242, 202, 84, 0.16);
  animation: qr-gg-sprite-in 520ms cubic-bezier(.22, 1.18, .36, 1) both;
}

body[data-room="greek-gods"] .qr-result-eyebrow,
body[data-room="greek-gods"] .qr-result-dossier-eyebrow { color: var(--qr-accent); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 0; }
body[data-room="greek-gods"] .qr-result-name { color: var(--qr-fg) !important; font-family: "Press Start 2P", monospace; font-size: 20px; line-height: 1.35; text-shadow: 0 3px 0 #000; }
body[data-room="greek-gods"] .qr-result-tagline { color: var(--qr-gg-bronze); font-size: 14px; line-height: 1.5; }
body[data-room="greek-gods"] .qr-result-desc,
body[data-room="greek-gods"] .qr-result-runner { color: var(--qr-fg-dim); line-height: 1.6; }
body[data-room="greek-gods"] .qr-result-receipts { background: linear-gradient(180deg, rgba(246, 226, 196, 0.07), rgba(13, 10, 16, 0.34)), var(--qr-bg-elev); border: 1px solid var(--qr-gg-line); border-radius: var(--qr-radius); }
body[data-room="greek-gods"] .qr-result-receipts h3 { color: var(--qr-accent); font-family: "Press Start 2P", monospace; font-size: 11px; letter-spacing: 0; }
body[data-room="greek-gods"] .qr-resume-banner,
body[data-room="greek-gods"] .qr-stub { padding: 14px; color: var(--qr-fg-dim); background: rgba(13, 10, 16, 0.64); border: 1px solid var(--qr-gg-line); border-radius: var(--qr-radius); }
body[data-room="greek-gods"] .qr-stub h2 { margin-top: 0; color: var(--qr-accent); }

/* 5. Per-puzzle scene hooks for the sequence */
body[data-room="greek-gods"] .qr-board:has(.qr-gg-oracle) { border-color: rgba(112, 145, 168, 0.58); }
body[data-room="greek-gods"] .qr-board:has(.qr-gg-myth) { border-color: rgba(246, 226, 196, 0.48); }
body[data-room="greek-gods"] .qr-board:has(.qr-gg-olympus) { border-color: rgba(242, 202, 84, 0.58); }
body[data-room="greek-gods"] .qr-board:has(.qr-gg-judgment) { border-color: rgba(168, 170, 178, 0.58); }
body[data-room="greek-gods"] .qr-board:has(.qr-gg-tribute) { border-color: rgba(72, 105, 83, 0.70); }

.qr-gg-oracle,
.qr-gg-myth,
.qr-gg-judgment,
.qr-gg-tribute { display: flex; flex-direction: column; gap: 14px; }

.qr-gg-oracle .qr-scene { border-color: rgba(112, 145, 168, 0.62); }
.qr-gg-myth .qr-scene { border-color: rgba(246, 226, 196, 0.54); }
.qr-gg-judgment .qr-scene { border-color: rgba(168, 170, 178, 0.62); }
.qr-gg-tribute .qr-scene { border-color: rgba(72, 105, 83, 0.72); }

.qr-gg-oracle .qr-choice-prompt,
.qr-gg-myth .qr-choice-prompt,
.qr-gg-judgment .qr-choice-prompt,
.qr-gg-tribute .qr-choice-prompt { padding: 10px 12px; background: rgba(13, 10, 16, 0.42); border: 1px solid var(--qr-gg-line-soft); border-radius: var(--qr-radius); }

.qr-gg-oracle .qr-choice-prompt h2 { color: var(--qr-gg-storm); }
.qr-gg-myth .qr-choice-prompt h2 { color: var(--qr-gg-marble-warm); }
.qr-gg-judgment .qr-choice-prompt h2 { color: var(--qr-gg-moon); }
.qr-gg-tribute .qr-choice-prompt h2 { color: var(--qr-gg-olive); }
.qr-gg-oracle .qr-choice { border-color: rgba(112, 145, 168, 0.44); }
.qr-gg-myth .qr-choice { border-color: rgba(246, 226, 196, 0.34); }
.qr-gg-judgment .qr-choice { border-color: rgba(168, 170, 178, 0.44); }
.qr-gg-tribute .qr-choice { border-color: rgba(72, 105, 83, 0.58); }
.qr-gg-oracle .qr-choice::before { background: linear-gradient(135deg, var(--qr-gg-storm), var(--qr-gg-moon)); }
.qr-gg-myth .qr-choice::before { background: linear-gradient(135deg, var(--qr-gg-marble-warm), var(--qr-gg-bronze)); }
.qr-gg-judgment .qr-choice::before { background: linear-gradient(135deg, var(--qr-gg-moon), var(--qr-gg-gold)); }
.qr-gg-tribute .qr-choice::before { background: linear-gradient(135deg, var(--qr-gg-olive), var(--qr-gg-gold)); }
.qr-gg-oracle .qr-counter span,
.qr-gg-oracle .qr-status.win { color: var(--qr-gg-storm); }
.qr-gg-myth .qr-counter span,
.qr-gg-myth .qr-status.win { color: var(--qr-gg-marble-warm); }
.qr-gg-judgment .qr-counter span,
.qr-gg-judgment .qr-status.win { color: var(--qr-gg-moon); }
.qr-gg-tribute .qr-counter span,
.qr-gg-tribute .qr-status.win { color: var(--qr-gg-olive); }
.qr-gg-oracle-oracle-smoke,
.qr-gg-myth-scroll,
.qr-gg-judgment-scales,
.qr-gg-tribute-offering { image-rendering: pixelated; animation: qr-gg-prop-bob 1800ms ease-in-out infinite; }

/* 6. Actual Puzzle 3: The Olympus Seating Chart */
body[data-room="greek-gods"] .qr-gg-olympus { display: flex; flex-direction: column; gap: 14px; }
body[data-room="greek-gods"] .qr-gg-olympus .qr-scene { border-color: rgba(242, 202, 84, 0.64); }

body[data-room="greek-gods"] .qr-gg-olympus-prompt {
  padding: 10px 12px;
  background: rgba(13, 10, 16, 0.42);
  border: 1px solid var(--qr-gg-line-soft);
  border-radius: var(--qr-radius);
}

body[data-room="greek-gods"] .qr-gg-olympus-prompt h2 { margin: 0 0 6px; color: var(--qr-accent); font-size: 14px; }
body[data-room="greek-gods"] .qr-gg-olympus-prompt p { margin: 0; color: var(--qr-fg-dim); font-size: 14px; line-height: 1.55; }

body[data-room="greek-gods"] .qr-gg-olympus-tablewrap {
  max-width: 360px;
  padding: 8px;
  background: radial-gradient(circle at 50% 50%, rgba(246, 226, 196, 0.09), transparent 58%), rgba(13, 10, 16, 0.46);
  border: 1px solid rgba(242, 202, 84, 0.22);
  border-radius: var(--qr-radius);
}

body[data-room="greek-gods"] .qr-gg-olympus-svg { filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.32)); }
body[data-room="greek-gods"] .qr-gg-olympus-marble { fill: var(--qr-gg-marble); stroke: var(--qr-gg-gold); stroke-width: 4; }
body[data-room="greek-gods"] .qr-gg-olympus-ring { stroke: var(--qr-gg-bronze); stroke-width: 1.5; opacity: 0.68; }
body[data-room="greek-gods"] .qr-gg-olympus-seat-hit { cursor: pointer; outline: none; }
body[data-room="greek-gods"] .qr-gg-olympus-seat-hit:focus-visible { outline: 2px solid var(--qr-accent); outline-offset: 4px; }
body[data-room="greek-gods"] .qr-gg-olympus-seat { fill: #f6e2c4; stroke: #5f4618; stroke-width: 2; }
body[data-room="greek-gods"] .qr-gg-olympus-seat.locked { fill: var(--qr-gg-gold); stroke: #4a3512; }
body[data-room="greek-gods"] .qr-gg-olympus-seat.selectable { fill: #ebe8da; stroke: var(--qr-gg-bronze); }
body[data-room="greek-gods"] .qr-gg-olympus-seat.filled { fill: #f2ca54; stroke: #4a3512; animation: qr-gg-seat-pop 220ms ease-out; transform-origin: center; transform-box: fill-box; }
body[data-room="greek-gods"] .qr-gg-olympus-seatlabel,
body[data-room="greek-gods"] .qr-gg-olympus-seatcrown { fill: #2a1b0a; font-family: "Inter", sans-serif; font-weight: 800; letter-spacing: 0; }
body[data-room="greek-gods"] .qr-gg-olympus-line { stroke-width: 3; opacity: 0; }
body[data-room="greek-gods"] .qr-gg-olympus-line.alliance { stroke: var(--qr-accent); opacity: 0.9; filter: drop-shadow(0 0 5px rgba(242, 202, 84, 0.7)); }
body[data-room="greek-gods"] .qr-gg-olympus-line.feud { stroke: var(--qr-danger); opacity: 0.9; }
body[data-room="greek-gods"] .qr-gg-olympus-score { fill: #2a1b0a; font-family: "Press Start 2P", monospace; font-weight: 700; }
body[data-room="greek-gods"] .qr-gg-olympus-score.pos { fill: #486953; }
body[data-room="greek-gods"] .qr-gg-olympus-score.neg { fill: #a83f47; }
body[data-room="greek-gods"] .qr-gg-olympus-scorelabel { fill: #6f5420; font-family: "Inter", sans-serif; font-weight: 800; letter-spacing: 0; }
body[data-room="greek-gods"] .qr-gg-olympus-palette { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }

body[data-room="greek-gods"] .qr-gg-olympus-godcard {
  min-height: 58px;
  color: var(--qr-fg);
  background: linear-gradient(135deg, rgba(242, 202, 84, 0.10), rgba(112, 145, 168, 0.06)), var(--qr-gg-ink);
  border: 1px solid rgba(242, 202, 84, 0.34);
  border-radius: var(--qr-radius);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

body[data-room="greek-gods"] .qr-gg-olympus-godcard:hover:not(:disabled),
body[data-room="greek-gods"] .qr-gg-olympus-godcard:focus-visible { border-color: var(--qr-accent); filter: brightness(1.12); transform: translateY(-1px); box-shadow: 0 5px 0 rgba(0, 0, 0, 0.22), 0 0 0 2px rgba(242, 202, 84, 0.14); }
body[data-room="greek-gods"] .qr-gg-olympus-godcard.selected { color: #130d0a; background: linear-gradient(180deg, var(--qr-gg-gold), var(--qr-gg-bronze)); border-color: var(--qr-accent); box-shadow: 0 0 0 2px rgba(242, 202, 84, 0.28), 0 0 18px rgba(242, 202, 84, 0.25); }
body[data-room="greek-gods"] .qr-gg-olympus-godcard.placed { opacity: 0.45; cursor: default; filter: grayscale(0.25); }
body[data-room="greek-gods"] .qr-gg-olympus-godcard-name { color: var(--qr-accent); font-size: 9px; letter-spacing: 0; }
body[data-room="greek-gods"] .qr-gg-olympus-godcard.selected .qr-gg-olympus-godcard-name { color: #130d0a; }
body[data-room="greek-gods"] .qr-gg-olympus-godcard-epithet { color: var(--qr-fg-dim); font-size: 9px; }
body[data-room="greek-gods"] .qr-gg-olympus-godcard.selected .qr-gg-olympus-godcard-epithet { color: rgba(19, 13, 10, 0.72); }
body[data-room="greek-gods"] .qr-gg-olympus-feedback { color: var(--qr-fg-dim); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 0; }
body[data-room="greek-gods"] .qr-gg-olympus-feedback.show { opacity: 1; }
body[data-room="greek-gods"] .qr-gg-olympus-feedback.warn { color: var(--qr-warn); }
body[data-room="greek-gods"] .qr-gg-olympus-feedback.good { color: var(--qr-gg-olive); }
body[data-room="greek-gods"] .qr-gg-olympus-actions { display: flex; gap: 8px; }
body[data-room="greek-gods"] .qr-gg-olympus-actions .qr-btn { flex: 1; width: auto; margin-top: 0; }
body[data-room="greek-gods"] .qr-gg-olympus-skip { color: var(--qr-fg); background: rgba(13, 10, 16, 0.74); border-color: rgba(244, 234, 213, 0.22); box-shadow: none; }
body[data-room="greek-gods"] .qr-gg-olympus-result { padding: 12px; color: var(--qr-accent); background: rgba(13, 10, 16, 0.62); border: 1px solid var(--qr-gg-line); border-radius: var(--qr-radius); font-size: 11px; line-height: 1.65; text-align: center; }
body[data-room="greek-gods"] .qr-gg-olympus-result[hidden],
body[data-room="greek-gods"] .qr-gg-olympus-feedback[hidden] { display: none; }

/* 7. Motion */
@keyframes qr-gg-scene-in {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes qr-gg-sprite-in {
  from { opacity: 0; transform: translateY(10px) scale(0.92); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes qr-gg-prop-bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}

@keyframes qr-gg-choice-icon-bob {
  0%, 100% { transform: translateY(-50%) translateY(0); }
  50% { transform: translateY(-50%) translateY(-3px); }
}

@keyframes qr-gg-choice-lift {
  from { filter: brightness(1); }
  to { filter: brightness(1.08); }
}

@keyframes qr-gg-seat-pop {
  from { opacity: 0; transform: scale(0.72); }
  to { opacity: 1; transform: scale(1); }
}

@media (prefers-reduced-motion: reduce) {
  body[data-room="greek-gods"] *,
  body[data-room="greek-gods"] *::before,
  body[data-room="greek-gods"] *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}

/* 8. Mobile */
@media (max-width: 520px) {
  body[data-room="greek-gods"] #qr-root { max-width: 100%; padding: 18px 12px 28px; }
  body[data-room="greek-gods"] .qr-board { min-height: 320px; padding: 15px 12px 18px; }
  body[data-room="greek-gods"] .qr-scene { max-height: 148px; margin-bottom: 14px; }
  body[data-room="greek-gods"] .qr-choice-prompt h2,
  body[data-room="greek-gods"] .qr-gg-olympus-prompt h2 { font-size: 12px; }
  body[data-room="greek-gods"] .qr-choice-prompt p,
  body[data-room="greek-gods"] .qr-gg-olympus-prompt p,
  body[data-room="greek-gods"] .qr-result-desc { font-size: 13px; }
  body[data-room="greek-gods"] .qr-choice,
  body[data-room="greek-gods"] .qr-btn,
  body[data-room="greek-gods"] .qr-gg-olympus-godcard { min-height: 44px; }
  body[data-room="greek-gods"] .qr-choice { padding: 11px 11px 11px 48px; }
  body[data-room="greek-gods"] .qr-choice-grid,
  body[data-room="greek-gods"] .qr-gg-olympus-palette { grid-template-columns: 1fr; }
  body[data-room="greek-gods"] .qr-gg-olympus-tablewrap { max-width: 330px; padding: 6px; }
  body[data-room="greek-gods"] .qr-gg-olympus-actions,
  body[data-room="greek-gods"] .qr-actions { flex-direction: column; }
}

@media (max-width: 360px) {
  body[data-room="greek-gods"] .qr-board { padding-left: 10px; padding-right: 10px; }
  body[data-room="greek-gods"] .qr-btn { padding-left: 10px; padding-right: 10px; font-size: 10px; }
  body[data-room="greek-gods"] .qr-result-sprite { width: 176px; height: 176px; }
}
