/* ===========================================================
   CRYSTAL DJ — Sunny's Maths Decks
   Dark DJ-booth aesthetic, neon crystals, big tactile targets.
   Built for a 7yo on a Mac in Chrome. Touch + click friendly.
   =========================================================== */

:root{
  --bg:#0a0a14;
  --bg2:#141428;
  --ink:#ffffff;
  --muted:#9aa0c0;
  --neon:#7c5bff;
  --neon2:#33d6ff;
  --gold:#ffd23f;
  --good:#33d6a6;
  --bad:#ff6b6b;
  --radius:22px;
  --tap:84px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;margin:0;}
body{
  font-family:"Baloo 2","Fredoka",system-ui,-apple-system,"Segoe UI",sans-serif;
  background:
    radial-gradient(1200px 700px at 50% -10%, #1d1b44 0%, transparent 60%),
    radial-gradient(900px 600px at 90% 110%, #0d2a4a 0%, transparent 55%),
    var(--bg);
  color:var(--ink);
  overflow:hidden;
  user-select:none;
  -webkit-user-select:none;
  touch-action:manipulation;
}

/* ---------- screens ---------- */
.screen{
  position:fixed;inset:0;
  display:none;flex-direction:column;align-items:center;
  padding:18px;
  animation:fade .35s ease;
}
.screen.active{display:flex;}
@keyframes fade{from{opacity:0;transform:scale(.98)}to{opacity:1;transform:none}}

/* ---------- shared buttons ---------- */
.big-btn{
  font-family:inherit;font-weight:800;font-size:1.6rem;letter-spacing:.5px;
  color:#fff;border:none;border-radius:var(--radius);
  padding:20px 34px;cursor:pointer;
  background:linear-gradient(135deg,var(--neon),var(--neon2));
  box-shadow:0 10px 0 #3a2a8a,0 16px 30px rgba(124,91,255,.5);
  transition:transform .08s, box-shadow .08s;
}
.big-btn:active{transform:translateY(8px);box-shadow:0 2px 0 #3a2a8a;}
.glow{animation:glow 2.2s ease-in-out infinite;}
@keyframes glow{50%{filter:brightness(1.15) drop-shadow(0 0 18px var(--neon))}}
.ghost-btn{
  margin-top:14px;background:none;border:none;color:var(--muted);
  font-family:inherit;font-size:1rem;cursor:pointer;text-decoration:underline;
}

/* ---------- LOGIN ---------- */
.login-card{margin:auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;}
.logo-crystal{font-size:5rem;filter:drop-shadow(0 0 24px var(--neon2));animation:float 3s ease-in-out infinite;}
@keyframes float{50%{transform:translateY(-12px) rotate(-4deg)}}
.title-neon{
  font-size:3.4rem;margin:.1em 0 0;font-weight:900;letter-spacing:2px;
  background:linear-gradient(90deg,var(--neon2),var(--neon),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 30px rgba(124,91,255,.4);
}
.subtitle{margin:0;color:var(--gold);font-weight:700;font-size:1.3rem;letter-spacing:4px;text-transform:uppercase;}
.login-prompt{color:var(--muted);margin:22px 0 8px;font-size:1.15rem;}
.name-input{
  font-family:inherit;font-size:2rem;font-weight:800;text-align:center;
  width:min(80vw,360px);padding:16px;border-radius:18px;border:3px solid var(--neon);
  background:rgba(255,255,255,.06);color:#fff;outline:none;margin-bottom:18px;
}
.name-input::placeholder{color:#6a6f96;}
.name-input:focus{border-color:var(--neon2);box-shadow:0 0 22px rgba(51,214,255,.4);}

/* ---------- topbar ---------- */
.topbar{width:100%;max-width:680px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.player-chip{background:rgba(255,255,255,.08);padding:8px 18px;border-radius:30px;font-weight:800;font-size:1.1rem;}
.crystal-counter{display:flex;align-items:center;gap:8px;background:rgba(255,210,63,.12);
  padding:8px 18px;border-radius:30px;font-weight:900;font-size:1.3rem;color:var(--gold);}
.crystal-counter.session{background:rgba(124,91,255,.16);color:#cdbcff;}
.gem{font-size:1.2rem;}
.icon-btn{font-size:1.6rem;background:rgba(255,255,255,.08);border:none;border-radius:16px;
  width:52px;height:52px;cursor:pointer;}
.streak-chip{background:rgba(255,107,107,.15);color:#ffb3b3;padding:8px 16px;border-radius:30px;font-weight:800;}

/* ---------- HOME ---------- */
.home-body{display:flex;gap:20px;width:100%;max-width:820px;margin-top:14px;align-items:flex-start;justify-content:center;}
.home-main{flex:1;display:flex;flex-direction:column;align-items:center;min-width:0;}

/* vertical DJ-tour ladder (left) — Rookie at top, working down */
.ladder-board{width:188px;flex:0 0 188px;background:rgba(255,255,255,.05);border-radius:20px;padding:12px 10px;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.06);}
.ladder-title{text-align:center;color:var(--gold);font-weight:900;font-size:.85rem;letter-spacing:1px;margin-bottom:10px;}
.ladder-rungs{display:flex;flex-direction:column;gap:8px;}
.rung{position:relative;border-radius:12px;padding:9px 10px;background:rgba(255,255,255,.05);
  border:2px solid transparent;transition:all .3s;}
.rung .rung-name{font-weight:800;font-size:.92rem;color:#cfd2ee;display:flex;align-items:center;gap:6px;}
.rung .rung-venue{font-size:.68rem;color:var(--muted);margin-top:1px;}
.rung.done{background:linear-gradient(90deg,rgba(255,210,63,.22),rgba(255,138,63,.12));}
.rung.done .rung-name{color:#ffe08a;}
.rung.current{border-color:var(--gold);background:linear-gradient(90deg,rgba(124,91,255,.3),rgba(51,214,255,.12));
  box-shadow:0 0 18px rgba(124,91,255,.5);transform:scale(1.04);}
.rung.current .rung-name{color:#fff;}
.rung.locked{opacity:.45;}
.rung .rung-prog{height:6px;border-radius:6px;background:rgba(0,0,0,.3);margin-top:6px;overflow:hidden;display:none;}
.rung.current .rung-prog{display:block;}
.rung .rung-prog-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--gold),#ff8a3f);transition:width .8s cubic-bezier(.2,1,.3,1);}
.rung .you{position:absolute;right:8px;top:8px;font-size:.9rem;}

.pick-title{font-size:1.7rem;margin:0 0 14px;text-align:center;}
.deck-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:520px;}
.deck-card{
  font-family:inherit;border:none;cursor:pointer;border-radius:var(--radius);
  padding:22px 14px;display:flex;flex-direction:column;align-items:center;gap:6px;color:#06121e;
  background:linear-gradient(150deg,var(--c1),var(--c2));
  box-shadow:0 8px 0 rgba(0,0,0,.35),0 14px 28px rgba(0,0,0,.4);
  transition:transform .1s, box-shadow .1s;
}
.deck-card:active{transform:translateY(6px);box-shadow:0 2px 0 rgba(0,0,0,.35);}
.deck-card.wide{grid-column:1 / -1;flex-direction:row;justify-content:center;gap:14px;padding:16px;}
.deck-card.wide .deck-emoji{font-size:2.2rem;}
.deck-card.wide .deck-name{font-size:1.2rem;}
.deck-emoji{font-size:3rem;filter:drop-shadow(0 3px 4px rgba(0,0,0,.3));}
.deck-name{font-weight:900;font-size:1.25rem;color:#08121d;}
.deck-sub{font-weight:700;font-size:.9rem;color:rgba(8,18,29,.7);}


.mute-btn{position:fixed;bottom:16px;right:16px;font-size:1.4rem;background:rgba(255,255,255,.08);
  border:none;border-radius:50%;width:54px;height:54px;cursor:pointer;}
.voice-btn{position:fixed;bottom:16px;left:16px;font-family:inherit;font-weight:800;font-size:.95rem;color:#fff;
  background:linear-gradient(135deg,#7c5bff,#ff5bb0);border:none;border-radius:30px;padding:12px 18px;cursor:pointer;
  box-shadow:0 5px 0 #4a2a8a;}
.voice-btn:active{transform:translateY(3px);box-shadow:0 2px 0 #4a2a8a;}

/* voice picker overlay */
.overlay{position:fixed;inset:0;z-index:20;background:rgba(5,6,15,.82);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:20px;}
.overlay.show{display:flex;animation:fade .25s ease;}
.overlay-card{background:linear-gradient(160deg,#20204a,#15152e);border-radius:24px;padding:26px;max-width:420px;width:100%;
  text-align:center;box-shadow:0 20px 50px rgba(0,0,0,.6);box-shadow:inset 0 0 0 2px rgba(124,91,255,.4);}
.overlay-card h3{margin:0 0 4px;font-size:1.5rem;color:#fff;}
.overlay-sub{color:var(--muted);margin:0 0 18px;}
.voice-chips{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:22px;}
.voice-chip{font-family:inherit;font-weight:800;font-size:1rem;color:#0a0a14;border:none;border-radius:16px;
  padding:18px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;
  background:linear-gradient(150deg,#e9e9ff,#b9b9e6);box-shadow:0 5px 0 #6a6a9a;}
.voice-chip .vc-emoji{font-size:1.6rem;}
.voice-chip.sel{background:linear-gradient(150deg,#ffd23f,#ff8a3f);box-shadow:0 5px 0 #a85d12;}
.voice-chip:active{transform:translateY(3px);}

/* ---------- GAME ---------- */
.stage{position:relative;margin:18px 0 6px;display:flex;flex-direction:column;align-items:center;}
.turntable{width:150px;height:150px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,#222 0%,#0c0c12 70%);
  box-shadow:0 0 0 8px #1a1a2c,0 14px 40px rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;}
.platter{width:120px;height:120px;border-radius:50%;background:#08080d;display:flex;align-items:center;justify-content:center;}
.record{width:120px;height:120px;border-radius:50%;
  background:repeating-radial-gradient(circle,#1a1a22 0 3px,#101018 3px 6px);
  position:relative;}
.record::after{content:"💎";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem;}
.turntable.spin .record{animation:spin 1.1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}

.dj-bubble{margin-top:16px;background:#fff;color:#13132a;font-weight:800;font-size:1.15rem;
  padding:12px 22px;border-radius:20px;max-width:90vw;text-align:center;position:relative;
  box-shadow:0 8px 20px rgba(0,0,0,.4);min-height:1.4em;}
.dj-bubble::before{content:"";position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  border:10px solid transparent;border-bottom-color:#fff;border-top:0;}
.dj-bubble.cheer{background:var(--good);color:#04241b;animation:pop .4s ease;}
.dj-bubble.oops{background:#fff3c4;color:#5a4500;}
@keyframes pop{0%{transform:scale(.6)}60%{transform:scale(1.12)}100%{transform:scale(1)}}

.question-card{position:relative;margin:14px 0;background:linear-gradient(160deg,#20204a,#15152e);
  border:2px solid rgba(124,91,255,.4);border-radius:var(--radius);
  padding:22px 30px;min-width:min(86vw,420px);text-align:center;box-shadow:0 10px 30px rgba(0,0,0,.4);}
.read-btn{position:absolute;top:8px;right:10px;font-size:1.1rem;background:rgba(255,255,255,.1);
  border:none;border-radius:12px;width:40px;height:40px;cursor:pointer;}
.read-btn:active{transform:scale(.9);}
.concert-story{color:#cfd2ee;font-size:.95rem;margin-top:8px;max-width:90vw;font-style:italic;}
.q-text{font-size:2.4rem;font-weight:900;letter-spacing:1px;}
.q-text .blank{display:inline-block;min-width:1.4em;border-bottom:5px solid var(--gold);color:var(--gold);}
.q-coins{font-size:2.6rem;letter-spacing:4px;}

/* ---------- Australian currency ---------- */
.coin-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:center;margin-top:12px;}
/* ---- high-fidelity, sale-safe AU coins (size set inline via --cz) ---- */
.coin{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;
  width:var(--cz,52px);height:var(--cz,52px);overflow:hidden;
  box-shadow:inset 0 2px 4px rgba(255,255,255,.75), inset 0 -5px 9px rgba(0,0,0,.4),
    inset 0 0 0 3px rgba(0,0,0,.08), 0 4px 7px rgba(0,0,0,.5);
  /* milled edge: tiny repeating ticks around the rim */
  background-clip:padding-box;}
.coin::before{content:"";position:absolute;inset:0;border-radius:inherit;
  background:repeating-conic-gradient(rgba(0,0,0,.16) 0deg 3deg, transparent 3deg 6deg);opacity:.5;mix-blend-mode:multiply;}
.coin.silver{background:radial-gradient(circle at 36% 30%, #ffffff 0%, #dfe3ea 38%, #b3b8c4 64%, #888fa0 86%, #c2c6d0 100%);}
.coin.gold{background:radial-gradient(circle at 36% 30%, #fff6cf 0%, #f4d873 38%, #d9ad3e 66%, #b98a23 86%, #ead066 100%);}
.coin.twelve{border-radius:6px;
  clip-path:polygon(50% 0%,75% 6.7%,93.3% 25%,100% 50%,93.3% 75%,75% 93.3%,50% 100%,25% 93.3%,6.7% 75%,0% 50%,6.7% 25%,25% 6.7%);}
.coin-shine{position:absolute;top:6%;left:14%;width:46%;height:32%;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.85),transparent 70%);filter:blur(2px);pointer-events:none;}
.coin-motif{position:absolute;top:13%;font-size:calc(var(--cz,52px)*.34);line-height:1;
  filter:grayscale(1) contrast(.85);opacity:.5;mix-blend-mode:luminosity;}
.coin-val{position:relative;z-index:2;font-weight:900;font-size:calc(var(--cz,52px)*.30);
  color:#2a2d36;text-shadow:0 1px 0 rgba(255,255,255,.6),0 -1px 1px rgba(0,0,0,.3);margin-top:18%;}
.coin.gold .coin-val{color:#5a4410;}
.coin-au{position:absolute;bottom:7%;font-size:calc(var(--cz,52px)*.12);font-weight:800;letter-spacing:.5px;
  color:rgba(0,0,0,.4);text-transform:uppercase;}
.coin.twelve .coin-motif{top:18%;}

/* ---- photoreal coin images (sale-safe generated art; size via --cz) ---- */
.coin-img-wrap{position:relative;display:inline-flex;width:var(--cz,56px);height:var(--cz,56px);
  align-items:center;justify-content:center;filter:drop-shadow(0 4px 6px rgba(0,0,0,.55));}
.coin-img{width:100%;height:100%;object-fit:contain;-webkit-user-drag:none;user-select:none;}
.coin-img-wrap.coin-fallback::after{content:attr(data-l);position:absolute;inset:0;display:flex;
  align-items:center;justify-content:center;border-radius:50%;font-weight:900;color:#2a2d36;
  background:radial-gradient(circle at 36% 30%,#fff,#c2c6d0 88%);font-size:calc(var(--cz,56px)*.3);}

/* ---- polymer notes: real colours + window + denomination (sale-safe) ---- */
.note{position:relative;display:inline-flex;align-items:center;justify-content:center;width:96px;height:50px;border-radius:8px;
  overflow:hidden;box-shadow:inset 0 1px 2px rgba(255,255,255,.5), 0 4px 8px rgba(0,0,0,.5);border:1px solid rgba(0,0,0,.25);}
.note-val{position:relative;z-index:2;font-weight:900;font-size:1.35rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.6);}
.note-motif{position:absolute;right:8px;bottom:3px;font-size:1.1rem;opacity:.85;z-index:2;}
.note-au{position:absolute;left:7px;top:4px;font-size:.42rem;font-weight:800;letter-spacing:.5px;color:rgba(255,255,255,.85);text-transform:uppercase;z-index:2;}
.note-win{position:absolute;right:0;top:0;width:20px;height:100%;
  background:linear-gradient(180deg,rgba(255,255,255,.35),rgba(255,255,255,.08));border-left:1px solid rgba(255,255,255,.3);}
.note.n5{background:linear-gradient(135deg,#c08fd6,#7e4f9e);}
.note.n10{background:linear-gradient(135deg,#5aa9e0,#26619c);}
.note.n20{background:linear-gradient(135deg,#ef7d44,#bb3e16);}
.note.n50{background:linear-gradient(135deg,#f6ca1e,#c79100);}
.note.n50 .note-val{color:#4a3600;text-shadow:0 1px 1px rgba(255,255,255,.4);}
.note.n100{background:linear-gradient(135deg,#62cf8c,#2a8f56);}

.answer-pads{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:560px;margin:6px 0;}
.pad{
  font-family:inherit;font-weight:900;font-size:1.7rem;color:#0a0a14;
  min-width:var(--tap);min-height:var(--tap);padding:0 14px;border:none;border-radius:18px;cursor:pointer;
  background:linear-gradient(150deg,#e9e9ff,#b9b9e6);
  box-shadow:0 6px 0 #6a6a9a;transition:transform .07s, box-shadow .07s, background .2s;
}
.pad:active{transform:translateY(5px);box-shadow:0 1px 0 #6a6a9a;}
.pad.correct{background:linear-gradient(150deg,#5cf0c0,#23c79a);box-shadow:0 6px 0 #138a66;color:#04241b;}
/* Numero centre cards (playing-card look) */
.pad.numero-card{background:linear-gradient(160deg,#fffef5,#ffe9b8);box-shadow:0 6px 0 #b8923a;color:#3a2a00;
  border:2px solid #d4a843;position:relative;}
.pad.numero-card.picked{background:linear-gradient(160deg,#ffd23f,#ff9e3f);box-shadow:0 6px 0 #a85d12;transform:translateY(2px);outline:4px solid #fff;}
.pad.wrong{background:linear-gradient(150deg,#ffb3b3,#ff7a7a);box-shadow:0 6px 0 #b23b3b;animation:shake .3s;}
@keyframes shake{0%,100%{transform:none}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}

.mic-row{display:flex;align-items:center;gap:14px;margin:8px 0;}
.mic-btn{font-size:1.8rem;width:74px;height:74px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(150deg,#ff5bb0,#c4248a);box-shadow:0 8px 0 #8a1860,0 0 0 0 rgba(255,91,176,.6);
  transition:transform .08s;}
.mic-btn:active{transform:scale(.94);}
.mic-btn.listening{animation:pulse 1s ease-in-out infinite;}
@keyframes pulse{0%,100%{box-shadow:0 8px 0 #8a1860,0 0 0 0 rgba(255,91,176,.6)}
  50%{box-shadow:0 8px 0 #8a1860,0 0 0 22px rgba(255,91,176,0)}}
.mic-btn.off{filter:grayscale(1) brightness(.7);}
.mic-hint{color:var(--muted);font-size:.95rem;max-width:48vw;}

.drop-btn{
  font-family:inherit;font-weight:900;font-size:1.5rem;letter-spacing:1px;color:#fff;margin-top:6px;
  border:none;border-radius:var(--radius);padding:18px 40px;cursor:pointer;
  background:linear-gradient(135deg,#ffd23f,#ff7a3f);
  box-shadow:0 9px 0 #a85d12,0 14px 30px rgba(255,138,63,.5);transition:transform .08s,box-shadow .08s,opacity .2s;
}
.drop-btn:disabled{opacity:.35;filter:grayscale(.6);box-shadow:0 9px 0 #555;}
.drop-btn:not(:disabled):active{transform:translateY(7px);box-shadow:0 2px 0 #a85d12;}
.drop-btn.ready{animation:glow 1.2s infinite;}

/* ---------- WIN ---------- */
.win-card{margin:auto;text-align:center;display:flex;flex-direction:column;align-items:center;z-index:2;}
.win-crystal{font-size:5.5rem;filter:drop-shadow(0 0 30px var(--gold));animation:float 2.4s ease-in-out infinite;}
.win-title{font-size:2.8rem;margin:.1em 0;color:var(--gold);font-weight:900;letter-spacing:2px;}
.win-line{font-size:1.4rem;color:#fff;margin:.2em 0 1em;}
.win-crystals{font-size:2.4rem;letter-spacing:6px;margin-bottom:20px;min-height:1.4em;}

/* ---------- break button on game ---------- */
.break-btn{margin-top:12px;font-family:inherit;font-weight:800;font-size:1rem;color:#fff;
  background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.18);border-radius:16px;padding:12px 22px;cursor:pointer;}
.break-btn:active{transform:translateY(2px);}

/* ---------- CONCERT ---------- */
.concert-bg{position:fixed;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
/* dim the photo toward the top + bottom so the rank text & pads stay readable */
#screen-concert::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(8,6,20,.65) 0%,rgba(8,6,20,.1) 35%,rgba(8,6,20,.15) 60%,rgba(8,6,20,.8) 100%);}
.crowd-canvas{position:fixed;inset:0;z-index:1;pointer-events:none;}
.concert-ui{position:relative;z-index:2;margin:auto 0 0;width:100%;display:flex;flex-direction:column;align-items:center;
  padding-bottom:22px;gap:12px;}
.concert-banner{text-align:center;margin-top:auto;}
.concert-rank{font-size:3rem;font-weight:900;letter-spacing:2px;
  background:linear-gradient(90deg,var(--neon2),var(--gold),var(--neon));-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 30px rgba(255,210,63,.5);animation:pop .5s ease;}
.concert-venue{font-size:1.4rem;font-weight:800;color:#fff;}
.concert-crowd-label{color:var(--gold);font-weight:700;margin-top:2px;}
.dj-back{font-size:3.4rem;margin:6px 0;filter:drop-shadow(0 0 18px var(--neon2));animation:bopdj .5s ease-in-out infinite;}
@keyframes bopdj{50%{transform:translateY(-6px) rotate(-3deg)}}
.concert-pads,.break-pads{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;width:100%;max-width:440px;margin:4px auto;}
.beat-pad{font-family:inherit;font-weight:800;font-size:.8rem;color:#08121d;border:none;border-radius:16px;
  height:64px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  background:linear-gradient(150deg,#e9e9ff,#aeb0e6);box-shadow:0 5px 0 #6a6a9a;transition:transform .06s,box-shadow .06s,filter .1s;}
.beat-pad .pe{font-size:1.4rem;}
.beat-pad:active{transform:translateY(4px);box-shadow:0 1px 0 #6a6a9a;filter:brightness(1.2);}
.beat-pad.lit{filter:brightness(1.4) saturate(1.4);}

/* ---------- BREAK ROOM (DJ decks) ---------- */
#screen-break{justify-content:flex-start;}
.break-head{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:560px;margin-top:8px;}
.break-title{font-size:1.4rem;font-weight:900;color:var(--neon2);}
.break-timer{font-size:1.5rem;font-weight:900;color:var(--gold);font-variant-numeric:tabular-nums;
  background:rgba(255,210,63,.12);padding:4px 14px;border-radius:14px;}
.break-controls{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;width:100%;max-width:560px;margin:10px 0;}
.ctl-group{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;}
.ctl-btn{font-family:inherit;font-weight:800;font-size:.82rem;color:#cfd2ee;border:2px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);border-radius:14px;padding:9px 12px;cursor:pointer;}
.ctl-btn.on{color:#08121d;background:linear-gradient(150deg,var(--gold),#ff8a3f);border-color:transparent;box-shadow:0 0 14px rgba(255,210,63,.5);}
.ctl-btn:active{transform:translateY(2px);}
.sound-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;width:100%;max-width:560px;margin:4px auto;}
.rec-row{display:flex;gap:10px;margin:16px 0;flex-wrap:wrap;justify-content:center;}
.rec-btn,.rec-play,.rec-back{font-family:inherit;font-weight:800;font-size:.95rem;color:#fff;border:none;border-radius:16px;padding:13px 18px;cursor:pointer;}
.rec-btn{background:linear-gradient(150deg,#ff5bb0,#c4248a);box-shadow:0 6px 0 #8a1860;}
.rec-btn.recording{animation:pulse 1s infinite;}
.rec-play{background:linear-gradient(150deg,#33d6a6,#0f8a6a);box-shadow:0 6px 0 #0a5a44;}
.rec-play:disabled{opacity:.4;box-shadow:0 6px 0 #555;}
.rec-back{background:linear-gradient(135deg,#ffd23f,#ff7a3f);box-shadow:0 6px 0 #a85d12;color:#3a2400;}
.rec-btn:active,.rec-play:active,.rec-back:active{transform:translateY(3px);}

/* sound-grid pad colours by category (mirrors the multicolour VTech grid) */
.beat-pad.cat-drum{background:linear-gradient(150deg,#ff8a5b,#e0521a);color:#2a0f02;box-shadow:0 5px 0 #9c3a12;}
.beat-pad.cat-scr{background:linear-gradient(150deg,#b58cff,#7c3fd6);color:#fff;box-shadow:0 5px 0 #4a2a8a;}
.beat-pad.cat-fx{background:linear-gradient(150deg,#5bd6ff,#2a7fcc);color:#04202e;box-shadow:0 5px 0 #155a8a;}
.beat-pad.cat-tag{background:linear-gradient(150deg,#ff7ac4,#c4248a);color:#fff;box-shadow:0 5px 0 #8a1860;}

/* ---------- fx ---------- */
.fx-canvas{position:fixed;inset:0;pointer-events:none;z-index:1;}

/* ---------- responsive (phones / pubs) ---------- */
@media(max-width:720px){
  .home-body{flex-direction:column;align-items:center;}
  .ladder-board{width:100%;flex:none;max-width:520px;order:2;}
  .ladder-rungs{flex-direction:row;overflow-x:auto;gap:8px;-webkit-overflow-scrolling:touch;}
  .rung{flex:0 0 128px;}
  .rung .rung-prog{display:block;}
  .home-main{order:1;width:100%;}
}
@media(max-width:480px){
  .title-neon{font-size:2.7rem;}
  .q-text{font-size:2rem;}
  :root{--tap:72px;}
  .topbar{max-width:100%;}
  .deck-grid{max-width:100%;}
  .concert-rank{font-size:2.3rem;}
  .concert-pads,.break-pads{grid-template-columns:repeat(4,1fr);gap:8px;}
  .beat-pad{height:58px;font-size:.7rem;}
  .name-input{font-size:1.7rem;}
}
@media(max-height:680px) and (orientation:landscape){
  .turntable{width:96px;height:96px;}
  .platter,.record{width:76px;height:76px;}
}

/* ===================== READING MODULE ===================== */
/* word/phrase answer pads (comprehension, vocab) */
.pad.wordpad{
  font-size:1.05rem;font-weight:800;line-height:1.15;
  min-height:auto;padding:14px 16px;max-width:240px;white-space:normal;text-align:center;
  background:linear-gradient(150deg,#fdeaff,#e6c7ff);box-shadow:0 6px 0 #9a6abf;
}
.pad.wordpad.correct{background:linear-gradient(150deg,#5cf0c0,#23c79a);box-shadow:0 6px 0 #138a66;}
.pad.wordpad.wrong{background:linear-gradient(150deg,#ffb3b3,#ff7a7a);box-shadow:0 6px 0 #b23b3b;}

/* reading section header on home */
.reading-head{margin-top:18px;}
.reading-sub{font-size:.62em;font-weight:700;color:#9b8cff;opacity:.85;}

/* ---- passage reader screen ---- */
#screen-read{padding:0 16px 24px;overflow-y:auto;}
.read-focus{font-size:.85rem;font-weight:800;color:#9b8cff;background:rgba(155,91,255,.12);
  padding:6px 12px;border-radius:999px;}
.read-wrap{max-width:620px;margin:8px auto 0;display:flex;flex-direction:column;gap:14px;}
.read-title{font-size:1.7rem;font-weight:900;color:#fff;text-align:center;
  text-shadow:0 0 14px rgba(124,91,255,.6);margin:4px 0 0;}
.read-body{
  font-size:1.45rem;line-height:1.9;color:#f4f2ff;font-weight:600;
  background:linear-gradient(160deg,rgba(255,255,255,.07),rgba(255,255,255,.03));
  border:1px solid rgba(124,91,255,.3);border-radius:20px;padding:22px 24px;
  letter-spacing:.2px;
}
.read-actions{display:flex;flex-direction:column;gap:12px;align-items:center;margin-top:4px;}
.read-actions .ghost-btn{font-size:1.05rem;}

/* ---- find-the-evidence step ---- */
.evidence-wrap{max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:10px;}
.evidence-q{font-size:1.15rem;font-weight:800;color:#ffd23f;text-align:center;margin-bottom:4px;}
.ev-line{
  font-family:inherit;font-size:1.12rem;font-weight:600;line-height:1.45;color:#f4f2ff;text-align:left;
  background:linear-gradient(160deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
  border:2px solid rgba(124,91,255,.35);border-radius:14px;padding:12px 16px;cursor:pointer;
  transition:transform .07s, border-color .15s, background .2s;
}
.ev-line:active{transform:scale(.99);}
.ev-line.correct{background:linear-gradient(150deg,#1f7a5c,#23c79a);border-color:#5cf0c0;color:#fff;
  box-shadow:0 0 18px rgba(92,240,192,.5);}
.ev-line.wrong{border-color:#ff7a7a;background:rgba(255,122,122,.15);}

/* ===================== PROFILE PICKER ===================== */
.profile-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:4px 0 10px;}
.pc-label{width:100%;font-size:.85rem;color:#9b8cff;font-weight:700;margin-bottom:2px;}
.profile-chip{display:flex;flex-direction:column;align-items:center;gap:2px;
  background:linear-gradient(160deg,#2a2a4a,#1a1a32);border:2px solid #7c5bff;border-radius:14px;
  padding:8px 14px;cursor:pointer;color:#fff;font-family:inherit;min-width:72px;}
.profile-chip:active{transform:scale(.96);}
.pc-name{font-weight:900;font-size:1rem;}
.pc-gems{font-size:.72rem;color:#ffd23f;}

/* ===================== GRIT METER ===================== */
.grit-chip{background:linear-gradient(160deg,#6e4bd0,#9b6bff);color:#fff;font-weight:900;
  padding:6px 12px;border-radius:999px;font-size:1rem;box-shadow:0 0 12px rgba(155,107,255,.5);}
.grit-chip.pop{animation:gritpop .4s ease;}
@keyframes gritpop{0%{transform:scale(1);}40%{transform:scale(1.35);}100%{transform:scale(1);}}

/* ===================== MEASUREMENT + CLOCK ===================== */
.measure-strip{display:flex;align-items:center;gap:14px;justify-content:center;margin:14px 0;flex-wrap:wrap;}
.m-item{font-size:2.6rem;}
.m-units{font-size:1.9rem;letter-spacing:3px;line-height:1;}
.measure-vs{display:flex;align-items:center;gap:18px;justify-content:center;margin:14px 0;font-size:1.7rem;font-weight:900;color:#fff;}
.measure-vs .vs{font-size:1rem;color:#9b8cff;}
.clock-svg{display:block;margin:14px auto 4px;}
.clk-num{fill:#cfc7ff;font-size:13px;font-weight:800;text-anchor:middle;font-family:inherit;}

/* ===================== CATCH THE DJ ===================== */
.catch-head{font-size:1rem;font-weight:800;color:#ff8a8a;margin-bottom:6px;}
.catch-claim{margin-top:12px;font-size:1.15rem;color:#fff;background:rgba(255,77,77,.14);
  border:2px dashed #ff6b6b;border-radius:14px;padding:10px 14px;line-height:1.4;}
.catch-claim b{font-size:1.6rem;color:#ffd23f;display:inline-block;margin-top:2px;}
.pad.catch-judge{font-size:1.15rem;min-width:150px;padding:18px 16px;}
.pad.catch-judge.ok{background:linear-gradient(150deg,#5cf0c0,#23a079);box-shadow:0 6px 0 #138a66;color:#04241b;}
.pad.catch-judge.bad{background:linear-gradient(150deg,#ff9a6b,#ff4d4d);box-shadow:0 6px 0 #b01010;color:#2a0606;}

/* ===================== CRYSTALS (SVG) ===================== */
.cryst{display:block;margin:0 auto;}
.cryst.spin{transform-origin:50% 50%;animation:crystspin 6s linear infinite;}
.cryst.glow{filter:drop-shadow(0 0 16px rgba(255,255,255,.55));}
@keyframes crystspin{0%{transform:rotateY(0deg) scaleX(1);}25%{transform:scaleX(.25);}50%{transform:scaleX(-1);}75%{transform:scaleX(.25);}100%{transform:scaleX(1);}}
.cryst .glint{animation:glint 3s ease-in-out infinite;}
@keyframes glint{0%,70%{opacity:0;}80%{opacity:.85;}100%{opacity:0;}}

.won-crystal{margin-top:14px;display:flex;flex-direction:column;align-items:center;gap:4px;}
.wc-label{font-weight:900;color:#ffd23f;font-size:1.05rem;letter-spacing:.5px;}
.wc-name{font-weight:900;color:#fff;font-size:1.3rem;}
.wc-fact{font-size:.92rem;color:#d8d2ff;max-width:320px;line-height:1.4;}

.bank-btn{position:absolute;bottom:14px;left:14px;background:linear-gradient(160deg,#7c5bff,#33d6ff);
  color:#fff;border:none;border-radius:999px;padding:10px 16px;font-weight:900;font-family:inherit;cursor:pointer;
  box-shadow:0 4px 14px rgba(124,91,255,.5);font-size:.95rem;}
.parent-btn{position:absolute;bottom:14px;right:14px;background:rgba(255,255,255,.1);color:#fff;border:none;
  width:40px;height:40px;border-radius:50%;font-size:1.1rem;cursor:pointer;opacity:.5;}
.bank-title{font-weight:900;color:#fff;font-size:1.1rem;letter-spacing:.5px;}
.bank-count{font-weight:800;color:#ffd23f;}
.bank-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:12px;padding:16px;max-width:640px;margin:0 auto;width:100%;overflow-y:auto;}
.bank-cell{background:linear-gradient(160deg,#1c1c34,#12122a);border:2px solid #33335c;border-radius:16px;
  padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;font-family:inherit;}
.bank-cell.locked{opacity:.5;cursor:default;}
.bc-lock{font-size:2.4rem;filter:grayscale(1);}
.bc-name{font-size:.78rem;color:#cfc7ff;font-weight:700;}
.crystal-detail{padding:0 16px 24px;max-width:520px;margin:0 auto;text-align:center;}
.cd-hint{color:#9b8cff;font-weight:700;}
.cd-card{display:flex;flex-direction:column;align-items:center;gap:8px;background:rgba(124,91,255,.1);
  border:1px solid rgba(124,91,255,.3);border-radius:20px;padding:18px;}
.cd-name{font-size:1.5rem;font-weight:900;color:#fff;}
.cd-fact{font-size:1rem;color:#e6e2ff;line-height:1.5;}
.cd-where{font-size:.9rem;color:#ffd23f;font-weight:700;}

/* ===================== PARENT DASHBOARD ===================== */
.parent-wrap{padding:16px;max-width:560px;margin:0 auto;width:100%;overflow-y:auto;}
.pd-head{font-weight:900;color:#fff;font-size:1.05rem;margin-bottom:6px;}
.pd-note{font-size:.82rem;color:#9b8cff;background:rgba(124,91,255,.1);border-radius:12px;padding:10px 12px;margin-bottom:14px;line-height:1.4;}
.pd-h3{color:#ffd23f;font-size:.95rem;margin:14px 0 8px;}
.pd-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.pd-skill{flex:0 0 38%;font-size:.9rem;color:#e6e2ff;}
.pd-bar{flex:1;height:14px;background:#1c1c34;border-radius:999px;overflow:hidden;}
.pd-fill{display:block;height:100%;border-radius:999px;}
.pd-fill.good{background:linear-gradient(90deg,#33d6a6,#5cf0c0);}
.pd-fill.ok{background:linear-gradient(90deg,#ffd23f,#ffb03f);}
.pd-fill.low{background:linear-gradient(90deg,#ff7a7a,#ff4d4d);}
.pd-num{flex:0 0 auto;font-size:.85rem;color:#fff;font-weight:800;min-width:78px;text-align:right;}
.pd-num small{color:#9b8cff;font-weight:600;}
.pd-days{display:flex;flex-direction:column;gap:4px;}
.pd-day{display:flex;justify-content:space-between;font-size:.85rem;color:#cfc7ff;
  border-bottom:1px solid #26264a;padding:4px 0;}
.pd-empty{color:#777;font-size:.85rem;}

/* ===================== RETELL ===================== */
.retell-block{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:8px;}
.retell-q{font-size:1.15rem;font-weight:800;color:#ffd23f;text-align:center;line-height:1.4;}
.mic-btn.big{width:84px;height:84px;font-size:2.4rem;border-radius:50%;}
.retell-heard{min-height:24px;text-align:center;color:#e6e2ff;font-size:.95rem;}
.rt-quote{display:block;font-style:italic;color:#fff;margin-bottom:4px;}
.rt-praise{display:block;color:#33d6a6;font-weight:800;}

/* ===================== DJ HOOPS ===================== */
#screen-hoops{padding:0;overflow:hidden;}
.hoops-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;touch-action:none;}
.hoops-back{position:absolute;top:14px;right:14px;z-index:3;background:rgba(10,8,24,.66);color:#fff;
  border:none;border-radius:999px;padding:10px 18px;font-weight:900;font-family:inherit;font-size:1rem;cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,.5);backdrop-filter:blur(3px);}
.hoops-hint{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);text-align:center;color:#fff;font-size:.95rem;
  font-weight:800;z-index:3;pointer-events:none;background:rgba(10,8,24,.6);padding:9px 18px;border-radius:999px;
  backdrop-filter:blur(3px);box-shadow:0 4px 14px rgba(0,0,0,.5);max-width:90vw;}

/* ===================== SUNNY'S AFFIRMATIONS ===================== */
.affirm-btn{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  background:linear-gradient(160deg,#b15bff,#ff5bb0);color:#fff;border:none;border-radius:999px;
  padding:10px 18px;font-weight:900;font-family:inherit;cursor:pointer;font-size:.95rem;
  box-shadow:0 4px 16px rgba(177,91,255,.55);}
#screen-affirm{align-items:center;justify-content:center;text-align:center;}
.affirm-home{position:absolute;top:14px;left:14px;z-index:4;}
.affirm-card{position:relative;z-index:2;max-width:480px;padding:24px;display:flex;flex-direction:column;
  align-items:center;gap:18px;}
.affirm-head{font-size:1.1rem;font-weight:900;color:#ffb3e6;letter-spacing:.3px;}
.affirm-orb{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:3.4rem;background:radial-gradient(circle at 35% 30%,#c98bff,#7c2bd0);
  box-shadow:0 0 50px rgba(177,91,255,.7);animation:affirmpulse 3s ease-in-out infinite;}
@keyframes affirmpulse{0%,100%{transform:scale(1);}50%{transform:scale(1.06);}}
.affirm-text{font-size:1.5rem;line-height:1.5;font-weight:800;color:#fff;text-shadow:0 2px 14px rgba(177,91,255,.5);
  min-height:120px;display:flex;align-items:center;}
#screen-affirm .ghost-btn{font-size:1rem;}

/* ===================== DROP THE TRACK (homework) ===================== */
.homework-card{position:relative;animation:hwpulse 2.4s ease-in-out infinite;}
.homework-card::after{content:"NEW";position:absolute;top:-6px;right:-6px;background:#ff3b6b;color:#fff;
  font-size:.6rem;font-weight:900;padding:2px 7px;border-radius:999px;}
@keyframes hwpulse{0%,100%{box-shadow:0 6px 0 rgba(0,0,0,.2),0 0 0 rgba(255,210,63,.0);}50%{box-shadow:0 6px 0 rgba(0,0,0,.2),0 0 26px rgba(255,210,63,.6);}}
#screen-track{padding:0 16px 16px;}
#screen-track.active{display:flex;flex-direction:column;}
.track-title{font-weight:900;color:#fff;font-size:1.05rem;}
.track-shards{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin:10px 0;}
.shard{width:22px;height:22px;border-radius:5px;background:#23234a;border:1px solid #3a3a66;transform:rotate(45deg);
  transition:background .3s, box-shadow .3s;}
.shard.lit{background:linear-gradient(150deg,#ffd23f,#ff7a3f);box-shadow:0 0 12px rgba(255,210,63,.8);}
.track-stage{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center;}
.track-step{font-size:.95rem;font-weight:800;color:#ffd23f;letter-spacing:.5px;text-transform:uppercase;}
.track-line{font-size:2rem;line-height:1.5;font-weight:800;color:#fff;max-width:640px;
  text-shadow:0 2px 16px rgba(124,91,255,.5);padding:0 8px;}
.track-line.warm{font-size:3rem;color:#ffd23f;letter-spacing:1px;}
.track-actions{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin:10px 0;}
.track-hint{text-align:center;color:#cfc7ff;font-weight:700;font-size:1rem;min-height:24px;margin-bottom:6px;}

/* ===================== CALENDAR ===================== */
.cal-month{font-weight:900;color:#fff;font-size:1.1rem;min-width:150px;text-align:center;}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;max-width:520px;margin:6px auto 4px;width:100%;padding:0 10px;}
.cal-dow span{text-align:center;color:#9b8cff;font-weight:800;font-size:.72rem;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;max-width:520px;margin:0 auto;width:100%;padding:0 10px;}
.cal-cell{position:relative;aspect-ratio:1;border:none;border-radius:12px;background:#16162c;color:#cfc7ff;
  font-family:inherit;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:transform .07s, background .2s;}
.cal-cell:active{transform:scale(.94);}
.cal-cell.blank{background:transparent;pointer-events:none;}
.cal-cell .cal-d{font-size:.95rem;}
.cal-cell.played{background:linear-gradient(160deg,#2a1f4a,#1a2a3a);box-shadow:inset 0 0 0 2px rgba(255,210,63,.5);}
.cal-cell .cal-gem{position:absolute;bottom:3px;right:4px;font-size:.7rem;}
.cal-cell.today{box-shadow:0 0 0 3px #33d6ff;}

/* ===================== RECORDING STUDIO ===================== */
.studio-screen{overflow:hidden;}
.studio-screen.active{display:flex;flex-direction:column;}
.studio-bg{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 0%,#241a44 0%,#0c0a1c 60%,#05050f 100%);}
/* acoustic foam wall (pure CSS pyramids) */
.foam{position:absolute;inset:0;opacity:.5;
  background-image:
    linear-gradient(135deg,rgba(255,255,255,.04) 25%,transparent 25%),
    linear-gradient(225deg,rgba(255,255,255,.04) 25%,transparent 25%),
    linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 25%),
    linear-gradient(315deg,rgba(0,0,0,.25) 25%,transparent 25%);
  background-size:34px 34px;background-position:0 0,17px 0,17px -17px,0 17px;
  mask-image:linear-gradient(to bottom,#000,transparent 70%);}
.studio-glow{position:absolute;left:50%;top:8%;width:380px;height:380px;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(124,91,255,.35),transparent 65%);filter:blur(6px);
  animation:studiohue 8s linear infinite;}
@keyframes studiohue{0%{filter:blur(6px) hue-rotate(0deg);}100%{filter:blur(6px) hue-rotate(360deg);}}
.monitor{position:absolute;top:30%;width:74px;height:104px;border-radius:10px;
  background:linear-gradient(160deg,#1c1c2c,#0e0e18);border:1px solid #2c2c42;box-shadow:0 0 24px rgba(0,0,0,.5);}
.monitor::before{content:"";position:absolute;left:50%;top:34px;transform:translateX(-50%);width:44px;height:44px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,#3a3a55,#0a0a12 70%);box-shadow:inset 0 0 0 3px #14141f;}
.monitor::after{content:"";position:absolute;left:50%;top:14px;transform:translateX(-50%);width:18px;height:12px;border-radius:50%;
  background:radial-gradient(circle,#33d6ff,#0a0a12 70%);opacity:.7;}
.monitor.ml{left:10px;transform:perspective(300px) rotateY(18deg);}
.monitor.mr{right:10px;transform:perspective(300px) rotateY(-18deg);}
@media(max-width:520px){.monitor{display:none;}}

.onair{position:relative;z-index:2;align-self:center;margin-top:4px;font-weight:900;letter-spacing:1.5px;font-size:.8rem;
  color:#6a6a80;border:2px solid #6a6a80;border-radius:8px;padding:4px 12px;background:rgba(0,0,0,.3);transition:all .25s;}
.onair.live{color:#fff;border-color:#ff3b3b;background:#7a0d0d;box-shadow:0 0 18px rgba(255,59,59,.8);animation:onairblink 1s steps(2) infinite;}
@keyframes onairblink{50%{opacity:.65;}}

.studio-mic{position:relative;z-index:1;align-self:center;width:140px;height:210px;margin:2px auto 0;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.6));transform:scale(var(--mic-pulse,1));transition:transform .08s;}
.studio-mic.small{width:84px;height:126px;}
.studio-mic .mic-svg{width:100%;height:100%;}
.studio-mic .mic-halo{opacity:.25;transition:opacity .2s;}
.studio-mic.live .mic-halo{opacity:.85;}
.studio-scope{position:relative;z-index:1;width:min(560px,92%);height:70px;margin:6px auto 0;display:block;
  background:rgba(0,0,0,.35);border:1px solid rgba(51,214,255,.25);border-radius:12px;}
.studio-scope.mix{height:60px;flex:1;margin:0 8px;}

/* mixing console */
.mix-console{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:10px;
  width:min(620px,96%);margin:8px auto 0;padding:14px;border-radius:18px;
  background:linear-gradient(160deg,rgba(30,30,52,.85),rgba(16,16,30,.85));border:1px solid #33335c;
  box-shadow:0 -2px 30px rgba(124,91,255,.25),inset 0 1px 0 rgba(255,255,255,.06);}
.mix-label{font-size:.8rem;font-weight:800;color:#9b8cff;letter-spacing:.5px;text-transform:uppercase;}
.vinyl-row{display:flex;align-items:center;gap:10px;width:100%;}
.vinyl{width:56px;height:56px;border-radius:50%;flex:0 0 auto;
  background:repeating-radial-gradient(circle at 50% 50%,#1a1a1a 0 2px,#222 2px 4px);
  box-shadow:0 0 0 3px #0a0a0a,0 0 14px rgba(0,0,0,.6);position:relative;}
.vinyl::after{content:"";position:absolute;inset:38%;border-radius:50%;background:radial-gradient(circle,#ff5b8c,#7c5bff);}
.track-title{position:relative;z-index:2;}

/* studio ENTRANCE — the "woah" reveal when the booth appears */
.studio-screen.active .studio-mic{animation:micrise .8s cubic-bezier(.2,.8,.2,1);}
@keyframes micrise{0%{transform:translateY(40px) scale(.7);opacity:0;}60%{opacity:1;}100%{transform:translateY(0) scale(var(--mic-pulse,1));opacity:1;}}
.studio-screen.active .onair{animation:onairon 1.1s ease;}
@keyframes onairon{0%,20%{opacity:0;}25%,35%,55%{opacity:1;}30%,45%{opacity:.2;}100%{opacity:1;}}
.studio-screen.active .monitor{animation:monin .9s ease;}
@keyframes monin{0%{opacity:0;}100%{opacity:1;}}
.studio-screen.active .studio-glow{animation:glowin 1.2s ease, studiohue 8s linear infinite;}
@keyframes glowin{0%{opacity:0;transform:translateX(-50%) scale(.6);}100%{opacity:1;transform:translateX(-50%) scale(1);}}

/* ===================== CALENDAR v2 (phenomenal) ===================== */
.cal-banner{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:8px auto 2px;max-width:520px;width:100%;padding:0 10px;}
.cb-item{background:linear-gradient(160deg,rgba(124,91,255,.18),rgba(124,91,255,.06));border:1px solid rgba(124,91,255,.35);
  border-radius:999px;padding:5px 12px;font-size:.82rem;color:#d8d2ff;font-weight:700;}
.cb-item b{color:#ffd23f;font-size:1rem;}
.cal-cell.played{background:linear-gradient(160deg,#2a1f55,#16243f);box-shadow:inset 0 0 0 2px rgba(255,210,63,.55),0 0 12px rgba(255,210,63,.18);}
.cal-cell.played .cal-gem{filter:drop-shadow(0 0 4px rgba(255,210,63,.9));animation:gemfloat 3s ease-in-out infinite;animation-delay:calc(var(--gd,0)*-3s);}
@keyframes gemfloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-2px);}}
.cal-cell .cal-cnt{position:absolute;top:2px;right:4px;font-size:.6rem;font-weight:900;color:#ffd23f;background:rgba(0,0,0,.4);border-radius:8px;padding:0 4px;}
.cal-cell.sel{transform:scale(1.06);box-shadow:0 0 0 3px #ffd23f,0 0 16px rgba(255,210,63,.6);z-index:2;}
.cal-cell.today{box-shadow:0 0 0 3px #33d6ff,0 0 14px rgba(51,214,255,.5);animation:todaypulse 2s ease-in-out infinite;}
.cal-cell.today.played{box-shadow:0 0 0 3px #33d6ff,inset 0 0 0 2px rgba(255,210,63,.55);}
@keyframes todaypulse{0%,100%{box-shadow:0 0 0 3px #33d6ff,0 0 8px rgba(51,214,255,.4);}50%{box-shadow:0 0 0 3px #33d6ff,0 0 20px rgba(51,214,255,.8);}}

.cal-caption-wrap{max-width:540px;margin:14px auto 0;width:100%;padding:0 16px;display:flex;flex-direction:column;align-items:center;gap:8px;}
.cal-caption{text-align:center;font-size:1.4rem;line-height:1.7;font-weight:700;color:#cfc7ff;min-height:60px;}
.cal-caption .kw{transition:color .12s, text-shadow .12s, transform .12s;border-radius:6px;padding:0 1px;}
.cal-caption .kw.on{color:#fff;background:linear-gradient(120deg,#ffd23f,#ff9e3f);-webkit-background-clip:text;background-clip:text;
  color:transparent;text-shadow:0 0 18px rgba(255,210,63,.55);transform:scale(1.12);font-weight:900;}
@supports not (background-clip:text){.cal-caption .kw.on{color:#ffd23f;}}

/* Crystal Trail journey overlay */
.cal-grid-wrap{position:relative;max-width:520px;margin:0 auto;width:100%;}
.cal-trail{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;}
.cal-grid-wrap .cal-grid{position:relative;z-index:1;max-width:none;margin:0;padding:0 10px;}
.cal-cap-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.cal-cap-btns .ghost-btn{margin-top:0;}

/* ===================== MY TRACKS library ===================== */
.tracks-list{width:100%;max-width:560px;margin:10px auto 0;display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding:0 12px;}
.tracks-empty{text-align:center;color:#9b8cff;font-weight:700;padding:40px 16px;line-height:1.6;}
.track-row{display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:linear-gradient(160deg,rgba(124,91,255,.14),rgba(124,91,255,.05));
  border:1px solid rgba(124,91,255,.3);border-radius:16px;padding:12px 14px;}
.tr-title{font-weight:900;color:#fff;font-size:1.05rem;}
.tr-date{font-size:.78rem;color:#9b8cff;margin-top:2px;}
.tr-btns{display:flex;gap:8px;flex:0 0 auto;}
.tr-btn{width:44px;height:44px;border-radius:12px;border:none;cursor:pointer;font-family:inherit;font-size:1.1rem;
  background:rgba(255,255,255,.1);color:#fff;}
.tr-btn.play{background:linear-gradient(150deg,#33d6a6,#23a079);color:#04241b;font-weight:900;}
.tr-btn:active{transform:scale(.92);}

/* parent-dashboard sync setup */
.pd-sync{display:flex;flex-direction:column;gap:8px;margin-top:6px;}
.pd-input{font-family:inherit;font-size:.9rem;padding:10px 12px;border-radius:10px;border:1px solid #3a3a66;
  background:rgba(255,255,255,.05);color:#fff;outline:none;}
.pd-input:focus{border-color:#7c5bff;}
.pd-sync-btns{display:flex;gap:14px;}
.pd-sync-btns .ghost-btn{margin-top:0;}

/* ===================== NUMBER SENSE visuals ===================== */
.numviz{margin:12px auto 2px;display:flex;justify-content:center;}
.numviz.teach{margin-top:10px;animation:vizpop .4s ease;}
@keyframes vizpop{0%{transform:scale(.8);opacity:0;}100%{transform:scale(1);opacity:1;}}
/* ten-frame (DJ beat-pad grid) */
.tf-wrap{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;}
.tenframe{display:grid;grid-template-columns:repeat(5,1fr);grid-auto-rows:1fr;gap:5px;
  padding:7px;background:rgba(0,0,0,.3);border-radius:12px;border:2px solid #3a3a66;}
.tf-cell{width:30px;height:30px;border-radius:7px;background:#15152a;box-shadow:inset 0 0 0 2px #2a2a4a;}
.tf-cell.on{background:radial-gradient(circle at 35% 30%,#ffe890,#ffb43f);box-shadow:0 0 8px rgba(255,210,63,.6);}
.tf-cell.empty{background:#15152a;box-shadow:inset 0 0 0 2px #4a4a7a;}
.tf-cell.ans{background:radial-gradient(circle at 35% 30%,#7df0c8,#33d6a6);box-shadow:0 0 12px rgba(51,214,166,.8);animation:ansglow 1s ease-in-out infinite;}
.tf-cell.off{opacity:.12;}
@keyframes ansglow{50%{transform:scale(1.08);}}
.tenframe.subitise{grid-template-columns:repeat(5,1fr);}
.tenframe.subitise .tf-cell{border-radius:50%;}
.tenframe.subitise .tf-cell.on{background:radial-gradient(circle at 35% 30%,#c9a7ff,#7c5bff);box-shadow:0 0 8px rgba(124,91,255,.6);}
/* number line */
.numline{max-width:100%;height:auto;}
.nl-num{font-family:inherit;font-weight:900;font-size:14px;text-anchor:middle;}
.nl-hop{font-family:inherit;font-weight:900;font-size:14px;text-anchor:middle;}

/* generative ten-frame: tappable empty seats */
.tf-cell.build{cursor:pointer;background:#15152a;box-shadow:inset 0 0 0 2px #5a5f8a;
  animation:buildpulse 1.3s ease-in-out infinite;padding:0;border:none;}
.tf-cell.build:active{transform:scale(.9);}
@keyframes buildpulse{50%{box-shadow:inset 0 0 0 2px #9b8cff,0 0 8px rgba(124,91,255,.5);}}
.tf-cell.just{animation:tfpop .3s ease;}
@keyframes tfpop{0%{transform:scale(.5);}60%{transform:scale(1.2);}100%{transform:scale(1);}}
.build-hint{font-size:.95rem;font-weight:800;color:#ffd23f;text-align:center;margin-bottom:6px;}
/* "Show me" hint button */
.hint-btn{font-family:inherit;font-weight:800;font-size:.95rem;color:#0a0a14;border:none;border-radius:30px;
  padding:10px 16px;cursor:pointer;background:linear-gradient(150deg,#ffe890,#ffb43f);box-shadow:0 4px 0 #b8801a;}
.hint-btn:active{transform:translateY(3px);box-shadow:0 1px 0 #b8801a;}

/* ===================== HOME: scrollable + docked controls (fix bottom cutoff) ===================== */
#screen-home{overflow-y:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start;padding-bottom:80px;}
.home-dock{position:fixed;left:0;right:0;bottom:0;z-index:15;display:flex;justify-content:center;gap:8px;flex-wrap:wrap;
  padding:9px 10px;background:linear-gradient(0deg,rgba(8,8,16,.97) 55%,rgba(8,8,16,.4) 85%,transparent);}
.dock-btn{font-family:inherit;font-weight:800;font-size:.9rem;color:#fff;border:none;border-radius:24px;padding:11px 15px;cursor:pointer;
  background:linear-gradient(150deg,#7c5bff,#5a2ad0);box-shadow:0 3px 0 #3a1f8a;white-space:nowrap;}
.dock-btn:active{transform:translateY(2px);box-shadow:0 1px 0 #3a1f8a;}
.dock-btn.parent{background:rgba(255,255,255,.12);box-shadow:none;opacity:.65;}
/* phone: stack ladder above decks so the deck grid gets full width + everything reachable by scroll */
@media(max-width:600px){
  #screen-home{padding:12px 12px 84px;}
  .home-body{flex-direction:column;align-items:stretch;gap:12px;margin-top:10px;}
  .ladder-board{width:100%;flex:none;}
  .ladder-rungs{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;gap:8px;padding-bottom:4px;}
  .rung{flex:0 0 130px;}
  .rung .rung-prog{display:none;}
  .deck-grid{max-width:none;}
}

/* ===================== real generated crystal images (spin on axis + glisten) ===================== */
.cryst-img-wrap{position:relative;display:inline-block;perspective:600px;}
.cryst-img{width:100%;height:100%;object-fit:contain;mix-blend-mode:screen;
  filter:drop-shadow(0 0 14px rgba(255,255,255,.35));transform-style:preserve-3d;}
.cryst-img-wrap.spin .cryst-img{animation:crystturn 6s linear infinite;}
.cryst-img-wrap.glow .cryst-img{filter:drop-shadow(0 0 24px rgba(255,255,255,.6));}
@keyframes crystturn{0%{transform:rotateY(0deg);}50%{transform:rotateY(180deg);}100%{transform:rotateY(360deg);}}
.cryst-img-wrap .cryst-shine{position:absolute;inset:0;pointer-events:none;border-radius:50%;
  background:radial-gradient(circle at 35% 28%,rgba(255,255,255,.5),transparent 45%);
  mix-blend-mode:screen;animation:crystshine 3s ease-in-out infinite;}
@keyframes crystshine{0%,70%{opacity:.15;}82%{opacity:.7;}100%{opacity:.15;}}

/* ===================== GARAGE (pick your old-school car) ===================== */
#screen-garage{overflow-y:auto;}
.garage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;
  max-width:680px;margin:10px auto 0;width:100%;padding:0 12px 24px;}
.garage-card{background:linear-gradient(160deg,#1a1a30,#101020);border:2px solid #33335c;border-radius:18px;
  padding:8px;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:4px;
  transition:transform .1s, border-color .2s;}
.garage-card:active{transform:scale(.96);}
.garage-card.sel{border-color:#ffd23f;box-shadow:0 0 18px rgba(255,210,63,.5);}
.garage-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;mix-blend-mode:screen;}
.garage-name{font-weight:800;font-size:.8rem;color:#fff;text-align:center;}

/* ===================== vision-panel visual fixes ===================== */
/* Numero card was colliding with the dock — give the home real clearance + a solid dock */
#screen-home{padding-bottom:96px;}
.home-dock{background:#0a0a16;box-shadow:0 -8px 20px rgba(0,0,0,.6);border-top:1px solid rgba(124,91,255,.25);}
/* deck subtitles: bigger + higher contrast (panel: too faint) */
.deck-sub{font-size:.95rem;color:rgba(6,14,22,.82);font-weight:800;}
.deck-card.wide{padding:18px 16px;}
.deck-card.wide .deck-sub{text-align:center;}
/* friendlier headline */
.pick-title{font-weight:800;letter-spacing:.3px;}

/* ===================== FULL vision-audit polish pass ===================== */
/* #1 COHESION: every deck icon gets the same glossy glass medallion → one visual language */
.deck-emoji{width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:2.1rem;
  border-radius:50%;background:radial-gradient(circle at 36% 30%,rgba(255,255,255,.55),rgba(255,255,255,.08) 55%,rgba(0,0,0,.22));
  box-shadow:inset 0 2px 4px rgba(255,255,255,.5),inset 0 -4px 8px rgba(0,0,0,.25),0 3px 8px rgba(0,0,0,.3);}
.deck-card.wide .deck-emoji{width:52px;height:52px;font-size:1.8rem;}
.homework-card .deck-emoji{background:radial-gradient(circle at 36% 30%,rgba(255,255,255,.6),rgba(255,255,255,.1) 55%,rgba(0,0,0,.2));}
/* #2 CONTRAST: instructions + day numbers + subtitles */
.login-prompt{color:#cfd2ee;}
.name-input{color:#fff;}
.cal-cell .cal-d{color:#eef0ff;font-weight:900;}
.cal-cell.played .cal-d{color:#fff;}
/* #4 MIC button → match the purple palette (was clashing pink) + bigger tap */
.mic-btn{background:linear-gradient(150deg,#9b6bff,#6a3ad0)!important;}
/* #3 reduce the turntable/stage vertical weight so the actual question sits higher */
.stage{margin:2px 0;}
.turntable{width:84px;height:84px;}
.platter,.record{width:66px;height:66px;}
.dj-bubble{font-size:1rem;padding:8px 14px;}
/* #5 PADDING: question/answer cards breathe */
.question-card{padding:18px 18px 16px;}
.answer-pads{gap:14px;}
/* word answers → tidy 2-col grid (fixes the "orphan button" look) */
.answer-pads:has(.wordpad){display:grid;grid-template-columns:1fr 1fr;max-width:420px;}
.pad.wordpad{width:100%;max-width:none;}
/* #6 CATCH-THE-DJ: solid framed claim, not a debug-looking dashed box */
.catch-claim{border-style:solid;border-width:2px;background:rgba(255,77,77,.12);}
.catch-head{font-size:1.15rem;}
/* #8 RECORDING STUDIO: bolder ON-AIR + the scope reads as a real meter */
.onair{font-size:1rem;padding:6px 16px;border-width:3px;}
.studio-scope{border:2px solid rgba(51,214,255,.4);box-shadow:inset 0 0 18px rgba(51,214,255,.12);height:76px;}
/* #9 STORY reader: center it, lift the focus pill into the header */
.read-wrap{margin:auto 0;justify-content:center;}
.read-focus{font-size:.8rem;}
/* #11 BANK: faint glow behind dark gems so obsidian/garnet read on the dark cell */
.bank-cell{background:radial-gradient(circle at 50% 42%,rgba(124,91,255,.16),#12122a 70%);}
.bank-cell .cryst-img{filter:drop-shadow(0 0 10px rgba(255,255,255,.4));}
/* #4 unify big-button corner radius + the dock */
.tr-btn,.ctl-btn{border-radius:14px;}

/* ===================== parent dashboard brand polish ===================== */
.parent-wrap{background:linear-gradient(160deg,rgba(124,91,255,.06),rgba(0,0,0,0));border-radius:20px;}
.pd-head{background:linear-gradient(150deg,#2a2a4a,#1a1a32);border-radius:14px;padding:12px 14px;
  box-shadow:inset 0 0 0 1px rgba(124,91,255,.25);}
.pd-h3{border-bottom:1px solid rgba(124,91,255,.2);padding-bottom:4px;}
.pd-row{background:rgba(255,255,255,.03);border-radius:10px;padding:6px 8px;}
.pd-day{padding:6px 8px;border-radius:8px;}
.pd-input{border-radius:12px;}
.pd-empty{font-style:italic;}
cd ~/sunny-maths/js && node --check main.js && echo "syntax ok"
/* ===================== bespoke deck icons (self-contained glossy tiles) ===================== */
.deck-emoji.has-icon{background:none;box-shadow:none;width:74px;height:74px;}
.deck-card.wide .deck-emoji.has-icon{width:58px;height:58px;}
.deck-icon{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 9px rgba(0,0,0,.45));}

/* ===================== re-review fixes: answer grid + typography ===================== */
/* number answers in a tidy 2-col grid too (was a cramped single row) — numero stays flexible */
.answer-pads{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:360px;justify-items:center;align-items:center;}
.answer-pads:has(.numero-card){display:flex;flex-wrap:wrap;justify-content:center;max-width:560px;}
.answer-pads .pad{width:100%;max-width:160px;}
.answer-pads .numero-card{width:auto;}
/* premium typography to match the icons */
.deck-name{font-size:1.35rem;font-weight:800;letter-spacing:.2px;}
.deck-card.wide .deck-name{font-size:1.25rem;}
.pick-title{font-size:1.8rem;font-weight:800;}

/* ===================== nav + dock neon-glass icons ===================== */
.icon-btn .navi{width:38px;height:38px;object-fit:contain;}
.dock-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;}
.dock-btn .navi{width:27px;height:27px;object-fit:contain;}
.dock-btn.parent{padding:7px 9px;}
.dock-btn.parent .navi{width:25px;height:25px;}
.dock-label{font-weight:800;font-size:.85rem;}

/* ===================== final fixes: never clip a CTA (vision panel #1) ===================== */
/* guarantee the primary buttons are always reachable on any phone height */
#screen-game{overflow-y:auto;padding-bottom:14px;}
#screen-track{overflow-y:auto;padding-bottom:16px;}
#screen-mytrack{overflow-y:auto;padding-bottom:16px;}
/* the hero mic was 210px tall and pushed the studio DONE button off-screen + left dead space */
.studio-mic{width:128px;height:172px;}
.studio-scope{height:62px;}
.track-stage{flex:initial;gap:10px;margin:8px 0;min-height:90px;justify-content:flex-start;}
.track-actions{margin-top:6px;}
.mic-row{margin:6px 0;}
.break-btn{margin:8px 0 6px;}

/* ===== claw back vertical space so the DROP button (primary CTA) fits without scrolling ===== */
#screen-game .stage{margin:2px 0 0;}
#screen-game .dj-bubble{margin-top:8px;}
#screen-game .question-card{margin:8px 0 6px;padding:14px 18px 12px;}
#screen-game .answer-pads{margin:4px 0;}
#screen-game .mic-row{margin:4px 0;}
#screen-game .drop-btn{padding:13px 38px;margin-top:2px;font-size:1.35rem;}
#screen-game .break-btn{margin:6px 0 2px;}
.tf-wrap{gap:10px;}
.tf-cell{width:26px;height:26px;}

/* ===== structural CTA guarantee: question card scrolls internally; answer pads + DROP always pinned/visible ===== */
#screen-game{overflow:hidden;padding-bottom:10px;}
#screen-game .topbar{flex:0 0 auto;}
#screen-game .stage{flex:0 0 auto;}
#screen-game #question-card{flex:0 1 auto;min-height:0;overflow-y:auto;}
#screen-game #answer-pads,
#screen-game .mic-row,
#screen-game #btn-drop,
#screen-game #btn-break{flex:0 0 auto;}

#screen-game{padding:14px 14px 6px;}
#screen-game #btn-break{padding:8px 18px;font-size:.95rem;}

/* ===== integrate photoreal gems into the glass system: fade the photo's square edges to nothing ===== */
.cryst-img{
  -webkit-mask:radial-gradient(circle at 50% 47%, #000 54%, rgba(0,0,0,.45) 68%, transparent 80%);
          mask:radial-gradient(circle at 50% 47%, #000 54%, rgba(0,0,0,.45) 68%, transparent 80%);
}
.bank-cell{background:radial-gradient(circle at 50% 40%,rgba(124,91,255,.22),#141430 72%);
  box-shadow:inset 0 0 22px rgba(0,0,0,.45),0 6px 18px rgba(0,0,0,.35);}
.bank-cell .cryst-img-wrap::after{content:"";position:absolute;left:50%;bottom:4px;transform:translateX(-50%);
  width:54%;height:10px;border-radius:50%;background:radial-gradient(ellipse,rgba(124,91,255,.5),transparent 70%);filter:blur(2px);}

/* ===== studio: fill the dead space — the line-to-read centers in the available space, DONE pinned below ===== */
#screen-track{justify-content:flex-start;}
#screen-track .track-stage{flex:1 1 auto;display:flex;flex-direction:column;justify-content:center;gap:12px;min-height:120px;}
#screen-track .track-actions{flex:0 0 auto;}
#screen-track .track-hint{flex:0 0 auto;}

/* ===== fix: the question card holds the QUESTION (coins/ten-frame) — it must never clip.
   Make the decorative stage/turntable the shrinkable element; screen scrolls as last resort. ===== */
#screen-game{overflow-y:auto;}
#screen-game .stage{flex:0 1 auto;min-height:0;overflow:hidden;}
#screen-game #question-card{flex:0 0 auto;overflow:visible;}

/* ===================== MY GARAGE — collect-to-unlock car showroom ===================== */
/* home hero banner: his current ride + progress to the next car (always-visible carrot) */
.garage-hero{display:flex;align-items:center;gap:14px;width:100%;max-width:560px;margin:0 auto 14px;
  background:linear-gradient(120deg,#1c1438,#241a44 60%,#15264a);border:2px solid #3a3a66;border-radius:20px;
  padding:10px 14px;cursor:pointer;font-family:inherit;color:#fff;text-align:left;
  box-shadow:0 8px 22px rgba(0,0,0,.4),inset 0 0 24px rgba(124,91,255,.14);transition:transform .1s,border-color .2s;}
.garage-hero:active{transform:scale(.98);}
.garage-hero:hover{border-color:#7c5bff;}
.garage-hero-stage{flex:0 0 96px;height:62px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 50% 60%,rgba(124,91,255,.35),transparent 70%);border-radius:12px;}
.garage-hero-car{width:96px;height:58px;object-fit:contain;mix-blend-mode:screen;filter:drop-shadow(0 3px 6px rgba(0,0,0,.6));}
.garage-hero-txt{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0;}
.garage-hero-title{font-weight:900;font-size:1.05rem;letter-spacing:.5px;}
.garage-hero-sub{font-size:.82rem;color:#c9bcff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.garage-hero-sub b{color:#ffd23f;}
.garage-hero-bar{display:block;height:8px;border-radius:6px;background:rgba(255,255,255,.12);overflow:hidden;}
.garage-hero-bar span{display:block;height:100%;width:0;border-radius:6px;
  background:linear-gradient(90deg,#33d6ff,#7c5bff,#ffd23f);transition:width .6s ease;}
.garage-hero-count{flex:0 0 auto;font-weight:900;font-size:.85rem;color:#9b8cff;
  background:rgba(124,91,255,.18);padding:5px 10px;border-radius:30px;}

/* showroom progress header */
.garage-head{max-width:680px;margin:6px auto 0;width:100%;padding:0 14px;text-align:center;}
.gh-count{font-weight:900;color:#9b8cff;font-size:.9rem;}
.gh-next{font-size:1.05rem;color:#fff;margin:4px 0 8px;} .gh-next b{color:#ffd23f;}
.gh-bar{height:12px;border-radius:8px;background:rgba(255,255,255,.12);overflow:hidden;max-width:420px;margin:0 auto;}
.gh-bar span{display:block;height:100%;width:0;border-radius:8px;background:linear-gradient(90deg,#33d6ff,#7c5bff,#ffd23f);
  box-shadow:0 0 12px rgba(124,91,255,.7);transition:width .7s ease;}

/* tier accents */
.garage-card.tier-common{border-color:#3a8f6a;} .garage-card.tier-rare{border-color:#3a6bd0;}
.garage-card.tier-epic{border-color:#a04bd0;} .garage-card.tier-legend{border-color:#e0a93a;
  box-shadow:0 0 18px rgba(224,169,58,.35);background:linear-gradient(160deg,#2a2030,#171022);}
.garage-tier{font-size:.62rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#9b8cff;}
.garage-card.tier-legend .garage-tier{color:#ffd23f;}
.garage-sel-badge{font-size:.6rem;font-weight:900;color:#04241b;background:#33d6a6;border-radius:20px;padding:2px 8px;letter-spacing:.5px;}

/* LOCKED car: teased silhouette + price + progress (never hidden, never "failure") */
.garage-card.locked{cursor:pointer;border-color:#2a2a4a;background:linear-gradient(160deg,#15152a,#0d0d18);}
.garage-card.locked .locked-img{filter:brightness(.04) contrast(.6);opacity:.85;mix-blend-mode:normal;}
.garage-card.locked .garage-lock{position:absolute;top:50%;left:50%;transform:translate(-50%,-90%);font-size:1.7rem;
  filter:drop-shadow(0 2px 4px #000);}
.garage-card{position:relative;}
.garage-name.locked{color:#8a8ab0;}
.garage-cost{font-weight:900;font-size:.85rem;color:#ffd23f;}
.garage-mini-bar{display:block;width:80%;height:6px;border-radius:5px;background:rgba(255,255,255,.1);overflow:hidden;}
.garage-mini-bar span{display:block;height:100%;width:0;border-radius:5px;background:linear-gradient(90deg,#7c5bff,#ffd23f);}
@keyframes carnudge{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.garage-card.nudge{animation:carnudge .35s ease;}

.garage-toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%) translateY(20px);
  background:#241a44;border:2px solid #7c5bff;color:#fff;font-weight:800;padding:12px 20px;border-radius:30px;
  box-shadow:0 8px 24px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;z-index:40;max-width:88vw;text-align:center;}
.garage-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.garage-race-btn{position:sticky;bottom:14px;margin:6px auto 14px;display:block;}

/* unlock celebration overlay */
.car-unlock{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;
  background:rgba(8,6,20,.86);backdrop-filter:blur(6px);padding:20px;}
.car-unlock.show{display:flex;animation:fade .3s ease;}
.cu-card{text-align:center;max-width:460px;width:100%;display:flex;flex-direction:column;align-items:center;gap:8px;}
.cu-burst{font-size:2.4rem;animation:gritpop .6s ease;}
.cu-label{font-weight:900;font-size:1.6rem;letter-spacing:1px;color:#ffd23f;text-shadow:0 0 16px rgba(255,210,63,.6);}
.cu-stage{width:min(360px,80vw);height:200px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 50% 60%,rgba(124,91,255,.4),transparent 72%);}
.cu-car{width:100%;height:100%;object-fit:contain;mix-blend-mode:screen;filter:drop-shadow(0 8px 18px rgba(0,0,0,.7));
  animation:carrevin .8s cubic-bezier(.2,.8,.2,1);}
@keyframes carrevin{from{transform:translateX(-40%) scale(.7);opacity:0}to{transform:none;opacity:1}}
.cu-name{font-weight:900;font-size:1.7rem;color:#fff;}
.cu-tier{font-size:.8rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#9b8cff;}
.cu-actions{display:flex;gap:12px;align-items:center;margin-top:10px;flex-wrap:wrap;justify-content:center;}

/* garage: clear the sticky race button + make the showroom scroll cleanly */
#screen-garage{overflow-y:auto;}
#screen-garage .garage-grid{padding-bottom:88px;}
.garage-race-btn{z-index:30;}

/* ===== desktop: keep screens looking like an app, not stretched (studio dead-space fix) ===== */
@media (min-width:720px){
  #screen-track{justify-content:center;max-width:620px;margin:0 auto;}
  #screen-track .track-stage{flex:0 0 auto;}
  #screen-track .studio-scope{width:min(460px,80%);}
  .studio-bg{max-width:620px;left:50%;transform:translateX(-50%);}
  #screen-game{max-width:560px;margin:0 auto;}
  #screen-game .answer-pads{max-width:420px;}
}

/* ===================== VISION-PANEL POLISH PASS (garage + calendar) ===================== */
/* (2) RACE button must never overlap cars: pin it as a real footer, grid scrolls above it */
#screen-garage.active{display:flex;flex-direction:column;}
#screen-garage .garage-head{flex:0 0 auto;}
#screen-garage .garage-grid{flex:1 1 auto;min-height:0;overflow-y:auto;padding-bottom:16px;}
.garage-race-btn{position:static;flex:0 0 auto;margin:8px auto 12px;}

/* (1) HOME HERO car was a murky blob — brighten the stage so the screen-blended car pops, and enlarge it */
.garage-hero-stage{flex:0 0 116px;height:70px;
  background:radial-gradient(ellipse at 50% 58%,rgba(150,130,255,.6),rgba(80,150,255,.25) 45%,transparent 72%);}
.garage-hero-car{width:116px;height:66px;filter:drop-shadow(0 3px 7px rgba(0,0,0,.55)) brightness(1.18) contrast(1.06);}
.garage-hero-title{font-size:1.1rem;}
.garage-hero-bar{height:10px;}

/* (5) showroom cars: give each card real depth — a lit floor + reflection so they don't look like flat stickers */
.garage-card:not(.locked){background:
  radial-gradient(ellipse at 50% 88%,rgba(124,91,255,.28),transparent 62%),
  linear-gradient(160deg,#20203c,#101022);}
.garage-img{filter:drop-shadow(0 6px 10px rgba(0,0,0,.5));}

/* (4) padlock: drop the brass clip-art emoji into a frosted glass badge so it reads premium */
.garage-card.locked .garage-lock{transform:translate(-50%,-90%);font-size:1.15rem;width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;border-radius:50%;
  background:rgba(20,20,40,.55);backdrop-filter:blur(3px);box-shadow:inset 0 0 0 2px rgba(155,140,255,.5),0 4px 10px rgba(0,0,0,.5);
  filter:grayscale(.4) brightness(1.2);}
/* (3) locked progress + cost were invisible — brighten the track, glow the fill, enlarge the cost */
.garage-card.locked .locked-img{filter:brightness(.09) contrast(.7);opacity:.92;}
.garage-cost{font-size:1.02rem;color:#ffe27a;text-shadow:0 1px 3px rgba(0,0,0,.6);}
.garage-mini-bar{height:8px;background:rgba(255,255,255,.18);box-shadow:inset 0 0 0 1px rgba(255,255,255,.1);}
.garage-mini-bar span{background:linear-gradient(90deg,#33d6ff,#ffd23f);box-shadow:0 0 8px rgba(255,210,63,.8);min-width:8px;}

/* (6) calendar read-along caption: was low-contrast purple — brighten + open the line-height */
#cal-caption{color:#eef0ff;line-height:1.7;font-size:1.05rem;}
#cal-caption .kw{color:#cdd2ff;}
#cal-caption .kw.on{color:#fff;background:linear-gradient(180deg,#7c5bff,#5b3fd0);}

/* race button overlap: the SCREEN must not scroll — only the grid does, so the footer button stays pinned */
#screen-garage{overflow:hidden;}

/* home hero car: brighter solid stage + fill it so the car reads crisp (not a murky blob) */
.garage-hero-stage{background:radial-gradient(ellipse at 50% 50%,#6b6be0,#3a3a8f 55%,#1a1a3a 100%);
  border-radius:14px;overflow:hidden;box-shadow:inset 0 0 18px rgba(0,0,0,.4);}
.garage-hero-car{width:118px;height:68px;object-fit:cover;object-position:center 42%;
  mix-blend-mode:screen;filter:brightness(1.3) contrast(1.12) saturate(1.1);}

/* crisp hero car: stage matches the car's own black bg, NO blend — car reads solid + vibrant */
.garage-hero-stage{background:radial-gradient(ellipse at 50% 45%,#141425,#070710 80%);}
.garage-hero-car{mix-blend-mode:normal;filter:brightness(1.08) contrast(1.05) saturate(1.08);object-position:center 40%;}

/* car parts strip (bridges the gaps between car unlocks) */
.gh-parts{display:flex;align-items:center;justify-content:center;gap:6px;margin:8px auto 0;flex-wrap:wrap;}
.gh-part{font-size:1rem;filter:grayscale(1) brightness(.6);opacity:.5;transition:.2s;}
.gh-part.on{filter:none;opacity:1;transform:scale(1.05);text-shadow:0 0 8px rgba(124,91,255,.8);}
.gh-part-txt{font-size:.78rem;color:#9b8cff;margin-left:6px;font-weight:700;}

/* ===================== HOW TO PLAY — home button + narrated tour ===================== */
.howto-btn{display:block;width:100%;max-width:560px;margin:0 auto 14px;font-family:inherit;cursor:pointer;
  background:linear-gradient(120deg,#2a1a4a,#3a2a6a);border:2px solid #7c5bff;border-radius:18px;
  padding:12px 16px;color:#fff;font-weight:900;font-size:1.05rem;text-align:center;
  box-shadow:0 6px 18px rgba(124,91,255,.35);transition:transform .1s;}
.howto-btn:active{transform:scale(.98);}
.howto-btn span{display:block;font-weight:700;font-size:.82rem;color:#cdbcff;margin-top:2px;}

#screen-tour.active{display:flex;flex-direction:column;align-items:center;overflow:hidden;}
.tour-body{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;text-align:center;max-width:600px;width:100%;padding:8px 18px;min-height:0;}
.tour-icon{font-size:5rem;line-height:1;filter:drop-shadow(0 6px 16px rgba(124,91,255,.6));animation:tourpop .5s cubic-bezier(.2,.9,.3,1.3);}
@keyframes tourpop{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
.tour-title{font-weight:900;font-size:1.9rem;color:#ffd23f;letter-spacing:.5px;text-shadow:0 0 16px rgba(255,210,63,.4);}
.tour-text{font-size:1.4rem;line-height:1.7;color:#eef0ff;max-width:560px;font-weight:600;}
.tour-text .kw{transition:color .12s,background .12s;border-radius:6px;padding:0 1px;}
.tour-text .kw.on{color:#fff;background:linear-gradient(180deg,#7c5bff,#5b3fd0);box-shadow:0 0 10px rgba(124,91,255,.6);}
.tour-dots{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;padding:6px 18px;flex:0 0 auto;max-width:90vw;}
.tour-dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.2);transition:.2s;}
.tour-dot.seen{background:#7c5bff;} .tour-dot.on{background:#ffd23f;transform:scale(1.5);box-shadow:0 0 8px rgba(255,210,63,.8);}
.tour-nav{display:flex;gap:14px;align-items:center;justify-content:center;padding:8px 18px 18px;flex:0 0 auto;}

/* ===================== garage cars spin on their axis — same as the gemstones ===================== */
.garage-grid{perspective:900px;}
/* world-class 3D SHOWCASE turn — a flat photo can't do a true 360 without going
   edge-on/paper-thin (the panel's #1 bug), so we rock it through beauty angles only */
.garage-card:not(.locked) .garage-img{animation:carshow 4.5s ease-in-out infinite;transform-style:preserve-3d;
  filter:drop-shadow(0 9px 11px rgba(0,0,0,.6));}
@keyframes carshow{0%{transform:rotateY(-26deg);}50%{transform:rotateY(26deg);}100%{transform:rotateY(-26deg);}}
.garage-card:nth-child(3n) .garage-img{animation-delay:-1.5s;}
.garage-card:nth-child(3n+1) .garage-img{animation-delay:-3s;}
/* a lit floor under each car so it doesn't float */
.garage-card:not(.locked)::after{content:"";position:absolute;left:50%;bottom:42%;transform:translateX(-50%);
  width:62%;height:14px;border-radius:50%;background:radial-gradient(ellipse,rgba(0,0,0,.55),transparent 72%);filter:blur(3px);z-index:0;}
.garage-img{position:relative;z-index:1;}
/* unlock celebration: dramatic reveal, then an elegant showcase turn */
.cu-stage{perspective:1100px;}
.cu-car{animation:carrevin .8s cubic-bezier(.2,.8,.2,1), carshow 5s ease-in-out .8s infinite !important;}

/* gem meaning line (bank detail + win screen) */
.cd-meaning{font-size:1.05rem;color:#aee8ff;font-weight:800;margin:2px 0;}
.wc-meaning{font-size:.95rem;color:#aee8ff;font-weight:800;margin-top:2px;}

/* ===================== secret-code (PIN) login gate ===================== */
.pin-gate{position:fixed;inset:0;z-index:70;display:none;align-items:center;justify-content:center;
  background:rgba(8,6,20,.9);backdrop-filter:blur(8px);padding:20px;}
.pin-gate.show{display:flex;animation:fade .25s ease;}
.pin-card{background:linear-gradient(160deg,#1c1c38,#12122a);border:2px solid #7c5bff;border-radius:24px;
  padding:26px 22px;max-width:340px;width:100%;text-align:center;box-shadow:0 18px 50px rgba(0,0,0,.6);}
.pin-icon{font-size:2.6rem;}
.pin-title{font-weight:900;font-size:1.5rem;color:#fff;margin-top:6px;}
.pin-title span{color:#ffd23f;}
.pin-sub{color:#cdbcff;font-size:.95rem;margin:4px 0 16px;}
.pin-input{width:100%;font-family:inherit;font-size:1.6rem;font-weight:800;text-align:center;letter-spacing:.4em;
  padding:14px;border-radius:16px;border:2px solid #3a3a66;background:#0e0e1f;color:#fff;outline:none;}
.pin-input:focus{border-color:#7c5bff;}
.pin-show{margin-top:10px;background:rgba(255,255,255,.08);border:none;color:#cdbcff;font-family:inherit;
  font-weight:800;padding:8px 16px;border-radius:30px;cursor:pointer;font-size:.95rem;}
.pin-err{color:#ff8a9b;font-weight:800;min-height:1.2em;margin-top:8px;}
.pin-actions{display:flex;gap:12px;justify-content:center;align-items:center;margin-top:14px;}
.pin-card.nudge{animation:carnudge .35s ease;}
.pc-lock{font-size:.8em;opacity:.9;}

/* garage: fade the scroll edge so a half-visible row reads as 'scroll for more', not clipping */
#screen-garage{position:relative;}
#screen-garage .garage-grid{-webkit-mask-image:linear-gradient(to bottom,#000 calc(100% - 30px),transparent);
  mask-image:linear-gradient(to bottom,#000 calc(100% - 30px),transparent);}

/* ===================== CAR DETAIL — true 360° turntable + V8 ===================== */
.car-detail{position:fixed;inset:0;z-index:65;display:none;align-items:center;justify-content:center;
  background:rgba(8,6,20,.9);backdrop-filter:blur(8px);padding:18px;}
.car-detail.show{display:flex;animation:fade .25s ease;}
.cd2-card{background:linear-gradient(160deg,#1a1a34,#101022);border:2px solid #7c5bff;border-radius:24px;
  padding:18px;max-width:430px;width:100%;text-align:center;position:relative;box-shadow:0 18px 50px rgba(0,0,0,.6);}
.cd2-close{position:absolute;top:10px;right:12px;background:rgba(255,255,255,.1);border:none;color:#fff;
  width:38px;height:38px;border-radius:50%;font-size:1.1rem;cursor:pointer;z-index:2;}
.cd2-stage{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at 50% 62%,rgba(124,91,255,.32),transparent 70%);border-radius:18px;position:relative;overflow:hidden;perspective:1000px;}
.cd2-video{width:100%;height:100%;object-fit:contain;mix-blend-mode:screen;}
.cd2-img{width:88%;height:88%;object-fit:contain;mix-blend-mode:screen;}
.cd2-img.spin{animation:carshow 4.5s ease-in-out infinite;transform-style:preserve-3d;}
.cd2-img.locked-img{filter:brightness(.1) contrast(.7);}
.cd2-lock{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2.4rem;filter:drop-shadow(0 2px 6px #000);}
.cd2-name{font-weight:900;font-size:1.6rem;color:#fff;margin-top:8px;}
.cd2-tier{font-size:.78rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#9b8cff;}
.cd2-status{color:#cdd2ff;margin:8px 0;font-size:1rem;} .cd2-status b{color:#ffd23f;}
.cd2-actions{display:flex;gap:12px;justify-content:center;align-items:center;margin-top:8px;flex-wrap:wrap;}
