/* Demon Slayer Quiz Room - night forest, Corps green, wisteria, ember, and dawn */

/* 1. Room variables */
:root,
body[data-room="demon-slayer"],
.qr-room-demon-slayer {
  --qr-bg: #101115;
  --qr-bg-elev: #1d2020;
  --qr-fg: #f2efe2;
  --qr-fg-dim: #bda98d;
  --qr-accent: #1f6a50;
  --qr-accent-dim: #295045;
  --qr-warn: #f0c84b;
  --qr-danger: #c94132;
  --qr-radius: 6px;
  --qr-ds-ink: #101115;
  --qr-ds-charcoal: #2b302e;
  --qr-ds-green: #1f6a50;
  --qr-ds-water: #2d6f9f;
  --qr-ds-wisteria: #7c5aa8;
  --qr-ds-burgundy: #7a1f2f;
  --qr-ds-flame: #c94132;
  --qr-ds-orange: #ed7d24;
  --qr-ds-gold: #f0c84b;
  --qr-ds-wood: #39251d;
  --qr-ds-cream: #f2efe2;
  --qr-scene-selection: #7c5aa8;
  --qr-scene-breath: #2d6f9f;
  --qr-scene-nezuko: #c94132;
  --qr-scene-hashira: #f0c84b;
  --qr-scene-muzan: #7a1f2f;
  --qr-prop-blade: url('objects/nichirin_blade.png');
  --qr-prop-wisp: url('objects/breath_wisp.png');
  --qr-prop-eye: url('objects/demon_eye.png');
  --qr-prop-bamboo: url('objects/bamboo_muzzle.png');
  --qr-prop-haori: url('objects/hashira_haori.png');
  --qr-prop-water: url('objects/water_form.png');
  --qr-prop-flame: url('objects/flame_form.png');
  --qr-prop-thunder: url('objects/lightning_form.png');
  --qr-prop-beast: url('objects/beast_mask.png');
  --qr-prop-butterfly: url('objects/butterfly_pin.png');
  --qr-prop-sun: url('objects/sun_circle.png');
  --qr-prop-cell: url('objects/muzan_cell.png');
}

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

body {
  margin: 0; padding: 0; min-height: 100vh; color: var(--qr-fg);
  background: linear-gradient(180deg, rgba(31, 106, 80, .22) 0%, rgba(16, 17, 21, 0) 38%), repeating-linear-gradient(90deg, rgba(242, 239, 226, .025) 0 1px, transparent 1px 34px), linear-gradient(180deg, #171312 0%, var(--qr-bg) 48%, #090a0d 100%);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  display: flex; flex-direction: column; align-items: center;
}

#qr-root { width: 100%; max-width: 492px; padding: 24px 16px; }
.qr-stage { display: flex; flex-direction: column; gap: 16px; }
.qr-progress { color: var(--qr-fg-dim); font-family: 'Press Start 2P', monospace; font-size: 10px; letter-spacing: 0; text-align: right; text-shadow: 0 0 9px rgba(240, 200, 75, .18); }

.qr-board {
  position: relative; min-height: 340px; padding: 18px 16px 20px; overflow: hidden;
  background: linear-gradient(180deg, rgba(124, 90, 168, .08), rgba(31, 106, 80, .04) 42%, rgba(16, 17, 21, 0)), repeating-linear-gradient(0deg, transparent 0 9px, rgba(242, 239, 226, .018) 10px), var(--qr-bg-elev);
  border: 1px solid rgba(31, 106, 80, .62); border-radius: var(--qr-radius);
  box-shadow: 0 12px 0 rgba(0, 0, 0, .24), 0 22px 44px rgba(0, 0, 0, .38), inset 0 0 0 1px rgba(242, 239, 226, .045);
}
.qr-board::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(90deg, rgba(242, 239, 226, .035), transparent 19%, transparent 82%, rgba(0, 0, 0, .16)), repeating-linear-gradient(90deg, transparent 0 63px, rgba(240, 200, 75, .035) 64px);
}

.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-board h2,
.qr-choice-prompt h2,
.qr-ds-sel-prompt h2 { margin: 0 0 8px; color: var(--qr-accent); font-family: 'Press Start 2P', monospace; font-size: 14px; line-height: 1.45; letter-spacing: 0; text-transform: uppercase; }
.qr-choice-prompt,
.qr-ds-sel-prompt { position: relative; z-index: 1; margin: 0 0 14px; color: var(--qr-fg-dim); }
.qr-choice-prompt p,
.qr-ds-sel-prompt p { margin: 0; color: var(--qr-fg-dim); font-size: 14px; line-height: 1.56; }

.qr-scene {
  position: relative; z-index: 1; display: block; width: 100%; max-height: 174px; object-fit: cover;
  margin: 0 0 16px; border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); background: var(--qr-bg);
  image-rendering: pixelated; image-rendering: crisp-edges;
  box-shadow: 0 0 0 1px rgba(242, 239, 226, .06), 0 10px 24px rgba(0, 0, 0, .34);
  animation: qr-ds-scene-in 300ms ease-out both;
}
.qr-scene[src$="scene_selection.png"] { border-color: var(--qr-scene-selection); }
.qr-scene[src$="scene_breath.png"] { border-color: var(--qr-scene-breath); }
.qr-scene[src$="scene_nezuko.png"] { border-color: var(--qr-scene-nezuko); }
.qr-scene[src$="scene_hashira.png"] { border-color: var(--qr-scene-hashira); }
.qr-scene[src$="scene_muzan.png"] { border-color: var(--qr-scene-muzan); }

/* 3. Shared controls */
.qr-choice-list { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr; gap: 10px; margin: 0 0 12px; }
.qr-choice {
  --qr-choice-icon: var(--qr-prop-blade);
  appearance: none; position: relative; width: 100%; min-height: 62px; padding: 12px 13px 12px 58px;
  color: var(--qr-fg); background: linear-gradient(180deg, rgba(242, 239, 226, .055), rgba(0, 0, 0, 0)), var(--qr-bg);
  border: 2px solid var(--qr-accent-dim); 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.45; 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: 12px; top: 50%; width: 34px; height: 34px;
  background: var(--qr-choice-icon) center / contain no-repeat; image-rendering: pixelated;
  transform: translateY(-50%); filter: drop-shadow(0 3px 0 rgba(0, 0, 0, .55)); animation: qr-ds-prop-bob 2.9s ease-in-out infinite;
}
.qr-choice::after { content: ''; position: absolute; left: 50px; top: 11px; bottom: 11px; width: 1px; background: rgba(242, 239, 226, .18); }
.qr-choice:hover:not(:disabled),
.qr-choice:focus-visible {
  border-color: var(--qr-warn);
  box-shadow: 0 5px 0 rgba(9, 10, 13, .88), 0 0 18px rgba(240, 200, 75, .15);
  animation: qr-ds-choice-lift 170ms ease-out both;
}
.qr-choice.picked {
  color: var(--qr-fg);
  background: linear-gradient(90deg, rgba(31, 106, 80, .24), rgba(201, 65, 50, .10)), var(--qr-bg);
  border-color: var(--qr-accent);
  opacity: 1;
  box-shadow: 0 0 0 2px rgba(31, 106, 80, .28), inset 0 -2px 0 rgba(0, 0, 0, .18);
}
.qr-choice:disabled:not(.picked) { cursor: not-allowed; opacity: .56; filter: grayscale(.38); }
.qr-choice-name { display: block; margin-bottom: 5px; color: var(--qr-warn); font-family: 'Press Start 2P', monospace; font-size: 10px; line-height: 1.45; letter-spacing: 0; }

.qr-btn {
  appearance: none; position: relative; z-index: 1; width: 100%; min-height: 44px; margin-top: 16px; padding: 12px 18px;
  color: var(--qr-bg); background: linear-gradient(180deg, var(--qr-ds-gold), var(--qr-accent));
  border: 1px solid rgba(242, 239, 226, .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; line-height: 1.35; 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); box-shadow: 0 5px 0 var(--qr-accent-dim), 0 0 16px rgba(240, 200, 75, .18); }
.qr-btn:disabled { opacity: .5; cursor: not-allowed; filter: grayscale(.45); transform: none; box-shadow: none; }
.qr-btn-sm { width: auto; min-height: 44px; margin-top: 0; padding: 8px 12px; font-size: 10px; }

.qr-counter,
.qr-status {
  position: relative; z-index: 1; margin: 0 0 12px; padding: 9px 10px;
  color: var(--qr-fg-dim); background: rgba(16, 17, 21, .58); border: 1px solid var(--qr-accent-dim); 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-counter.complete span,
.qr-status.win { color: var(--qr-accent); }
.qr-status.warn { color: var(--qr-warn); }
.qr-status.bad { color: var(--qr-danger); }

.qr-outcome,
.qr-ds-sel-result {
  position: relative; z-index: 1; margin-top: 14px; padding: 13px 14px; color: var(--qr-fg);
  background: rgba(16, 17, 21, .68); border: 1px dashed var(--qr-warn); border-radius: var(--qr-radius);
  font-size: 13px; line-height: 1.5; animation: qr-ds-scene-in 220ms ease-out;
}
.qr-outcome[hidden],
.qr-ds-sel-result[hidden],
.qr-choice-list[hidden] { display: none; }
.qr-hint { padding: 10px 12px; color: var(--qr-warn); background: rgba(122, 31, 47, .16); border-left: 3px solid var(--qr-warn); border-radius: var(--qr-radius); font-size: 12px; font-style: italic; line-height: 1.45; }
.qr-hint-visible { opacity: 1; }

/* 4. Puzzle 1 - The Breath Chain */
body[data-room="demon-slayer"] .qr-ds-sel,
.qr-room-demon-slayer .qr-ds-sel,
body:has(.qr-ds-sel) .qr-ds-sel { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 14px; }
body:has(.qr-ds-sel) .qr-ds-sel-prompt h2 { color: var(--qr-scene-selection); }
body:has(.qr-ds-sel) .qr-ds-sel-meter-wrap { gap: 6px; }
body:has(.qr-ds-sel) .qr-ds-sel-meter-label {
  color: var(--qr-fg-dim);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  letter-spacing: 0;
}
body:has(.qr-ds-sel) .qr-ds-sel-meter-label strong { color: var(--qr-warn); }
body:has(.qr-ds-sel) .qr-ds-sel-meter { height: 16px; background: rgba(16, 17, 21, .74); border: 1px solid rgba(124, 90, 168, .58); border-radius: var(--qr-radius); }
body:has(.qr-ds-sel) .qr-ds-sel-meter-fill { background: linear-gradient(90deg, var(--qr-ds-water), var(--qr-ds-flame), var(--qr-ds-gold)); }
body:has(.qr-ds-sel) .qr-ds-sel-slots { background: rgba(16, 17, 21, .52); border: 1px dashed rgba(124, 90, 168, .68); border-radius: var(--qr-radius); }
body:has(.qr-ds-sel) .qr-ds-sel-slot-num {
  color: var(--qr-warn);
  font-family: 'Press Start 2P', monospace;
  font-size: 9px;
  letter-spacing: 0;
}
body:has(.qr-ds-sel) .qr-ds-sel-slot,
body:has(.qr-ds-sel) .qr-ds-sel-card {
  background: linear-gradient(180deg, rgba(242, 239, 226, .05), rgba(0, 0, 0, 0)), var(--qr-bg);
  border: 1px solid rgba(124, 90, 168, .56);
  border-radius: var(--qr-radius);
  color: var(--qr-fg);
}
body:has(.qr-ds-sel) .qr-ds-sel-slot.filled { border-color: var(--qr-warn); }
body:has(.qr-ds-sel) .qr-ds-sel-deck { gap: 9px; }
body:has(.qr-ds-sel) .qr-ds-sel-card { position: relative; min-height: 72px; padding: 10px 10px 10px 54px; }
body:has(.qr-ds-sel) .qr-ds-sel-card::before {
  content: '';
  position: absolute;
  left: 11px;
  top: 50%;
  width: 32px;
  height: 32px;
  background: var(--qr-prop-blade) center / contain no-repeat;
  image-rendering: pixelated;
  transform: translateY(-50%);
  animation: qr-ds-prop-bob 3s ease-in-out infinite;
}
body:has(.qr-ds-sel) .qr-ds-sel-card:nth-child(1)::before { background-image: var(--qr-prop-water); }
body:has(.qr-ds-sel) .qr-ds-sel-card:nth-child(2)::before { background-image: var(--qr-prop-thunder); }
body:has(.qr-ds-sel) .qr-ds-sel-card:nth-child(3)::before { background-image: var(--qr-prop-flame); }
body:has(.qr-ds-sel) .qr-ds-sel-card:nth-child(4)::before { background-image: var(--qr-prop-beast); }
body:has(.qr-ds-sel) .qr-ds-sel-card:nth-child(5)::before { background-image: var(--qr-prop-wisp); }
body:has(.qr-ds-sel) .qr-ds-sel-card:nth-child(6)::before,
body:has(.qr-ds-sel) .qr-ds-sel-card:nth-child(7)::before { background-image: var(--qr-prop-butterfly); }
body:has(.qr-ds-sel) .qr-ds-sel-card:nth-child(8)::before { background-image: var(--qr-prop-haori); }
body:has(.qr-ds-sel) .qr-ds-sel-card:hover:not(.placed) { border-color: var(--qr-warn); animation: qr-ds-choice-lift 170ms ease-out both; }
body:has(.qr-ds-sel) .qr-ds-sel-card-name { color: var(--qr-warn); letter-spacing: 0; }
body:has(.qr-ds-sel) .qr-ds-sel-card-cue { color: var(--qr-fg-dim); }
body:has(.qr-ds-sel) .qr-ds-sel-actions { gap: 8px; }
body:has(.qr-ds-sel) .qr-ds-sel-skip { background: var(--qr-bg); color: var(--qr-fg-dim); border-color: rgba(124, 90, 168, .5); }
body:has(.qr-ds-sel) .qr-ds-sel-strike { background: linear-gradient(180deg, var(--qr-ds-flame), var(--qr-ds-green)); color: var(--qr-fg); }
.qr-ds-sel-done { background: linear-gradient(180deg, var(--qr-ds-gold), var(--qr-ds-green)); }

/* 5. Puzzle 2 - Breath Form */
body:has(.qr-ds-breath-done) .qr-choice-prompt h2 { color: var(--qr-scene-breath); }
body:has(.qr-ds-breath-done) .qr-choice-prompt { padding: 12px 58px 12px 13px; background: rgba(16, 17, 21, .54); border: 1px solid rgba(45, 111, 159, .36); border-radius: var(--qr-radius); }
body:has(.qr-ds-breath-done) .qr-choice-prompt::after {
  content: '';
  position: absolute;
  right: 11px;
  top: 50%;
  width: 36px;
  height: 36px;
  background: var(--qr-prop-wisp) center / contain no-repeat;
  image-rendering: pixelated;
  transform: translateY(-50%);
  animation: qr-ds-prop-bob 2.6s ease-in-out infinite;
}
body:has(.qr-ds-breath-done) .qr-choice-list { gap: 9px; }
body:has(.qr-ds-breath-done) .qr-choice { border-color: rgba(45, 111, 159, .56); }
body:has(.qr-ds-breath-done) .qr-choice[data-id="water"] { --qr-choice-icon: var(--qr-prop-water); border-color: var(--qr-ds-water); }
body:has(.qr-ds-breath-done) .qr-choice[data-id="flame"] { --qr-choice-icon: var(--qr-prop-flame); border-color: var(--qr-ds-flame); }
body:has(.qr-ds-breath-done) .qr-choice[data-id="beast"] { --qr-choice-icon: var(--qr-prop-beast); border-color: #a86e4a; }
body:has(.qr-ds-breath-done) .qr-choice[data-id="thunder"] { --qr-choice-icon: var(--qr-prop-thunder); border-color: var(--qr-ds-gold); }
body:has(.qr-ds-breath-done) .qr-choice[data-id="insect"] { --qr-choice-icon: var(--qr-prop-butterfly); border-color: var(--qr-ds-wisteria); }
body:has(.qr-ds-breath-done) .qr-choice[data-id="stone"] { --qr-choice-icon: var(--qr-prop-haori); border-color: var(--qr-fg-dim); }
body:has(.qr-ds-breath-done) .qr-choice[data-id="sound"] { --qr-choice-icon: var(--qr-prop-wisp); border-color: var(--qr-ds-orange); }
.qr-ds-breath-done { background: linear-gradient(180deg, var(--qr-ds-water), var(--qr-ds-green)); color: var(--qr-fg); }

/* 6. Puzzle 3 - Defending Nezuko */
body:has(.qr-ds-nez-done) .qr-choice-prompt h2 { color: var(--qr-scene-nezuko); }
body:has(.qr-ds-nez-done) .qr-choice-prompt {
  padding: 12px 13px;
  background: linear-gradient(90deg, rgba(122, 31, 47, .22), rgba(16, 17, 21, .58));
  border: 1px solid rgba(201, 65, 50, .42);
  border-radius: var(--qr-radius);
}
body:has(.qr-ds-nez-done) .qr-choice-list { gap: 9px; padding-left: 8px; border-left: 3px solid rgba(201, 65, 50, .42); }
body:has(.qr-ds-nez-done) .qr-choice { min-height: 66px; border-color: rgba(201, 65, 50, .48); }
body:has(.qr-ds-nez-done) .qr-choice[data-id="protect"] { --qr-choice-icon: var(--qr-prop-bamboo); border-color: var(--qr-danger); }
body:has(.qr-ds-nez-done) .qr-choice[data-id="persuade"] { --qr-choice-icon: var(--qr-prop-butterfly); border-color: var(--qr-ds-wisteria); }
body:has(.qr-ds-nez-done) .qr-choice[data-id="fight"] { --qr-choice-icon: var(--qr-prop-blade); border-color: var(--qr-fg-dim); }
body:has(.qr-ds-nez-done) .qr-choice[data-id="plead"] { --qr-choice-icon: var(--qr-prop-sun); border-color: var(--qr-warn); }
body:has(.qr-ds-nez-done) .qr-choice[data-id="separate"] { --qr-choice-icon: var(--qr-prop-haori); border-color: var(--qr-accent); }
body:has(.qr-ds-nez-done) .qr-choice.picked { background: linear-gradient(90deg, rgba(201, 65, 50, .24), rgba(31, 106, 80, .14)), var(--qr-bg); border-color: var(--qr-danger); }
.qr-ds-nez-done { background: linear-gradient(180deg, var(--qr-danger), var(--qr-ds-burgundy)); color: var(--qr-fg); }

/* 7. Puzzle 4 - Hashira Meeting */
body:has(.qr-ds-h-done) .qr-choice-prompt h2 { color: var(--qr-scene-hashira); }
body:has(.qr-ds-h-done) .qr-choice-prompt { padding: 12px 58px 12px 13px; background: rgba(57, 37, 29, .42); border: 1px solid rgba(240, 200, 75, .4); border-radius: var(--qr-radius); }
body:has(.qr-ds-h-done) .qr-choice-prompt::after {
  content: '';
  position: absolute;
  right: 11px;
  top: 50%;
  width: 36px;
  height: 36px;
  background: var(--qr-prop-haori) center / contain no-repeat;
  image-rendering: pixelated;
  transform: translateY(-50%);
  animation: qr-ds-prop-bob 2.8s ease-in-out infinite;
}
body:has(.qr-ds-h-done) .qr-choice-list { gap: 8px; }
body:has(.qr-ds-h-done) .qr-choice { min-height: 64px; border-style: solid; }
body:has(.qr-ds-h-done) .qr-choice[data-id="rengoku"] { --qr-choice-icon: var(--qr-prop-flame); border-color: var(--qr-ds-flame); }
body:has(.qr-ds-h-done) .qr-choice[data-id="shinobu"] { --qr-choice-icon: var(--qr-prop-butterfly); border-color: var(--qr-ds-wisteria); }
body:has(.qr-ds-h-done) .qr-choice[data-id="tomioka"] { --qr-choice-icon: var(--qr-prop-water); border-color: var(--qr-ds-water); }
body:has(.qr-ds-h-done) .qr-choice[data-id="mitsuri"] { --qr-choice-icon: var(--qr-prop-bamboo); border-color: #edc193; }
body:has(.qr-ds-h-done) .qr-choice[data-id="sanemi"] { --qr-choice-icon: var(--qr-prop-blade); border-color: var(--qr-fg-dim); }
body:has(.qr-ds-h-done) .qr-choice:hover:not(:disabled) { border-color: var(--qr-warn); }
.qr-ds-h-done { background: linear-gradient(180deg, var(--qr-ds-gold), var(--qr-ds-orange)); color: var(--qr-bg); }

/* 8. Puzzle 5 - Muzan */
body:has(.qr-ds-mz-done) .qr-board {
  border-color: rgba(122, 31, 47, .72);
  box-shadow: 0 12px 0 rgba(0, 0, 0, .3), 0 22px 44px rgba(0, 0, 0, .46), inset 0 0 28px rgba(122, 31, 47, .13);
}
body:has(.qr-ds-mz-done) .qr-choice-prompt h2 { color: var(--qr-scene-muzan); }
body:has(.qr-ds-mz-done) .qr-choice-prompt {
  padding: 12px 58px 12px 13px;
  background: linear-gradient(90deg, rgba(122, 31, 47, .28), rgba(16, 17, 21, .64));
  border: 1px solid rgba(122, 31, 47, .58);
  border-radius: var(--qr-radius);
}
body:has(.qr-ds-mz-done) .qr-choice-prompt::after {
  content: '';
  position: absolute;
  right: 11px;
  top: 50%;
  width: 36px;
  height: 36px;
  background: var(--qr-prop-eye) center / contain no-repeat;
  image-rendering: pixelated;
  transform: translateY(-50%);
  animation: qr-ds-eye-pulse 1.8s ease-in-out infinite;
}
body:has(.qr-ds-mz-done) .qr-choice { border-color: rgba(122, 31, 47, .58); }
body:has(.qr-ds-mz-done) .qr-choice[data-id="rally"] { --qr-choice-icon: var(--qr-prop-haori); border-color: var(--qr-accent); }
body:has(.qr-ds-mz-done) .qr-choice[data-id="alone"] { --qr-choice-icon: var(--qr-prop-blade); border-color: var(--qr-warn); }
body:has(.qr-ds-mz-done) .qr-choice[data-id="poison"] { --qr-choice-icon: var(--qr-prop-butterfly); border-color: var(--qr-ds-wisteria); }
body:has(.qr-ds-mz-done) .qr-choice[data-id="sister"] { --qr-choice-icon: var(--qr-prop-bamboo); border-color: var(--qr-danger); }
body:has(.qr-ds-mz-done) .qr-choice[data-id="survive"] { --qr-choice-icon: var(--qr-prop-sun); border-color: var(--qr-ds-gold); }
body:has(.qr-ds-mz-done) .qr-choice.picked { border-color: var(--qr-scene-muzan); box-shadow: 0 0 0 2px rgba(122, 31, 47, .34), inset 0 -2px 0 rgba(0, 0, 0, .2); }
.qr-ds-mz-done { background: linear-gradient(180deg, var(--qr-ds-burgundy), var(--qr-bg)); color: var(--qr-fg); }

/* 9. Result screen */
.qr-result { position: relative; z-index: 1; padding: 26px 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;
  image-rendering: crisp-edges;
  background: linear-gradient(180deg, rgba(31, 106, 80, .18), rgba(122, 31, 47, .15)), var(--qr-bg);
  border: 4px solid var(--qr-accent);
  border-radius: var(--qr-radius);
  box-shadow: 0 8px 0 var(--qr-accent-dim), 0 0 0 1px rgba(242, 239, 226, .16);
  animation: qr-ds-sprite-enter 560ms cubic-bezier(.22,1.18,.36,1);
}
.qr-result-eyebrow,
.qr-result-dossier-eyebrow {
  color: var(--qr-warn);
  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-warn); font-size: 14px; font-style: italic; }
.qr-result-desc { margin: 0 0 16px; padding: 0 8px; color: var(--qr-fg); font-size: 15px; line-height: 1.6; text-align: left; }
.qr-result-runner { color: var(--qr-fg-dim); font-size: 13px; }
.qr-result-receipts.qr-result-dossier {
  margin-top: 22px;
  padding: 16px;
  text-align: left;
  background: linear-gradient(180deg, rgba(124, 90, 168, .12), rgba(16, 17, 21, .5)), var(--qr-bg-elev);
  border: 1px solid rgba(124, 90, 168, .34);
  border-radius: var(--qr-radius);
}
.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;
  text-transform: uppercase;
}
.qr-result-dossier-lines { display: flex; flex-direction: column; gap: 10px; margin: 12px 0; padding: 0; list-style: none; }
.qr-result-dossier-lines li { padding-bottom: 10px; color: var(--qr-fg); border-bottom: 1px dashed rgba(189, 169, 141, .36); font-size: 14px; font-weight: 650; line-height: 1.45; }
.qr-result-dossier-lines li:last-child { border-bottom: none; padding-bottom: 0; }
.qr-result-dossier-stamp { text-align: right; }

/* 10. Animations */
@keyframes qr-ds-sprite-enter {
  from { opacity: 0; transform: translateY(12px) scale(.9); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes qr-ds-scene-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes qr-ds-prop-bob {
  0%, 100% { transform: translateY(-50%); }
  50% { transform: translateY(calc(-50% - 3px)); }
}
@keyframes qr-ds-choice-lift {
  0% { transform: translateY(0); }
  100% { transform: translateY(-2px); }
}
@keyframes qr-ds-eye-pulse {
  0%, 100% { transform: translateY(-50%) scale(1); filter: drop-shadow(0 0 0 rgba(201, 65, 50, 0)); }
  50% { transform: translateY(-50%) scale(1.06); filter: drop-shadow(0 0 8px rgba(201, 65, 50, .42)); }
}

/* 11. Mobile */
@media (max-width: 520px) {
  #qr-root { max-width: 100%; padding: 16px 12px; }
  .qr-board { min-height: 320px; padding: 15px 12px 18px; }
  .qr-progress { font-size: 9px; }
  .qr-scene { width: 100%; max-height: 42vw; object-fit: cover; }
  .qr-board h2,
  .qr-choice-prompt h2,
  .qr-ds-sel-prompt h2 { font-size: 12px; line-height: 1.5; }
  .qr-choice-prompt p,
  .qr-ds-sel-prompt p { font-size: 13px; line-height: 1.5; }
  .qr-choice,
  .qr-btn,
  .qr-btn-sm,
  .qr-ds-sel-slot,
  .qr-ds-sel-card { min-height: 44px; }
  .qr-choice { padding: 11px 11px 11px 52px; font-size: 12px; }
  .qr-choice::before { left: 10px; width: 30px; height: 30px; }
  .qr-choice::after { left: 45px; }
  .qr-choice-name { font-size: 9px; line-height: 1.5; }
  body:has(.qr-ds-sel) .qr-ds-sel-deck { grid-template-columns: 1fr; }
  body:has(.qr-ds-sel) .qr-ds-sel-card { padding-left: 52px; }
  body:has(.qr-ds-sel) .qr-ds-sel-actions { flex-direction: column; }
  body:has(.qr-ds-breath-done) .qr-choice-prompt,
  body:has(.qr-ds-h-done) .qr-choice-prompt,
  body:has(.qr-ds-mz-done) .qr-choice-prompt { padding-right: 52px; }
  .qr-result-sprite { width: 192px; height: 192px; }
  .qr-result-name { font-size: 17px; line-height: 1.45; }
}

@media (max-width: 380px) {
  .qr-choice { padding-left: 48px; }
  .qr-choice::before { width: 28px; height: 28px; }
  .qr-choice::after { display: none; }
  body:has(.qr-ds-breath-done) .qr-choice-prompt::after,
  body:has(.qr-ds-h-done) .qr-choice-prompt::after,
  body:has(.qr-ds-mz-done) .qr-choice-prompt::after { width: 30px; height: 30px; }
}

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