/* Hamilton Quiz Room - candlelit parchment, Federalist navy, brass, and revolution red */

:root,
body[data-room="hamilton"],
.qr-room-hamilton {
  --qr-bg: #110d08;
  --qr-bg-elev: #1c1610;
  --qr-fg: #f0e6cc;
  --qr-fg-dim: #b8a27d;
  --qr-accent: #b03a2e;
  --qr-accent-dim: #6a1b14;
  --qr-warn: #d4a017;
  --qr-danger: #8a0a0a;
  --qr-radius: 6px;
  --qr-ham-ink: #121418;
  --qr-ham-navy: #243044;
  --qr-ham-blue: #405262;
  --qr-ham-burgundy: #702a26;
  --qr-ham-red: #aa4030;
  --qr-ham-gold: #cc9c48;
  --qr-ham-paper: #eedbaa;
  --qr-ham-paper-dim: #d0b783;
  --qr-ham-wood: #462a1c;
  --qr-ham-line: rgba(204, 156, 72, 0.34);
  --qr-ham-shadow: rgba(10, 7, 5, 0.74);
  --qr-ham-choice-icon: url("objects/quill.png");
  --qr-ham-puzzle-accent: var(--qr-ham-gold);
}

body[data-room="hamilton"] {
  background: linear-gradient(180deg, rgba(204,156,72,.08) 0%, transparent 32%), linear-gradient(180deg, #1a120c 0%, var(--qr-bg) 52%, #080604 100%);
  color: var(--qr-fg);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

body[data-room="hamilton"] #qr-root { max-width: 500px; }
.qr-stage { gap: 16px; }
.qr-progress {
  color: var(--qr-ham-paper-dim);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  letter-spacing: 0;
  text-shadow: 0 1px 0 var(--qr-ham-ink);
}

.qr-board {
  position: relative;
  overflow: hidden;
  min-height: 340px;
  padding: 18px 16px 20px;
  background: linear-gradient(180deg, rgba(238,219,170,.05), transparent 44%), repeating-linear-gradient(0deg, rgba(238,219,170,.025) 0 1px, transparent 1px 13px), var(--qr-bg-elev);
  border: 1px solid var(--qr-ham-line);
  border-radius: var(--qr-radius);
  box-shadow: 0 10px 0 rgba(0,0,0,.18), inset 0 0 0 1px rgba(238,219,170,.06);
}
.qr-board::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(255,255,255,.03), transparent 18%, transparent 82%, rgba(0,0,0,.12)), linear-gradient(180deg, transparent 0 88%, rgba(0,0,0,.16));
}
.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-fg); }

.qr-choice-prompt { margin: 0 0 14px; }
.qr-choice-prompt h2 {
  margin: 0 0 8px;
  color: var(--qr-ham-puzzle-accent);
  font-family: 'Press Start 2P', monospace;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 1.42;
  text-shadow: 0 2px 0 var(--qr-ham-shadow);
  text-transform: uppercase;
}
.qr-choice-prompt p { margin: 0; color: var(--qr-fg-dim); font-size: 14px; line-height: 1.55; }

.qr-scene {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 0 16px;
  border: 1px solid var(--qr-ham-line);
  border-radius: var(--qr-radius);
  background: var(--qr-ham-ink);
  image-rendering: pixelated;
  image-rendering: -moz-crisp-edges;
  image-rendering: crisp-edges;
  box-shadow: 0 6px 0 rgba(0,0,0,.18);
  animation: qr-ham-scene-in 360ms ease-out both;
}

.qr-choice-list { display: grid; grid-template-columns: 1fr; gap: 9px; margin: 0 0 12px; }
.qr-choice {
  appearance: none;
  position: relative;
  min-height: 64px;
  padding: 12px 13px 12px 58px;
  overflow: hidden;
  color: var(--qr-fg);
  background: linear-gradient(180deg, rgba(238,219,170,.06), rgba(0,0,0,.03)), var(--qr-bg);
  border: 1px solid rgba(204,156,72,.44);
  border-radius: var(--qr-radius);
  box-shadow: inset 0 -2px 0 rgba(0,0,0,.22);
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  line-height: 1.43;
  text-align: left;
  touch-action: manipulation;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease, box-shadow 120ms ease;
}
.qr-choice::before {
  content: "";
  position: absolute;
  left: 13px;
  top: 50%;
  width: 32px;
  height: 32px;
  transform: translateY(-50%);
  background: var(--qr-ham-choice-icon) center / contain no-repeat;
  image-rendering: pixelated;
  filter: drop-shadow(0 3px 0 rgba(0,0,0,.24));
  animation: qr-ham-prop-bob 3s ease-in-out infinite;
}
.qr-choice::after {
  content: "";
  position: absolute;
  top: 9px;
  bottom: 9px;
  left: 50px;
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--qr-ham-line), transparent);
}
.qr-choice:hover:not(:disabled),
.qr-choice:focus-visible {
  border-color: var(--qr-ham-puzzle-accent);
  box-shadow: 0 5px 0 rgba(0,0,0,.22), inset 0 -2px 0 rgba(0,0,0,.16);
  animation: qr-ham-choice-lift 180ms ease-out both;
  outline: none;
}
.qr-choice.picked {
  color: #22170f;
  background: linear-gradient(180deg, rgba(238,219,170,.92), rgba(204,156,72,.82)), var(--qr-ham-paper);
  border-color: var(--qr-warn);
  box-shadow: 0 5px 0 var(--qr-accent-dim);
}
.qr-choice:disabled { cursor: not-allowed; }
.qr-choice:disabled:not(.picked) { opacity: .56; filter: grayscale(.32); }
.qr-choice .qr-choice-name {
  display: block;
  margin-bottom: 5px;
  color: var(--qr-warn);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  letter-spacing: 0;
  line-height: 1.5;
  text-transform: uppercase;
}
.qr-choice.picked .qr-choice-name { color: var(--qr-accent-dim); }

.qr-btn {
  appearance: none;
  width: 100%;
  min-height: 44px;
  margin-top: 16px;
  padding: 12px 18px;
  color: #1b120b;
  background: linear-gradient(180deg, var(--qr-warn), var(--qr-ham-gold));
  border: 1px solid rgba(238,219,170,.22);
  border-radius: var(--qr-radius);
  box-shadow: 0 4px 0 var(--qr-accent-dim);
  cursor: pointer;
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  letter-spacing: 0;
  text-transform: uppercase;
  transition: transform 100ms ease, filter 100ms ease, box-shadow 100ms ease;
}
.qr-btn:hover:not(:disabled), .qr-btn:focus-visible { filter: brightness(1.08); transform: translateY(-1px); outline: none; }
.qr-btn:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--qr-accent-dim); }
.qr-btn:disabled { cursor: not-allowed; opacity: .52; filter: grayscale(.45); transform: none; }
.qr-btn-sm { width: auto; min-height: 44px; margin-top: 0; padding: 8px 14px; font-size: 10px; }

.qr-counter,
.qr-status {
  margin: 0 0 12px;
  padding: 9px 10px;
  color: var(--qr-fg-dim);
  background: rgba(17,13,8,.66);
  border: 1px solid var(--qr-ham-line);
  border-radius: var(--qr-radius);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  letter-spacing: 0;
  text-align: center;
}
.qr-counter span, .qr-status span { color: var(--qr-warn); }
.qr-status.warn { color: var(--qr-warn); }
.qr-status.win { color: var(--qr-ham-gold); }
.qr-status.bad { color: var(--qr-danger); }

.qr-outcome {
  margin-top: 14px;
  padding: 13px 14px;
  color: var(--qr-fg);
  background: rgba(17,13,8,.72);
  border: 1px dashed var(--qr-ham-puzzle-accent);
  border-radius: var(--qr-radius);
  font-size: 13px;
  line-height: 1.52;
  animation: qr-ham-scene-in 220ms ease-out both;
}
.qr-hint {
  padding: 10px 12px;
  color: var(--qr-warn);
  background: rgba(28,22,16,.92);
  border-left: 3px solid var(--qr-warn);
  border-radius: var(--qr-radius);
  font-size: 12px;
  font-style: italic;
  line-height: 1.45;
  opacity: 0;
  transition: opacity 320ms ease;
}
.qr-hint-visible { opacity: 1; }
.qr-resume-banner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
  padding: 12px;
  color: var(--qr-fg);
  background: rgba(28,22,16,.94);
  border: 1px solid var(--qr-warn);
  border-radius: var(--qr-radius);
  font-size: 13px;
}

.qr-result { padding: 28px 4px 10px; text-align: center; }
.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;
  background: var(--qr-ham-ink);
  border: 4px solid var(--qr-ham-puzzle-accent);
  border-radius: var(--qr-radius);
  box-shadow: 0 8px 0 var(--qr-accent-dim), 0 0 0 1px rgba(238,219,170,.16);
  animation: qr-ham-sprite-in 520ms cubic-bezier(.22,1.18,.36,1) both;
}
.qr-result-eyebrow,
.qr-result-dossier-eyebrow {
  color: var(--qr-accent);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  letter-spacing: 0;
  text-transform: uppercase;
}
.qr-result-name {
  margin: 8px 0;
  color: var(--qr-fg) !important;
  font-family: 'Press Start 2P', monospace;
  font-size: 20px;
  letter-spacing: 0;
  line-height: 1.35;
}
.qr-result-tagline { margin: 0 0 14px; color: var(--qr-fg-dim); font-size: 14px; font-style: italic; }
.qr-result-desc { padding: 0 6px; color: var(--qr-fg); font-size: 14px; line-height: 1.65; text-align: left; }
.qr-result-runner { color: var(--qr-fg-dim); font-size: 13px; }
.qr-result-receipts.qr-result-dossier {
  background: linear-gradient(180deg, rgba(238,219,170,.08), rgba(28,22,16,.96)), var(--qr-bg-elev);
  border: 1px solid var(--qr-ham-line);
  box-shadow: inset 0 0 0 1px rgba(238,219,170,.04);
}
.qr-result-dossier-header,
.qr-result-dossier-stamp {
  color: var(--qr-fg-dim);
  font-family: 'Press Start 2P', monospace;
  font-size: 9px;
  letter-spacing: 0;
}
.qr-result-dossier-lines li { color: var(--qr-fg); border-bottom-color: rgba(204,156,72,.28); }
.qr-result-share-row { gap: 8px; }
.qr-btn-secondary, .qr-result-cta { color: var(--qr-fg); background: rgba(17,13,8,.64); border-color: var(--qr-ham-line); }
.qr-result-cta { box-shadow: inset 0 0 0 1px rgba(238,219,170,.04); }
.qr-result-cta:hover, .qr-result-cta:focus-visible { border-color: var(--qr-warn); box-shadow: 0 4px 0 rgba(0,0,0,.18); }
.qr-result-cta-eyebrow { color: var(--qr-warn); letter-spacing: 0; }

/* Puzzle 1: Schuyler ballroom */
.qr-board:has(.qr-ham-sch-done) {
  --qr-ham-puzzle-accent: var(--qr-ham-gold);
  --qr-ham-choice-icon: url("objects/schuyler_fan.png");
}
.qr-board:has(.qr-ham-sch-done) .qr-scene[src$="scene_schuyler.png"] {
  border-color: rgba(204,156,72,.58);
  box-shadow: 0 6px 0 rgba(112,42,38,.32);
}
.qr-board:has(.qr-ham-sch-done) .qr-choice-prompt { border-left: 3px solid var(--qr-ham-gold); padding-left: 11px; }
.qr-board:has(.qr-ham-sch-done) .qr-choice[data-id="eliza"] { --qr-ham-choice-icon: url("objects/parchment_letter.png"); }
.qr-board:has(.qr-ham-sch-done) .qr-choice[data-id="angelica"] { --qr-ham-choice-icon: url("objects/schuyler_fan.png"); }
.qr-board:has(.qr-ham-sch-done) .qr-choice[data-id="peggy"] { --qr-ham-choice-icon: url("objects/eagle_feather.png"); }
.qr-board:has(.qr-ham-sch-done) .qr-choice[data-id="noone"] { --qr-ham-choice-icon: url("objects/quill.png"); }
.qr-board:has(.qr-ham-sch-done) .qr-choice:hover:not(:disabled) { border-color: var(--qr-ham-gold); }
.qr-board:has(.qr-ham-sch-done) .qr-outcome { border-color: var(--qr-ham-gold); }
.qr-ham-sch-done { background: linear-gradient(180deg, var(--qr-ham-paper), var(--qr-ham-gold)); }

/* Puzzle 2: Cabinet bank battle */
.qr-board:has(.qr-ham-b-done) {
  --qr-ham-puzzle-accent: var(--qr-ham-red);
  --qr-ham-choice-icon: url("objects/cabinet_seal.png");
}
.qr-board:has(.qr-ham-b-done) .qr-scene[src$="scene_bank.png"] {
  border-color: rgba(170,64,48,.64);
  filter: saturate(1.06) contrast(1.03);
}
.qr-board:has(.qr-ham-b-done) .qr-choice-prompt { border-left: 3px solid var(--qr-ham-red); padding-left: 11px; }
.qr-board:has(.qr-ham-b-done) .qr-choice { border-color: rgba(170,64,48,.44); }
.qr-board:has(.qr-ham-b-done) .qr-choice[data-id="pro"] { --qr-ham-choice-icon: url("objects/federal_paper.png"); }
.qr-board:has(.qr-ham-b-done) .qr-choice[data-id="against"] { --qr-ham-choice-icon: url("objects/congressional_seal.png"); }
.qr-board:has(.qr-ham-b-done) .qr-choice[data-id="broker"] { --qr-ham-choice-icon: url("objects/washington_sword.png"); }
.qr-board:has(.qr-ham-b-done) .qr-choice[data-id="wait"] { --qr-ham-choice-icon: url("objects/tricorn_hat.png"); }
.qr-board:has(.qr-ham-b-done) .qr-choice[data-id="protest"] { --qr-ham-choice-icon: url("objects/cabinet_seal.png"); }
.qr-ham-b-done { background: linear-gradient(180deg, #d05f47, var(--qr-accent)); color: #f7ead0; }

/* Puzzle 3: Reynolds pamphlet */
.qr-board:has(.qr-ham-pam-done) {
  --qr-ham-puzzle-accent: var(--qr-ham-paper);
  --qr-ham-choice-icon: url("objects/ink_well.png");
}
.qr-board:has(.qr-ham-pam-done) .qr-scene[src$="scene_pamphlet.png"] {
  border-color: rgba(238,219,170,.58);
  filter: brightness(1.04) sepia(.12);
}
.qr-board:has(.qr-ham-pam-done) .qr-choice-prompt { border-left: 3px solid var(--qr-ham-paper); padding-left: 11px; }
.qr-board:has(.qr-ham-pam-done) .qr-choice[data-id="publish"] { --qr-ham-choice-icon: url("objects/quill.png"); }
.qr-board:has(.qr-ham-pam-done) .qr-choice[data-id="deny"] { --qr-ham-choice-icon: url("objects/ink_well.png"); }
.qr-board:has(.qr-ham-pam-done) .qr-choice[data-id="pay"] { --qr-ham-choice-icon: url("objects/congressional_seal.png"); }
.qr-board:has(.qr-ham-pam-done) .qr-choice[data-id="eliza"] { --qr-ham-choice-icon: url("objects/parchment_letter.png"); }
.qr-board:has(.qr-ham-pam-done) .qr-choice[data-id="angelica"] { --qr-ham-choice-icon: url("objects/schuyler_fan.png"); }
.qr-board:has(.qr-ham-pam-done) .qr-choice.picked { background: linear-gradient(180deg, #f2dfad, var(--qr-ham-gold)); }
.qr-ham-pam-done { color: #1d130c; background: linear-gradient(180deg, #f2dfad, var(--qr-ham-gold)); }

/* Puzzle 4: Election of 1800 */
.qr-board:has(.qr-ham-1800-done) {
  --qr-ham-puzzle-accent: var(--qr-ham-blue);
  --qr-ham-choice-icon: url("objects/federal_paper.png");
}
.qr-board:has(.qr-ham-1800-done) .qr-scene[src$="scene_1800.png"] {
  border-color: rgba(64,82,98,.74);
  filter: contrast(1.04);
}
.qr-board:has(.qr-ham-1800-done) .qr-choice-prompt { border-left: 3px solid var(--qr-ham-blue); padding-left: 11px; }
.qr-board:has(.qr-ham-1800-done) .qr-choice { border-color: rgba(64,82,98,.56); }
.qr-board:has(.qr-ham-1800-done) .qr-choice[data-id="jefferson"] { --qr-ham-choice-icon: url("objects/eagle_feather.png"); }
.qr-board:has(.qr-ham-1800-done) .qr-choice[data-id="burr"] { --qr-ham-choice-icon: url("objects/tricorn_hat.png"); }
.qr-board:has(.qr-ham-1800-done) .qr-choice[data-id="silent"] { --qr-ham-choice-icon: url("objects/washington_sword.png"); }
.qr-board:has(.qr-ham-1800-done) .qr-choice[data-id="third"] { --qr-ham-choice-icon: url("objects/congressional_seal.png"); }
.qr-board:has(.qr-ham-1800-done) .qr-choice-name { color: var(--qr-ham-paper); }
.qr-ham-1800-done { background: linear-gradient(180deg, #7d94a3, var(--qr-ham-blue)); color: #f7ead0; }

/* Puzzle 5: Weehawken duel */
.qr-board:has(.qr-ham-duel-done) {
  --qr-ham-puzzle-accent: var(--qr-ham-burgundy);
  --qr-ham-choice-icon: url("objects/duel_pistol_pair.png");
}
.qr-board:has(.qr-ham-duel-done) .qr-scene[src$="scene_duel.png"] {
  border-color: rgba(112,42,38,.72);
  filter: saturate(.96) brightness(1.02);
}
.qr-board:has(.qr-ham-duel-done) .qr-choice-prompt { border-left: 3px solid var(--qr-ham-burgundy); padding-left: 11px; }
.qr-board:has(.qr-ham-duel-done) .qr-choice-name { color: var(--qr-ham-paper); }
.qr-board:has(.qr-ham-duel-done) .qr-choice[data-id="aim_sky"] { --qr-ham-choice-icon: url("objects/duel_pistol_pair.png"); }
.qr-board:has(.qr-ham-duel-done) .qr-choice[data-id="aim_him"] { --qr-ham-choice-icon: url("objects/pistol.png"); }
.qr-board:has(.qr-ham-duel-done) .qr-choice[data-id="apologize"] { --qr-ham-choice-icon: url("objects/parchment_letter.png"); }
.qr-board:has(.qr-ham-duel-done) .qr-choice[data-id="flee"] { --qr-ham-choice-icon: url("objects/tricorn_hat.png"); }
.qr-board:has(.qr-ham-duel-done) .qr-choice[data-id="witness"] { --qr-ham-choice-icon: url("objects/washington_sword.png"); }
.qr-ham-duel-done { background: linear-gradient(180deg, #95372f, var(--qr-ham-burgundy)); color: #f7ead0; }

@keyframes qr-ham-scene-in {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes qr-ham-prop-bob {
  0%, 100% { transform: translateY(-50%); }
  50% { transform: translateY(calc(-50% - 2px)); }
}
@keyframes qr-ham-choice-lift {
  from { transform: translateY(0); }
  to { transform: translateY(-2px); }
}
@keyframes qr-ham-sprite-in {
  0% { opacity: 0; transform: translateY(10px) scale(.94); }
  70% { opacity: 1; transform: translateY(-2px) scale(1.02); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

@media (max-width: 600px) {
  body[data-room="hamilton"] #qr-root, #qr-root { padding: 18px 12px; }
  .qr-board { min-height: 320px; padding: 15px 12px 18px; }
  .qr-scene { margin-bottom: 14px; }
  .qr-choice-prompt h2 { font-size: 12px; line-height: 1.5; }
  .qr-choice-prompt p, .qr-result-desc { font-size: 13px; }
  .qr-choice { min-height: 64px; padding: 12px 12px 12px 54px; }
  .qr-choice::before { left: 12px; width: 30px; height: 30px; }
  .qr-choice::after { left: 47px; }
  .qr-btn, .qr-btn-sm, .qr-result-share-row .qr-btn { min-height: 44px; }
  .qr-result-name { font-size: 16px; line-height: 1.45; }
  .qr-result-sprite { width: 208px; height: 208px; }
}

@media (max-width: 380px) {
  .qr-choice { font-size: 12px; line-height: 1.45; }
  .qr-choice .qr-choice-name { font-size: 9px; }
  .qr-progress, .qr-counter, .qr-status { font-size: 9px; }
}

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