/* Disney Princesses Quiz Room - pixel royal trial */

:root {
  --qr-bg: #181020;
  --qr-bg-elev: #261832;
  --qr-fg: #fff5f7;
  --qr-fg-dim: #d9bfd0;
  --qr-accent: #e85f9d;
  --qr-accent-dim: #8b3e6f;
  --qr-warn: #efc55b;
  --qr-danger: #c84f65;
  --qr-radius: 6px;
  --qr-royal: #4d285f;
  --qr-rose: #bd4076;
  --qr-glass: #81cbe0;
  --qr-ocean: #258695;
  --qr-lily: #56965b;
  --qr-parchment: #e5efe6;
  --qr-shadow: #2a1c34;
  --qr-panel: #31203f;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  padding: 0;
  background:
    radial-gradient(circle at 50% 0, rgba(232, 95, 157, 0.16), transparent 32%),
    linear-gradient(180deg, #21152c 0%, var(--qr-bg) 54%, #0f1422 100%);
  color: var(--qr-fg);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  min-height: 100vh;
  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 {
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  color: var(--qr-fg-dim);
  text-align: right;
  letter-spacing: 1px;
}

.qr-board {
  background: linear-gradient(180deg, rgba(255, 245, 247, 0.045), transparent 120px), var(--qr-bg-elev);
  border: 1px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  box-shadow: 0 10px 0 rgba(20, 12, 28, 0.5);
  min-height: 320px;
  overflow: hidden;
  padding: 18px 16px 20px;
}

.qr-board h2,
.qr-result-name {
  font-family: 'Press Start 2P', monospace;
  letter-spacing: 1px;
}

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

.qr-choice-prompt::before {
  content: '';
  display: block;
  width: 100%;
  aspect-ratio: 8 / 3;
  margin: 0 0 14px;
  border: 1px solid color-mix(in srgb, var(--qr-accent) 45%, var(--qr-bg));
  border-radius: var(--qr-radius);
  background-color: var(--qr-shadow);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  image-rendering: pixelated;
  animation: qr-scene-fade 340ms ease-out both;
}

.qr-choice-prompt h2 {
  color: var(--qr-accent);
  font-size: 14px;
  line-height: 1.35;
  margin: 0 0 10px;
}

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

.qr-choice-list { display: flex; flex-direction: column; gap: 9px; margin: 0; }

.qr-choice {
  appearance: none;
  width: 100%;
  min-height: 64px;
  padding: 11px 12px;
  border: 2px solid color-mix(in srgb, var(--qr-accent-dim) 78%, #000);
  border-radius: var(--qr-radius);
  background: linear-gradient(180deg, rgba(255, 245, 247, 0.06), rgba(0, 0, 0, 0.08)), var(--qr-bg);
  color: var(--qr-fg);
  cursor: pointer;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: center;
  gap: 11px;
  font-family: inherit;
  text-align: left;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease;
  touch-action: manipulation;
}

.qr-choice::before {
  content: '';
  width: 44px;
  height: 44px;
  background: url('objects/mirror.png') center / contain no-repeat;
  image-rendering: pixelated;
  filter: drop-shadow(0 2px 0 rgba(0, 0, 0, 0.35));
  animation: qr-prop-bob 2200ms ease-in-out infinite;
}

.qr-choice:hover,
.qr-choice:focus-visible {
  border-color: var(--qr-accent);
  transform: translateY(-1px);
  outline: none;
}

.qr-choice.picked {
  background: linear-gradient(180deg, rgba(239, 197, 91, 0.18), rgba(232, 95, 157, 0.08)), var(--qr-panel);
  border-color: var(--qr-warn);
  box-shadow: inset 0 0 0 1px rgba(239, 197, 91, 0.25);
}

.qr-choice:disabled { cursor: default; }
.qr-choice:disabled:not(.picked) { opacity: 0.42; filter: grayscale(0.4); }

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

.qr-choice span:not(.qr-choice-name) {
  color: var(--qr-fg-dim);
  display: block;
  font-size: 13px;
  line-height: 1.45;
}

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

.qr-btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.qr-btn:disabled { cursor: not-allowed; filter: grayscale(0.55); opacity: 0.48; transform: none; }

.qr-outcome {
  margin-top: 14px;
  padding: 12px 13px;
  border: 1px solid color-mix(in srgb, var(--qr-warn) 65%, transparent);
  border-radius: var(--qr-radius);
  background: rgba(239, 197, 91, 0.09);
  color: var(--qr-fg);
  font-size: 13px;
  line-height: 1.5;
  animation: qr-choice-lift 220ms ease-out both;
}

.qr-hint { color: var(--qr-warn); font-size: 12px; font-style: italic; margin-top: 8px; opacity: 0; transition: opacity 400ms; }
.qr-hint-visible { opacity: 1; }

.qr-resume-banner {
  align-items: center;
  background: var(--qr-bg-elev);
  border: 1px solid var(--qr-warn);
  border-radius: var(--qr-radius);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
  padding: 12px;
}
.qr-resume-banner span { color: var(--qr-fg); font-size: 13px; }

/* Puzzle 1: The Ball */
.qr-board:has(.qr-dp-ball-stage) .qr-choice-prompt::before { background-image: url('objects/scene_ball.png'); }
.qr-dp-ball-stage { margin-top: 2px; }
.qr-dp-ball-stage .qr-choice-list { gap: 8px; }
.qr-board:has(.qr-dp-ball-stage) .qr-choice { border-color: color-mix(in srgb, var(--qr-rose) 62%, var(--qr-accent-dim)); }
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="simple"]::before { background-image: url('objects/slipper.png'); }
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="practical"]::before,
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="early"]::before { background-image: url('objects/helmet.png'); }
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="reading"]::before,
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="never"]::before { background-image: url('objects/book.png'); }
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="work"]::before,
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="stay"]::before { background-image: url('objects/lotus.png'); }
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="crown"]::before,
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="crown2"]::before { background-image: url('objects/crown.png'); }
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="sea"]::before,
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="sail"]::before { background-image: url('objects/oar.png'); }
.qr-board:has(.qr-dp-ball-stage) .qr-choice[data-id="midnight"]::before { background-image: url('objects/slipper.png'); }
.qr-dp-ball-done { background: linear-gradient(180deg, var(--qr-accent), var(--qr-rose)); }

/* Puzzle 2: The Library */
.qr-board:has(.qr-dp-lib-done) .qr-choice-prompt::before { background-image: url('objects/scene_library.png'); }
.qr-board:has(.qr-dp-lib-done) .qr-choice-prompt h2 { color: var(--qr-warn); }
.qr-board:has(.qr-dp-lib-done) .qr-choice-list { gap: 10px; }
.qr-board:has(.qr-dp-lib-done) .qr-choice {
  background: linear-gradient(90deg, rgba(239, 197, 91, 0.06), rgba(129, 203, 224, 0.04)), var(--qr-bg);
  border-color: color-mix(in srgb, var(--qr-warn) 45%, var(--qr-accent-dim));
}
.qr-board:has(.qr-dp-lib-done) .qr-choice[data-id="read"]::before { background-image: url('objects/book.png'); }
.qr-board:has(.qr-dp-lib-done) .qr-choice[data-id="organize"]::before,
.qr-board:has(.qr-dp-lib-done) .qr-choice[data-id="list"]::before { background-image: url('objects/scroll.png'); }
.qr-board:has(.qr-dp-lib-done) .qr-choice[data-id="door"]::before { background-image: url('objects/mirror.png'); }
.qr-board:has(.qr-dp-lib-done) .qr-choice[data-id="wait"]::before { background-image: url('objects/slipper.png'); }
.qr-board:has(.qr-dp-lib-done) .qr-choice[data-id="sing"]::before { background-image: url('objects/lantern.png'); }
.qr-dp-lib-done { background: var(--qr-warn); color: #2a1c10; }

/* Puzzle 3: The Honor */
.qr-board:has(.qr-dp-honor-done) .qr-choice-prompt::before { background-image: url('objects/scene_honor.png'); }
.qr-board:has(.qr-dp-honor-done) .qr-choice-prompt h2 { color: #f8d779; }
.qr-board:has(.qr-dp-honor-done) .qr-choice { border-color: color-mix(in srgb, var(--qr-lily) 55%, var(--qr-accent-dim)); }
.qr-board:has(.qr-dp-honor-done) .qr-choice:hover,
.qr-board:has(.qr-dp-honor-done) .qr-choice:focus-visible { border-color: var(--qr-lily); }
.qr-board:has(.qr-dp-honor-done) .qr-choice[data-id="family"]::before { background-image: url('objects/helmet.png'); }
.qr-board:has(.qr-dp-honor-done) .qr-choice[data-id="kingdom"]::before { background-image: url('objects/crown.png'); }
.qr-board:has(.qr-dp-honor-done) .qr-choice[data-id="stranger"]::before,
.qr-board:has(.qr-dp-honor-done) .qr-choice[data-id="house"]::before { background-image: url('objects/lantern.png'); }
.qr-board:has(.qr-dp-honor-done) .qr-choice[data-id="work"]::before { background-image: url('objects/lotus.png'); }
.qr-board:has(.qr-dp-honor-done) .qr-choice[data-id="sail"]::before { background-image: url('objects/oar.png'); }
.qr-dp-honor-done { background: linear-gradient(180deg, var(--qr-lily), #3b7042); }

/* Puzzle 4: The Call */
.qr-board:has(.qr-dp-ocean-done) .qr-choice-prompt::before {
  background-image: url('objects/scene_ocean.png');
  border-color: color-mix(in srgb, var(--qr-ocean) 70%, var(--qr-accent-dim));
}
.qr-board:has(.qr-dp-ocean-done) .qr-choice-prompt h2 { color: var(--qr-glass); }
.qr-board:has(.qr-dp-ocean-done) .qr-choice {
  background: linear-gradient(90deg, rgba(37, 134, 149, 0.12), rgba(129, 203, 224, 0.04)), var(--qr-bg);
  border-color: color-mix(in srgb, var(--qr-ocean) 70%, var(--qr-accent-dim));
}
.qr-board:has(.qr-dp-ocean-done) .qr-choice.picked { border-color: var(--qr-glass); box-shadow: inset 0 0 0 1px rgba(129, 203, 224, 0.35); }
.qr-board:has(.qr-dp-ocean-done) .qr-choice[data-id="go"]::before { background-image: url('objects/oar.png'); }
.qr-board:has(.qr-dp-ocean-done) .qr-choice[data-id="stay"]::before,
.qr-board:has(.qr-dp-ocean-done) .qr-choice[data-id="build"]::before { background-image: url('objects/lotus.png'); }
.qr-board:has(.qr-dp-ocean-done) .qr-choice[data-id="study"]::before { background-image: url('objects/book.png'); }
.qr-board:has(.qr-dp-ocean-done) .qr-choice[data-id="serve"]::before { background-image: url('objects/helmet.png'); }
.qr-board:has(.qr-dp-ocean-done) .qr-choice[data-id="lead"]::before { background-image: url('objects/crown.png'); }
.qr-dp-ocean-done { background: linear-gradient(180deg, var(--qr-ocean), #185867); }

/* Puzzle 5: Coronation Day */
.qr-board:has(.qr-dp-cor-done) .qr-choice-prompt::before { background-image: url('objects/scene_coronation.png'); }
.qr-board:has(.qr-dp-cor-done) .qr-choice-prompt h2 { color: var(--qr-warn); }
.qr-counter {
  margin: 0 0 12px;
  padding: 9px 11px;
  border: 1px dashed color-mix(in srgb, var(--qr-warn) 55%, transparent);
  border-radius: var(--qr-radius);
  background: rgba(239, 197, 91, 0.07);
  color: var(--qr-fg-dim);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  letter-spacing: 1px;
  text-align: center;
}
.qr-dp-cor-count { color: var(--qr-warn); }
.qr-board:has(.qr-dp-cor-done) .qr-choice { grid-template-columns: 48px minmax(0, 1fr); min-height: 58px; color: var(--qr-fg); font-size: 13px; line-height: 1.45; }
.qr-board:has(.qr-dp-cor-done) .qr-choice[data-id="fed"]::before { background-image: url('objects/teapot.png'); }
.qr-board:has(.qr-dp-cor-done) .qr-choice[data-id="fair"]::before,
.qr-board:has(.qr-dp-cor-done) .qr-choice[data-id="truth"]::before { background-image: url('objects/scroll.png'); }
.qr-board:has(.qr-dp-cor-done) .qr-choice[data-id="open"]::before { background-image: url('objects/book.png'); }
.qr-board:has(.qr-dp-cor-done) .qr-choice[data-id="borders"]::before { background-image: url('objects/oar.png'); }
.qr-board:has(.qr-dp-cor-done) .qr-choice[data-id="soft"]::before { background-image: url('objects/slipper.png'); }
.qr-dp-cor-done { background: var(--qr-warn); color: #28190f; }
.qr-dp-cor-continue { background: linear-gradient(180deg, var(--qr-accent), var(--qr-royal)); }

/* Result screen */
.qr-result { padding: 28px 12px 32px; text-align: center; }
.qr-result-sprite-wrap { display: flex; justify-content: center; margin-bottom: 16px; }
.qr-result-sprite {
  width: 224px;
  height: 224px;
  border: 4px solid var(--qr-warn);
  border-radius: var(--qr-radius);
  background: linear-gradient(180deg, rgba(255, 245, 247, 0.1), transparent), var(--qr-panel);
  box-shadow: 0 8px 0 rgba(139, 62, 111, 0.6);
  image-rendering: pixelated;
  object-fit: contain;
  animation: qr-sprite-in 600ms cubic-bezier(.22, 1.2, .36, 1) both;
}
.qr-result-eyebrow { color: var(--qr-accent); font-family: 'Press Start 2P', monospace; font-size: 10px; letter-spacing: 2px; margin-bottom: 8px; }
.qr-result-name { color: var(--qr-fg); font-size: 21px; line-height: 1.35; margin: 0 0 8px; }
.qr-result-tagline { color: var(--qr-warn); font-size: 14px; font-style: italic; margin: 0 0 16px; }
.qr-result-desc { color: var(--qr-fg); font-size: 15px; line-height: 1.6; margin: 0 0 16px; text-align: left; }
.qr-result-runner { color: var(--qr-fg-dim); font-size: 13px; margin: 0 0 20px; }
.qr-result-receipts.qr-result-dossier { background: linear-gradient(180deg, rgba(239, 197, 91, 0.1), rgba(129, 203, 224, 0.04)), var(--qr-bg-elev); border: 1px solid color-mix(in srgb, var(--qr-warn) 40%, transparent); }
.qr-result-dossier-eyebrow { color: var(--qr-warn); }
.qr-result-share-row { display: grid; gap: 10px; margin-top: 16px; }
.qr-result-cta { border-color: color-mix(in srgb, var(--qr-accent) 34%, transparent); }

/* Animations */
@keyframes qr-sprite-in {
  from { opacity: 0; transform: translateY(-12px) scale(0.88); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes qr-scene-fade {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}

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

@keyframes qr-choice-lift {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

@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;
  }
}

@media (max-width: 420px) {
  #qr-root { padding: 16px 10px; }
  .qr-board { padding: 14px 12px 16px; }
  .qr-progress { font-size: 10px; }
  .qr-choice-prompt::before { aspect-ratio: 8 / 3; margin-bottom: 12px; }
  .qr-choice-prompt h2 { font-size: 12px; }
  .qr-choice-prompt p,
  .qr-choice span:not(.qr-choice-name) { font-size: 12px; }
  .qr-choice { grid-template-columns: 44px minmax(0, 1fr); gap: 9px; min-height: 60px; padding: 10px; }
  .qr-choice::before { height: 40px; width: 40px; }
  .qr-choice .qr-choice-name { font-size: 9px; }
  .qr-btn { min-height: 46px; padding: 12px 14px; }
  .qr-result-sprite { height: 192px; width: 192px; }
}
