/* Knives Out Quiz Room - walnut, brass, parchment, oxblood, detective glass */
/* 1. Room variables */
:root {
  --qr-bg: #0a0807; --qr-bg-elev: #18110e; --qr-fg: #f6efe0; --qr-fg-dim: #b9aa8c;
  --qr-accent: #b88a38; --qr-accent-dim: #6f431f; --qr-warn: #ead7aa; --qr-danger: #7a1e22; --qr-radius: 6px;
  --qr-ko-ink: #0a0807; --qr-ko-walnut: #241814; --qr-ko-mahogany: #4a2c20; --qr-ko-copper: #8f4f2e;
  --qr-ko-brass: #b88a38; --qr-ko-parchment: #ead7aa; --qr-ko-oxblood: #7a1e22; --qr-ko-navy: #263847;
  --qr-ko-green: #365c50; --qr-ko-silver: #a7a69a;
  --qr-scene-room: url('objects/scene_room.png'); --qr-scene-shoe: url('objects/scene_shoe.png'); --qr-scene-witness: url('objects/scene_witness.png');
  --qr-scene-doughnut: url('objects/scene_doughnut.png'); --qr-scene-name: url('objects/scene_name.png');
  --qr-prop-magnify: url('objects/magnifying_glass.png'); --qr-prop-will: url('objects/will_envelope.png'); --qr-prop-throne: url('objects/dagger_throne.png');
  --qr-prop-syringe: url('objects/syringe.png'); --qr-prop-doughnut: url('objects/doughnut.png'); --qr-prop-blood: url('objects/blood_drop.png');
  --qr-prop-record: url('objects/vinyl_record_clue.png'); --qr-prop-key: url('objects/key_ring.png'); --qr-prop-letter: url('objects/monogrammed_letter.png');
  --qr-prop-phone: url('objects/vintage_phone.png'); --qr-prop-book: url('objects/library_book.png'); --qr-prop-mug: url('objects/mug_my_house.png');
}
/* 2. Base room frame and typography */
* { box-sizing: border-box; }
body {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  color: var(--qr-fg);
  background:
    radial-gradient(circle at 50% -12%, rgba(184, 138, 56, .18), transparent 38%),
    linear-gradient(180deg, rgba(122, 30, 34, .22), rgba(10, 8, 7, 0) 42%),
    repeating-linear-gradient(90deg, rgba(234, 215, 170, .035) 0 1px, transparent 1px 44px),
    var(--qr-bg);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  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 {
  color: var(--qr-fg-dim);
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  letter-spacing: 1px;
  text-align: right;
  text-shadow: 0 0 10px rgba(184, 138, 56, .24);
}
.qr-board {
  position: relative;
  min-height: 320px;
  padding: 18px 16px 20px;
  background:
    linear-gradient(180deg, rgba(234, 215, 170, .06), rgba(0, 0, 0, 0) 36%),
    linear-gradient(180deg, var(--qr-bg-elev), var(--qr-ko-ink));
  border: 1px solid color-mix(in srgb, var(--qr-accent-dim) 76%, var(--qr-accent));
  border-radius: var(--qr-radius);
  box-shadow: 0 18px 38px rgba(0, 0, 0, .42), inset 0 0 0 1px rgba(246, 239, 224, .05);
}
.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 {
  margin: 0 0 8px;
  color: var(--qr-accent);
  font-family: 'Press Start 2P', monospace;
  font-size: 14px;
  line-height: 1.45;
  letter-spacing: 1px;
}
.qr-choice-prompt {
  position: relative;
  margin-bottom: 14px;
  color: var(--qr-fg-dim);
}
.qr-choice-prompt p {
  margin: 0;
  color: var(--qr-fg-dim);
  font-size: 14px;
  line-height: 1.55;
}
.qr-scene {
  display: block;
  width: 100%;
  max-height: 170px;
  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(246, 239, 224, .06), 0 10px 24px rgba(0, 0, 0, .35);
  animation: qrKoSceneFade 260ms ease-out both;
}
/* 3. Shared controls */
.qr-choice-list { display: grid; grid-template-columns: 1fr; gap: 10px; margin-bottom: 12px; }
.qr-choice {
  --qr-choice-icon: var(--qr-prop-magnify);
  appearance: none;
  position: relative;
  width: 100%;
  min-height: 58px;
  padding: 12px 13px 12px 58px;
  color: var(--qr-fg);
  background:
    linear-gradient(180deg, rgba(246, 239, 224, .055), rgba(0, 0, 0, 0)),
    var(--qr-bg);
  border: 2px solid var(--qr-accent-dim);
  border-left-width: 4px;
  border-radius: var(--qr-radius);
  font-family: inherit;
  font-size: 13px;
  line-height: 1.45;
  text-align: left;
  cursor: pointer;
  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 2px 0 rgba(0, 0, 0, .58));
}
.qr-choice::after {
  content: '';
  position: absolute;
  left: 50px;
  top: 11px;
  bottom: 11px;
  width: 1px;
  background: rgba(234, 215, 170, .2);
}
.qr-choice:hover {
  border-color: var(--qr-accent);
  transform: translateY(-1px);
  box-shadow: 0 4px 0 rgba(10, 8, 7, .9), 0 0 14px rgba(184, 138, 56, .15);
}
.qr-choice:disabled { cursor: not-allowed; opacity: .66; transform: none; }
.qr-choice.picked {
  color: var(--qr-fg);
  background:
    linear-gradient(180deg, rgba(184, 138, 56, .2), rgba(122, 30, 34, .1)),
    var(--qr-bg);
  border-color: var(--qr-accent);
  opacity: 1;
  animation: qrKoChoiceLift 180ms ease-out;
}
.qr-btn {
  appearance: none;
  width: 100%;
  min-height: 44px;
  margin-top: 16px;
  padding: 12px 18px;
  color: var(--qr-bg);
  background: var(--qr-accent);
  border: 1px solid rgba(246, 239, 224, .18);
  border-radius: var(--qr-radius);
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  line-height: 1.35;
  letter-spacing: 1px;
  cursor: pointer;
  transition: transform 100ms ease, filter 100ms ease, background 100ms ease;
}
.qr-btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.qr-btn:disabled { opacity: .48; cursor: not-allowed; filter: grayscale(.35); transform: none; }
.qr-btn-sm { width: auto; min-height: 36px; margin-top: 0; padding: 8px 12px; font-size: 10px; }
.qr-counter,
.qr-status {
  border-radius: var(--qr-radius);
  background: rgba(24, 17, 14, .88);
  border: 1px solid rgba(184, 138, 56, .28);
}
.qr-counter {
  margin: 0 0 12px;
  padding: 9px 10px;
  color: var(--qr-fg-dim);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  line-height: 1.5;
  text-align: center;
}
.qr-counter span { color: var(--qr-warn); }
.qr-counter.complete span { color: var(--qr-accent); }
.qr-status { min-height: 34px; margin-bottom: 10px; padding: 9px 10px; color: var(--qr-fg-dim); font-size: 12px; line-height: 1.35; text-align: center; }
.qr-status.warn { color: var(--qr-warn); }
.qr-status.win { color: var(--qr-accent); }
.qr-status.bad { color: #f0a0a0; border-color: rgba(122, 30, 34, .62); }
.qr-outcome {
  margin-top: 12px;
  padding: 13px 14px;
  color: var(--qr-fg);
  background: rgba(74, 44, 32, .45);
  border: 1px solid var(--qr-accent);
  border-radius: var(--qr-radius);
  font-size: 13px;
  line-height: 1.55;
  box-shadow: inset 0 0 0 1px rgba(246, 239, 224, .05);
}
.qr-outcome[hidden],
.qr-choice-list[hidden],
.qr-choice-grid[hidden] { display: none; }
/* 4. Shared scene prompts */
body:has(.qr-ko-room-done) .qr-choice-prompt,
body:has(.qr-ko-w-done) .qr-choice-prompt,
body:has(.qr-ko-name-done) .qr-choice-prompt {
  padding: 12px 58px 12px 13px;
  background: rgba(24, 17, 14, .76);
  border: 1px solid rgba(184, 138, 56, .26);
  border-radius: var(--qr-radius);
}
body:has(.qr-ko-room-done) .qr-choice-prompt::after,
body:has(.qr-ko-w-done) .qr-choice-prompt::after,
body:has(.qr-ko-name-done) .qr-choice-prompt::after {
  content: '';
  position: absolute;
  right: 10px;
  top: 50%;
  width: 38px;
  height: 38px;
  background: var(--qr-prompt-prop) center / contain no-repeat;
  image-rendering: pixelated;
  transform: translateY(-50%);
  filter: drop-shadow(0 3px 0 rgba(0, 0, 0, .58));
  animation: qrKoPropBob 2.8s ease-in-out infinite;
}
body:has(.qr-ko-room-done) .qr-choice-prompt { --qr-prompt-prop: var(--qr-prop-will); }
body:has(.qr-ko-w-done) .qr-choice-prompt { --qr-prompt-prop: var(--qr-prop-book); }
body:has(.qr-ko-name-done) .qr-choice-prompt { --qr-prompt-prop: var(--qr-prop-magnify); }
/* 5. Puzzle 1 - The Reading */
body:has(.qr-ko-room-done) .qr-scene { border-color: var(--qr-ko-brass); }
body:has(.qr-ko-room-done) .qr-board { box-shadow: 0 18px 38px rgba(0, 0, 0, .42), inset 0 0 24px rgba(184, 138, 56, .08); }
body:has(.qr-ko-room-done) .qr-choice-list { gap: 9px; }
body:has(.qr-ko-room-done) .qr-choice[data-id="apologize"] { --qr-choice-icon: var(--qr-prop-mug); border-left-color: var(--qr-ko-green); }
body:has(.qr-ko-room-done) .qr-choice[data-id="enforce"] { --qr-choice-icon: var(--qr-prop-will); border-left-color: var(--qr-ko-brass); }
body:has(.qr-ko-room-done) .qr-choice[data-id="leave"] { --qr-choice-icon: var(--qr-prop-key); border-left-color: var(--qr-ko-silver); }
body:has(.qr-ko-room-done) .qr-choice[data-id="detective"] { --qr-choice-icon: var(--qr-prop-magnify); border-left-color: var(--qr-ko-navy); }
body:has(.qr-ko-room-done) .qr-choice[data-id="enjoy"] { --qr-choice-icon: var(--qr-prop-throne); border-left-color: var(--qr-ko-oxblood); }
.qr-ko-room-done { background: var(--qr-ko-brass); color: var(--qr-bg); }
/* 6. Puzzle 2 - The Shoe */
.qr-ko-stage {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.qr-ko-shoe-option {
  position: relative;
  display: flex;
  min-height: 126px;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  overflow: hidden;
  padding: 10px;
  text-align: center;
  background:
    radial-gradient(circle at 50% 18%, rgba(234, 215, 170, .08), transparent 42%),
    var(--qr-bg);
}
.qr-ko-shoe-option::before {
  left: 50%;
  top: auto;
  bottom: 12px;
  width: 88px;
  height: 48px;
  background: none;
  transform: translateX(-50%);
  filter: none;
}
.qr-ko-shoe-label {
  display: block;
  color: var(--qr-warn);
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  line-height: 1.35;
}
.qr-ko-shoe-print {
  position: relative;
  display: block;
  width: min(100px, 100%);
  height: 58px;
  border: 1px solid rgba(184, 138, 56, .5);
  border-radius: 62% 42% 48% 36% / 52% 44% 52% 40%;
  background:
    radial-gradient(circle at 26% 44%, rgba(246, 239, 224, .18) 0 2px, transparent 3px),
    radial-gradient(circle at 42% 48%, rgba(246, 239, 224, .15) 0 2px, transparent 3px),
    radial-gradient(circle at 58% 50%, rgba(246, 239, 224, .13) 0 2px, transparent 3px),
    linear-gradient(90deg, rgba(246, 239, 224, .08), rgba(246, 239, 224, .17) 46%, rgba(10, 8, 7, .28));
  box-shadow: inset -12px 0 12px rgba(0, 0, 0, .22), inset 0 -7px 8px rgba(0, 0, 0, .24);
  transform: rotate(-7deg);
}
.qr-ko-shoe-sole {
  position: absolute;
  top: 10px;
  right: 13px;
  width: 16px;
  height: 36px;
  border-left: 2px solid rgba(184, 138, 56, .62);
  border-radius: 12px;
}
.qr-ko-shoe-option.is-smudged .qr-ko-shoe-sole::after {
  content: '';
  position: absolute;
  top: 17px;
  left: -5px;
  width: 14px;
  height: 6px;
  border-radius: 50%;
  background: rgba(107, 63, 45, .9);
  box-shadow: 0 0 4px 1px rgba(107, 63, 45, .52), 5px 1px 7px rgba(107, 63, 45, .32);
  transform: rotate(-16deg);
}
.qr-ko-r,
.qr-ko-c { color: var(--qr-warn); }
body:has(.qr-ko-stage) .qr-scene { border-color: var(--qr-ko-silver); }
body:has(.qr-ko-stage) .qr-counter { border-color: rgba(167, 166, 154, .36); }
/* 7. Puzzle 3 - The Witness */
body:has(.qr-ko-w-done) .qr-scene { border-color: var(--qr-ko-green); }
body:has(.qr-ko-w-done) .qr-board { box-shadow: 0 18px 38px rgba(0, 0, 0, .42), inset 0 0 24px rgba(54, 92, 80, .1); }
body:has(.qr-ko-w-done) .qr-choice[data-id="kindness"] { --qr-choice-icon: var(--qr-prop-mug); border-left-color: var(--qr-ko-green); }
body:has(.qr-ko-w-done) .qr-choice[data-id="pressure"] { --qr-choice-icon: var(--qr-prop-letter); border-left-color: var(--qr-ko-oxblood); }
body:has(.qr-ko-w-done) .qr-choice[data-id="sit"] { --qr-choice-icon: var(--qr-prop-magnify); border-left-color: var(--qr-ko-brass); }
body:has(.qr-ko-w-done) .qr-choice[data-id="flatter"] { --qr-choice-icon: var(--qr-prop-phone); border-left-color: var(--qr-ko-copper); }
body:has(.qr-ko-w-done) .qr-choice[data-id="leave"] { --qr-choice-icon: var(--qr-prop-book); border-left-color: var(--qr-ko-navy); }
.qr-ko-w-done { background: var(--qr-ko-green); color: var(--qr-fg); }
/* 8. Puzzle 4 - The Suspect Board */
body:has(.qr-ko-board) .qr-scene { border-color: var(--qr-ko-oxblood); }
body:has(.qr-ko-board) .qr-ko-board { gap: 14px; }
body:has(.qr-ko-board) .qr-ko-board-prompt {
  position: relative;
  padding: 12px 58px 12px 13px;
  background: rgba(24, 17, 14, .78);
  border: 1px solid rgba(122, 30, 34, .38);
  border-radius: var(--qr-radius);
}
body:has(.qr-ko-board) .qr-ko-board-prompt::after {
  content: '';
  position: absolute;
  right: 10px;
  top: 50%;
  width: 38px;
  height: 38px;
  background: var(--qr-prop-doughnut) center / contain no-repeat;
  image-rendering: pixelated;
  transform: translateY(-50%);
  animation: qrKoEvidencePulse 2.4s ease-in-out infinite;
}
body:has(.qr-ko-board) .qr-ko-board-prompt h2 { color: var(--qr-accent); font-size: 14px; }
body:has(.qr-ko-board) .qr-ko-board-prompt p { color: var(--qr-fg-dim); font-size: 13px; }
body:has(.qr-ko-board) .qr-ko-board-status { gap: 8px; color: var(--qr-fg-dim); }
body:has(.qr-ko-board) .qr-ko-board-status span {
  padding: 9px 10px;
  background: rgba(10, 8, 7, .7);
  border: 1px solid rgba(184, 138, 56, .24);
  border-radius: var(--qr-radius);
}
body:has(.qr-ko-board) .qr-ko-board-status strong { color: var(--qr-warn); }
body:has(.qr-ko-board) .qr-ko-board-card {
  background: linear-gradient(180deg, rgba(234, 215, 170, .06), rgba(0, 0, 0, 0)), var(--qr-bg);
  border-color: rgba(184, 138, 56, .44);
  box-shadow: inset 4px 0 0 rgba(122, 30, 34, .44);
}
body:has(.qr-ko-board) .qr-ko-board-clue-title { color: var(--qr-warn); line-height: 1.45; }
body:has(.qr-ko-board) .qr-ko-board-clue-prose { color: var(--qr-fg-dim); }
body:has(.qr-ko-board) .qr-ko-board-row { border-top-color: rgba(184, 138, 56, .22); }
body:has(.qr-ko-board) .qr-ko-board-suspect { color: var(--qr-fg); }
body:has(.qr-ko-board) .qr-ko-board-mark {
  min-height: 44px;
  color: var(--qr-fg-dim);
  background: rgba(10, 8, 7, .78);
  border-color: rgba(184, 138, 56, .44);
}
body:has(.qr-ko-board) .qr-ko-board-mark:hover { border-color: var(--qr-accent); filter: brightness(1.1); }
body:has(.qr-ko-board) .qr-ko-board-mark.picked-true { background: rgba(54, 92, 80, .32); border-color: var(--qr-ko-green); color: #cce5d6; }
body:has(.qr-ko-board) .qr-ko-board-mark.picked-false { background: rgba(122, 30, 34, .32); border-color: var(--qr-ko-oxblood); color: #f0c0b8; }
body:has(.qr-ko-board) .qr-ko-board-mark.picked-unknown { background: rgba(184, 138, 56, .22); border-color: var(--qr-accent); color: var(--qr-warn); }
body:has(.qr-ko-board) .qr-ko-board-actions { gap: 8px; }
body:has(.qr-ko-board) .qr-ko-board-skip { background: transparent; color: var(--qr-fg-dim); border: 1px solid var(--qr-accent-dim); }
body:has(.qr-ko-board) .qr-ko-board-accuse {
  background: rgba(24, 17, 14, .78);
  border-color: var(--qr-accent);
}
body:has(.qr-ko-board) .qr-ko-board-accuse-title { color: var(--qr-warn); }
body:has(.qr-ko-board) .qr-ko-board-accuse-btn {
  min-height: 48px;
  background: rgba(10, 8, 7, .78);
  border-color: rgba(184, 138, 56, .38);
  color: var(--qr-fg);
}
body:has(.qr-ko-board) .qr-ko-board-accuse-btn:hover { border-color: var(--qr-accent); }
body:has(.qr-ko-board) .qr-ko-board-accuse-btn.picked { background: rgba(184, 138, 56, .18); border-color: var(--qr-accent); }
body:has(.qr-ko-board) .qr-ko-board-result { color: var(--qr-warn); background: rgba(74, 44, 32, .44); }
body:has(.qr-ko-board) .qr-ko-board-result.fail { color: #f0b1a8; }
.qr-ko-board-done { background: var(--qr-ko-oxblood); color: var(--qr-fg); }
/* 9. Puzzle 5 - Name the Killer */
body:has(.qr-ko-name-done) .qr-scene { border-color: var(--qr-ko-brass); }
body:has(.qr-ko-name-done) .qr-choice-list { gap: 8px; }
body:has(.qr-ko-name-done) .qr-choice { min-height: 64px; }
body:has(.qr-ko-name-done) .qr-choice[data-id="heir"] { --qr-choice-icon: var(--qr-prop-will); border-left-color: var(--qr-ko-brass); }
body:has(.qr-ko-name-done) .qr-choice[data-id="nurse"] { --qr-choice-icon: var(--qr-prop-syringe); border-left-color: var(--qr-ko-green); }
body:has(.qr-ko-name-done) .qr-choice[data-id="butler"] { --qr-choice-icon: var(--qr-prop-key); border-left-color: var(--qr-ko-silver); }
body:has(.qr-ko-name-done) .qr-choice[data-id="eldest"] { --qr-choice-icon: var(--qr-prop-throne); border-left-color: var(--qr-ko-oxblood); }
body:has(.qr-ko-name-done) .qr-choice[data-id="staffer"] { --qr-choice-icon: var(--qr-prop-letter); border-left-color: var(--qr-ko-copper); }
body:has(.qr-ko-name-done) .qr-choice[data-id="noone"] { --qr-choice-icon: var(--qr-prop-record); border-left-color: var(--qr-ko-navy); }
.qr-ko-name-done { background: var(--qr-ko-brass); color: var(--qr-bg); }
/* 10. Result screen */
.qr-result { text-align: center; padding: 24px 0; }
.qr-result-sprite-wrap { margin-bottom: 16px; }
.qr-result-sprite {
  width: 192px;
  height: 192px;
  image-rendering: pixelated;
  border: 4px solid var(--qr-accent);
  border-radius: var(--qr-radius);
  background: rgba(184, 138, 56, .08);
  box-shadow: 0 10px 0 rgba(111, 67, 31, .7), 0 0 0 1px rgba(246, 239, 224, .16);
  animation: qrKoSpriteEntrance 340ms cubic-bezier(.2, .9, .2, 1.25) both;
}
.qr-result-eyebrow { color: var(--qr-accent); font-family: 'Press Start 2P', monospace; font-size: 11px; letter-spacing: 2px; }
.qr-result-name { margin: 6px 0 8px; color: var(--qr-fg); font-family: 'Press Start 2P', monospace; font-size: 20px; line-height: 1.4; }
.qr-result-tagline { margin-top: 0; color: var(--qr-fg-dim); font-style: italic; }
.qr-result-desc { padding: 0 8px; color: var(--qr-fg); line-height: 1.65; text-align: left; }
.qr-result-receipts { background: rgba(24, 17, 14, .82); border: 1px solid var(--qr-accent-dim); border-radius: var(--qr-radius); }
.qr-result-receipts h3 { color: var(--qr-accent); font-family: 'Press Start 2P', monospace; font-size: 12px; }
/* 11. Animations */
@keyframes qrKoSceneFade {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes qrKoChoiceLift {
  from { transform: translateY(0); }
  50% { transform: translateY(-2px); }
  to { transform: translateY(0); }
}
@keyframes qrKoPropBob {
  0%, 100% { transform: translateY(-50%); }
  50% { transform: translateY(calc(-50% - 3px)); }
}
@keyframes qrKoEvidencePulse {
  0%, 100% { transform: translateY(-50%) scale(1); filter: drop-shadow(0 3px 0 rgba(0, 0, 0, .58)); }
  50% { transform: translateY(-50%) scale(1.05); filter: drop-shadow(0 0 9px rgba(184, 138, 56, .32)); }
}
@keyframes qrKoSpriteEntrance {
  from { opacity: 0; transform: translateY(10px) scale(.92); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
/* 12. Mobile */
@media (max-width: 520px) {
  #qr-root { padding: 18px 12px; }
  .qr-board { padding: 15px 12px 18px; }
  .qr-scene { max-height: 150px; margin-bottom: 14px; }
  .qr-choice-prompt h2,
  .qr-board h2 { font-size: 12px; }
  .qr-choice-prompt p,
  .qr-choice,
  body:has(.qr-ko-board) .qr-ko-board-clue-prose { font-size: 12px; }
  .qr-choice { min-height: 58px; padding: 11px 11px 11px 52px; }
  .qr-choice::before { left: 11px; width: 30px; height: 30px; }
  .qr-choice::after { left: 45px; }
  .qr-btn,
  .qr-choice,
  .qr-counter,
  .qr-status,
  .qr-ko-board-mark,
  .qr-ko-board-accuse-btn { min-height: 44px; }
  .qr-ko-stage { grid-template-columns: 1fr; }
  .qr-ko-shoe-option { min-height: 104px; }
  body:has(.qr-ko-board) .qr-ko-board-row { grid-template-columns: 1fr; gap: 8px; }
  body:has(.qr-ko-board) .qr-ko-board-marks { display: grid; grid-template-columns: repeat(3, 1fr); }
  body:has(.qr-ko-board) .qr-ko-board-actions { flex-direction: column; }
  body:has(.qr-ko-board) .qr-ko-board-actions .qr-btn { width: 100%; }
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}
