/* Studio Ghibli Quiz Room - bathhouse, forest, and flight pixel theme */

/* 1. Room variables */
:root,
body[data-room="ghibli"],
.qr-room-ghibli {
  --qr-bg: #0d1814;
  --qr-bg-elev: #17231a;
  --qr-fg: #f6ead0;
  --qr-fg-dim: rgba(246, 234, 208, 0.68);
  --qr-accent: #dca947;
  --qr-accent-dim: #7f6330;
  --qr-warn: #8bb66f;
  --qr-danger: #bd4d32;
  --qr-radius: 6px;
  --qr-ghibli-ink: #0d1814;
  --qr-ghibli-cedar: #233724;
  --qr-ghibli-moss: #53784a;
  --qr-ghibli-sky: #7eaeab;
  --qr-ghibli-river: #36637b;
  --qr-ghibli-red: #974231;
  --qr-ghibli-gold: #e0a947;
  --qr-ghibli-paper: #f6e4be;
  --qr-ghibli-soot: #2a201c;
  --qr-ghibli-rose: #d37478;
  --qr-ghibli-line: rgba(246, 228, 190, 0.18);
  --qr-ghibli-line-strong: rgba(224, 169, 71, 0.46);
  --qr-ghibli-shadow: rgba(0, 0, 0, 0.58);
  --qr-scene-spell: url("objects/scene_spell.png");
  --qr-scene-bath: url("objects/scene_bath.png");
  --qr-scene-feast: url("objects/scene_feast.png");
  --qr-scene-flight: url("objects/scene_flight.png");
  --qr-scene-farewell: url("objects/scene_farewell.png");
  --qr-prop-charm: url("objects/charm_token.png");
  --qr-prop-herb: url("objects/herb_bundle.png");
  --qr-prop-bath: url("objects/bath_tag.png");
  --qr-prop-lantern: url("objects/lantern.png");
  --qr-prop-rice: url("objects/rice_ball.png");
  --qr-prop-tea: url("objects/teacup.png");
  --qr-prop-broom: url("objects/broom.png");
  --qr-prop-airship: url("objects/airship.png");
  --qr-prop-name: url("objects/name_card.png");
  --qr-prop-mask: url("objects/forest_mask.png");
  --qr-prop-ham: url("objects/ham_plate.png");
}

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

body[data-room="ghibli"] {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  color: var(--qr-fg);
  background: linear-gradient(180deg, rgba(151, 66, 49, .30), transparent 28%), linear-gradient(135deg, #0d1814 0%, #17231a 44%, #233724 100%);
  font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  display: flex;
  flex-direction: column;
  align-items: center;
}

body[data-room="ghibli"] #qr-root { width: 100%; max-width: 500px; padding: 24px 16px 28px; }
body[data-room="ghibli"] .qr-stage { display: flex; flex-direction: column; gap: 16px; }

body[data-room="ghibli"] .qr-progress {
  color: var(--qr-accent);
  font-family: "Press Start 2P", monospace;
  font-size: 10px;
  letter-spacing: 1px;
  text-align: right;
  text-shadow: 0 2px 0 #000;
}

body[data-room="ghibli"] .qr-board {
  position: relative;
  min-height: 340px;
  padding: 18px 16px 20px;
  overflow: hidden;
  color: var(--qr-fg);
  background: linear-gradient(180deg, rgba(246, 228, 190, .05), rgba(13, 24, 20, .04)), var(--qr-bg-elev);
  border: 1px solid var(--qr-ghibli-line-strong);
  border-radius: var(--qr-radius);
  box-shadow: 0 12px 0 rgba(0, 0, 0, .22), inset 0 0 0 1px rgba(246, 228, 190, .05);
}

body[data-room="ghibli"] .qr-board::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(246, 228, 190, .05) 1px, transparent 1px) 0 0 / 32px 32px, linear-gradient(180deg, rgba(246, 228, 190, .035) 1px, transparent 1px) 0 0 / 32px 32px;
  opacity: .36;
}

body[data-room="ghibli"] .qr-board > * { position: relative; z-index: 1; }

body[data-room="ghibli"] .qr-board h1,
body[data-room="ghibli"] .qr-board h2,
body[data-room="ghibli"] .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;
  text-transform: uppercase;
}

body[data-room="ghibli"] .qr-choice-prompt { margin-bottom: 12px; }
body[data-room="ghibli"] .qr-choice-prompt p,
body[data-room="ghibli"] .qrx-prompt p { margin: 0; color: var(--qr-fg-dim); font-size: 14px; line-height: 1.55; }

/* 3. Scene art */
body[data-room="ghibli"] .qr-scene {
  display: block;
  width: 100%;
  aspect-ratio: 8 / 3;
  height: auto;
  max-height: 172px;
  object-fit: cover;
  margin: 0 0 16px;
  background: var(--qr-bg);
  border: 1px solid var(--qr-ghibli-line-strong);
  border-radius: var(--qr-radius);
  image-rendering: pixelated;
  image-rendering: -moz-crisp-edges;
  image-rendering: crisp-edges;
  box-shadow: inset 0 0 0 1px rgba(246, 228, 190, .08);
  animation: qr-ghibli-scene-in 320ms ease-out both;
}

body[data-room="ghibli"] .qrx-scene {
  display: grid;
  grid-template-columns: 54px 1fr;
  gap: 12px;
  align-items: end;
  min-height: 126px;
  margin-bottom: 14px;
  padding: 12px;
  color: var(--qr-fg);
  background: var(--qr-scene-bath) center / cover no-repeat;
  border: 1px solid var(--qr-ghibli-line-strong);
  border-radius: var(--qr-radius);
  image-rendering: pixelated;
  animation: qr-ghibli-scene-in 320ms ease-out both;
}

body[data-room="ghibli"] .qrx-scene[data-scene="spell"] { background-image: var(--qr-scene-spell); }
body[data-room="ghibli"] .qrx-scene[data-scene="bath"] { background-image: var(--qr-scene-bath); }
body[data-room="ghibli"] .qrx-scene[data-scene="feast"] { background-image: var(--qr-scene-feast); }
body[data-room="ghibli"] .qrx-scene[data-scene="flight"] { background-image: var(--qr-scene-flight); }
body[data-room="ghibli"] .qrx-scene[data-scene="farewell"] { background-image: var(--qr-scene-farewell); }

body[data-room="ghibli"] .qrx-scene-glyph {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  color: var(--qr-ghibli-ink);
  background: var(--qr-accent);
  border: 2px solid var(--qr-ghibli-paper);
  border-radius: var(--qr-radius);
  font-family: "Press Start 2P", monospace;
  font-size: 20px;
  box-shadow: 0 4px 0 var(--qr-ghibli-shadow);
}

body[data-room="ghibli"] .qrx-scene-copy { padding: 8px 10px; background: rgba(13, 24, 20, .72); border: 1px solid rgba(246, 228, 190, .18); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qrx-scene-copy span { display: block; margin-bottom: 4px; color: var(--qr-warn); font-family: "Press Start 2P", monospace; font-size: 9px; letter-spacing: 1px; text-transform: uppercase; }
body[data-room="ghibli"] .qrx-scene-copy strong { display: block; color: var(--qr-fg); font-size: 14px; line-height: 1.35; }

/* 4. Buttons, cards, counters */
body[data-room="ghibli"] .qr-btn {
  appearance: none;
  width: 100%;
  min-height: 44px;
  margin-top: 16px;
  padding: 12px 18px;
  color: var(--qr-ghibli-ink);
  background: var(--qr-accent);
  border: 1px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  font-family: "Press Start 2P", monospace;
  font-size: 11px;
  line-height: 1.4;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 4px 0 var(--qr-accent-dim);
  transition: filter 120ms ease, transform 100ms ease, box-shadow 100ms ease;
}

body[data-room="ghibli"] .qr-btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
body[data-room="ghibli"] .qr-btn:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--qr-accent-dim); }
body[data-room="ghibli"] .qr-btn:disabled { opacity: .52; cursor: not-allowed; filter: grayscale(.35); transform: none; }
body[data-room="ghibli"] .qr-btn-sm { min-height: 44px; padding: 9px 12px; font-size: 10px; }
body[data-room="ghibli"] .qr-actions { display: flex; gap: 10px; }
body[data-room="ghibli"] .qr-actions .qr-btn { width: auto; flex: 1; margin-top: 0; }
body[data-room="ghibli"] .qr-choice-list,
body[data-room="ghibli"] .qrx-choice-list { display: grid; grid-template-columns: 1fr; gap: 9px; margin-bottom: 12px; }

body[data-room="ghibli"] .qr-choice {
  --qr-choice-icon: var(--qr-prop-charm);
  position: relative;
  min-height: 58px;
  padding: 12px 12px 12px 58px;
  color: var(--qr-fg);
  background: rgba(13, 24, 20, .72);
  border: 2px solid var(--qr-accent-dim);
  border-radius: var(--qr-radius);
  font-size: 13px;
  line-height: 1.45;
  text-align: left;
  box-shadow: inset 0 0 0 1px rgba(246, 228, 190, .05);
  transition: border-color 120ms ease, background 120ms ease, transform 120ms ease;
}

body[data-room="ghibli"] .qr-choice::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 50%;
  width: 34px;
  height: 34px;
  transform: translateY(-50%);
  background: var(--qr-choice-icon) center / contain no-repeat;
  image-rendering: pixelated;
  filter: drop-shadow(0 3px 0 rgba(0, 0, 0, .36));
}

body[data-room="ghibli"] .qr-choice:hover:not(:disabled) { border-color: var(--qr-accent); background: rgba(35, 55, 36, .84); animation: qr-ghibli-choice-lift 140ms ease-out both; }
body[data-room="ghibli"] .qr-choice.picked { color: var(--qr-ghibli-ink); background: linear-gradient(180deg, var(--qr-ghibli-paper), var(--qr-accent)); border-color: var(--qr-ghibli-paper); }
body[data-room="ghibli"] .qr-choice:disabled { cursor: not-allowed; }
body[data-room="ghibli"] .qr-choice-name { display: block; margin-bottom: 4px; color: var(--qr-accent); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; }
body[data-room="ghibli"] .qr-choice.picked .qr-choice-name { color: var(--qr-ghibli-red); }
body[data-room="ghibli"] .qr-counter,
body[data-room="ghibli"] .qr-status { color: var(--qr-fg-dim); background: rgba(13, 24, 20, .58); border: 1px solid var(--qr-ghibli-line); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-counter { padding: 9px 10px; font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 1px; text-align: center; }
body[data-room="ghibli"] .qr-counter span,
body[data-room="ghibli"] .qr-counter.complete span { color: var(--qr-accent); }
body[data-room="ghibli"] .qr-status { min-height: 34px; padding: 9px 10px; font-size: 12px; line-height: 1.45; text-align: center; }
body[data-room="ghibli"] .qr-status.warn { color: var(--qr-warn); }
body[data-room="ghibli"] .qr-status.win { color: var(--qr-accent); }
body[data-room="ghibli"] .qr-status.bad { color: var(--qr-danger); }
body[data-room="ghibli"] .qr-outcome,
body[data-room="ghibli"] .qrx-outcome { margin-top: 12px; padding: 12px 14px; color: var(--qr-fg); background: rgba(13, 24, 20, .72); border: 1px dashed var(--qr-accent); border-radius: var(--qr-radius); font-size: 13px; line-height: 1.55; animation: qr-ghibli-scene-in 220ms ease-out both; }
body[data-room="ghibli"] .qr-hint { padding: 10px 12px; color: var(--qr-warn); background: rgba(13, 24, 20, .88); 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; }
body[data-room="ghibli"] .qr-hint-visible { opacity: 1; }
body[data-room="ghibli"] .qr-resume-banner { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; margin-bottom: 16px; padding: 12px; color: var(--qr-fg); background: rgba(23, 35, 26, .94); border: 1px solid var(--qr-accent); border-radius: var(--qr-radius); font-size: 13px; }

/* 5. Puzzle 1: ghibli-spell */
body[data-room="ghibli"] .qr-ghibli-spell { position: relative; }
body[data-room="ghibli"] .qr-ghibli-spell-prompt h2 { color: var(--qr-ghibli-paper); text-shadow: 0 2px 0 var(--qr-ghibli-red); }
body[data-room="ghibli"] img.qr-scene[src$="scene_spell.png"] { border-color: rgba(224, 169, 71, .62); }
body[data-room="ghibli"] .qr-ghibli-spell-charm { position: relative; min-height: 92px; margin: 12px 0; padding: 14px 14px 14px 88px; background: rgba(151, 66, 49, .18); border: 1px solid rgba(224, 169, 71, .46); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-ghibli-spell-charm::before { content: ""; position: absolute; width: 64px; height: 64px; margin-left: -76px; background: var(--qr-prop-charm) center / contain no-repeat; image-rendering: pixelated; animation: qr-ghibli-prop-bob 2.8s ease-in-out infinite; }
body[data-room="ghibli"] .qr-ghibli-spell .qr-choice,
body[data-room="ghibli"] .qr-ghibli-spell-choice { --qr-choice-icon: var(--qr-prop-name); }
body[data-room="ghibli"] .qr-ghibli-spell .qr-choice:nth-child(2n),
body[data-room="ghibli"] .qr-ghibli-spell-choice:nth-child(2n) { --qr-choice-icon: var(--qr-prop-charm); }
body[data-room="ghibli"] .qr-ghibli-spell .qr-choice:nth-child(3n),
body[data-room="ghibli"] .qr-ghibli-spell-choice:nth-child(3n) { --qr-choice-icon: var(--qr-prop-tea); }
body[data-room="ghibli"] .qr-ghibli-spell-counter,
body[data-room="ghibli"] .qr-ghibli-spell .qr-counter { border-color: rgba(224, 169, 71, .46); }
body[data-room="ghibli"] .qr-ghibli-spell-status,
body[data-room="ghibli"] .qr-ghibli-spell .qr-status { color: var(--qr-ghibli-paper); }

/* 6. Puzzle 2: ghibli-bath */
body[data-room="ghibli"] .qr-ghibli-bath { display: flex; flex-direction: column; gap: 14px; }
body[data-room="ghibli"] .qr-ghibli-bath-prompt h2 { color: var(--qr-accent); }
body[data-room="ghibli"] .qr-ghibli-bath-prompt p { color: var(--qr-fg-dim); }
body[data-room="ghibli"] .qr-ghibli-bath-status { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; padding: 10px; color: var(--qr-fg-dim); background: rgba(13, 24, 20, .72); border: 1px solid var(--qr-ghibli-line); border-radius: var(--qr-radius); font-family: "Press Start 2P", monospace; font-size: 9px; letter-spacing: 1px; text-align: center; }
body[data-room="ghibli"] .qr-ghibli-bath-status strong { display: block; margin-top: 3px; color: var(--qr-accent); font-size: 12px; }
body[data-room="ghibli"] .qr-ghibli-bath-spirit { background: linear-gradient(180deg, rgba(126, 174, 171, .10), rgba(13, 24, 20, .18)), var(--qr-bg-elev); border: 2px solid var(--qr-ghibli-line-strong); border-radius: var(--qr-radius); box-shadow: inset 0 0 0 1px rgba(246, 228, 190, .05); }
body[data-room="ghibli"] .qr-ghibli-bath-spirit-name { color: var(--qr-accent); text-shadow: 0 1px 0 #000; }
body[data-room="ghibli"] .qr-ghibli-bath-spirit-hint { color: var(--qr-fg-dim); }
body[data-room="ghibli"] .qr-ghibli-bath-stack { border-color: var(--qr-ghibli-line-strong); box-shadow: 0 0 0 1px rgba(13, 24, 20, .42); }
body[data-room="ghibli"] .qr-ghibli-bath-layer { min-height: 46px; text-shadow: 0 2px 0 rgba(0, 0, 0, .42); }
body[data-room="ghibli"] .qr-ghibli-bath-layer.cleansing { box-shadow: inset 0 0 0 2px rgba(246, 228, 190, .44); }
body[data-room="ghibli"] .qr-ghibli-bath-layer.locked { outline-color: var(--qr-danger); }
body[data-room="ghibli"] .qr-ghibli-bath-sparkle { background: var(--qr-ghibli-paper); }
body[data-room="ghibli"] .qr-ghibli-bath-dial-label { color: var(--qr-fg-dim); }
body[data-room="ghibli"] .qr-ghibli-bath-segs { gap: 7px; }
body[data-room="ghibli"] .qr-ghibli-bath-seg { min-height: 44px; color: var(--qr-fg); background: rgba(13, 24, 20, .72); border-color: var(--qr-accent-dim); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-ghibli-bath-seg:hover:not(:disabled) { border-color: var(--qr-accent); background: rgba(83, 120, 74, .22); }
body[data-room="ghibli"] .qr-ghibli-bath-seg.chosen { color: var(--qr-ghibli-ink); background: var(--qr-accent); border-color: var(--qr-ghibli-paper); box-shadow: 0 3px 0 var(--qr-accent-dim); }
body[data-room="ghibli"] .qr-ghibli-bath-actions { display: flex; gap: 8px; }
body[data-room="ghibli"] .qr-ghibli-bath-feedback,
body[data-room="ghibli"] .qr-ghibli-bath-result { color: var(--qr-fg-dim); background: rgba(13, 24, 20, .72); border: 1px solid var(--qr-ghibli-line); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-ghibli-bath-feedback.full { color: var(--qr-warn); }
body[data-room="ghibli"] .qr-ghibli-bath-feedback.partial { color: var(--qr-accent); }
body[data-room="ghibli"] .qr-ghibli-bath-feedback.zero { color: var(--qr-danger); }

/* 7. Puzzle 3: ghibli-feast */
body[data-room="ghibli"] .qr-ghibli-feast { position: relative; }
body[data-room="ghibli"] img.qr-scene[src$="scene_feast.png"] { border-color: rgba(151, 66, 49, .74); }
body[data-room="ghibli"] .qr-ghibli-feast-table { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 12px 0; padding: 10px; background: rgba(151, 66, 49, .18); border: 1px solid rgba(224, 169, 71, .38); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-ghibli-feast-plate { min-height: 68px; background: rgba(246, 228, 190, .08); border: 1px dashed rgba(246, 228, 190, .28); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-ghibli-feast .qr-choice,
body[data-room="ghibli"] .qr-ghibli-feast-choice { --qr-choice-icon: var(--qr-prop-rice); }
body[data-room="ghibli"] .qr-ghibli-feast .qr-choice:nth-child(2n),
body[data-room="ghibli"] .qr-ghibli-feast-choice:nth-child(2n) { --qr-choice-icon: var(--qr-prop-ham); }
body[data-room="ghibli"] .qr-ghibli-feast .qr-choice:nth-child(3n),
body[data-room="ghibli"] .qr-ghibli-feast-choice:nth-child(3n) { --qr-choice-icon: var(--qr-prop-lantern); }
body[data-room="ghibli"] .qr-ghibli-feast-counter,
body[data-room="ghibli"] .qr-ghibli-feast .qr-counter { color: var(--qr-ghibli-paper); }
body[data-room="ghibli"] .qr-ghibli-feast-status,
body[data-room="ghibli"] .qr-ghibli-feast .qr-status { border-color: rgba(151, 66, 49, .62); }
body[data-room="ghibli"] .qr-ghibli-feast-done .qr-outcome { border-color: var(--qr-ghibli-red); }

/* 8. Puzzle 4: ghibli-flight */
body[data-room="ghibli"] .qr-ghibli-flight { position: relative; }
body[data-room="ghibli"] img.qr-scene[src$="scene_flight.png"] { border-color: rgba(126, 174, 171, .70); }
body[data-room="ghibli"] .qr-ghibli-flight-route { min-height: 116px; margin: 12px 0; padding: 12px; background: linear-gradient(180deg, rgba(126, 174, 171, .26), rgba(54, 99, 123, .18)), rgba(13, 24, 20, .52); border: 1px solid rgba(126, 174, 171, .42); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-ghibli-flight-path { height: 8px; margin: 38px 8px 0; background: repeating-linear-gradient(90deg, var(--qr-ghibli-paper) 0 10px, transparent 10px 18px); opacity: .72; }
body[data-room="ghibli"] .qr-ghibli-flight-marker { width: 54px; height: 54px; background: var(--qr-prop-broom) center / contain no-repeat; image-rendering: pixelated; animation: qr-ghibli-prop-bob 2.2s ease-in-out infinite; }
body[data-room="ghibli"] .qr-ghibli-flight .qr-choice,
body[data-room="ghibli"] .qr-ghibli-flight-choice { --qr-choice-icon: var(--qr-prop-broom); }
body[data-room="ghibli"] .qr-ghibli-flight .qr-choice:nth-child(2n),
body[data-room="ghibli"] .qr-ghibli-flight-choice:nth-child(2n) { --qr-choice-icon: var(--qr-prop-airship); }
body[data-room="ghibli"] .qr-ghibli-flight .qr-choice:nth-child(3n),
body[data-room="ghibli"] .qr-ghibli-flight-choice:nth-child(3n) { --qr-choice-icon: var(--qr-prop-mask); }
body[data-room="ghibli"] .qr-ghibli-flight-counter,
body[data-room="ghibli"] .qr-ghibli-flight .qr-counter { border-color: rgba(126, 174, 171, .46); }
body[data-room="ghibli"] .qr-ghibli-flight-status,
body[data-room="ghibli"] .qr-ghibli-flight .qr-status { color: var(--qr-ghibli-sky); }

/* 9. Puzzle 5: ghibli-farewell */
body[data-room="ghibli"] .qr-ghibli-farewell { position: relative; }
body[data-room="ghibli"] img.qr-scene[src$="scene_farewell.png"] { border-color: rgba(211, 116, 120, .70); }
body[data-room="ghibli"] .qr-ghibli-farewell-platform { min-height: 118px; margin: 12px 0; padding: 12px; background: linear-gradient(180deg, rgba(211, 116, 120, .14), rgba(224, 169, 71, .10)), rgba(13, 24, 20, .68); border: 1px solid rgba(211, 116, 120, .44); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-ghibli-farewell-ticket { position: relative; max-width: 220px; min-height: 62px; margin: 0 auto; padding: 12px 14px 12px 58px; color: var(--qr-ghibli-ink); background: var(--qr-ghibli-paper); border-left: 5px solid var(--qr-ghibli-rose); border-radius: var(--qr-radius); font-size: 12px; line-height: 1.45; }
body[data-room="ghibli"] .qr-ghibli-farewell-ticket::before { content: ""; position: absolute; width: 38px; height: 38px; margin-left: -48px; margin-top: -2px; background: var(--qr-prop-name) center / contain no-repeat; image-rendering: pixelated; }
body[data-room="ghibli"] .qr-ghibli-farewell .qr-choice,
body[data-room="ghibli"] .qr-ghibli-farewell-choice { --qr-choice-icon: var(--qr-prop-lantern); }
body[data-room="ghibli"] .qr-ghibli-farewell .qr-choice:nth-child(2n),
body[data-room="ghibli"] .qr-ghibli-farewell-choice:nth-child(2n) { --qr-choice-icon: var(--qr-prop-name); }
body[data-room="ghibli"] .qr-ghibli-farewell .qr-choice:nth-child(3n),
body[data-room="ghibli"] .qr-ghibli-farewell-choice:nth-child(3n) { --qr-choice-icon: var(--qr-prop-tea); }
body[data-room="ghibli"] .qr-ghibli-farewell-counter,
body[data-room="ghibli"] .qr-ghibli-farewell .qr-counter { border-color: rgba(211, 116, 120, .48); }
body[data-room="ghibli"] .qr-ghibli-farewell-status,
body[data-room="ghibli"] .qr-ghibli-farewell .qr-status { color: var(--qr-ghibli-rose); }

/* 10. Result and dossier */
body[data-room="ghibli"] .qr-result { padding: 28px 4px 10px; text-align: center; }
body[data-room="ghibli"] .qr-result-sprite-wrap { display: flex; justify-content: center; margin-bottom: 16px; }
body[data-room="ghibli"] .qr-result-sprite { width: 224px; height: 224px; object-fit: contain; image-rendering: pixelated; image-rendering: -moz-crisp-edges; image-rendering: crisp-edges; background: linear-gradient(180deg, rgba(246, 228, 190, .10), rgba(13, 24, 20, .86)); 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(246, 228, 190, .16); animation: qr-ghibli-sprite-in 520ms cubic-bezier(.22, 1.18, .36, 1); }
body[data-room="ghibli"] .qr-result-eyebrow,
body[data-room="ghibli"] .qr-result-dossier-eyebrow { color: var(--qr-accent); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; }
body[data-room="ghibli"] .qr-result-name { margin: 8px 0; color: var(--qr-fg) !important; font-family: "Press Start 2P", monospace; font-size: 20px; line-height: 1.35; letter-spacing: 1px; }
body[data-room="ghibli"] .qr-result-tagline { margin: 0 0 14px; color: var(--qr-fg-dim); font-size: 14px; font-style: italic; }
body[data-room="ghibli"] .qr-result-desc { margin: 0 0 16px; padding: 0 8px; color: var(--qr-fg); font-size: 15px; line-height: 1.6; text-align: left; }
body[data-room="ghibli"] .qr-result-runner { color: var(--qr-fg-dim); font-size: 13px; }
body[data-room="ghibli"] .qr-result-receipts,
body[data-room="ghibli"] .qr-result-receipts.qr-result-dossier { margin-top: 22px; padding: 16px; text-align: left; background: rgba(13, 24, 20, .72); border: 1px solid var(--qr-ghibli-line); border-radius: var(--qr-radius); }
body[data-room="ghibli"] .qr-result-dossier-header,
body[data-room="ghibli"] .qr-result-dossier-stamp { color: var(--qr-warn); font-family: "Press Start 2P", monospace; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; }
body[data-room="ghibli"] .qr-result-dossier-lines { margin: 12px 0 0; padding-left: 20px; color: var(--qr-fg-dim); font-size: 13px; line-height: 1.6; }
body[data-room="ghibli"] .qr-result-share-row,
body[data-room="ghibli"] .qr-result-next { display: grid; gap: 10px; margin-top: 16px; }
body[data-room="ghibli"] .qr-result-cta { display: block; padding: 12px; color: var(--qr-fg); text-decoration: none; background: rgba(13, 24, 20, .58); border: 1px solid var(--qr-ghibli-line); border-radius: var(--qr-radius); }

/* 11. Backdrop injection for simple choice-list puzzles */
@supports selector(:has(*)) {
  body[data-room="ghibli"] .qr-board:has(.qr-ghibli-spell-done) > .qr-choice-prompt::before,
  body[data-room="ghibli"] .qr-board:has(.qr-ghibli-feast-done) > .qr-choice-prompt::before,
  body[data-room="ghibli"] .qr-board:has(.qr-ghibli-flight-done) > .qr-choice-prompt::before,
  body[data-room="ghibli"] .qr-board:has(.qr-ghibli-farewell-done) > .qr-choice-prompt::before {
    content: "";
    display: block;
    width: 100%;
    aspect-ratio: 8 / 3;
    margin: 0 0 14px;
    background-color: var(--qr-bg);
    background-position: center;
    background-size: cover;
    border: 1px solid var(--qr-ghibli-line-strong);
    border-radius: var(--qr-radius);
    image-rendering: pixelated;
    animation: qr-ghibli-scene-in 260ms ease-out both;
  }

  body[data-room="ghibli"] .qr-board:has(.qr-ghibli-spell-done) > .qr-choice-prompt::before { background-image: var(--qr-scene-spell); }
  body[data-room="ghibli"] .qr-board:has(.qr-ghibli-feast-done) > .qr-choice-prompt::before { background-image: var(--qr-scene-feast); }
  body[data-room="ghibli"] .qr-board:has(.qr-ghibli-flight-done) > .qr-choice-prompt::before { background-image: var(--qr-scene-flight); }
  body[data-room="ghibli"] .qr-board:has(.qr-ghibli-farewell-done) > .qr-choice-prompt::before { background-image: var(--qr-scene-farewell); }
}

/* 12. Animations */
@keyframes qr-ghibli-scene-in {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes qr-ghibli-sprite-in {
  0% { opacity: 0; transform: translateY(14px) scale(.92); }
  65% { opacity: 1; transform: translateY(-2px) scale(1.02); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

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

@keyframes qr-ghibli-choice-lift {
  from { transform: translateY(0); }
  to { transform: translateY(-2px); }
}

@keyframes qr-ghibli-glow {
  0%, 100% { box-shadow: 0 0 0 rgba(224, 169, 71, 0); }
  50% { box-shadow: 0 0 14px rgba(224, 169, 71, .34); }
}

/* 13. Mobile */
@media (max-width: 520px) {
  body[data-room="ghibli"] #qr-root { padding: 16px 12px 24px; }
  body[data-room="ghibli"] .qr-board { min-height: 320px; padding: 14px 12px 16px; }
  body[data-room="ghibli"] .qr-board h2,
  body[data-room="ghibli"] .qr-choice-prompt h2 { font-size: 12px; line-height: 1.5; }
  body[data-room="ghibli"] .qr-choice-prompt p { font-size: 13px; }
  body[data-room="ghibli"] .qr-scene,
  body[data-room="ghibli"] .qrx-scene { max-height: none; min-height: 112px; }
  body[data-room="ghibli"] .qr-choice,
  body[data-room="ghibli"] .qr-btn,
  body[data-room="ghibli"] .qr-ghibli-bath-seg,
  body[data-room="ghibli"] .qr-ghibli-bath-run,
  body[data-room="ghibli"] .qr-ghibli-bath-skip { min-height: 44px; }
  body[data-room="ghibli"] .qr-choice { padding-left: 52px; font-size: 12px; }
  body[data-room="ghibli"] .qr-choice::before { left: 10px; width: 30px; height: 30px; }
  body[data-room="ghibli"] .qr-ghibli-bath-status { grid-template-columns: 1fr; text-align: left; }
  body[data-room="ghibli"] .qr-ghibli-bath-segs { grid-template-columns: 1fr; }
  body[data-room="ghibli"] .qr-ghibli-bath-actions,
  body[data-room="ghibli"] .qr-actions { flex-direction: column; }
  body[data-room="ghibli"] .qr-result-sprite { width: 192px; height: 192px; }
}

@media (prefers-reduced-motion: reduce) {
  body[data-room="ghibli"] *,
  body[data-room="ghibli"] *::before,
  body[data-room="ghibli"] *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
