/* Bridgerton Quiz Room - candlelit Regency palette */
:root {
  --qr-bg: #1e1822; --qr-bg-elev: #2f2638; --qr-fg: #f5efe4; --qr-fg-dim: #c8b9a2; --qr-accent: #cfa85c; --qr-accent-dim: #7f6334; --qr-warn: #e2c95a; --qr-danger: #a64d50; --qr-radius: 6px; --qr-br-blue: #587096; --qr-br-blue-soft: #94abbe; --qr-br-plum: #3b3046; --qr-br-sage: #58794c; --qr-br-rose: #a65245; --qr-br-paper: #ebe1c9; --qr-br-pearl: #f5efe4; --qr-br-ink: #211918;
}
* {
  box-sizing: border-box;
}
body {
  margin: 0; padding: 0; min-height: 100vh; display: flex; flex-direction: column; align-items: center; color: var(--qr-fg); font-family: Georgia, "Times New Roman", serif; letter-spacing: 0;
  background:
    radial-gradient(circle at 50% 0, rgba(207, 168, 92, 0.13), transparent 260px),
    linear-gradient(180deg, #1e1822 0%, #2f2638 52%, #1e1822 100%);
}
#qr-root {
  width: 100%; max-width: 480px; padding: 24px 16px;
}
.qr-stage {
  display: flex; flex-direction: column; gap: 16px;
}
.qr-progress {
  color: var(--qr-accent); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 0; text-align: right;
}
.qr-board {
  min-height: 320px; padding: 20px 16px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius);
  background:
    linear-gradient(180deg, rgba(245, 239, 224, 0.04), rgba(207, 168, 92, 0.02)),
    var(--qr-bg-elev);
  box-shadow: 0 10px 0 rgba(33, 25, 24, 0.28);
}
.qr-board h1,
.qr-board h2,
.qr-board h3,
.qr-choice-prompt h1,
.qr-choice-prompt h2,
.qr-choice-prompt h3 {
  margin-top: 0; color: var(--qr-br-pearl); font-family: Georgia, "Times New Roman", serif; letter-spacing: 0;
}
.qr-board h2,
.qr-choice-prompt h2 {
  margin-bottom: 8px; color: var(--qr-accent); font-size: 22px; line-height: 1.15;
}
.qr-choice-prompt {
  margin-bottom: 14px;
}
.qr-choice-prompt p {
  margin: 0; color: var(--qr-fg-dim); font-size: 15px; line-height: 1.5;
}
.qr-scene {
  display: block; width: 100%; height: auto; margin: 0 0 16px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); background: var(--qr-bg); box-shadow: inset 0 0 0 2px rgba(245, 239, 224, 0.06), 0 6px 0 rgba(33, 25, 24, 0.20); image-rendering: pixelated; image-rendering: -moz-crisp-edges; image-rendering: crisp-edges; animation: qr-br-scene-in 360ms ease-out both;
}
.qr-btn {
  appearance: none; width: 100%; min-height: 44px; padding: 12px 18px; border: 1px solid #e7d18b; border-radius: var(--qr-radius); color: var(--qr-br-ink); background: linear-gradient(180deg, #d8b96e, #b98f43); cursor: pointer; font-family: "Press Start 2P", monospace; font-size: 11px; letter-spacing: 0; transition: filter 120ms ease, transform 120ms ease, box-shadow 120ms ease;
}
.qr-btn:hover {
  filter: brightness(1.05); transform: translateY(-1px); box-shadow: 0 4px 0 var(--qr-accent-dim);
}
.qr-btn:disabled {
  cursor: not-allowed; filter: grayscale(0.45); opacity: 0.58; transform: none;
}
.qr-btn-sm {
  width: auto; min-height: 44px; margin-top: 0; padding: 8px 12px; font-size: 10px;
}
.qr-btn-secondary {
  color: var(--qr-fg); border-color: var(--qr-accent-dim); background: rgba(245, 239, 224, 0.06);
}
.qr-choice-list,
.qrx-choice-list {
  display: grid; grid-template-columns: 1fr; gap: 10px; margin-bottom: 12px;
}
.qr-choice-grid,
.qrx-sequence-actions {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.qr-choice,
.qrx-choice-card,
.qrx-sequence-action {
  appearance: none; min-height: 52px; padding: 12px 14px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); color: var(--qr-fg); background: linear-gradient(180deg, rgba(245, 239, 224, 0.06), rgba(207, 168, 92, 0.03)), var(--qr-bg); cursor: pointer; font-family: Georgia, "Times New Roman", serif; font-size: 14px; line-height: 1.35; text-align: left; transition: background 150ms ease, border-color 150ms ease, transform 150ms ease;
}
.qr-choice:hover,
.qrx-choice-card:hover,
.qrx-sequence-action:hover {
  border-color: var(--qr-accent); animation: qr-br-choice-lift 180ms ease-out both;
}
.qr-choice.picked,
.qrx-choice-card.picked,
.qrx-sequence-action.picked,
.qrx-sequence-action.selected {
  border-color: var(--qr-accent); background: rgba(207, 168, 92, 0.16); box-shadow: inset 0 0 0 1px rgba(245, 239, 224, 0.20);
}
.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.45;
}
.qr-counter,
.qrx-counter,
.qr-status,
.qrx-status {
  margin: 10px 0 12px; color: var(--qr-fg-dim); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 0; line-height: 1.55;
}
.qr-counter span,
.qrx-counter span {
  color: var(--qr-warn);
}
.qr-counter.complete span,
.qrx-counter.complete span,
.qr-status.win,
.qrx-status.win {
  color: var(--qr-accent);
}
.qr-status.warn,
.qrx-status.warn {
  color: var(--qr-warn);
}
.qr-status.bad,
.qrx-status.bad {
  color: var(--qr-danger);
}
.qr-outcome,
.qrx-outcome {
  margin: 12px 0; padding: 12px 14px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); color: var(--qr-fg); background: rgba(245, 239, 224, 0.06); font-size: 14px; line-height: 1.55;
}
.qr-actions {
  display: flex; gap: 10px; margin-top: 12px;
}
.qr-actions .qr-btn {
  width: auto; flex: 1; margin-top: 0;
}
.qr-hint {
  margin-top: 8px; padding: 10px 12px; border-left: 3px solid var(--qr-warn); border-radius: var(--qr-radius); color: var(--qr-warn); background: rgba(226, 201, 90, 0.07); font-size: 13px; line-height: 1.45; opacity: 0; transition: opacity 320ms ease;
}
.qr-hint-visible {
  opacity: 1;
}
/* Puzzle 1: Whistledown column */
.qr-br-column,
.qr-column,
.qrx-puzzle[data-puzzle="br-column"] {
  position: relative;
}
.qr-br-column .qr-scene,
.qr-column .qr-scene {
  border-color: var(--qr-br-blue-soft);
}
.qr-br-column-desk {
  display: grid; grid-template-columns: 76px 1fr; gap: 10px; margin: 12px 0; padding: 10px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); background: linear-gradient(180deg, rgba(235, 225, 201, 0.10), rgba(88, 112, 150, 0.08));
}
.qr-br-column-paper {
  min-height: 76px; padding: 8px; position: relative; border: 1px solid var(--qr-accent); border-radius: 3px; color: var(--qr-br-ink); background: var(--qr-br-paper);
}
.qr-br-column-paper::before {
  content: ""; width: 16px; height: 16px; position: absolute; top: 8px; right: 8px; border-radius: 999px; background: var(--qr-br-rose);
}
.qr-br-column-headline {
  color: var(--qr-br-ink); font-family: "Press Start 2P", monospace; font-size: 9px; letter-spacing: 0; line-height: 1.4;
}
.qr-br-column-line,
.qr-br-column-gossip {
  height: 3px; margin-top: 7px; background: rgba(33, 25, 24, 0.18);
}
.qr-br-column-quill,
.qr-br-column-seal {
  image-rendering: pixelated; animation: qr-br-prop-bob 2600ms ease-in-out infinite;
}
.qr-br-column .qr-choice {
  border-style: dashed;
}
.qr-br-column .qr-choice.picked {
  border-style: solid;
}
/* Puzzle 2: Ballroom dance */
.qr-br-dance,
.qr-dance,
.qrx-puzzle[data-puzzle="br-dance"] {
  position: relative;
}
.qr-br-dance-floor {
  min-height: 100px; margin: 12px 0; padding: 12px; overflow: hidden; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); background: linear-gradient(135deg, rgba(207, 168, 92, 0.20) 25%, transparent 25% 50%, rgba(207, 168, 92, 0.16) 50% 75%, transparent 75%), rgba(88, 53, 43, 0.35); background-size: 26px 26px;
}
.qr-br-dance-card {
  margin-bottom: 12px; padding: 10px; border: 1px solid var(--qr-accent); border-radius: var(--qr-radius); color: var(--qr-br-ink); background: var(--qr-br-paper);
}
.qr-br-dance-card-title {
  margin-bottom: 7px; color: var(--qr-br-rose); font-family: "Press Start 2P", monospace; font-size: 9px; letter-spacing: 0;
}
.qr-br-dance-card-line {
  min-height: 20px; padding: 4px 0; border-bottom: 1px dashed rgba(33, 25, 24, 0.28);
}
.qr-br-dance-partners {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; margin: 12px 0;
}
.qr-br-dance-partner,
.qr-br-dance-step {
  min-height: 44px; padding: 9px 10px; border: 1px dashed var(--qr-accent-dim); border-radius: var(--qr-radius); color: var(--qr-fg-dim); background: rgba(88, 112, 150, 0.18);
}
.qr-br-dance-partner.picked,
.qr-br-dance-step.active {
  color: var(--qr-fg); border-color: var(--qr-accent); background: rgba(207, 168, 92, 0.18);
}
.qr-br-dance-count span {
  color: var(--qr-warn);
}
/* Puzzle 3: Dawn duel */
.qr-br-duel,
.qr-duel,
.qrx-puzzle[data-puzzle="br-duel"] {
  position: relative;
}
.qr-br-duel-field {
  min-height: 112px; margin: 12px 0; padding: 12px; overflow: hidden; border: 1px solid var(--qr-br-blue-soft); border-radius: var(--qr-radius); background: linear-gradient(180deg, rgba(245, 239, 224, 0.16), rgba(88, 121, 76, 0.20)), var(--qr-br-sage);
}
.qr-br-duel-distance {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; margin: 10px 0;
}
.qr-br-duel-step {
  height: 22px; border: 1px solid rgba(245, 239, 224, 0.20); border-radius: 3px; background: rgba(245, 239, 224, 0.08);
}
.qr-br-duel-step.active {
  background: var(--qr-accent); box-shadow: 0 0 0 2px rgba(207, 168, 92, 0.24);
}
.qr-br-duel-pistols {
  display: flex; justify-content: space-between; gap: 10px; margin: 12px 0;
}
.qr-br-duel-pistol {
  width: 56px; image-rendering: pixelated;
}
.qr-br-duel-honor {
  padding: 10px; border: 1px dashed var(--qr-danger); border-radius: var(--qr-radius); color: var(--qr-fg); background: rgba(166, 77, 80, 0.10); line-height: 1.45;
}
.qr-br-duel .qr-choice:hover {
  border-color: var(--qr-danger);
}
.qr-br-duel .qr-status.bad {
  animation: qr-br-shake 360ms ease;
}
/* Puzzle 4: Garden proposal */
.qr-br-proposal,
.qr-proposal,
.qrx-puzzle[data-puzzle="br-proposal"] {
  position: relative;
}
.qr-br-proposal-garden {
  min-height: 112px; margin: 12px 0; padding: 12px; border: 1px solid var(--qr-br-sage); border-radius: var(--qr-radius); background: radial-gradient(circle at 18% 20%, rgba(245, 239, 224, 0.18), transparent 60px), linear-gradient(180deg, rgba(148, 171, 190, 0.18), rgba(88, 121, 76, 0.24));
}
.qr-br-proposal-ring-box {
  display: flex; align-items: center; justify-content: center; width: 84px; height: 64px; margin: 0 auto 12px; border: 1px solid var(--qr-accent); border-radius: var(--qr-radius); background: var(--qr-br-plum);
}
.qr-br-proposal-ring {
  width: 48px; image-rendering: pixelated; animation: qr-br-candle 1900ms ease-in-out infinite;
}
.qr-br-proposal-vows {
  display: grid; gap: 8px; margin: 12px 0;
}
.qr-br-proposal-line,
.qr-br-proposal-tone {
  min-height: 44px; padding: 10px 12px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); color: var(--qr-fg-dim); background: rgba(245, 239, 224, 0.07); line-height: 1.45;
}
.qr-br-proposal-line.picked,
.qr-br-proposal-tone.active {
  color: var(--qr-fg); border-color: var(--qr-br-sage); background: rgba(88, 121, 76, 0.20);
}
.qr-br-proposal .qr-outcome {
  border-color: var(--qr-br-sage);
}
/* Puzzle 5: Diamond of the season */
.qr-br-diamond,
.qr-diamond,
.qrx-puzzle[data-puzzle="br-diamond"] {
  position: relative;
}
.qr-br-diamond-dais {
  min-height: 116px; margin: 12px 0; padding: 12px; border: 1px solid var(--qr-accent); border-radius: var(--qr-radius); background: linear-gradient(180deg, rgba(207, 168, 92, 0.18), rgba(88, 112, 150, 0.12)), var(--qr-br-plum); box-shadow: inset 0 0 0 2px rgba(245, 239, 224, 0.06);
}
.qr-br-diamond-candidates {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 12px 0;
}
.qr-br-diamond-candidate {
  min-height: 60px; padding: 8px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); background: rgba(245, 239, 224, 0.08); text-align: center;
}
.qr-br-diamond-candidate.picked {
  border-color: var(--qr-accent); background: rgba(207, 168, 92, 0.18);
}
.qr-br-diamond-crown,
.qr-br-diamond-tiara {
  image-rendering: pixelated; animation: qr-br-candle 2200ms ease-in-out infinite;
}
.qr-br-diamond-score {
  padding: 10px; border: 1px solid var(--qr-accent); border-radius: var(--qr-radius); color: var(--qr-br-ink); background: var(--qr-br-paper); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 0; line-height: 1.5;
}
.qr-br-diamond-status.queen,
.qr-br-diamond .qr-status.win {
  color: var(--qr-warn);
}
/* Shared helper and result surfaces */
.qrx-pick-slots,
.qrx-sequence-track,
.qrx-sort-items,
.qrx-sort-bins {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 12px 0;
}
.qrx-sort-items,
.qrx-sort-bins {
  grid-template-columns: 1fr 1fr;
}
.qrx-pick-slot,
.qrx-step-slot,
.qrx-sort-item,
.qrx-sort-bin {
  min-height: 48px; padding: 10px; border: 1px dashed var(--qr-accent-dim); border-radius: var(--qr-radius); color: var(--qr-fg-dim); background: rgba(245, 239, 224, 0.05);
}
.qrx-pick-slot.filled,
.qrx-step-slot.filled,
.qrx-sort-item.active,
.qrx-sort-bin.active {
  color: var(--qr-fg); border-style: solid; border-color: var(--qr-accent); background: rgba(207, 168, 92, 0.16);
}
.qr-result {
  padding: 30px 12px; text-align: center;
}
.qr-result-sprite-wrap {
  display: flex; justify-content: center; margin-bottom: 16px;
}
.qr-result-sprite {
  width: 192px; height: 192px; border: 4px solid var(--qr-accent); border-radius: var(--qr-radius); background: rgba(245, 239, 224, 0.06); box-shadow: 0 8px 0 var(--qr-accent-dim); image-rendering: pixelated; image-rendering: -moz-crisp-edges; image-rendering: crisp-edges; animation: qr-br-sprite-in 560ms cubic-bezier(.18, 1.1, .28, 1) both;
}
.qr-result-eyebrow,
.qr-result-dossier-eyebrow,
.qr-result-receipts h3 {
  color: var(--qr-accent); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 0;
}
.qr-result-name {
  margin: 0 0 8px; color: var(--qr-fg); font-family: Georgia, "Times New Roman", serif; font-size: 28px; line-height: 1.1;
}
.qr-result-tagline,
.qr-result-runner {
  color: var(--qr-fg-dim);
}
.qr-result-desc {
  color: var(--qr-fg); font-size: 15px; line-height: 1.6; text-align: left;
}
.qr-result-receipts {
  margin: 20px 0; padding: 14px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); background: rgba(245, 239, 224, 0.06); text-align: left;
}
.qr-result-share-row {
  display: flex; flex-wrap: wrap; gap: 10px;
}
.qr-result-share-row .qr-btn {
  flex: 1 1 140px; margin-top: 0;
}
@keyframes qr-br-sprite-in {
  from { opacity: 0; transform: translateY(14px) scale(0.88); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes qr-br-scene-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes qr-br-prop-bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}
@keyframes qr-br-choice-lift {
  from { transform: translateY(0); }
  to { transform: translateY(-2px); }
}
@keyframes qr-br-candle {
  0%, 100% { filter: brightness(1); transform: translateY(0); }
  50% { filter: brightness(1.18); transform: translateY(-2px); }
}
@keyframes qr-br-shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-4px); }
  75% { transform: translateX(4px); }
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
@media (max-width: 520px) {
  #qr-root {
    padding: 18px 12px;
  }
  .qr-board {
    padding: 16px 12px;
  }
  .qr-board h2,
  .qr-choice-prompt h2 {
    font-size: 20px;
  }
  .qr-choice,
  .qrx-choice-card,
  .qrx-sequence-action,
  .qrx-sort-item,
  .qrx-sort-bin {
    min-height: 44px;
    padding: 11px 12px;
  }
  .qr-scene {
    max-height: 180px;
    object-fit: contain;
  }
  .qr-choice-grid,
  .qrx-sequence-actions,
  .qr-br-dance-partners,
  .qr-br-diamond-candidates,
  .qrx-sort-items,
  .qrx-sort-bins {
    grid-template-columns: 1fr;
  }
  .qr-br-column-desk {
    grid-template-columns: 1fr;
  }
  .qr-actions,
  .qr-result-share-row {
    flex-direction: column;
  }
  .qr-actions .qr-btn,
  .qr-result-share-row .qr-btn {
    width: 100%;
  }
  .qr-result-sprite {
    width: 168px;
    height: 168px;
  }
}
