/* ═══════════════════════════════════════════════════════════
   DRAGONMASTERS — Crystal Sanctum (v7 — Pip-flies palette)
   Design tokens adopted from "Pip flies — Layout C — design guide":
   violet-blue crystal land + warm coral character + gold accent.
   Fonts: Fredoka (display) / Quicksand (body) / Inter for UI numbers.
═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Quicksand:wght@400;500;600;700&family=Inter:wght@400;600;700&family=Fraunces:ital,wght@1,400;1,500;1,600&family=JetBrains+Mono:wght@400;600;700&display=swap');

:root {
  /* Pip-flies palette */
  --sky-top:      #1a0f3d;   /* deep violet — sky top */
  --sky-mid:      #5b3aa8;   /* royal violet — sky middle */
  --sky-bottom:   #9b7fe0;   /* lilac — sky bottom */
  --mtn-back:     #5b3aa8;
  --mtn-mid:      #1a0f3d;
  --mtn-mid-light:#9b7fe0;
  --mtn-front:    #0c0726;
  --crystal-a:    #9b7fe0;
  --crystal-b:    #bfd4ee;
  --accent:       #FFD97A;   /* warm gold — sparkles, drop target, gold pill */
  --pip:          #FF6FA5;   /* warm coral — dragon body, "new!" badge */
  --pip-deep:     #C7367A;
  --pip-light:    #FFB3CE;

  /* Legacy aliases — kept so old rules keep working until removed */
  --gold:        var(--accent);
  --magenta:     var(--pip);
  --cyan:        #7dd3fc;
  --lavender:    var(--sky-bottom);
  --dark:        var(--sky-top);
  --darker:      #0a0512;
  --night:       var(--sky-top);
  --panel:       rgba(255,255,255,0.06);
  --panel-border:rgba(255,255,255,0.10);
  --radius:      clamp(12px, 3vw, 22px);

  --text-xs:   clamp(0.68rem, 1.8vw, 0.80rem);
  --text-sm:   clamp(0.80rem, 2.2vw, 0.95rem);
  --text-base: clamp(0.90rem, 2.8vw, 1.05rem);
  --text-md:   clamp(1.00rem, 3.5vw, 1.20rem);
  --text-lg:   clamp(1.10rem, 4.0vw, 1.35rem);
  --text-xl:   clamp(1.30rem, 4.5vw, 2.00rem);
  --text-2xl:  clamp(1.50rem, 6.0vw, 2.80rem);

  --space-xs:  clamp(0.25rem, 1vw,  0.50rem);
  --space-sm:  clamp(0.50rem, 2vw,  0.80rem);
  --space-md:  clamp(0.80rem, 3vw,  1.20rem);
  --space-lg:  clamp(1.00rem, 4vw,  2.00rem);
  --space-xl:  clamp(1.20rem, 5vw,  2.50rem);

  --font-display: 'Fredoka', 'Inter', system-ui, sans-serif;
  --font-body:    'Quicksand', 'Inter', system-ui, sans-serif;
  --font-main:    var(--font-body);
  --serif:        var(--font-display); /* legacy — old rules using --serif now get Fredoka */
  --candle:       #f4ecff;
  --warm:         #FFD97A;
  --warm-deep:    #c4793d;
  --shadow-text-hard: 0 1px 1px rgba(0,0,0,0.7), 0 2px 6px rgba(0,0,0,0.55), 0 4px 18px rgba(0,0,0,0.4);
}

/* ── Reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body { overflow: hidden; touch-action: none; }

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  background: #0a0512;
  color: #e8e0f4;
  min-height: 100vh;
  -webkit-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

/* ── Screens ───────────────────────────────────────────── */
.screen { display: none; min-height: 100vh; width: 100%; position: relative; }

.screen.active {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  overflow-y: auto;
  padding: var(--space-lg) var(--space-sm);
  animation: fadeIn 0.35s ease;
}

.screen.active > .welcome-box { margin: auto 0; }

#screen-game.active {
  display: block;
  padding: 0;
  overflow: hidden;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════ WELCOME SCREEN ═════════════════════════ */
#screen-welcome {
  background: radial-gradient(ellipse at 50% 0%, #3a1060 0%, var(--darker) 70%);
}

.stars {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    radial-gradient(1px 1px at 10% 15%, #fff 0%, transparent 100%),
    radial-gradient(1px 1px at 30% 40%, #fff 0%, transparent 100%),
    radial-gradient(1px 1px at 55% 10%, #fff 0%, transparent 100%),
    radial-gradient(1px 1px at 75% 30%, #fff 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 60%, #fff 0%, transparent 100%),
    radial-gradient(1px 1px at 20% 70%, #fff 0%, transparent 100%),
    radial-gradient(1px 1px at 50% 85%, #fff 0%, transparent 100%),
    radial-gradient(2px 2px at 40% 55%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(2px 2px at 65% 70%, rgba(255,255,255,.5) 0%, transparent 100%);
}

.welcome-box {
  position: relative;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--panel-border);
  border-radius: clamp(16px, 4vw, 24px);
  padding: var(--space-xl);
  width: min(92%, 640px);
  text-align: center;
  backdrop-filter: blur(8px);
}

.dragon-banner {
  font-size: clamp(3rem, 12vw, 5rem);
  display: block;
  margin-bottom: var(--space-xs);
  animation: float 3s ease-in-out infinite;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-10px); }
}

h1 {
  font-size: var(--text-2xl);
  letter-spacing: clamp(1px, 0.6vw, 4px);
  background: linear-gradient(135deg, var(--magenta) 0%, var(--lavender) 50%, var(--cyan) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-xs);
}

.subtitle {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.6);
  letter-spacing: clamp(1px, 0.4vw, 2px);
  text-transform: uppercase;
  margin-bottom: var(--space-sm);
}

.intro-text {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.8);
  line-height: 1.6;
  margin-bottom: var(--space-lg);
}

.player-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(130px, 100%), 1fr));
  gap: var(--space-sm);
  align-items: center;
  margin-bottom: var(--space-lg);
}

.player-card {
  background: var(--panel);
  border: 2px solid var(--panel-border);
  border-radius: var(--radius);
  padding: var(--space-md) var(--space-lg);
  text-align: center;
  transition: transform 0.2s;
}
.player-card:hover { transform: translateY(-3px); }

#card-ivy    { border-color: var(--ivy);    background: rgba(232,93,58,0.12); }
#card-oliver { border-color: var(--oliver); background: rgba(58,139,232,0.12); }

.player-avatar { font-size: clamp(1.8rem, 6vw, 2.4rem); }
.player-name   { font-size: var(--text-md); font-weight: 700; margin: var(--space-xs) 0; }
.player-dragon { font-size: var(--text-xs); color: rgba(255,255,255,0.65); }
.player-title  { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 1px; color: var(--magenta); margin-top: var(--space-xs); }

#card-ivy    .player-name { color: #ff8c6e; }
#card-oliver .player-name { color: #6eb4ff; }

.versus { font-size: var(--text-xl); color: var(--magenta); font-weight: 900; text-align: center; }

.ipad-hint {
  margin-top: var(--space-md);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.45);
  letter-spacing: 1px;
}

/* ═══════════════ BUTTONS ════════════════════════════════ */
.btn-primary {
  background: linear-gradient(135deg, var(--magenta) 0%, var(--lavender) 100%);
  color: #1a0a30;
  border: none;
  border-radius: 50px;
  padding: clamp(0.7rem, 2.4vw, 0.95rem) clamp(1.6rem, 5vw, 2.6rem);
  font-size: var(--text-base);
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
  box-shadow: 0 4px 18px rgba(197,88,224,0.45);
  white-space: nowrap;
}
.btn-primary:hover  { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(197,88,224,0.6); }
.btn-primary:active { transform: translateY(1px); }
.btn-primary:disabled { opacity: 0.5; cursor: default; transform: none; }

.btn-continue {
  display: block;
  margin-top: var(--space-sm);
  background: transparent;
  border: 2px solid var(--cyan);
  color: var(--cyan);
  border-radius: 50px;
  padding: clamp(0.55rem, 1.8vw, 0.7rem) clamp(1rem, 4vw, 2rem);
  font-size: var(--text-sm);
  font-weight: 700;
  cursor: pointer;
  width: 100%;
  transition: all 0.2s;
}
.btn-continue:hover {
  background: rgba(125,211,252,0.12);
  box-shadow: 0 0 12px rgba(125,211,252,0.3);
}

.btn-startover {
  display: block;
  margin-top: var(--space-sm);
  background: transparent;
  border: 1px solid rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.55);
  border-radius: 50px;
  padding: clamp(0.45rem, 1.4vw, 0.6rem) clamp(0.9rem, 3vw, 1.6rem);
  font-size: var(--text-xs);
  cursor: pointer;
  width: 100%;
  transition: all 0.2s;
}
.btn-startover.primed {
  border-color: #e84343;
  color: #ff7373;
  background: rgba(232,67,67,0.08);
  animation: shake 0.4s ease-in-out;
}
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-3px); }
  75% { transform: translateX(3px); }
}

.btn-small {
  background: rgba(197,88,224,0.18);
  border: 1px solid rgba(197,88,224,0.5);
  color: var(--lavender);
  border-radius: 999px;
  padding: 0.3em 0.8em;
  font-size: var(--text-xs);
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
}
.btn-small:hover { background: rgba(197,88,224,0.32); }

/* ═══════════════ GAME SCREEN ════════════════════════════ */
#screen-game {
  background: var(--night);
}

#three-canvas {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  display: block;
  touch-action: none;
}

/* ── Boot splash ── */
.boot-splash {
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 35%, rgba(244,184,122,0.18) 0%, transparent 55%),
    radial-gradient(ellipse at 50% 60%, #3a1060 0%, var(--night) 55%, #0a0418 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  z-index: 250;
  transition: opacity 0.7s ease;
  padding: var(--space-lg);
}
.boot-splash p {
  color: var(--candle); font-size: var(--text-md); letter-spacing: 1px;
  text-shadow: var(--shadow-text-hard);
}
.boot-banner { font-size: clamp(3.4rem, 13vw, 5.6rem); animation: float 3s ease-in-out infinite; }
.boot-title {
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(2.2rem, 8vw, 4rem);
  letter-spacing: 0.08em;
  color: var(--candle);
  text-shadow: var(--shadow-text-hard);
  margin-bottom: 0.4rem;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: initial;
  background: none;
}
.boot-eyebrow {
  font-family: var(--font-main);
  font-weight: 600;
  font-size: 0.7rem;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--warm);
  margin-bottom: 0.4rem;
  text-shadow: var(--shadow-text-hard);
}
.boot-line {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 500;
  color: rgba(253,246,232,0.78);
  font-size: clamp(0.95rem, 2.6vw, 1.15rem);
  letter-spacing: 0.02em;
  text-shadow: var(--shadow-text-hard);
}
.boot-hint {
  font-family: var(--font-main);
  color: rgba(253,246,232,0.42);
  font-size: 0.72rem;
  margin-top: var(--space-md);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  text-shadow: var(--shadow-text-hard);
}
.boot-loading { display: flex; flex-direction: column; align-items: center; gap: 0.3rem; }
.boot-story {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg);
  max-width: min(92vw, 620px);
  text-align: center;
  cursor: pointer;
}
.boot-story[hidden] { display: none; }
.boot-story.panel-in {
  animation: panelIn 0.55s ease-out;
}
@keyframes panelIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
/* Story art — a real dragon, lit by a soft halo. The "asleep" panel
   desaturates the dragon and dims its glow; the others glow warm. */
.story-art-wrap {
  position: relative;
  width: clamp(180px, 33vw, 300px);
  display: flex; align-items: center; justify-content: center;
  animation: float 3.6s ease-in-out infinite;
}
.story-art-glow {
  position: absolute; inset: -30% -16%;
  background: radial-gradient(circle at 50% 48%, rgba(255,217,122,0.4), transparent 62%);
  filter: blur(14px); pointer-events: none;
}
.story-art {
  position: relative; display: block; width: 100%; height: auto;
  filter: drop-shadow(0 14px 34px rgba(0,0,0,0.55));
}
.story-art-wrap.glow .story-art-glow {
  inset: -38% -20%;
  background: radial-gradient(circle at 50% 48%,
              rgba(255,217,122,0.6), rgba(255,143,200,0.22) 42%, transparent 68%);
}
.story-art-wrap.dim .story-art {
  filter: grayscale(0.88) brightness(0.5) drop-shadow(0 14px 28px rgba(0,0,0,0.6));
}
.story-art-wrap.dim .story-art-glow {
  background: radial-gradient(circle at 50% 48%, rgba(120,112,158,0.22), transparent 60%);
}
.story-text {
  font-family: 'Fraunces', 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.05rem, 3vw, 1.4rem);
  color: var(--candle);
  line-height: 1.55;
  letter-spacing: 0.01em;
  max-width: 34ch;
  text-shadow: var(--shadow-text-hard);
}
.story-next {
  margin-top: var(--space-sm);
  background: transparent;
  color: var(--warm);
  border: 2px solid var(--warm);
  border-radius: 999px;
  padding: clamp(0.55rem, 1.8vw, 0.75rem) clamp(1.5rem, 5vw, 2.3rem);
  font-family: var(--font-main);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: all 0.2s;
}
.story-next:hover {
  background: rgba(244,184,122,0.12);
  box-shadow: 0 0 18px rgba(244,184,122,0.35);
}
.story-next:active { transform: translateY(1px); }

.boot-error {
  margin-top: var(--space-md);
  padding: var(--space-md);
  max-width: min(92vw, 600px);
  max-height: 35vh;
  overflow: auto;
  background: rgba(232,67,67,0.10);
  border: 1px solid rgba(232,67,67,0.45);
  border-radius: var(--radius);
  color: #ffaaaa;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: var(--text-xs);
  text-align: left;
  white-space: pre-wrap;
  word-break: break-word;
}
.boot-error-btn {
  margin-top: var(--space-md);
  background: rgba(232,67,67,0.25);
  border: 2px solid rgba(232,67,67,0.7);
  color: #fff;
  border-radius: 999px;
  padding: 0.6rem 1.6rem;
  font-size: var(--text-base);
  font-weight: 700;
  cursor: pointer;
}
.boot-splash.fade-out { opacity: 0; pointer-events: none; }

/* ── Joystick ── */
.joystick {
  position: fixed;
  bottom: clamp(20px, 5vw, 48px);
  left:   clamp(20px, 5vw, 48px);
  width:  clamp(120px, 18vw, 168px);
  height: clamp(120px, 18vw, 168px);
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(197,88,224,0.18) 0%, rgba(26,26,78,0.5) 60%, rgba(0,0,0,0.0) 100%);
  border: 2px solid rgba(197,88,224,0.45);
  box-shadow: 0 0 28px rgba(197,88,224,0.25), inset 0 0 20px rgba(0,0,0,0.4);
  z-index: 100;
  display: flex; align-items: center; justify-content: center;
  touch-action: none;
}
.joystick-knob {
  width: 38%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, var(--lavender) 0%, var(--magenta) 70%, #5a1a8a 100%);
  box-shadow: 0 0 20px rgba(197,88,224,0.7), 0 4px 12px rgba(0,0,0,0.5);
  pointer-events: none;
  transition: transform 0.05s linear;
}

/* ── Interact button ── */
.interact-btn {
  position: fixed;
  bottom: clamp(28px, 6vw, 56px);
  right:  clamp(28px, 6vw, 56px);
  min-width: clamp(120px, 16vw, 180px);
  padding: clamp(0.9rem, 2vw, 1.2rem) clamp(1rem, 2.5vw, 1.5rem);
  background: linear-gradient(135deg, rgba(26,26,78,0.85), rgba(58,16,96,0.85));
  border: 2px solid rgba(255,255,255,0.18);
  border-radius: 999px;
  color: rgba(255,255,255,0.5);
  font-size: var(--text-base);
  font-weight: 700;
  cursor: pointer;
  z-index: 100;
  display: flex; align-items: center; gap: 0.5em;
  justify-content: center;
  transition: all 0.25s ease;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}
.interact-btn .interact-icon { font-size: 1.3em; opacity: 0.45; transition: opacity 0.2s; }
.interact-btn .interact-label { display: none; }
.interact-btn.available {
  border-color: var(--magenta);
  color: #fff;
  background: linear-gradient(135deg, rgba(58,16,96,0.95), rgba(106,26,138,0.95));
  box-shadow: 0 0 28px rgba(197,88,224,0.55), 0 4px 16px rgba(0,0,0,0.4);
  animation: interact-pulse 1.6s ease-in-out infinite;
}
.interact-btn.available .interact-icon { opacity: 1; }
.interact-btn.available .interact-label { display: inline; }
@keyframes interact-pulse {
  0%, 100% { box-shadow: 0 0 28px rgba(197,88,224,0.55), 0 4px 16px rgba(0,0,0,0.4); }
  50%      { box-shadow: 0 0 44px rgba(197,88,224,0.8),  0 4px 16px rgba(0,0,0,0.4); }
}

/* ── Journal button (top-right) ── */
.journal-btn {
  position: fixed;
  top: clamp(20px, 4vw, 36px);
  right: clamp(20px, 4vw, 36px);
  z-index: 110;
  width:  clamp(48px, 9vw, 60px);
  height: clamp(48px, 9vw, 60px);
  font-size: clamp(1.4rem, 4vw, 1.8rem);
  border-radius: 50%;
  background: rgba(26,26,78,0.85);
  border: 2px solid rgba(197,88,224,0.45);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 18px rgba(197,88,224,0.3);
  backdrop-filter: blur(8px);
  transition: transform 0.15s, box-shadow 0.2s;
}
.journal-btn:hover { transform: scale(1.06); box-shadow: 0 0 24px rgba(197,88,224,0.55); }

/* ═══════════════ OVERLAY SCREENS (demo + journal) ════════ */
.overlay-screen {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(10, 5, 25, 0.78);
  backdrop-filter: blur(10px);
  z-index: 200;
  padding: clamp(0.5rem, 2vw, 1.5rem);
  overflow-y: auto;
  animation: fadeIn 0.25s ease;
}
.overlay-screen.active { display: flex; }

.overlay-body {
  width: min(92vw, 720px);
  max-height: 92vh;
  overflow-y: auto;
  background: linear-gradient(160deg, rgba(58,16,96,0.92), rgba(26,26,78,0.92));
  border: 2px solid rgba(197,88,224,0.45);
  border-radius: clamp(16px, 3vw, 24px);
  padding: clamp(1.2rem, 3vw, 2rem);
  box-shadow: 0 12px 60px rgba(197,88,224,0.35);
  position: relative;
}

.overlay-close, .demo-close {
  position: absolute;
  top: clamp(0.5rem, 2vw, 1rem);
  right: clamp(0.5rem, 2vw, 1rem);
  width:  clamp(34px, 5vw, 44px);
  height: clamp(34px, 5vw, 44px);
  border-radius: 50%;
  background: rgba(0,0,0,0.4);
  border: 1px solid rgba(255,255,255,0.18);
  color: #fff;
  font-size: 1.1rem;
  cursor: pointer;
  z-index: 2;
}
.overlay-close:hover, .demo-close:hover { background: rgba(232,67,67,0.4); border-color: #ff7373; }

/* ═══════════════ DEMO CARD ══════════════════════════════ */
.demo-card { position: relative; }

.demo-dragon {
  display: flex;
  align-items: center;
  gap: 0.6em;
  margin-bottom: var(--space-sm);
  padding: 0.4em 0.8em;
  background: linear-gradient(90deg, rgba(197,88,224,0.18), rgba(125,211,252,0.10));
  border: 1px solid rgba(197,88,224,0.35);
  border-radius: 999px;
  width: fit-content;
}
.dragon-emoji { font-size: 1.4em; filter: drop-shadow(0 0 8px rgba(251,207,106,0.55)); }
.dragon-text { display: flex; flex-direction: column; line-height: 1.1; }
.dragon-name {
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--gold);
  letter-spacing: 0.5px;
}
.dragon-title {
  font-size: var(--text-xs);
  color: var(--lavender);
  letter-spacing: 0.5px;
}

.demo-subtitle {
  font-size: var(--text-sm);
  color: var(--cyan);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: var(--space-sm);
}

.demo-lore {
  font-style: italic;
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.78);
  line-height: 1.55;
  margin-bottom: var(--space-sm);
  padding: var(--space-xs) var(--space-sm);
  border-left: 2px solid rgba(197,88,224,0.55);
}

.jc-subtitle {
  font-size: var(--text-xs);
  color: var(--lavender);
  margin-top: -0.15rem;
  margin-bottom: 0.3rem;
  font-style: italic;
}

.demo-title {
  font-size: var(--text-xl);
  background: linear-gradient(135deg, var(--magenta) 0%, var(--lavender) 50%, var(--cyan) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-xs);
  letter-spacing: 1px;
}
.demo-concept {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.75);
  margin-bottom: var(--space-md);
  line-height: 1.5;
}

/* Clean vertical demo layout: header → question → canvas → status → controls.
   The canvas is the visual hero but doesn't have overlays smashed on top. */
.demo-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}
.demo-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  width: 100%;
  margin-bottom: var(--space-md);
}
.q-canvas-wrap {
  position: relative;       /* hero intro overlays this only */
  width: 100%;
  max-width: 640px;
  aspect-ratio: 16 / 10;
  border-radius: var(--radius);
  overflow: hidden;
  background: #1a0f3d;
  box-shadow: 0 0 32px rgba(155,127,224,0.30);
}

/* ─── Landscape (iPad) layout ─────────────────────────────────────────
   The design's Layout-Cw model: scene fills left, tray docks right.
   Triggers when the viewport is wide enough AND landscape, regardless
   of device. Falls back to the portrait stack on narrow screens. */
@media (min-width: 900px) and (orientation: landscape) {
  /* Let the overlay frame breathe wider */
  #screen-demo .overlay-body {
    width: min(96vw, 1120px);
    max-height: 92vh;
  }
  .demo-card {
    display: grid;
    grid-template-columns: 1fr 360px;
    grid-template-areas:
      "header header"
      "stage  controls"
      "reveal reveal"
      "read   read";
    gap: 18px 22px;
    align-items: start;
  }
  .demo-header  { grid-area: header;  margin: 0; }
  .demo-stage   { grid-area: stage;   margin: 0; }
  .demo-controls{ grid-area: controls;
                  align-self: stretch;
                  background: linear-gradient(180deg, rgba(20,9,31,0.55), rgba(29,15,51,0.55));
                  border: 1px solid rgba(255,255,255,0.08);
                  border-radius: var(--radius);
                  padding: 18px;
                  display: flex;
                  flex-direction: column;
                  gap: 14px;
                  justify-content: center; }
  .demo-reveal  { grid-area: reveal; }
  .demo-card .btn-read { grid-area: read; justify-self: center; }
  /* Canvas takes the full stage column — drop the max-width cap */
  .q-canvas-wrap { max-width: none; aspect-ratio: 16 / 10; }
  /* Landscape pills: wider rows since they have more room */
  .q-row { flex-direction: column; gap: 8px; align-items: stretch; }
  .q-row-label { font-size: var(--text-base); min-width: 0; text-align: left; padding-left: 4px; }
  .q-pills { display: flex; gap: 10px; }
  .q-pill { padding: 0.55em 0.4em; }
}
.demo-canvas, .q-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.demo-controls {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}

.demo-result {
  font-size: var(--text-base);
  color: var(--cyan);
  text-align: center;
  margin-top: var(--space-xs);
  line-height: 1.5;
  max-width: 540px;
}

/* ═══════════════ QUESTION-PATTERN DEMO ═══════════════════ */
.q-stage-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  width: 100%;
}
/* Question text sits above the canvas as the hero line */
.q-question {
  font-family: var(--serif, 'Cormorant Garamond', Georgia, serif);
  font-size: clamp(1.2rem, 4vw, 1.7rem);
  font-weight: 600;
  font-style: italic;
  color: var(--candle);
  text-align: center;
  margin: 0;
  letter-spacing: 0.01em;
  text-shadow: var(--shadow-text-hard);
}
.q-status {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  width: 100%;
}
.q-canvas {
  /* override: canvas now lives inside .demo-stage absolutely positioned */
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.q-answer {
  padding: 0.55em 1.3em;
  background: linear-gradient(90deg, rgba(251,207,106,0.20), rgba(197,88,224,0.18));
  border: 2px solid rgba(251,207,106,0.75);
  border-radius: 999px;
  display: flex;
  align-items: baseline;
  gap: 0.45em;
  box-shadow: 0 0 22px rgba(251,207,106,0.45);
  animation: answer-pop 0.45s ease-out;
}
@keyframes answer-pop {
  from { transform: scale(0.85); opacity: 0; }
  to   { transform: scale(1.0);  opacity: 1; }
}
.q-answer-value {
  font-size: clamp(1.6rem, 5vw, 2.2rem);
  font-weight: 800;
  color: var(--gold);
  letter-spacing: 1px;
  font-family: 'Segoe UI', system-ui, sans-serif;
}
.q-answer-unit  { font-size: var(--text-sm); color: rgba(255,255,255,0.85); }
.q-answer-extra { font-size: var(--text-sm); color: var(--lavender); font-style: italic; }
.q-new-badge {
  font-size: var(--text-sm);
  font-weight: 700;
  color: #1a0a30;
  background: linear-gradient(90deg, #fbcf6a, #fff1a0);
  padding: 0.18em 0.6em;
  border-radius: 999px;
  margin-left: 0.4em;
  letter-spacing: 0.5px;
  animation: newBadgePop 0.55s ease-out;
}
@keyframes newBadgePop {
  0%   { transform: scale(0); opacity: 0; }
  70%  { transform: scale(1.18); opacity: 1; }
  100% { transform: scale(1.0); }
}
/* Progress chip lives below the canvas in the status row */
.q-progress {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--cyan);
  letter-spacing: 0.5px;
  margin: 0;
  padding: 0.3em 0.7em;
  background: rgba(26,10,48,0.5);
  border-radius: 999px;
}

/* Hero intro card: overlays the canvas wrap (not the whole stage) when
   a demo first opens. Big dragon name + lore line, fades on tap or 3s. */
.q-intro {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: var(--space-lg);
  text-align: center;
  background: linear-gradient(180deg, rgba(26,10,48,0.92), rgba(58,16,96,0.92));
  backdrop-filter: blur(14px);
  animation: introIn 0.55s ease-out;
  cursor: pointer;
}
.q-intro.fading { animation: introOut 0.55s ease-in forwards; }
@keyframes introIn {
  from { opacity: 0; transform: scale(1.04); }
  to   { opacity: 1; transform: scale(1.0); }
}
@keyframes introOut {
  to   { opacity: 0; transform: scale(0.96); }
}
.q-intro-emoji {
  font-size: clamp(3rem, 10vw, 4.5rem);
  line-height: 1;
  filter: drop-shadow(0 0 24px rgba(251,207,106,0.5));
  margin-bottom: 0.2rem;
}
.q-intro-name {
  font-family: var(--serif, 'Cormorant Garamond', Georgia, serif);
  font-size: clamp(2rem, 7vw, 3rem);
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.03em;
  margin: 0;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
.q-intro-rank {
  font-family: var(--serif, 'Cormorant Garamond', Georgia, serif);
  font-style: italic;
  font-size: clamp(0.95rem, 2.8vw, 1.2rem);
  color: var(--lavender);
  margin: 0 0 0.35rem;
  letter-spacing: 0.04em;
}
.q-intro-lore {
  font-family: var(--serif, 'Cormorant Garamond', Georgia, serif);
  font-style: italic;
  font-size: clamp(0.9rem, 2.6vw, 1.1rem);
  color: rgba(255,255,255,0.9);
  line-height: 1.5;
  max-width: 32ch;
  margin: 0;
}
.q-intro-tap {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-top: 0.8rem;
}

/* Header bar: dragon chip on the left, close button on the right.
   Header is in normal flow above the stage — not overlaying anything. */
.demo-header .demo-dragon {
  margin: 0;
  flex: 0 1 auto;
}
.demo-header .demo-close {
  position: static;
  flex: 0 0 auto;
}

/* When an overlay is open, hide the page-level TTS/music toggles —
   they were punching through the demo and clashing with the dragon chip. */
body:has(.overlay-screen.active) .tts-toggle,
body:has(.overlay-screen.active) .music-toggle,
body:has(.overlay-screen.active) .journal-btn {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
}

/* Compact pill rows — secondary to the canvas */
.q-row {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4em;
  margin-top: var(--space-xs);
}
.q-row-label {
  font-family: var(--serif, 'Cormorant Garamond', Georgia, serif);
  font-style: italic;
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.65);
  letter-spacing: 0.5px;
  min-width: 4.2em;
}
.q-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35em;
  flex: 1;
}
/* Layout-C sticker — square-ish, big tap target, coral accent when active */
.q-pill, .q-sticker {
  flex: 1 1 auto;
  min-width: 60px;
  min-height: 52px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.18em;
  padding: 0.5em 0.6em;
  border-radius: 16px;
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.85);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.15s, background 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.q-pill:active, .q-sticker:active { transform: scale(0.94); }
.q-pill-emoji {
  font-size: 1.6em;
  line-height: 1;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4));
}
.q-pill-label { letter-spacing: 0.2px; font-size: 0.78em; }
.q-pill:hover, .q-sticker:hover {
  background: rgba(255,143,181,0.18);
  border-color: rgba(255,143,181,0.6);
}
.q-pill.active, .q-sticker.is-active, .q-sticker.active {
  background: linear-gradient(180deg, rgba(255,143,181,0.42), rgba(255,143,181,0.12));
  border-color: rgba(255,143,181,0.85);
  color: #fff;
  box-shadow: 0 4px 18px rgba(255,111,165,0.35);
}

/* iPad landscape: bigger stickers (88px height per design spec) */
@media (min-width: 900px) and (orientation: landscape) {
  .q-pill, .q-sticker { min-height: 78px; border-radius: 22px; }
  .q-pill-emoji { font-size: 2em; }
  .q-pill-label { font-size: 0.85em; }
}

/* ─── Status emote chip — drawn at top-right of canvas wrap ───────────── */
.q-emote {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  z-index: 4;
  border: 2px solid rgba(255,255,255,0.4);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  transition: background 0.35s;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  font-family: var(--font-display);
}
.q-emote-happy { background: linear-gradient(135deg, #FFB347, #FF6FA5); }
.q-emote-zoom  { background: linear-gradient(135deg, #FFD97A, #FF8FB5); }
.q-emote-sad   { background: linear-gradient(135deg, #6b7280, #4b5563); }
@media (min-width: 900px) and (orientation: landscape) {
  .q-emote { width: 52px; height: 52px; font-size: 24px; top: 18px; right: 18px; }
}

.q-actions {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: var(--space-md);
}
.q-solve {
  font-size: var(--text-md);
  padding: clamp(0.8rem, 2.5vw, 1.05rem) clamp(2rem, 6vw, 3rem);
  letter-spacing: 1.5px;
  background: linear-gradient(135deg, var(--gold) 0%, var(--magenta) 100%);
  color: #1a0a30;
  box-shadow: 0 4px 22px rgba(251,207,106,0.5);
  animation: solvePulse 2.4s ease-in-out infinite;
}
.q-solve:disabled { animation: none; opacity: 0.6; }
@keyframes solvePulse {
  0%, 100% { box-shadow: 0 4px 22px rgba(251,207,106,0.5); transform: scale(1); }
  50%      { box-shadow: 0 6px 30px rgba(251,207,106,0.8); transform: scale(1.04); }
}

/* Pill rows briefly pulse after each Solve, hinting "tap something else" */
.q-pills.pulse-hint {
  animation: pillsHint 1.6s ease-out;
}
@keyframes pillsHint {
  0%   { transform: translateY(0); filter: brightness(1); }
  20%  { transform: translateY(-2px); filter: brightness(1.25); }
  60%  { transform: translateY(0);    filter: brightness(1.1); }
  100% { transform: translateY(0);    filter: brightness(1); }
}

.demo-prompt {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.75);
  text-align: center;
  margin-bottom: var(--space-xs);
}
.demo-button-row {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
}

.journal-startover {
  display: flex;
  justify-content: center;
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid rgba(255,255,255,0.12);
}
.journal-startover .btn-startover { width: auto; max-width: 340px; }

/* Reveal block — concept + fun fact, shown only after Solve It! */
.demo-reveal {
  margin-top: var(--space-sm);
  animation: fadeIn 0.5s ease-out;
}

/* Compact one-line "Did you know?" chip — concept paragraph removed
   from the UI per design feedback; full text still in TTS. */
.demo-funfact {
  padding: 0.55em 0.95em;
  background: linear-gradient(90deg, rgba(125,211,252,0.14), rgba(255,217,122,0.10));
  border: 1px solid rgba(125,211,252,0.4);
  border-radius: 999px;
  display: flex;
  align-items: center;
  gap: 0.5em;
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.92);
  line-height: 1.35;
}
.ff-label {
  color: var(--cyan);
  font-weight: 700;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}

.demo-question {
  font-size: var(--text-md);
  color: #fff;
  text-align: center;
  margin-bottom: var(--space-md);
}
.demo-choices {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(180px, 100%), 1fr));
  gap: var(--space-xs);
}
.choice-btn {
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.08);
  border: 2px solid var(--panel-border);
  color: #fff;
  font-size: var(--text-sm);
  cursor: pointer;
  transition: all 0.2s;
}
.choice-btn:hover:not(:disabled) {
  border-color: var(--lavender);
  background: rgba(183,148,244,0.15);
}
.choice-btn.correct { border-color: #4caf50; background: rgba(76,175,80,0.18); }
.choice-btn.wrong   { border-color: #e84343; background: rgba(232,67,67,0.18); }
.choice-btn:disabled { cursor: default; }

.demo-slider-wrap { width: 100%; max-width: 520px; }
.demo-slider-wrap label {
  display: block;
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.85);
  text-align: center;
  margin-bottom: var(--space-xs);
}
.slider-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}
.slider-row input[type=range] {
  flex: 1;
  -webkit-appearance: none;
  height: 6px;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  border-radius: 3px;
  outline: none;
}
.slider-row input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 24px; height: 24px;
  background: radial-gradient(circle at 35% 35%, #fff, var(--lavender) 60%, var(--magenta));
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 0 12px rgba(197,88,224,0.6);
}
.slider-label {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.65);
  min-width: 5em;
  text-align: center;
}

.btn-read {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  margin: var(--space-md) auto 0;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.6);
  border-radius: 999px;
  padding: 0.4em 1em;
  font-size: var(--text-xs);
  cursor: pointer;
  transition: all 0.2s;
}
.btn-read:hover { border-color: var(--cyan); color: var(--cyan); }

/* ═══════════════ JOURNAL ═══════════════════════════════ */
.overlay-body h2 {
  font-size: var(--text-xl);
  color: var(--magenta);
  margin-bottom: var(--space-xs);
}
.journal-progress {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.75);
  margin-bottom: var(--space-md);
}
.journal-progress strong { color: var(--cyan); }

.journal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr));
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}
.journal-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--panel-border);
  border-radius: var(--radius);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  text-align: center;
}
.journal-card.found { border-color: rgba(197,88,224,0.55); background: rgba(58,16,96,0.4); }
.journal-card.locked { opacity: 0.55; }
.jc-emoji { font-size: 1.8rem; }
.jc-title { font-weight: 700; color: #fff; }
.jc-concept { font-size: var(--text-xs); color: rgba(255,255,255,0.65); line-height: 1.4; }
.jc-status {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--cyan);
  margin: 0.3em 0;
  letter-spacing: 0.5px;
}
.jc-status.fully {
  color: var(--gold);
}
.journal-card.fully {
  border-color: var(--gold);
  background: linear-gradient(160deg, rgba(247,201,72,0.18), rgba(58,16,96,0.42));
  box-shadow: 0 0 22px rgba(247,201,72,0.25);
}
.jc-replay { margin: 0.4rem auto 0; }

.journal-section {
  font-size: var(--text-md);
  color: var(--cyan);
  margin-bottom: var(--space-xs);
}
.journal-achievements {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}
.journal-achievements li {
  font-size: var(--text-sm);
  padding: 0.4em 0.8em;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
}
.journal-achievements li.unlocked { color: var(--gold); background: rgba(247,201,72,0.12); }
.journal-achievements li.locked   { color: rgba(255,255,255,0.4); }

/* ═══════════════ AUDIO TOGGLES ══════════════════════════ */
.tts-toggle, .music-toggle {
  position: fixed;
  top:   clamp(20px, 4vw, 36px);
  z-index: 300;
  background: rgba(16,8,32,0.85);
  border: 1px solid var(--panel-border);
  border-radius: 50%;
  width:  clamp(44px, 8vw, 54px);
  height: clamp(44px, 8vw, 54px);
  font-size: clamp(1.2rem, 4vw, 1.5rem);
  cursor: pointer;
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 12px rgba(0,0,0,0.4);
  transition: border-color 0.2s, opacity 0.2s;
}
.tts-toggle    { left: clamp(20px, 4vw, 36px); }
.music-toggle  { left: calc(clamp(20px, 4vw, 36px) + clamp(54px, 9vw, 64px)); }
.music-toggle.muted { opacity: 0.4; }
.music-toggle:hover { border-color: var(--magenta); }
.tts-toggle:hover    { border-color: var(--cyan); }
.tts-toggle.muted    { opacity: 0.45; }
.tts-toggle.speaking { border-color: var(--cyan); animation: tts-pulse 1.2s ease-in-out infinite; }
@keyframes tts-pulse {
  0%, 100% { box-shadow: 0 0 0 0    rgba(125,211,252,0.5); }
  50%       { box-shadow: 0 0 0 8px rgba(125,211,252,0);   }
}

/* ═══════════════ Globals ═══════════════════════════════ */
h2 { color: var(--lavender); }
p  { line-height: 1.6; color: rgba(255,255,255,0.8); }

/* iPad landscape layout polish */
@media (min-width: 900px) and (orientation: landscape) {
  .joystick { bottom: 40px; left: 40px; }
  .interact-btn { bottom: 56px; right: 56px; }
}

/* iPhone tightening */
@media (max-width: 480px) {
  .interact-btn { min-width: 96px; padding: 0.7rem 0.9rem; }
  .joystick { width: 100px; height: 100px; }
}

/* ═══════════════════════════════════════════════════════════
   MINI-GAME "STAGE" — responsive full-viewport lesson overlay
   No fixed-size board: a flex column where the phenomenon area
   flexes to whatever the picker shelf leaves, so nothing clips.
═══════════════════════════════════════════════════════════ */

/* Demo overlay turns full-bleed when a Stage is mounted. Journal screen
   (#screen-journal) is untouched — it keeps the centered card. */
.overlay-screen:has(.stage-host) {
  padding: 0; background: #0a0512; backdrop-filter: none;
}
.overlay-body.stage-host {
  width: 100vw; max-width: none; height: 100vh; height: 100dvh; max-height: none;
  margin: 0; padding: 0; overflow: hidden;
  background: none; border: none; border-radius: 0; box-shadow: 0 0 0 0;
}

.dms-screen {
  position: absolute; inset: 0; overflow: hidden;
  display: flex; flex-direction: column;
  color: #f4ecff;
  font-family: 'Quicksand', system-ui, sans-serif;
  background: radial-gradient(ellipse at 50% 38%, #3a1b6a 0%, #0a0512 75%);
}
.dms-sky {
  position: absolute; inset: 0; width: 100%; height: 100%;
  opacity: 0.9; pointer-events: none;
}

/* Upper area — chrome floats over the phenomenon SVG; flexes to fill. */
.dms-stagewrap { position: relative; flex: 1; min-height: 0; }

/* ── Close button ─────────────────────────────────────────── */
.dms-close {
  position: absolute; top: clamp(10px,1.8vw,24px); left: clamp(10px,1.8vw,24px);
  width: 40px; height: 40px; z-index: 10; border-radius: 99px;
  background: rgba(10,5,18,0.55); border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(8px);
  display: grid; place-items: center;
  font-size: 14px; color: rgba(255,255,255,0.75); cursor: pointer;
}
.dms-close:hover { background: rgba(10,5,18,0.8); }
.dms-close:focus-visible { outline: 2px solid rgba(255,217,122,0.6); outline-offset: 2px; }

/* ── Progress chip ────────────────────────────────────────── */
.dms-chip {
  position: absolute; top: clamp(10px,1.8vw,24px); right: clamp(10px,1.8vw,24px);
  z-index: 10; display: flex; align-items: center; gap: 10px;
  padding: 6px 14px 6px 6px; border-radius: 99px;
  background: rgba(10,5,18,0.55); border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
}
.dms-arc { position: relative; width: 44px; height: 44px; }
.dms-arc-fill { transition: stroke-dashoffset 0.6s ease; }
.dms-arc-num {
  position: absolute; inset: 0; display: grid; place-items: center;
  font-family: 'Fredoka', sans-serif; font-weight: 700; font-size: 12px; color: #FFD97A;
}
.dms-chip-label {
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,0.65); font-weight: 600;
}
/* On a phone the label is first to go — the arc still shows the count. */
@media (max-width: 560px) { .dms-chip-label { display: none; } }

/* ── Dragon companion — corner portrait + name plate ──────── */
.dms-dragon {
  position: absolute; top: clamp(10px,2vh,38px); left: clamp(12px,3vw,58px);
  z-index: 4; pointer-events: none; width: clamp(120px,16vw,210px);
}
.dms-dragon-art { position: relative; width: 100%; }
.dms-dragon-glow {
  position: absolute; inset: -16% -8%;
  background: radial-gradient(circle at 52% 46%, #ffd0ec44, transparent 62%);
  filter: blur(10px); pointer-events: none;
}
.dms-dragon-img {
  display: block; width: 100%; height: auto;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,0.5));
}
.dms-kicker {
  font-family: 'JetBrains Mono', monospace; font-size: clamp(7px,0.7vw,9px);
  letter-spacing: 0.32em; text-transform: uppercase; color: rgba(255,217,122,0.7);
}
.dms-name {
  font-family: 'Fraunces', serif; font-style: italic; font-weight: 600;
  font-size: clamp(15px,2vw,26px); color: #FFD97A; letter-spacing: 0.02em;
  text-shadow: 0 0 16px rgba(255,217,122,0.5);
}

/* ── Question ─────────────────────────────────────────────── */
.dms-question {
  position: absolute; top: clamp(12px,3vh,90px); left: 50%;
  transform: translateX(-50%);
  width: min(560px,56vw); z-index: 5; text-align: center;
  font-family: 'Fraunces', serif; font-style: italic; font-weight: 500;
  font-size: clamp(17px,2.6vw,30px); color: #f4ecff;
  letter-spacing: 0.01em; line-height: 1.2;
  text-shadow: 0 1px 3px rgba(0,0,0,0.6), 0 4px 18px rgba(0,0,0,0.35);
}

/* ── Centre phenomenon — one self-contained SVG, scales to fit ─ */
.dms-center { position: absolute; inset: 0; z-index: 2; pointer-events: none; }
.dms-cms-svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
/* Physics-sim demos render onto a canvas. It paints the same twilight
   backdrop as the Stage, so the letterbox from object-fit is invisible. */
.dms-sim-canvas { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; }
/* The wind-flight demo renders a live 3D galewing dragon here. */
.dms-wind-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }

/* Result readout for the sim demos (the colour demo shows its result
   inside the orb instead). */
.dms-readout {
  position: absolute; top: clamp(74px,17vh,198px); left: 50%;
  transform: translateX(-50%); z-index: 5;
  display: flex; align-items: center; gap: 8px; white-space: nowrap;
  padding: 6px 18px; border-radius: 99px;
  background: rgba(10,5,18,0.6); border: 1px solid rgba(255,217,122,0.32);
  backdrop-filter: blur(8px);
}
.dms-readout-value {
  font-family: 'Fraunces', serif; font-style: italic; font-weight: 600;
  font-size: clamp(20px,3vw,38px); color: #FFD97A; line-height: 1;
}
.dms-readout-unit {
  font-family: 'Quicksand', sans-serif; font-weight: 600;
  font-size: clamp(11px,1.4vw,15px); color: rgba(255,255,255,0.72);
}
.dms-readout .dms-new-badge { margin-top: 0; }

.dms-beam { opacity: 0.85; transition: stroke-dashoffset 0.5s ease-out; }
.dms-sparkles { opacity: 0; transition: opacity 0.4s ease 0.3s; }
.dms-beams.on .dms-sparkles { opacity: 1; }

.dms-result-orb {
  opacity: 0; transform: scale(0.6);
  transform-box: fill-box; transform-origin: center;
  transition: opacity 0.35s ease-out, transform 0.35s ease-out;
}
.dms-result-orb.on { opacity: 1; transform: scale(1); }

.dms-result-label {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  height: 100%; text-align: center;
  opacity: 0; transition: opacity 0.2s ease 0.2s;
}
.dms-result-label.on { opacity: 1; }
.dms-result-kicker {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 700;
  letter-spacing: 0.32em; color: rgba(60,30,10,0.7); margin-bottom: 2px;
}
.dms-result-word {
  font-family: 'Fraunces', serif; font-style: italic; font-weight: 600;
  font-size: 58px; color: #fff; letter-spacing: 0.02em; line-height: 1;
  text-shadow: 0 0 20px #c4793d, 0 2px 0 rgba(150,80,20,0.45);
}
.dms-new-badge {
  margin-top: 8px;
  font-family: 'Fredoka', sans-serif; font-size: 10px; font-weight: 800;
  letter-spacing: 0.28em; color: #0a0512;
  background: linear-gradient(135deg, #fff, #FFD97A);
  padding: 3px 10px; border-radius: 99px;
  box-shadow: 0 4px 14px rgba(255,217,122,0.6);
}
.dms-new-badge.pop { animation: dmsBadgePop 0.4s ease-out; }
@keyframes dmsBadgePop {
  0%   { transform: scale(0); opacity: 0; }
  70%  { transform: scale(1.18); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

/* ── Read-to-me chip ──────────────────────────────────────── */
.dms-read {
  position: absolute; right: clamp(10px,2vw,30px); bottom: clamp(10px,2vh,26px);
  z-index: 6; display: flex; align-items: center; gap: 8px;
  padding: 7px 14px; border-radius: 99px; cursor: pointer;
  background: rgba(10,5,18,0.5); border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  font-size: 12px; color: rgba(255,255,255,0.7);
}
.dms-read-icon { color: #FFD97A; font-size: 14px; }
.dms-read.playing .dms-read-icon { animation: dmsReadPulse 0.8s ease-in-out infinite; }
.dms-read:focus-visible { outline: 2px solid rgba(255,217,122,0.6); outline-offset: 2px; }
@keyframes dmsReadPulse { 0%,100% { opacity: 0.5; } 50% { opacity: 1; } }

/* ── Picker shelf — fully responsive ──────────────────────────
   Pickers flow side-by-side and stack on a phone; buttons grow to
   fill and wrap to a second row when the row runs out of width. */
.dms-shelf {
  flex-shrink: 0;
  display: flex; flex-wrap: wrap; gap: clamp(8px,1.6vw,20px);
  margin: clamp(6px,1.2vw,14px) clamp(8px,2.6vw,50px) clamp(8px,2vw,28px);
  padding: clamp(8px,1.5vw,18px) clamp(10px,1.8vw,22px);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(10,5,18,0.55));
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 -8px 30px rgba(0,0,0,0.5);
}
.dms-picker { flex: 1 1 252px; min-width: 0; }
.dms-picker-label {
  font-family: 'Fraunces', serif; font-style: italic; font-size: 13px;
  color: rgba(255,255,255,0.6); margin-bottom: 8px; letter-spacing: 0.02em;
}
.dms-picker-row { display: flex; flex-wrap: wrap; gap: clamp(6px,1vw,10px); }
.dms-opt {
  flex: 1 1 76px; min-width: 66px; min-height: 62px;
  padding: 8px 6px; border-radius: 14px;
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 5px;
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  transition: background .2s, border-color .2s, transform .2s, box-shadow .2s;
}
/* The active ring is an inset shadow, not a thicker border — so selecting
   a button never changes its size and never re-flows the wrap. */
.dms-opt.active {
  background: rgba(255,217,122,0.18); border-color: rgba(255,217,122,0.85);
  transform: translateY(-3px);
  box-shadow: 0 8px 18px rgba(255,217,122,0.3),
              inset 0 0 0 1px rgba(255,217,122,0.85);
}
.dms-opt:focus-visible { outline: 2px solid rgba(255,217,122,0.6); outline-offset: 2px; }
.dms-opt-orb {
  width: clamp(28px,3.4vw,40px); height: clamp(28px,3.4vw,40px);
  display: block; overflow: visible;
}
.dms-opt-emoji { font-size: clamp(22px,3vw,32px); line-height: 1; }
.dms-opt-name {
  font-family: 'Fredoka', sans-serif; font-weight: 600;
  font-size: clamp(11px,1.2vw,13px); color: rgba(255,255,255,0.65);
  text-align: center;
}
.dms-opt.active .dms-opt-name { color: #fff; }
