/* Lord of the Rings Quiz Room - Fellowship trials theme */

:root {
  --qr-bg: #101611;
  --qr-bg-elev: #182016;
  --qr-fg: #f1ead6;
  --qr-fg-dim: #b4a987;
  --qr-accent: #caa65a;
  --qr-accent-dim: #6f5a2f;
  --qr-warn: #e0a446;
  --qr-danger: #b54b36;
  --qr-radius: 6px;
  --qr-forest: #243723;
  --qr-moss: #53673a;
  --qr-leather: #503722;
  --qr-ember: #a95f2e;
  --qr-gold: #be9a46;
  --qr-parchment: #e0cf9e;
  --qr-mithril: #bfc4b8;
  --qr-elven: #58706f;
  --qr-shadow: #101611;
  --qr-ring-glow: rgba(202, 166, 90, 0.34);
  --qr-fire-glow: rgba(181, 75, 54, 0.28);
  --qr-choice-bg: rgba(16, 22, 17, 0.82);
  --qr-choice-border: rgba(202, 166, 90, 0.48);
}

* { box-sizing: border-box; }

body {
  background: linear-gradient(180deg, #101611 0%, #151b13 54%, #21170f 100%);
  color: var(--qr-fg);
  font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

#qr-root {
  max-width: 500px;
}

.qr-stage {
  gap: 18px;
}

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

.qr-board {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(224, 207, 158, 0.06), rgba(16, 22, 17, 0)), var(--qr-bg-elev);
  border: 1px solid rgba(202, 166, 90, 0.52);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.32), inset 0 0 0 1px rgba(241, 234, 214, 0.04);
}

.qr-board::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 5px);
  opacity: 0.7;
}

.qr-board > * {
  position: relative;
  z-index: 1;
}

.qr-board h1,
.qr-board h2,
.qr-board h3,
.qr-choice-prompt h1,
.qr-choice-prompt h2,
.qr-choice-prompt h3 {
  color: var(--qr-accent);
  letter-spacing: 1px;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.35);
}

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

.qr-choice-prompt h2,
.qr-lotr-mountdoom-prompt h2 {
  font-family: "Press Start 2P", monospace;
  font-size: 14px;
  line-height: 1.45;
  margin: 0 0 8px;
}

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

.qr-scene {
  border: 2px solid rgba(202, 166, 90, 0.56);
  border-radius: var(--qr-radius);
  background: var(--qr-shadow);
  box-shadow: 0 0 0 1px rgba(241, 234, 214, 0.05), 0 12px 24px rgba(0, 0, 0, 0.26);
  image-rendering: pixelated;
  image-rendering: -moz-crisp-edges;
  image-rendering: crisp-edges;
  animation: qr-lotr-scene-fade 420ms ease-out both;
}

.qr-btn {
  min-height: 46px;
  background: linear-gradient(180deg, #d5b76b 0%, var(--qr-accent) 100%);
  color: #17130b;
  border: 1px solid rgba(242, 236, 214, 0.18);
  box-shadow: 0 3px 0 #5a4724;
}

.qr-btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.qr-btn:active { box-shadow: 0 1px 0 #5a4724; transform: translateY(1px); }
.qr-btn:disabled { background: var(--qr-accent-dim); color: rgba(241, 234, 214, 0.64); box-shadow: none; }

.qr-choice-list {
  gap: 10px;
  margin-bottom: 14px;
}

.qr-choice {
  min-height: 58px;
  padding: 13px 14px;
  background: linear-gradient(180deg, rgba(224, 207, 158, 0.05), rgba(16, 22, 17, 0)), var(--qr-choice-bg);
  border: 2px solid var(--qr-choice-border);
  color: var(--qr-fg);
  border-radius: var(--qr-radius);
  line-height: 1.45;
  transition: background 140ms ease, border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.qr-choice:hover,
.qr-choice:focus-visible {
  border-color: var(--qr-accent);
  box-shadow: 0 0 0 3px rgba(202, 166, 90, 0.18);
  transform: translateY(-2px);
}

.qr-choice.picked {
  background: linear-gradient(180deg, rgba(202, 166, 90, 0.22), rgba(80, 55, 34, 0.18)), var(--qr-bg);
  border-color: var(--qr-accent);
  box-shadow: inset 0 0 0 1px rgba(242, 236, 214, 0.12);
}

.qr-choice:disabled { cursor: not-allowed; }
.qr-choice small { font-family: "Press Start 2P", monospace; font-size: 9px; line-height: 1.6; text-transform: uppercase; }

.qr-counter {
  padding: 9px 10px;
  margin: 0 0 10px;
  background: rgba(16, 22, 17, 0.74);
  border: 1px solid rgba(202, 166, 90, 0.34);
  border-radius: var(--qr-radius);
  color: var(--qr-fg-dim);
}

.qr-counter span,
.qr-lotr-r,
.qr-lotr-f {
  color: var(--qr-warn);
}

.qr-counter.complete {
  color: var(--qr-accent);
  border-color: var(--qr-accent);
  box-shadow: 0 0 16px rgba(202, 166, 90, 0.16);
}

.qr-status {
  min-height: 24px;
  color: var(--qr-fg-dim);
  font-size: 13px;
  line-height: 1.45;
}

.qr-status.win { color: var(--qr-accent); }
.qr-status.bad { color: var(--qr-danger); animation: qr-lotr-status-jolt 260ms ease-out; }

.qr-outcome {
  margin-top: 14px;
  padding: 13px 14px;
  background: linear-gradient(180deg, rgba(224, 207, 158, 0.08), rgba(80, 55, 34, 0.10)), rgba(16, 22, 17, 0.86);
  border: 1px solid var(--qr-accent);
  color: var(--qr-fg);
  box-shadow: inset 0 0 0 1px rgba(242, 236, 214, 0.05);
  animation: qr-lotr-choice-lift 240ms ease-out both;
}

.qr-hint { color: var(--qr-warn); border-left: 3px solid var(--qr-warn); padding-left: 10px; }
.qr-result { color: var(--qr-fg); }

.qr-result-sprite {
  background: linear-gradient(180deg, rgba(202, 166, 90, 0.10), rgba(16, 22, 17, 0.18)), var(--qr-bg);
  border-color: var(--qr-accent);
  box-shadow: 0 0 0 1px rgba(242, 236, 214, 0.08), 0 0 28px rgba(202, 166, 90, 0.16);
  animation: qr-lotr-sprite-enter 520ms ease-out both;
}

.qr-result-eyebrow,
.qr-result-dossier-eyebrow {
  color: var(--qr-accent);
}

.qr-result-receipts.qr-result-dossier {
  background: linear-gradient(180deg, rgba(224, 207, 158, 0.10), rgba(16, 22, 17, 0.86)), var(--qr-bg-elev);
  border-color: rgba(202, 166, 90, 0.48);
}

/* Puzzle 1: Rivendell Council */
.qr-scene[src$="scene_council.png"] {
  border-color: rgba(224, 207, 158, 0.72);
  box-shadow: 0 0 0 1px rgba(88, 112, 111, 0.35), 0 14px 26px rgba(0, 0, 0, 0.28);
}

.qr-choice[data-id="volunteer"] { border-left-color: var(--qr-gold); }
.qr-choice[data-id="destroy"] { border-left-color: var(--qr-elven); }
.qr-choice[data-id="use"] { border-left-color: var(--qr-ember); }
.qr-choice[data-id="follow"] { border-left-color: var(--qr-mithril); }
.qr-choice[data-id="guard"] { border-left-color: var(--qr-moss); }

.qr-choice[data-id="volunteer"].picked,
.qr-choice[data-id="guard"].picked {
  box-shadow: inset 4px 0 0 var(--qr-gold);
}

.qr-choice[data-id="destroy"].picked,
.qr-choice[data-id="follow"].picked {
  box-shadow: inset 4px 0 0 var(--qr-mithril);
}

.qr-choice[data-id="use"].picked { box-shadow: inset 4px 0 0 var(--qr-danger); }
.qr-lotr-council-done { background: linear-gradient(180deg, var(--qr-parchment), var(--qr-accent)); }
.qr-lotr-council-done:not([hidden]) { animation: qr-lotr-choice-lift 240ms ease-out both; }

/* Puzzle 2: Mines of Moria */
.qr-scene[src$="scene_moria.png"] {
  border-color: rgba(191, 196, 184, 0.54);
  box-shadow: 0 0 22px rgba(88, 112, 111, 0.18), inset 0 0 20px rgba(0, 0, 0, 0.32);
}

.qr-lotr-stage {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
  margin: 4px 0 14px !important;
}

.qr-lotr-stage .qr-choice {
  min-height: 94px !important;
  padding: 12px 8px;
  text-align: center;
  background: linear-gradient(180deg, rgba(88, 112, 111, 0.18), rgba(16, 22, 17, 0.88)), var(--qr-bg);
}

.qr-lotr-stage .qr-choice::after {
  content: "";
  display: block;
  width: 42px;
  height: 4px;
  margin: 10px auto 0;
  background: rgba(191, 196, 184, 0.36);
  border-radius: 2px;
}

.qr-lotr-stage .qr-choice:hover { background: linear-gradient(180deg, rgba(191, 196, 184, 0.18), rgba(16, 22, 17, 0.88)), var(--qr-bg); }
.qr-lotr-stage .qr-choice[data-idx="0"] { transform-origin: 50% 100%; }
.qr-lotr-stage .qr-choice[data-idx="1"] { box-shadow: inset 0 -12px 0 rgba(88, 112, 111, 0.08); }
.qr-lotr-stage .qr-choice[data-idx="2"] { transform-origin: 50% 100%; }
.qr-lotr-stage .qr-choice:disabled { opacity: 0.68; }
.qr-lotr-r, .qr-lotr-f { text-shadow: 0 0 8px rgba(224, 164, 70, 0.4); }

/* Puzzle 3: Lothlorien Gifts */
.qr-scene[src$="scene_lothlorien.png"] {
  border-color: rgba(224, 207, 158, 0.82);
  box-shadow: 0 0 26px rgba(202, 166, 90, 0.18), 0 14px 26px rgba(0, 0, 0, 0.22);
}

.qr-choice[data-id="phial"] { border-left-color: var(--qr-parchment); }
.qr-choice[data-id="rope"] { border-left-color: var(--qr-moss); }
.qr-choice[data-id="bow"] { border-left-color: var(--qr-elven); }
.qr-choice[data-id="sword"] { border-left-color: var(--qr-mithril); }
.qr-choice[data-id="hair"] { border-left-color: var(--qr-gold); }
.qr-choice[data-id="mirror"] { border-left-color: var(--qr-danger); }

.qr-choice[data-id="phial"].picked,
.qr-choice[data-id="hair"].picked {
  background: linear-gradient(180deg, rgba(224, 207, 158, 0.22), rgba(202, 166, 90, 0.10)), var(--qr-bg);
}

.qr-choice[data-id="mirror"].picked {
  box-shadow: inset 4px 0 0 var(--qr-elven), 0 0 18px rgba(88, 112, 111, 0.18);
}

.qr-lotr-loth-done { background: linear-gradient(180deg, #efe3bc, var(--qr-gold)); }
.qr-lotr-loth-done:not([hidden]) { animation: qr-lotr-prop-bob 1100ms ease-in-out infinite; }

/* Puzzle 4: Helm's Deep */
.qr-scene[src$="scene_helmsdeep.png"] {
  border-color: rgba(191, 196, 184, 0.62);
  box-shadow: 0 0 24px rgba(181, 75, 54, 0.12), 0 14px 26px rgba(0, 0, 0, 0.34);
}

.qr-choice[data-id="wall"] { border-left-color: var(--qr-mithril); }
.qr-choice[data-id="ride"] { border-left-color: var(--qr-gold); }
.qr-choice[data-id="gandalf"] { border-left-color: var(--qr-parchment); }
.qr-choice[data-id="count"] { border-left-color: var(--qr-ember); }
.qr-choice[data-id="civilians"] { border-left-color: var(--qr-moss); }
.qr-choice[data-id="parley"] { border-left-color: var(--qr-elven); }

.qr-choice[data-id="wall"].picked,
.qr-choice[data-id="ride"].picked,
.qr-choice[data-id="gandalf"].picked {
  box-shadow: inset 4px 0 0 var(--qr-accent), 0 0 18px rgba(202, 166, 90, 0.16);
}

.qr-choice[data-id="count"].picked,
.qr-choice[data-id="parley"].picked {
  box-shadow: inset 4px 0 0 var(--qr-ember);
}

.qr-choice[data-id="civilians"].picked { box-shadow: inset 4px 0 0 var(--qr-moss); }
.qr-lotr-hd-done { background: linear-gradient(180deg, var(--qr-mithril), var(--qr-accent)); }
.qr-lotr-hd-done:not([hidden]) { animation: qr-lotr-ember-pulse 1200ms ease-in-out infinite; }

/* Puzzle 5: Mount Doom */
.qr-scene[src$="scene_mountdoom.png"] {
  border-color: rgba(181, 75, 54, 0.72);
  box-shadow: 0 0 28px rgba(181, 75, 54, 0.20), 0 14px 28px rgba(0, 0, 0, 0.38);
}

.qr-board .qr-lotr-mountdoom { gap: 15px; }
.qr-board .qr-lotr-mountdoom-prompt h2 { color: var(--qr-warn); font-size: 15px; }
.qr-board .qr-lotr-mountdoom-status { gap: 9px; }

.qr-board .qr-lotr-mountdoom-status span {
  min-height: 50px;
  padding: 9px 6px;
  background: rgba(16, 22, 17, 0.76);
  border: 1px solid rgba(202, 166, 90, 0.34);
  border-radius: var(--qr-radius);
}

.qr-board .qr-lotr-mountdoom-status strong {
  color: var(--qr-warn);
  text-shadow: 0 0 10px rgba(224, 164, 70, 0.32);
}

.qr-board .qr-lotr-mountdoom-scale {
  min-height: 148px;
  background: linear-gradient(180deg, rgba(181, 75, 54, 0.12), rgba(16, 22, 17, 0.86)), var(--qr-bg);
  border-color: rgba(181, 75, 54, 0.62);
}

.qr-board .qr-lotr-mountdoom-beam {
  background: linear-gradient(90deg, var(--qr-parchment), var(--qr-accent), var(--qr-ember));
  box-shadow: 0 0 16px rgba(202, 166, 90, 0.16);
}

.qr-board .qr-lotr-mountdoom-pivot { background: var(--qr-accent); box-shadow: 0 0 14px var(--qr-ring-glow); }
.qr-board .qr-lotr-mountdoom-pan { background: rgba(16, 22, 17, 0.78); border-radius: 0 0 28px 28px; }
.qr-board .qr-lotr-mountdoom-pan-light { color: var(--qr-parchment); }
.qr-board .qr-lotr-mountdoom-pan-shadow { color: var(--qr-danger); }
.qr-board .qr-lotr-mountdoom-tilt-marker { color: var(--qr-fg-dim); }
.qr-board .qr-lotr-mountdoom-grid { gap: 9px; }

.qr-board .qr-lotr-mountdoom-burden {
  min-height: 64px;
  background: linear-gradient(180deg, rgba(224, 207, 158, 0.06), rgba(16, 22, 17, 0)), var(--qr-bg);
  border-color: rgba(202, 166, 90, 0.44);
}

.qr-board .qr-lotr-mountdoom-burden:hover { border-color: var(--qr-warn); transform: translateY(-1px); }
.qr-board .qr-lotr-mountdoom-burden-label { color: var(--qr-accent); }
.qr-board .qr-lotr-mountdoom-burden-sub { color: var(--qr-fg-dim); }
.qr-board .qr-lotr-mountdoom-burden[data-id="power"],
.qr-board .qr-lotr-mountdoom-burden[data-id="greed"] { border-left-color: var(--qr-danger); }
.qr-board .qr-lotr-mountdoom-burden[data-id="pity"],
.qr-board .qr-lotr-mountdoom-burden[data-id="mercy"] { border-left-color: var(--qr-elven); }
.qr-board .qr-lotr-mountdoom-burden[data-id="duty"],
.qr-board .qr-lotr-mountdoom-burden[data-id="fellowship"] { border-left-color: var(--qr-accent); }

.qr-board .qr-lotr-mountdoom-burden.removed { opacity: 0.34; border-style: dashed; }
.qr-board .qr-lotr-mountdoom-actions { gap: 10px; }
.qr-board .qr-lotr-mountdoom-cast { color: #17130b; }
.qr-board .qr-lotr-mountdoom-claim { background: linear-gradient(180deg, var(--qr-ember), var(--qr-danger)); color: var(--qr-fg); }
.qr-board .qr-lotr-mountdoom-result { color: var(--qr-warn); border: 1px solid rgba(224, 164, 70, 0.42); box-shadow: inset 0 0 0 1px rgba(242, 236, 214, 0.05); }
.qr-board .qr-lotr-mountdoom.shadow-won .qr-lotr-mountdoom-scale { box-shadow: inset 0 0 36px rgba(181, 75, 54, 0.34), 0 0 22px rgba(181, 75, 54, 0.14); }
.qr-board .qr-lotr-mountdoom-done:not([hidden]) { animation: qr-lotr-choice-lift 240ms ease-out both; }

@keyframes qr-lotr-sprite-enter {
  0% { opacity: 0; transform: translateY(12px) scale(0.96); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes qr-lotr-scene-fade {
  0% { opacity: 0; transform: translateY(6px); }
  100% { opacity: 1; transform: translateY(0); }
}

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

@keyframes qr-lotr-choice-lift {
  0% { opacity: 0; transform: translateY(6px); }
  100% { opacity: 1; transform: translateY(0); }
}

@keyframes qr-lotr-status-jolt {
  0%, 100% { transform: translateX(0); }
  35% { transform: translateX(-3px); }
  70% { transform: translateX(3px); }
}

@keyframes qr-lotr-ember-pulse {
  0%, 100% { box-shadow: 0 3px 0 #5a4724; }
  50% { box-shadow: 0 3px 0 #5a4724, 0 0 16px rgba(181, 75, 54, 0.24); }
}

@media (max-width: 600px) {
  #qr-root { max-width: 100%; padding: 18px 12px; }
  .qr-board { padding: 16px 12px; min-height: 300px; }
  .qr-scene { width: 100%; max-height: 180px; object-fit: contain; }
  .qr-choice-prompt h2, .qr-lotr-mountdoom-prompt h2 { font-size: 12px; }
  .qr-choice-prompt p, .qr-lotr-mountdoom-prompt p { font-size: 13px; }
  .qr-choice, .qr-btn, .qr-lotr-stage .qr-choice, .qr-lotr-mountdoom-burden { min-height: 44px !important; }
  .qr-choice { padding: 12px; font-size: 13px; }
  .qr-lotr-stage { grid-template-columns: 1fr !important; }
  .qr-lotr-stage .qr-choice { min-height: 72px !important; }
  .qr-board .qr-lotr-mountdoom-status { grid-template-columns: 1fr; }
  .qr-board .qr-lotr-mountdoom-grid { grid-template-columns: 1fr; }
  .qr-board .qr-lotr-mountdoom-actions { flex-direction: column; }
  .qr-board .qr-lotr-mountdoom-actions .qr-btn { min-width: 100%; }
}

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