:root{
  --bg:#071224;
  --bg2:#0b1324;
  --panel:#1f2a40;
  --panel2:#151f32;
  --field:#070d1b;
  --border:#45536d;
  --border-soft:#2b3850;
  --text:#f3f7ff;
  --muted:#a8b3c7;
  --cyan:#38bdf8;
  --gold:#f7bd43;
  --shadow:0 14px 36px rgba(0,0,0,.28);
}
*{box-sizing:border-box}
body{
  margin:0;
  min-height:100vh;
  font-family:Inter,Segoe UI,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 5% 18%,rgba(32,169,176,.20),transparent 12%),
    radial-gradient(circle at 93% 62%,rgba(40,172,113,.18),transparent 12%),
    linear-gradient(180deg,#071426 0%,#0a1222 48%,#080f1d 100%);
  overflow-x:hidden;
}
.emoji-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.float-emoji{position:absolute;font-size:42px;opacity:.28;filter:drop-shadow(0 8px 20px rgba(0,0,0,.3));animation:gentleBob 7s ease-in-out infinite}.float-emoji.left{left:34px}.float-emoji.right{right:34px}.float-emoji:nth-child(2n){animation-duration:8s}.float-emoji:nth-child(3n){animation-duration:9s}.float-emoji:nth-child(4n){animation-delay:-2s}.float-emoji:nth-child(5n){animation-delay:-3.5s}@keyframes gentleBob{0%,100%{transform:translateY(-5px)}50%{transform:translateY(5px)}}
.settings-pill{display:none!important}
.app{position:relative;z-index:1;max-width:910px;margin:0 auto;padding:58px 18px 80px}.hero img{display:block;width:100%;max-width:760px;margin:0 auto 16px;border-radius:8px}.section{margin:0 0 28px}.load-section{margin-bottom:34px}.form-grid{display:grid;gap:14px;align-items:end}.load-grid{grid-template-columns:1fr 1fr 190px}.class-grid-1{grid-template-columns:1.15fr .55fr .85fr;margin-bottom:14px}.class-grid-2{grid-template-columns:1fr 190px 190px}.field span{display:block;color:#dbe6f7;font-size:12px;font-weight:900;margin:0 0 7px}input,select{width:100%;height:36px;border:1px solid var(--border);border-radius:7px;background:var(--field);color:#fff;padding:0 12px;font-weight:700;outline:none}input::placeholder{color:#7f8ba2}select option{background:#101827;color:#fff}.gold-btn,.small-gold{border:0;border-radius:9px;background:var(--gold);color:#08111f;font-weight:950;height:36px;padding:0 18px;cursor:pointer;box-shadow:0 8px 18px rgba(247,189,67,.18)}.small-gold{height:42px;border-radius:14px}.dark-btn{border:1px solid var(--border);border-radius:10px;background:var(--panel2);color:#fff;font-weight:900;padding:12px 16px;cursor:pointer}h1{font-size:27px;margin:0 0 26px;font-weight:950;letter-spacing:-.04em}.selected-line{font-size:12px;color:var(--muted);margin:12px 0 20px}.selected-line span{color:#35d987}.current-class{border:1px solid var(--border);background:#101a2c;border-radius:15px;padding:16px 18px;margin-bottom:16px}.current-class b,.current-class small{display:block}.current-class small{color:#d5deee;margin-top:8px}.audio-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;color:#9ca8bb;font-size:13px}.sound-select{width:180px;display:none}.profile-card,.leader,.game-card{background:linear-gradient(180deg,var(--panel),#1b263a);border:1px solid var(--border);box-shadow:var(--shadow)}.profile-card{border-radius:16px;padding:18px}.profile-head{display:grid;grid-template-columns:56px 1fr 284px;gap:14px;align-items:center}.avatar-box{height:48px;width:48px;border:1px solid #1598d1;background:#164061;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:27px}.profile-title span,h4{color:var(--cyan);text-transform:uppercase;letter-spacing:.11em;font-size:11px;font-weight:950}.profile-title h2{font-size:30px;line-height:1;margin:3px 0 6px}.profile-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.profile-title p,.leaderboard-section p,.tiny{color:#c2cada;font-size:12px;margin:0}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat{height:58px;border:1px solid var(--border-soft);background:var(--field);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center}.stat b{color:var(--gold);font-size:19px}.stat span{font-size:8px;text-transform:uppercase;font-weight:950;margin-top:6px}.inventory-bar{margin:16px 0 10px;border:1px solid var(--border-soft);border-radius:11px;background:var(--field);height:42px;display:flex;align-items:center;padding:0 14px;font-size:24px}.badge-box{border:1px dashed var(--border);background:#172235;border-radius:13px;color:#d2daeb;font-size:12px;padding:16px}.parent-lock{display:grid;grid-template-columns:1fr auto auto auto;gap:10px;align-items:end;margin-top:16px}.game-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}.game-card{aspect-ratio:1/1;min-height:112px;max-height:136px;border-radius:14px;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;cursor:pointer;padding:10px;text-align:center}.game-card span{font-size:40px;line-height:1}.game-card b{font-size:11px;line-height:1.15}.muted-card{opacity:1}.game-card:hover{transform:translateY(-2px);border-color:#6f7d96}.hidden-view{display:none}.view{display:none}.view.active{display:block}.prompt-display{min-height:160px;border:2px dashed var(--border);background:var(--field);border-radius:18px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:42px;font-weight:950;padding:24px;margin-bottom:16px}.button-row{display:flex;gap:10px;flex-wrap:wrap}.placeholder-list{display:grid;gap:10px}.mini-card{background:var(--panel2);border:1px solid var(--border);border-radius:12px;padding:14px}.notice{background:#173222;border:1px solid #38c172;border-radius:10px;padding:12px 14px;margin:10px 0;color:#d8ffe6;font-weight:800}.leaderboard-section{padding-top:2px}.leaderboard-section .field{margin-bottom:18px}.leader-list{display:grid;gap:10px}.leader{border-radius:16px;padding:12px 14px;display:grid;grid-template-columns:1fr 130px 1fr;align-items:center;gap:12px}.leader strong{border:1px solid var(--border);border-radius:10px;text-align:center;color:var(--gold);font-size:21px;padding:8px}.leader strong span{display:block;color:#fff;font-size:8px;text-transform:uppercase}.leader small{color:#d2d9e8}
@media(max-width:1040px){.float-emoji.left{left:10px}.float-emoji.right{right:10px}.float-emoji{font-size:34px;opacity:.22}.app{max-width:820px}.game-grid{grid-template-columns:repeat(4,1fr)}.game-card{min-height:118px}}
@media(max-width:760px){.emoji-bg{display:none}.settings-pill{display:none!important}.app{padding:22px 12px 60px}.load-grid,.class-grid-1,.class-grid-2,.profile-head,.parent-lock,.leader{grid-template-columns:1fr}.profile-stats{grid-template-columns:repeat(2,1fr)}.game-grid{grid-template-columns:repeat(3,1fr);gap:12px}.game-card{min-height:96px}.game-card span{font-size:34px}.hero img{max-width:100%}}@media(max-width:500px){.game-grid{grid-template-columns:repeat(2,1fr)}}

/* Shared game-page header: used by every normal game screen */
.game-page{padding-top:12px}.game-top-nav{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin:0 0 28px}.game-top-nav button{width:48px;height:42px;border-radius:9px;border:1px solid var(--border);background:#121a2a;color:#fff;font-size:20px;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.18)}.game-top-nav button:hover{transform:translateY(-2px);border-color:#71809c}.back-home{border:0;border-radius:16px;background:var(--gold);color:#07111f;font-weight:950;font-size:16px;padding:14px 20px;cursor:pointer;box-shadow:0 12px 28px rgba(247,189,67,.22);margin-bottom:48px}.game-reward-row{display:grid;grid-template-columns:1fr;gap:18px;align-items:center;margin-bottom:28px}.game-coin-bar{min-height:76px;border:1px solid rgba(247,189,67,.55);border-radius:16px;background:linear-gradient(90deg,rgba(247,189,67,.09),rgba(20,30,49,.94));padding:16px 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}.game-coin-bar b{font-size:22px;color:#ffe39a}.game-coin-bar small{display:block;width:100%;color:#c8d1e0;font-size:13px;font-weight:800}.mini-avatar{font-size:22px}.bar-divider{font-size:28px;color:#fde68a;font-weight:950}.open-shop-btn{height:48px;border:0;border-radius:18px;background:var(--gold);color:#07111f;font-weight:950;font-size:16px;cursor:pointer;box-shadow:0 12px 28px rgba(247,189,67,.22)}.reward-buttons{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-bottom:72px}.reward-buttons button{height:42px;border:0;border-radius:15px;background:var(--gold);color:#07111f;font-size:16px;font-weight:950;cursor:pointer;box-shadow:0 12px 28px rgba(247,189,67,.16)}.reward-buttons span{font-size:12px;opacity:.55}.game-title{font-size:42px;margin:0 0 18px}.game-subtitle{font-size:18px;color:#cbd5e1;margin:0 0 28px}.prompt-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
@media(max-width:760px){.game-top-nav{gap:10px;margin-bottom:44px}.game-top-nav button{width:42px;height:38px}.game-reward-row{grid-template-columns:1fr}.reward-buttons{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:38px}.back-home{margin-bottom:30px}.game-title{font-size:32px}}

/* Prompt Spinner real layout */
.spinner-stage{display:grid;place-items:center;gap:34px;margin-top:18px}.wheel-wrap{position:relative;display:grid;place-items:center}.wheel-pointer{position:absolute;top:-16px;z-index:4;width:0;height:0;border-left:16px solid transparent;border-right:16px solid transparent;border-top:32px solid #101827;filter:drop-shadow(0 4px 8px rgba(0,0,0,.35))}.spinner-wheel{position:relative;width:min(390px,82vw);aspect-ratio:1/1;border-radius:50%;border:10px solid #fff;box-shadow:0 18px 40px rgba(0,0,0,.35);background:conic-gradient(#10d0a0 0deg 60deg,#18b987 60deg 120deg,#ef426f 120deg 180deg,#8237e9 180deg 240deg,#ff8600 240deg 300deg,#1b93b1 300deg 360deg);transition:transform 1.3s cubic-bezier(.2,.82,.15,1)}.spinner-wheel:after{content:"";position:absolute;inset:31%;border-radius:50%;background:#08111f;border:7px solid #fff;z-index:2}.wheel-center{position:absolute;inset:37%;z-index:3;border:0;border-radius:50%;background:#08111f;color:#fff;font-size:18px;font-weight:950;cursor:pointer}.wheel-num{position:absolute;z-index:1;color:#fff;font-size:42px;font-weight:950;text-shadow:0 3px 7px rgba(0,0,0,.45)}.wheel-num-1{left:50%;top:19%;transform:translate(-50%,-50%)}.wheel-num-2{right:20%;top:34%;transform:translate(50%,-50%)}.wheel-num-3{right:20%;bottom:34%;transform:translate(50%,50%)}.wheel-num-4{left:50%;bottom:19%;transform:translate(-50%,50%)}.wheel-num-5{left:20%;bottom:34%;transform:translate(-50%,50%)}.wheel-num-6{left:20%;top:34%;transform:translate(-50%,-50%)}.spin-label{margin-top:26px;border:0;border-radius:24px;background:rgba(13,22,38,.82);color:#fff;font-size:25px;font-weight:950;letter-spacing:.02em;padding:16px 36px;cursor:pointer}.spinner-selected-card{position:relative;width:min(735px,92vw);min-height:205px;border-radius:16px;background:#fff;color:#08111f;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:38px 72px;box-shadow:0 14px 40px rgba(0,0,0,.28)}.selected-number{font-size:44px;font-weight:950;line-height:1}.selected-main{font-size:40px;font-weight:950;line-height:1.15}.selected-main span{font-size:36px}.speaker-btn{border:0;border-radius:50%;width:56px;height:56px;background:#3c465b;color:#fff;font-size:25px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.2)}.selected-speaker{position:absolute;right:28px;top:28px;background:#eef1f7;color:#3c465b}.spinner-topic-block{margin-top:70px}.spinner-topic-block hr{border:0;border-top:1px solid rgba(255,255,255,.22);margin:0 0 46px}.spinner-topic-block h2{font-size:28px;margin:0 0 22px;font-weight:950}.spinner-topic-block p{color:#aeb8ca;font-weight:800;margin:0 0 24px}.spinner-list{display:grid;gap:12px}.spinner-list-row{min-height:88px;border:1px solid var(--border);border-radius:22px;background:#1f2a40;display:grid;grid-template-columns:48px 1fr 64px;gap:18px;align-items:center;padding:16px 22px;box-shadow:var(--shadow)}.number-badge{height:42px;width:42px;border-radius:50%;background:var(--gold);color:#07111f;font-size:22px;font-weight:950;display:flex;align-items:center;justify-content:center}.spinner-list-row b{font-size:34px;line-height:1.1}.row-emoji{font-size:30px;margin-right:8px}@media(max-width:760px){.spinner-wheel{width:min(330px,88vw);border-width:8px}.wheel-num{font-size:34px}.spinner-selected-card{padding:34px 54px}.selected-main{font-size:30px}.spinner-list-row{grid-template-columns:42px 1fr 54px;padding:14px}.spinner-list-row b{font-size:24px}.speaker-btn{width:48px;height:48px}.spin-label{font-size:20px}}
.wheel-center:disabled,.spin-label:disabled{opacity:.72;cursor:not-allowed;}

/* Batch 1 game screens: Fast Answer, Roleplay, Sentence Builder, Emoji Hunt */
.simple-game,.roleplay-grid,.builder-list,.match-game{margin-top:20px}.big-question-card{position:relative;width:min(780px,92vw);min-height:190px;border-radius:18px;background:#fff;color:#08111f;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 78px;margin:0 auto 24px;box-shadow:0 14px 40px rgba(0,0,0,.28)}.game-badge{font-size:42px;margin-bottom:10px}.big-question-text{font-size:34px;line-height:1.18;font-weight:950}.game-action-row{display:flex;justify-content:center;margin:10px 0 42px}.game-main-action{width:min(380px,88vw);height:48px}.game-list-title h2{font-size:28px;margin:0 0 10px}.game-list-title p{color:#aeb8ca;font-weight:800;margin:0 0 22px}.compact-row b{font-size:24px}.roleplay-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.role-card,.builder-card{background:#1f2a40;border:1px solid var(--border);border-radius:22px;padding:18px;box-shadow:var(--shadow)}.role-card-head,.builder-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}.role-card-head b,.builder-head b{font-size:22px}.role-line{display:grid;grid-template-columns:42px 1fr 56px;gap:12px;align-items:center;background:#121a2d;border:1px solid var(--border-soft);border-radius:16px;padding:12px 14px;margin-top:10px}.role-line span{height:34px;width:34px;border-radius:50%;background:var(--gold);color:#07111f;display:flex;align-items:center;justify-content:center;font-weight:950}.role-line p{margin:0;font-size:20px;font-weight:850;line-height:1.25}.builder-list{display:grid;gap:16px}.builder-head{display:grid;grid-template-columns:48px 1fr 56px}.word-bank{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0}.word-tile{border:1px solid var(--border);border-radius:14px;background:#101a2c;color:#fff;padding:11px 15px;font-size:18px;font-weight:900;cursor:pointer}.word-tile:disabled{opacity:.35;cursor:not-allowed}.built-sentence{min-height:58px;border:1px dashed var(--border);background:#121a2d;border-radius:14px;padding:14px;font-size:22px;font-weight:900;color:#fff}.builder-actions{margin-top:10px}.match-game{display:grid;grid-template-columns:1fr 1fr;gap:20px}.match-col{display:grid;gap:12px;align-content:start}.match-col h2{font-size:26px;margin:0 0 6px}.match-tile{position:relative;min-height:72px;border:1px solid var(--border);border-radius:18px;background:#1f2a40;color:#fff;font-size:22px;font-weight:950;text-align:left;padding:16px 18px;cursor:pointer;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}.match-tile.selected{outline:3px solid var(--gold)}.match-tile.matched{background:#163522;border-color:#38c172;opacity:.75}.match-tile.wrong{background:#421b25;border-color:#f05c77}.inline-speaker{margin-left:auto;flex-shrink:0;transform:scale(.82)}@media(max-width:760px){.roleplay-grid,.match-game{grid-template-columns:1fr}.big-question-card{padding:34px 56px}.big-question-text{font-size:27px}.role-line p,.match-tile{font-size:18px}.builder-head{grid-template-columns:42px 1fr}.builder-head .speaker-btn{grid-column:1/-1;justify-self:end}.compact-row b{font-size:20px}}


/* Fast Answer circular countdown */
.fast-answer-stage{display:grid;place-items:center;gap:22px;margin-top:18px}.fast-timer{width:168px;height:168px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--timer-color) var(--timer-deg),rgba(255,255,255,.15) 0deg);box-shadow:0 16px 34px rgba(0,0,0,.32);transition:background .25s ease,transform .2s ease}.fast-timer-inner{width:124px;height:124px;border-radius:50%;background:#101a2c;border:1px solid rgba(255,255,255,.14);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.fast-timer-inner span{font-size:54px;line-height:1;font-weight:950}.fast-timer-inner small{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:#aeb8ca;font-weight:900;margin-top:4px}.fast-timer.warning{transform:scale(1.03)}.fast-timer.danger{transform:scale(1.06)}.fast-timer.time-up .fast-timer-inner:after{content:"TIME UP";font-size:12px;font-weight:950;color:#f43f5e;margin-top:5px;letter-spacing:.08em}.fast-question-card{margin-top:0}@media(max-width:760px){.fast-timer{width:140px;height:140px}.fast-timer-inner{width:104px;height:104px}.fast-timer-inner span{font-size:44px}}

/* Sentence Match memory-card version */
.memory-match-wrap{margin-top:38px;display:grid;place-items:center;gap:28px}.memory-match-grid{width:min(800px,92vw);display:grid;grid-template-columns:repeat(4,minmax(135px,1fr));gap:16px}.memory-card{position:relative;min-height:144px;border:0;background:transparent;padding:0;perspective:900px;cursor:pointer}.memory-card-inner{position:absolute;inset:0;display:block;transform-style:preserve-3d;transition:transform .42s cubic-bezier(.2,.76,.18,1)}.memory-card.flipped .memory-card-inner,.memory-card.matched .memory-card-inner{transform:rotateY(180deg)}.memory-face{position:absolute;inset:0;border-radius:18px;border:2px solid rgba(255,255,255,.92);box-shadow:0 12px 30px rgba(0,0,0,.28);backface-visibility:hidden;overflow:hidden}.memory-back{background:#263348;display:grid;place-items:center}.memory-front{background:#f6fff9;color:#07111f;border-color:#09c177;transform:rotateY(180deg);display:flex;align-items:center;justify-content:center;text-align:center;padding:24px 18px}.memory-index{position:absolute;right:10px;top:8px;width:34px;height:34px;border-radius:50%;background:#fff;color:#111827;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:950;box-shadow:0 4px 12px rgba(0,0,0,.22);z-index:3}.memory-question{font-size:50px;font-weight:950;color:#fff}.memory-label{position:absolute;left:12px;top:10px;text-transform:uppercase;font-size:12px;letter-spacing:.08em;color:#58657a;font-weight:950}.memory-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-width:0;width:100%}.match-emoji{font-size:54px;line-height:1}.match-word{font-size:23px;line-height:1.08;font-weight:950;overflow-wrap:anywhere;hyphens:auto;max-width:100%}.match-speaker{position:absolute;right:12px;bottom:12px;width:38px;height:38px;font-size:18px;transform:none;background:#dfe7f2;color:#334155;box-shadow:0 6px 14px rgba(0,0,0,.18)}.memory-card.matched .memory-front{background:#dff7ea;border-color:#19c37d;box-shadow:0 0 0 3px rgba(25,195,125,.18),0 12px 30px rgba(0,0,0,.28)}.memory-card.matched .memory-front:after{content:"";position:absolute;inset:0;background:rgba(25,195,125,.16);pointer-events:none}.memory-card.wrong .memory-front{background:#ffe4e9;border-color:#f43f5e}.match-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.dark-action,.gray-action{border:0;border-radius:22px;color:#fff;font-size:18px;font-weight:950;padding:14px 28px;cursor:pointer;box-shadow:0 12px 26px rgba(0,0,0,.22)}.dark-action{background:#111b2e}.gray-action{background:#64748b}.memory-card:disabled{cursor:default}@media(max-width:900px){.memory-match-grid{grid-template-columns:repeat(2,minmax(160px,1fr));gap:14px}.memory-card{min-height:156px}.match-emoji{font-size:58px}.match-word{font-size:24px}}@media(max-width:520px){.memory-match-grid{grid-template-columns:1fr;gap:12px}.memory-card{min-height:128px}.memory-front{padding:20px 54px 20px 16px}.memory-content{flex-direction:row;gap:12px}.match-emoji{font-size:46px}.match-word{font-size:22px}.memory-question{font-size:44px}}

/* Sentence Builder Streamlit-style card version */
.sentence-builder-game{margin-top:34px;display:grid;gap:20px}.builder-top-row{display:grid;grid-template-columns:160px 1fr;gap:18px;align-items:center}.builder-solved-pill{background:#111b2e;color:#fff;border-radius:24px;padding:18px 20px;font-size:22px;font-weight:950;text-align:center;box-shadow:0 10px 26px rgba(0,0,0,.22)}.builder-instruction-card,.builder-task-card{background:#f8fafc;color:#111827;border:1px solid #e5e7eb;border-radius:14px;padding:16px 20px;font-size:20px;font-weight:950;line-height:1.22;box-shadow:0 10px 24px rgba(0,0,0,.18)}.builder-task-card{font-size:18px;color:#334155}.sentence-builder-list{display:grid;gap:16px}.sentence-builder-card{background:#fff;color:#111827;border-radius:22px;padding:20px 18px;border:1px solid rgba(255,255,255,.8);box-shadow:0 14px 34px rgba(0,0,0,.26);transition:box-shadow .18s,transform .18s,border-color .18s}.sentence-builder-head{display:flex;align-items:center;justify-content:space-between;text-transform:uppercase;letter-spacing:.08em;color:#667085;font-size:16px;font-weight:950;margin-bottom:16px}.sentence-builder-head span:last-child{text-transform:none;letter-spacing:0;font-size:15px}.builder-word-bank{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 14px}.builder-word-tile,.answer-word-tile{border:0;border-radius:11px;background:#0d1628;color:#fff;padding:12px 15px;font-size:23px;line-height:1.05;font-weight:950;cursor:pointer;box-shadow:0 4px 0 rgba(0,0,0,.28);max-width:100%;overflow-wrap:anywhere}.builder-word-tile:disabled{opacity:.28;cursor:not-allowed;transform:translateY(2px);box-shadow:none}.builder-answer-row{min-height:76px;border:2px dashed #e8c85e;background:#fff7ed;border-radius:16px;padding:13px;display:flex;align-items:center;align-content:center;flex-wrap:wrap;gap:10px;transition:background .18s,border-color .18s}.builder-answer-row.empty{color:#94a3b8;font-size:22px;font-weight:950}.builder-placeholder{color:#94a3b8;font-size:22px;font-weight:950}.answer-word-tile{background:#1e293b}.revealed-tile{background:#334155}.builder-button-row{margin-top:14px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.builder-button-row button:not(.speaker-btn){border:0;border-radius:22px;color:#fff;font-size:18px;font-weight:950;padding:13px 22px;cursor:pointer;box-shadow:0 8px 18px rgba(0,0,0,.2)}.builder-check-btn{background:#059669}.builder-clear-btn,.builder-shuffle-btn{background:#475569}.builder-reveal-btn{background:#c0261d}.builder-speak-btn{margin-left:auto}.builder-feedback{min-height:22px;margin-top:8px;font-size:18px;font-weight:950}.sentence-builder-card.correct{border-color:#16a34a;box-shadow:0 0 0 3px rgba(22,163,74,.18),0 14px 34px rgba(0,0,0,.26);background:#f0fdf4}.sentence-builder-card.correct .builder-answer-row{border-color:#16a34a;background:#dcfce7}.sentence-builder-card.incorrect{border-color:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.18),0 14px 34px rgba(0,0,0,.26)}.sentence-builder-card.incorrect .builder-answer-row{border-color:#ef4444;background:#fee2e2}.sentence-builder-card.correct .builder-feedback{color:#15803d}.sentence-builder-card.incorrect .builder-feedback{color:#b91c1c}@media(max-width:760px){.builder-top-row{grid-template-columns:1fr}.builder-solved-pill{text-align:left}.builder-instruction-card,.builder-task-card{font-size:17px}.builder-word-tile,.answer-word-tile{font-size:20px}.builder-button-row button:not(.speaker-btn){font-size:16px;padding:12px 18px}.builder-speak-btn{margin-left:0}.sentence-builder-head{font-size:14px}}

/* Roleplay Cards Streamlit-style selected-card version */
.roleplay-page{margin-top:22px;display:grid;gap:26px}.roleplay-ready{font-size:16px;color:#9aa7bb;font-weight:850}.roleplay-topic{font-size:30px;line-height:1.15;margin:0 0 6px;color:#f8fafc}.roleplay-random-row{display:flex;justify-content:center}.roleplay-random-btn{width:min(525px,80vw);font-size:17px;padding:14px 28px;border-radius:18px}.roleplay-selected-card{position:relative;background:#fff;color:#111827;border:2px solid rgba(255,255,255,.95);border-radius:26px;min-height:108px;padding:28px 82px 28px 38px;display:flex;align-items:center;justify-content:center;box-shadow:0 18px 36px rgba(0,0,0,.28);transition:transform .18s ease,box-shadow .18s ease}.roleplay-selected-card.picked{animation:rolePick .24s ease}.roleplay-selected-text{font-size:38px;font-weight:950;line-height:1.12;text-align:center;overflow-wrap:anywhere}.roleplay-selected-speaker{position:absolute;right:24px;top:50%;transform:translateY(-50%);width:56px;height:56px}.roleplay-divider{border:0;border-top:1px solid rgba(255,255,255,.18);width:100%;margin:18px 0 8px}.roleplay-list{display:grid;gap:24px}.roleplay-list-card{position:relative;width:100%;border:1px solid rgba(255,255,255,.88);border-radius:24px;background:#fff;color:#111827;min-height:76px;padding:18px 84px 18px 76px;text-align:left;display:flex;align-items:center;gap:16px;cursor:pointer;box-shadow:0 12px 28px rgba(0,0,0,.22);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease,background .14s ease}.roleplay-list-card:hover{transform:translateY(-1px);box-shadow:0 16px 32px rgba(0,0,0,.28)}.roleplay-list-card.active{background:#f6fff9;border-color:#18c37d;box-shadow:0 0 0 3px rgba(24,195,125,.16),0 12px 28px rgba(0,0,0,.22)}.roleplay-list-card .number-badge{position:absolute;left:22px;top:50%;transform:translateY(-50%);width:38px;height:38px;font-size:21px}.roleplay-list-card b{font-size:25px;line-height:1.18;overflow-wrap:anywhere}.roleplay-row-speaker{position:absolute;right:22px;top:50%;transform:translateY(-50%);width:52px;height:52px;display:flex;align-items:center;justify-content:center}.roleplay-row-speaker:hover{transform:translateY(-50%) scale(1.04)}@keyframes rolePick{0%{transform:scale(.985)}60%{transform:scale(1.012)}100%{transform:scale(1)}}@media(max-width:760px){.roleplay-topic{font-size:24px}.roleplay-selected-card{padding:24px 72px 24px 24px;min-height:96px}.roleplay-selected-text{font-size:27px}.roleplay-list-card{padding:16px 72px 16px 66px;min-height:72px}.roleplay-list-card b{font-size:20px}.roleplay-list-card .number-badge{left:16px}.roleplay-row-speaker{right:14px;width:48px;height:48px}}

/* v19 roleplay control fixes */
.roleplay-random-btn{
  height:46px !important;
  min-height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
  white-space:nowrap;
  padding:0 32px !important;
  border-radius:18px !important;
}
.roleplay-selected-speaker,
.roleplay-row-speaker{
  border:0 !important;
  border-radius:50% !important;
  background:#3c465b !important;
  color:#fff !important;
  font-size:25px !important;
  line-height:1 !important;
  padding:0 !important;
  font-family:inherit !important;
  box-shadow:0 10px 24px rgba(0,0,0,.2) !important;
}
.roleplay-row-speaker{
  position:absolute;
  right:22px;
  top:50%;
  transform:translateY(-50%);
  width:52px !important;
  height:52px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  cursor:pointer;
}
.roleplay-selected-speaker{
  width:56px !important;
  height:56px !important;
}
.roleplay-selected-speaker:hover{transform:translateY(-50%) scale(1.04)}
.roleplay-row-speaker:hover{transform:translateY(-50%) scale(1.04)}

/* Code Crack safe game */
.code-crack-game{margin-top:30px;display:grid;gap:24px}.code-word-grid{display:grid;grid-template-columns:repeat(3,minmax(190px,1fr));gap:16px}.code-word-card{position:relative;background:#1f2c46;border:1px solid rgba(147,164,197,.48);border-radius:18px;min-height:82px;padding:17px 58px 17px 78px;display:flex;align-items:center;box-shadow:0 12px 28px rgba(0,0,0,.22);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.code-word-card b{font-size:22px;line-height:1.12;color:#fff;overflow-wrap:anywhere}.code-word-card .number-badge{position:absolute;left:17px;top:50%;transform:translateY(-50%);width:46px;height:46px;font-size:24px}.code-word-speaker{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:42px;height:42px}.code-word-card.playing{}.code-controls{display:grid;grid-template-columns:180px 180px 1fr;gap:16px;align-items:center;justify-content:center;max-width:760px;margin:0 auto}.code-play-btn{height:56px;font-size:19px;border-radius:22px}.code-controls strong{font-size:21px;color:#fff;text-align:center}.safe-wrap{position:relative;width:min(280px,70vw);margin:28px auto 0}.safe-img{width:100%;display:block;filter:drop-shadow(0 20px 36px rgba(0,0,0,.36));transition:transform .35s ease,filter .35s ease}.safe-open-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(17,24,39,.72);border-radius:28px;color:#fff;font-size:34px;font-weight:950;opacity:0;transform:scale(.96);transition:opacity .25s ease,transform .25s ease;text-shadow:0 3px 12px rgba(0,0,0,.4)}.safe-wrap.open .safe-img{transform:scale(1.04) rotate(-1deg);filter:drop-shadow(0 0 30px rgba(246,192,74,.38)) drop-shadow(0 20px 36px rgba(0,0,0,.36))}.safe-wrap.open .safe-open-overlay{opacity:1;transform:scale(1)}.code-input-label{text-align:center;color:#c8d0dd;font-weight:900;font-size:14px;margin-bottom:-12px}.code-input{width:100%;box-sizing:border-box;background:#080d19;color:#fff;border:1px solid rgba(255,255,255,.16);border-radius:8px;height:42px;padding:0 14px;font-size:18px;outline:none}.code-input:focus{border-color:#f6c04a;box-shadow:0 0 0 3px rgba(246,192,74,.16)}.code-input.shake{animation:codeShake .34s linear}.code-action-row{display:grid;grid-template-columns:1fr 1fr;gap:32px}.code-action-row .gold-btn{height:48px;border-radius:18px;font-size:17px}.code-result{min-height:70px;display:flex;justify-content:center;align-items:center}.code-win,.code-try-again{width:min(620px,100%);border-radius:18px;padding:18px 22px;text-align:center;font-size:22px;font-weight:950}.code-win{background:#dcfce7;color:#052e16;border:2px solid #22c55e}.code-win span{display:block;margin-top:6px;font-size:26px}.code-try-again{background:#2b1720;color:#fecdd3;border:1px solid rgba(244,63,94,.45)}@keyframes codeShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}@media(max-width:850px){.class-grid-2{grid-template-columns:1fr}.practice-link-btn{width:100%}}
@media(max-width:850px){.code-word-grid{grid-template-columns:1fr 1fr}.code-controls{grid-template-columns:1fr;max-width:420px}.code-action-row{grid-template-columns:1fr;gap:14px}.code-word-card b{font-size:20px}}@media(max-width:520px){.code-word-grid{grid-template-columns:1fr}.code-word-card{min-height:72px}.safe-wrap{width:min(240px,72vw)}}

/* Tic Tac Toss */
.ttt-game{margin-top:34px;display:grid;gap:18px}.ttt-board-shell{background:linear-gradient(135deg,#fff6bf 0%,#fff 46%,#f4efff 100%);border:10px solid rgba(255,255,255,.94);border-radius:18px;padding:18px;box-shadow:0 18px 36px rgba(0,0,0,.28)}.ttt-board{max-width:410px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.ttt-cell{position:relative;aspect-ratio:1/1;border:2px dashed #c9a892;border-radius:16px;background:rgba(255,255,255,.55);cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden}.ttt-cell:hover{background:#fff;transform:translateY(-1px)}.ttt-cell:disabled{cursor:default}.ttt-cell-number{position:absolute;left:12px;top:7px;color:#88919e;font-size:28px;font-weight:950}.ttt-empty-dot{width:36px;height:36px;border-radius:50%;background:rgba(15,23,42,.05)}.ttt-bag{width:74px;height:66px;border-radius:19px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:46px;font-weight:950;line-height:1;box-shadow:0 12px 24px rgba(0,0,0,.18);animation:bagDrop .28s ease-out}.ttt-bag.blue{background:linear-gradient(135deg,#63a4ff,#2362d9);transform:rotate(-8deg)}.ttt-bag.red{background:linear-gradient(135deg,#ff6b6b,#c92a2a);transform:rotate(7deg)}.ttt-cell.winning{border:4px solid #e8c85e;background:#fff7ed}.ttt-control-panel{background:#f8fafc;color:#111827;border-radius:18px;padding:14px 12px;display:grid;grid-template-columns:1.25fr 1fr auto;gap:14px;align-items:center}.ttt-info small{display:block;color:#667085;font-weight:950;letter-spacing:.12em}.ttt-info h2{font-size:22px;margin:3px 0 0;line-height:1.05}.ttt-thrower{border:1px solid #cbd5e1;border-radius:14px;background:#fff;padding:11px}.ttt-thrower small{display:block;color:#667085;font-size:12px;font-weight:900}.ttt-thrower b{font-size:18px}.ttt-thrower span{display:block;margin-top:5px;font-size:14px;font-weight:950}.ttt-buttons{display:flex;gap:10px}.ttt-team-bars{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;gap:10px}.ttt-team-pill{border:1px solid #cbd5e1;border-radius:12px;background:#fff;text-align:center;font-weight:950;padding:8px}.ttt-control-panel p{grid-column:1/-1;margin:0;color:#667085;font-size:13px;font-weight:800}.ttt-modal{position:fixed;inset:0;z-index:20;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.52);padding:20px}.ttt-modal.show{display:flex}.ttt-modal-card{width:min(765px,92vw);background:#fff;color:#111827;border-radius:24px;padding:24px;box-shadow:0 24px 60px rgba(0,0,0,.38)}.ttt-modal-card h3{font-size:22px;margin:0 0 14px}.ttt-word-card{position:relative;min-height:158px;border:1px solid #d9dee8;background:#f8fafc;border-radius:16px;display:flex;align-items:center;justify-content:center;gap:18px;padding:20px 84px 20px 24px}.ttt-word-emoji{font-size:40px}.ttt-word-card b{font-size:42px;line-height:1.08;overflow-wrap:anywhere;text-align:center}.ttt-word-speaker{position:absolute;right:20px;top:50%;transform:translateY(-50%)}.ttt-modal-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:18px}.ttt-modal-actions button{border:0;border-radius:18px;color:#fff;font-weight:950;font-size:15px;padding:12px 18px;cursor:pointer}.ttt-correct{background:#16a34a}.ttt-practice{background:#dc2626}.ttt-cancel{background:#475569;min-width:150px}@keyframes bagDrop{0%{transform:translateY(-22px) scale(.8) rotate(0deg);opacity:.2}70%{transform:translateY(3px) scale(1.06)}100%{opacity:1}}@media(max-width:760px){.ttt-board{max-width:340px}.ttt-control-panel{grid-template-columns:1fr}.ttt-buttons{justify-content:space-between}.ttt-team-bars{grid-template-columns:1fr}.ttt-bag{width:58px;height:52px;font-size:36px}.ttt-cell-number{font-size:23px}.ttt-word-card b{font-size:30px}.ttt-word-emoji{font-size:32px}.ttt-word-card{padding-right:70px}}


/* Trivia Wheel */
.trivia-wheel{
  background:conic-gradient(#f44336 0deg 60deg,#ff8d00 60deg 120deg,#18b987 120deg 180deg,#1daee0 180deg 240deg,#7657eb 240deg 300deg,#ea3cb2 300deg 360deg);
}
.trivia-wheel-label{position:absolute;z-index:1;color:#fff;font-size:17px;font-weight:950;text-align:center;text-shadow:0 3px 6px rgba(0,0,0,.35);max-width:105px;line-height:1.05;}
.trivia-wheel-label-1{left:67%;top:24%;transform:translate(-50%,-50%)}
.trivia-wheel-label-2{left:80%;top:53%;transform:translate(-50%,-50%)}
.trivia-wheel-label-3{left:62%;top:80%;transform:translate(-50%,-50%)}
.trivia-wheel-label-4{left:34%;top:80%;transform:translate(-50%,-50%)}
.trivia-wheel-label-5{left:20%;top:53%;transform:translate(-50%,-50%)}
.trivia-wheel-label-6{left:36%;top:24%;transform:translate(-50%,-50%)}
.trivia-result-card{min-height:150px;}
.trivia-category-label{font-size:28px;font-weight:950;margin-bottom:18px;}
.trivia-question-text{font-size:40px;font-weight:950;line-height:1.12;}
.trivia-list-block{margin-top:42px;}
.trivia-list-block h2{font-size:28px;margin:0 0 8px;font-weight:950;}
.trivia-list-block p{color:#aeb8ca;font-weight:800;margin:0 0 18px;}
.trivia-category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.trivia-category-grid .mini-card{min-height:84px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:6px;}
.trivia-category-grid small{color:#aeb8ca;font-weight:800;}
@media(max-width:760px){.trivia-wheel-label{font-size:14px;max-width:80px}.trivia-question-text{font-size:28px}.trivia-category-grid{grid-template-columns:repeat(2,1fr)}}

/* Basketball Shot - student website version */
.basket-game{margin-top:34px;display:grid;grid-template-columns:minmax(420px,1.55fr) minmax(280px,.95fr);gap:16px;align-items:stretch}.basket-court{position:relative;min-height:510px;background:linear-gradient(145deg,#fff2dd 0%,#ffe1b8 100%);border:4px solid #c78f6d;border-radius:22px;box-shadow:0 20px 40px rgba(0,0,0,.28);overflow:hidden}.basket-scoreboard{position:absolute;left:22px;top:22px;background:#152033;color:#fff;border:3px solid #e8c85e;border-radius:16px;padding:12px 16px;width:190px;box-shadow:0 10px 24px rgba(0,0,0,.25)}.basket-scoreboard small{color:#ffc55c;font-weight:950;letter-spacing:.12em}.basket-scoreboard div:nth-child(2){display:flex;justify-content:space-between;margin-top:5px}.basket-scoreboard b{font-size:34px;line-height:1}.basket-scoreboard div:nth-child(3){display:flex;justify-content:space-between;font-size:12px;font-weight:950;color:#d5ddea}.basket-hoop-wrap{position:absolute;right:38px;top:76px;transform:none;width:210px;height:260px}.basket-backboard{position:absolute;left:39px;top:0;width:130px;height:96px;background:#f8fafc;border:8px solid #dbe4ef;border-radius:14px}.basket-square{position:absolute;left:40px;top:24px;width:56px;height:44px;border:4px solid #fb7c2f;border-radius:7px}.basket-rim{position:absolute;left:64px;top:91px;width:82px;height:18px;border:7px solid #f0525d;border-radius:20px;background:rgba(255,255,255,.3);z-index:3}.basket-net{position:absolute;left:82px;top:113px;width:45px;height:48px;border-left:4px dashed rgba(31,41,55,.35);border-right:4px dashed rgba(31,41,55,.35);border-bottom:4px dashed rgba(31,41,55,.25);border-radius:0 0 28px 28px}.basket-ball{position:absolute;left:86px;top:162px;font-size:42px;z-index:5;filter:drop-shadow(0 8px 10px rgba(0,0,0,.2));transform-origin:center;transition:opacity .15s}.basket-ball.shot-made{animation:basketMade .9s cubic-bezier(.15,.82,.24,1) forwards}.basket-ball.shot-miss{animation:basketMiss .9s cubic-bezier(.15,.82,.24,1) forwards}.basket-ball.shot-reset{animation:none;left:86px;top:162px;opacity:1}.basket-status{position:absolute;left:24px;right:24px;bottom:22px;background:rgba(255,255,255,.82);border:1px solid rgba(148,163,184,.5);border-radius:16px;padding:14px 16px;color:#111827;font-weight:950;font-size:17px}.basket-panel{background:#f8fafc;color:#111827;border-radius:22px;padding:20px 16px;box-shadow:0 20px 40px rgba(0,0,0,.24)}.basket-panel small{display:block;color:#667085;font-weight:950;letter-spacing:.12em}.basket-panel h2{font-size:25px;line-height:1.04;margin:5px 0 12px}.basket-prompt-card{position:relative;min-height:126px;background:#fff;border:1px solid #d9e1eb;border-radius:18px;display:flex;align-items:center;justify-content:center;gap:12px;text-align:center;padding:18px;margin-bottom:12px}.basket-prompt-emoji{font-size:38px;flex:0 0 auto}.basket-prompt-card b{font-size:clamp(20px,2.15vw,25px);line-height:1.16;white-space:normal;word-break:normal;overflow-wrap:normal;hyphens:none;max-width:100%}.basket-speaker{display:none}.basket-main-btn,.basket-reset-btn{width:100%;height:48px;border-radius:18px;margin-top:10px;font-size:17px}.basket-panel p{font-size:13px;line-height:1.25;color:#667085;font-weight:800;margin:12px 0 0}@keyframes basketMade{0%{left:86px;top:162px;transform:scale(1) rotate(0deg)}45%{left:82px;top:36px;transform:scale(.95) rotate(220deg)}70%{left:88px;top:92px;transform:scale(.82) rotate(360deg)}100%{left:91px;top:118px;transform:scale(.62) rotate(520deg);opacity:.15}}@keyframes basketMiss{0%{left:86px;top:162px;transform:scale(1) rotate(0deg)}45%{left:36px;top:42px;transform:scale(.95) rotate(220deg)}100%{left:2px;top:184px;transform:scale(.8) rotate(520deg);opacity:.35}}@media(max-width:880px){.basket-game{grid-template-columns:1fr}.basket-court{min-height:430px}.basket-panel h2{font-size:22px}}@media(max-width:520px){.basket-court{min-height:380px}.basket-scoreboard{width:145px;padding:10px}.basket-scoreboard b{font-size:28px}.basket-hoop-wrap{right:12px;top:82px;transform:scale(.72);transform-origin:top right}.basket-prompt-card{flex-direction:column}.basket-prompt-card b{font-size:20px}.basket-prompt-emoji{font-size:34px}}

/* Football Speller / Penalty Shootout */

.football-layout{display:grid;grid-template-columns:1fr;gap:18px;align-items:start;margin-top:30px;max-width:860px;margin-left:auto;margin-right:auto}.football-pitch{position:relative;min-height:560px;border-radius:22px;overflow:hidden;border:4px solid rgba(255,255,255,.85);background:linear-gradient(180deg,#22c55e 0%,#16a34a 48%,#15803d 100%);box-shadow:0 18px 38px rgba(0,0,0,.3)}.football-pitch:before{content:"";position:absolute;inset:16px;border:3px solid rgba(255,255,255,.45);border-radius:18px}.football-pitch:after{content:"";position:absolute;left:50%;bottom:34px;width:300px;height:150px;transform:translateX(-50%);border:4px solid rgba(255,255,255,.35);border-bottom:0;border-radius:160px 160px 0 0}.football-scoreboard{position:absolute;left:22px;top:20px;z-index:2;background:#111827;color:#fff;border:3px solid #e8c85e;border-radius:16px;padding:12px 16px;min-width:220px;box-shadow:0 10px 24px rgba(0,0,0,.25)}.football-scoreboard b{display:block;color:#f6dc7a;font-size:13px;letter-spacing:.12em}.football-scoreboard span{display:block;margin-top:6px;font-weight:950;font-size:16px}.football-goal{position:absolute;left:50%;top:58px;transform:translateX(-50%);width:300px;height:172px;border:12px solid #f8fafc;border-bottom:10px solid #f8fafc;border-radius:10px 10px 4px 4px;background:rgba(255,255,255,.18);box-shadow:0 14px 32px rgba(0,0,0,.28);z-index:1}.football-net{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.25) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.25) 1px,transparent 1px);background-size:24px 24px}.football-keeper{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);font-size:62px;filter:drop-shadow(0 8px 10px rgba(0,0,0,.25));transition:transform .35s ease}.football-keeper.save{transform:translateX(-50%) translateY(-8px) scale(1.15) rotate(-12deg)}.football-keeper.dive-wrong{transform:translateX(-118px) translateY(-6px) rotate(-25deg)}.football-ball{position:absolute;left:50%;bottom:128px;transform:translateX(-50%);font-size:54px;z-index:3;filter:drop-shadow(0 10px 12px rgba(0,0,0,.35));transition:all .7s cubic-bezier(.18,.8,.24,1)}.football-ball.goal{bottom:404px;transform:translateX(-50%) scale(.46);opacity:.95}.football-ball.saved{bottom:290px;transform:translateX(-28px) scale(.76) rotate(35deg)}.football-ball.saved-done{bottom:250px;transform:translateX(-30px) scale(.8) rotate(25deg)}.football-status{position:absolute;left:28px;right:28px;bottom:26px;z-index:2;background:rgba(255,255,255,.92);color:#111827;border-radius:16px;padding:15px 18px;font-weight:950;font-size:17px;text-align:center}.football-card{background:#f8fafc;color:#111827;border-radius:22px;padding:18px;box-shadow:0 16px 32px rgba(0,0,0,.25)}.football-card small{display:block;text-transform:uppercase;letter-spacing:.12em;color:#667085;font-weight:950}.football-card h2{font-size:24px;line-height:1.08;margin:5px 0 14px}.football-word-card{min-height:118px;background:#fff;border:1px solid #d7dde8;border-radius:18px;display:flex;align-items:center;justify-content:center;gap:18px;position:relative;padding:16px 76px 16px 18px}.football-emoji{font-size:62px}.football-word-card .speaker-btn{position:absolute;right:16px;top:50%;transform:translateY(-50%)}.football-answer-row{min-height:62px;border:2px dashed #e8c85e;background:#fff7ed;border-radius:16px;margin:14px 0;padding:9px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.football-answer-row span{color:#94a3b8;font-weight:950}.football-answer-letter,.football-letter-tile{border:0;border-radius:12px;background:#111827;color:#fff;font-weight:950;font-size:26px;min-width:46px;height:50px;padding:0 14px;box-shadow:0 5px 0 rgba(0,0,0,.25);cursor:pointer}/* Selected letters in the answer/making-word row are intentionally smaller than the letter-bank buttons.
   This keeps mobile words such as family, sister, brother, purple, yellow, etc. on one line. */
.football-answer-letter{background:#e8c85e;color:#111827;font-size:21px;min-width:38px;height:42px;padding:0 10px;border-radius:10px}
.football-answer-row{flex-wrap:nowrap;overflow-x:auto;justify-content:center;scrollbar-width:none}
.football-answer-row::-webkit-scrollbar{display:none}.football-letter-tile.used{opacity:.18;cursor:default}.football-letters{display:flex;gap:9px;flex-wrap:wrap;justify-content:center;margin-bottom:14px}.football-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.football-actions button{border:0;border-radius:16px;padding:12px 14px;font-size:15px;font-weight:950;cursor:pointer}.green-btn{background:#16a34a;color:#fff}.grey-btn{background:#475569;color:#fff}.gold-btn{background:#f6dc7a;color:#111827}@media(max-width:860px){.football-layout{max-width:100%}.football-pitch{min-height:480px}.football-goal{width:240px;height:140px}.football-emoji{font-size:54px}.football-card h2{font-size:22px}.football-actions{grid-template-columns:1fr 1fr}.football-scoreboard{position:absolute;left:18px;top:18px;min-width:190px}.football-ball{bottom:104px}.football-ball.goal{bottom:350px}}@media(max-width:520px){.football-answer-row{min-height:50px;gap:5px;padding:7px}.football-answer-letter{font-size:18px;min-width:30px;height:36px;padding:0 7px;border-radius:9px;box-shadow:0 4px 0 rgba(0,0,0,.22)}}



/* v32 Football Speller UI integration */
.football-field-panel{
  position:absolute;
  left:28px;
  right:28px;
  bottom:22px;
  z-index:4;
  display:grid;
  grid-template-columns:1fr auto;
  gap:14px;
  align-items:center;
}
.football-field-panel .football-status{
  position:static;
  left:auto;
  right:auto;
  bottom:auto;
  background:rgba(255,255,255,.94);
  color:#111827;
  border-radius:16px;
  padding:15px 18px;
  font-weight:950;
  font-size:17px;
  text-align:center;
}
.football-field-shot{
  border:0;
  border-radius:16px;
  padding:15px 22px;
  font-size:17px;
  font-weight:950;
  white-space:nowrap;
  box-shadow:0 10px 22px rgba(0,0,0,.22);
  cursor:pointer;
}
.football-actions-no-shot{grid-template-columns:repeat(3,minmax(0,1fr));}
.football-ball.goal{bottom:410px;transform:translateX(-50%) scale(.42);opacity:.98;}
@media(max-width:860px){
  .football-field-panel{grid-template-columns:1fr;left:18px;right:18px;bottom:18px;gap:10px;}
  .football-field-shot{width:100%;}
  .football-actions-no-shot{grid-template-columns:1fr 1fr;}
  .football-ball.goal{bottom:348px;}
}

/* Three Cups Game */
.cups-game-wrap{max-width:900px;margin:28px auto 0;}
.cups-board{position:relative;background:#fff;color:#111827;border-radius:24px;min-height:390px;border:1px solid #d8e0eb;box-shadow:0 20px 42px rgba(0,0,0,.28);overflow:hidden;padding:24px;}
.cups-instruction{position:absolute;left:22px;right:22px;top:18px;background:#17213a;color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:13px 16px;font-weight:950;text-align:center;z-index:5;}
.cups-stage{position:absolute;left:50%;top:56%;transform:translate(-50%,-50%);width:min(760px,94%);height:250px;}
.cup-shell{position:absolute;top:86px;width:150px;height:150px;border:0;background:transparent;cursor:pointer;transition:left .78s cubic-bezier(.18,.82,.28,1), transform .32s ease, filter .2s ease;transform:translateX(-50%);z-index:3;opacity:1 !important;}
.cup-shell[aria-disabled="true"]{cursor:default;pointer-events:none;opacity:1 !important;}
.cups-board .cup-shell[aria-disabled="true"] .cup-emoji,.cups-board.mixing .cup-shell .cup-emoji,.cups-board.covering .cup-shell .cup-emoji,.cups-board.pick .cup-shell .cup-emoji{opacity:1 !important;filter:drop-shadow(0 14px 16px rgba(0,0,0,.22));}
.cup-pos-0{left:18%;}.cup-pos-1{left:50%;}.cup-pos-2{left:82%;}
.cup-emoji{position:absolute;left:50%;bottom:0;transform:translateX(-50%);font-size:112px;filter:drop-shadow(0 14px 16px rgba(0,0,0,.22));z-index:3;}
.cups-ball{position:absolute;bottom:18px;transform:translateX(-50%);font-size:38px;z-index:1;transition:left .48s cubic-bezier(.18,.82,.28,1), opacity .2s ease;}
.cup-ball-pos-0{left:18%;}.cup-ball-pos-1{left:50%;}.cup-ball-pos-2{left:82%;}
.cups-board.covering .cups-ball,.cups-board.mixing .cups-ball,.cups-board.pick .cups-ball{opacity:0;}
.cup-shell.lifted{transform:translateX(-50%) translateY(-66px) rotate(-4deg);}
.cup-shell.winner .cup-emoji{filter:drop-shadow(0 14px 16px rgba(0,0,0,.22)) drop-shadow(0 0 12px rgba(34,197,94,.75));}
.cup-shell.miss .cup-emoji{filter:drop-shadow(0 14px 16px rgba(0,0,0,.22)) drop-shadow(0 0 10px rgba(244,63,94,.65));}
.cups-board.mixing .cup-shell{filter:none;opacity:1 !important;}
.cups-board.pick .cup-shell{animation:none;}
.cups-actions{display:flex;justify-content:center;margin-top:18px;}
.cups-start-btn{min-width:210px;height:52px;border-radius:18px;font-size:18px;}
.cups-note{text-align:center;color:#cbd5e1;font-size:13px;font-weight:800;margin:12px 0 0;}
@media(max-width:720px){.cups-board{min-height:330px;padding:18px}.cups-stage{height:210px}.cup-shell{width:104px;height:120px;top:82px}.cup-emoji{font-size:84px}.cups-ball{font-size:30px;bottom:12px}.cup-shell.lifted{transform:translateX(-50%) translateY(-48px) rotate(-4deg)}.cups-instruction{font-size:14px;}.cups-stage{width:96%;}.cup-pos-0,.cup-ball-pos-0{left:17%;}.cup-pos-1,.cup-ball-pos-1{left:50%;}.cup-pos-2,.cup-ball-pos-2{left:83%;}}


/* Lucky Machine - ported from Streamlit prize-machine logic */
.lucky-wrap{max-width:820px;margin:0 auto 40px}.lucky-panel{border:1px solid rgba(251,191,36,.35);border-radius:32px;padding:28px;background:radial-gradient(circle at top,rgba(251,191,36,.2),transparent 35%),linear-gradient(145deg,#111827,#020617);box-shadow:0 20px 48px rgba(0,0,0,.36),inset 0 1px 0 rgba(255,255,255,.08);text-align:center}.lucky-machine-head{display:flex;justify-content:space-between;gap:16px;align-items:center;text-align:left}.lucky-machine-head b{display:block;font-size:26px;color:#f8fafc}.lucky-machine-head small{display:block;color:#cbd5e1;margin-top:6px}.lucky-reels{display:flex;justify-content:center;gap:18px;margin:28px 0 20px}.lucky-reel{width:150px;height:150px;display:flex;align-items:center;justify-content:center;border-radius:26px;border:2px solid rgba(251,191,36,.45);background:linear-gradient(180deg,#f8fafc,#e5e7eb);color:#020617;font-size:78px;box-shadow:inset 0 8px 22px rgba(15,23,42,.18),0 14px 28px rgba(0,0,0,.25)}.lucky-reels.is-spinning .lucky-reel{animation:luckyJiggle .18s linear infinite}.lucky-reels.is-spinning .lucky-reel:nth-child(2){animation-delay:.04s}.lucky-reels.is-spinning .lucky-reel:nth-child(3){animation-delay:.08s}@keyframes luckyJiggle{0%{transform:translateY(0) rotate(0)}50%{transform:translateY(-5px) rotate(1deg)}100%{transform:translateY(0) rotate(0)}}.lucky-message{font-size:30px;font-weight:950;color:#fde68a;margin:12px 0 14px;min-height:42px}.lucky-pull{height:52px;font-size:18px;border-radius:18px;margin-top:10px}.lucky-pull:disabled{opacity:.5;cursor:not-allowed}.lucky-warning{color:#fecaca;font-weight:900}.lucky-prize-card{display:inline-flex;align-items:center;gap:12px;border:1px solid rgba(251,191,36,.32);border-radius:18px;background:rgba(15,23,42,.64);padding:10px 16px;margin:0 0 12px;color:#f8fafc}.lucky-prize-card span{font-size:34px}.lucky-prize-card b{font-size:18px}.lucky-prize-card small{color:#cbd5e1;font-weight:900}.lucky-rules{margin:18px auto 0;border:1px solid rgba(148,163,184,.24);border-radius:20px;padding:16px 20px;background:rgba(15,23,42,.55);color:#cbd5e1}.lucky-rules b{color:#f8fafc}.lucky-odds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:14px}.lucky-odds-grid span{border:1px solid rgba(148,163,184,.22);border-radius:12px;background:rgba(2,6,23,.32);padding:8px;font-size:12px;font-weight:900;color:#dbeafe}@media(max-width:720px){.lucky-machine-head{display:block;text-align:center}.lucky-machine-head .dark-btn{margin-top:12px}.lucky-reels{gap:10px}.lucky-reel{width:92px;height:92px;font-size:48px}.lucky-odds-grid{grid-template-columns:repeat(2,1fr)}}


/* Shop / Recipe Book / Crafting Cauldron */
.shop-wrap{max-width:1100px;margin:0 auto 60px;}
.shop-actions{display:grid;grid-template-columns:repeat(3,minmax(140px,1fr));gap:18px;margin:16px 0 12px;}
.refresh-credit-note{display:inline-flex;align-items:center;justify-content:center;max-width:100%;margin:0 0 18px;padding:8px 13px;border-radius:999px;border:1px solid rgba(251,191,36,.28);background:rgba(251,191,36,.1);color:#fde68a;font-size:12px;font-weight:950;letter-spacing:.01em;}
.claw-refresh-note{width:100%;box-sizing:border-box;margin-top:8px;margin-bottom:0;border-radius:14px;text-align:center;}
.shop-section{border-top:1px solid rgba(255,255,255,.16);padding:28px 0;}
.shop-section h2{font-size:30px;margin:0 0 10px;color:#fff;}
.shop-section h3{font-size:24px;margin:20px 0 10px;color:#fff;}
.shop-section p{color:#d5dbea;margin:0 0 16px;}
.shop-grid{display:grid;grid-template-columns:repeat(3,minmax(210px,1fr));gap:18px 64px;}
.shop-card{background:rgba(8,14,32,.58);border:1px solid rgba(255,255,255,.18);border-radius:10px;min-height:190px;text-align:center;padding:18px 16px;box-shadow:0 16px 26px rgba(0,0,0,.18);}
.shop-emoji{font-size:50px;line-height:1.1;margin-bottom:8px;}
.shop-card h3{font-size:24px;margin:4px 0 12px;}
.shop-meta{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px;}
.rarity-pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 12px;font-weight:900;font-size:12px;background:#3b465a;color:#fff;border:1px solid rgba(255,255,255,.2);}
.rarity-pill.common{background:#3d4654}.rarity-pill.uncommon{background:#20583f}.rarity-pill.rare{background:#263f6d}.rarity-pill.epic{background:#4b2b72}.rarity-pill.legendary{background:#7a4d12}.rarity-pill.worthless{background:#333;color:#bbb;}
.sell-list{display:grid;gap:14px;}
.sell-row{display:grid;grid-template-columns:1fr 170px 135px;align-items:center;gap:16px;background:rgba(8,14,32,.58);border:1px solid rgba(255,255,255,.16);border-radius:10px;padding:16px;}
.sell-main{display:flex;align-items:center;gap:20px;}
.sell-main>span{font-size:34px;min-width:48px;text-align:center;}
.sell-main b{font-size:19px;color:#fff;display:block;margin-bottom:6px;}
.sell-main small{color:#d7deef;font-weight:700;}
.sell-price{border:1px solid rgba(255,255,255,.13);border-radius:14px;text-align:center;padding:12px;background:rgba(0,0,0,.15);}
.sell-price b{display:block;font-size:20px;color:#ffe87a}.sell-price small{font-size:11px;font-weight:800;color:#d7deef;}
.select-label{display:block;font-size:13px;font-weight:900;color:#d7deef;margin:12px 0 8px;}
.wide-select{width:100%;background:#070d20;color:#fff;border:1px solid rgba(255,255,255,.22);border-radius:7px;padding:12px;font-weight:800;}
.helper-results{margin:18px 0;display:grid;gap:12px;}
.recipe-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:12px;max-height:520px;overflow:auto;padding-right:6px;}
.recipe-card{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:rgba(8,14,32,.58);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:14px;}
.recipe-formula{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:18px;color:#fff;}
.recipe-formula span{font-size:27px}.recipe-formula b{font-size:16px}.recipe-result-emoji{filter:drop-shadow(0 0 10px rgba(251,190,72,.45));}
.recipe-result{text-align:right}.recipe-result b{display:block;color:#fff}.recipe-result small{color:#ffe87a;font-weight:800;}

.recipe-book-modal-backdrop{position:fixed;inset:0;z-index:2600;display:flex;align-items:center;justify-content:center;padding:28px;background:rgba(2,6,23,.76);backdrop-filter:blur(3px);}
.recipe-book-modal{position:relative;width:min(980px,calc(100vw - 32px));max-height:min(82vh,780px);overflow:hidden;border:1px solid rgba(251,191,36,.55);border-radius:24px;background:radial-gradient(circle at top left,rgba(251,191,36,.14),transparent 36%),linear-gradient(145deg,#0d1b34,#070d20);box-shadow:0 28px 80px rgba(0,0,0,.62),0 0 0 1px rgba(255,255,255,.08) inset;padding:24px;}
.recipe-book-modal-head{padding:0 66px 16px 0;border-bottom:1px solid rgba(255,255,255,.14);margin-bottom:16px;}
.recipe-book-modal-head h2{font-size:30px;line-height:1.08;margin:0 0 7px;color:#fff;}
.recipe-book-modal-head p{margin:0;color:#d5dbea;font-weight:800;}
.recipe-book-close{position:absolute;right:16px;top:14px;width:54px;height:54px;border-radius:18px;border:2px solid rgba(255,255,255,.82);background:linear-gradient(180deg,#f87171,#dc2626);color:#fff;font-size:38px;font-weight:950;line-height:46px;cursor:pointer;box-shadow:0 8px 0 rgba(127,29,29,.62),0 16px 30px rgba(0,0,0,.36);text-shadow:0 2px 0 rgba(0,0,0,.28);}
.recipe-book-close:hover{transform:translateY(-1px);filter:brightness(1.06);}
.recipe-book-close:active{transform:translateY(4px);box-shadow:0 4px 0 rgba(127,29,29,.62),0 10px 20px rgba(0,0,0,.28);}
.recipe-modal-grid{max-height:calc(min(82vh,780px) - 150px);overflow:auto;padding:2px 8px 4px 2px;}

.brew-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:18px 0 16px;}.brew-row label{color:#d7deef;font-weight:900;font-size:13px;}
.brew-btn{width:100%;}
.inventory-bottom{background:rgba(8,14,32,.48);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:20px;margin-top:16px;}
.inventory-full{display:flex;gap:12px;flex-wrap:wrap;font-size:20px;color:#fff}.inventory-full span{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);padding:7px 10px;border-radius:999px;}
@media(max-width:900px){.shop-actions,.shop-grid,.recipe-grid,.brew-row{grid-template-columns:1fr}.sell-row{grid-template-columns:1fr}.recipe-result{text-align:left}}

/* v40: Fix Shop/Cauldron closed dropdown clipping.
   The global input/select rule forced 36px height, which clipped emoji labels
   inside the Recipe Helper and Brew item selects when closed. */
.shop-wrap select.wide-select,
.cauldron-section select.wide-select,
.recipe-book-panel select.wide-select{
  height:48px;
  min-height:48px;
  line-height:48px;
  padding:0 14px;
  font-size:16px;
  font-weight:900;
  color:#ffffff;
  background:#070d20;
  box-sizing:border-box;
  overflow:visible;
}
.shop-wrap select.wide-select option,
.cauldron-section select.wide-select option,
.recipe-book-panel select.wide-select option{
  background:#070d20;
  color:#ffffff;
  font-size:16px;
  line-height:1.6;
}


/* Claw Machine */
.claw-wrap{display:grid;grid-template-columns:minmax(390px,1.45fr) minmax(280px,.85fr);gap:24px;align-items:start;margin:14px auto 48px;}
.claw-board-panel,.claw-control-panel{border:1px solid rgba(148,163,184,.28);background:rgba(15,23,42,.58);border-radius:20px;padding:16px;box-shadow:0 18px 36px rgba(0,0,0,.2)}
.claw-tube{height:30px;border:1px solid rgba(148,163,184,.28);background:rgba(255,255,255,.08);border-radius:999px;margin-bottom:10px;}
.claw-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:9px;}
.claw-cell{height:68px;border:2px solid rgba(255,255,255,.18);border-radius:12px;background:rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;color:#fff;}
.claw-cell:disabled{cursor:default}.claw-cell.selected{border-color:#f6dc7a;box-shadow:0 0 0 3px rgba(251,191,36,.18),0 0 26px rgba(251,191,36,.28);transform:translateY(-1px)}
.claw-cell.caught{opacity:.45}.claw-emoji{font-size:31px;line-height:1}.rarity-pill{font-size:9px;font-weight:950;border-radius:999px;background:#334155;color:#fff;padding:2px 6px;margin-top:2px;line-height:1.1}.rarity-uncommon{background:#166534}.rarity-rare{background:#1e3a8a}.rarity-epic{background:#581c87}.rarity-legendary,.rarity-mythic{background:#7c2d12}.rarity-worthless{background:#334155}
.claw-start{width:100%;height:48px;border-radius:16px;font-size:16px;margin-bottom:8px}.claw-start:disabled{opacity:.48;cursor:not-allowed}.claw-limit-note{margin:0 0 12px;text-align:center;color:#cbd5e1;font-size:12px;font-weight:950}.claw-limit-note.limit-reached{color:#fde68a}.claw-controls-card{border:1px solid rgba(148,163,184,.24);background:rgba(2,6,23,.34);border-radius:18px;padding:14px;margin:0 0 18px;overflow:hidden}.claw-controls-title{text-align:center;text-transform:uppercase;letter-spacing:.08em;color:#67e8f9;font-size:12px;font-weight:950;margin-bottom:10px}.claw-controls{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr) minmax(0,1fr);grid-template-areas:". up ." "left grab right" ". down .";gap:8px;align-items:center;justify-items:stretch}.claw-controls.disabled{opacity:.45;pointer-events:none}.claw-controls button{border:1px solid rgba(251,191,36,.42);background:#f6dc7a;color:#07111f;font-weight:950;border-radius:14px;min-width:0;width:100%;height:44px;box-shadow:0 10px 20px rgba(251,191,36,.16);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;line-height:1;font-size:13px}.claw-controls button b{font:inherit;white-space:nowrap}.claw-controls #clawUp{grid-area:up}.claw-controls #clawDown{grid-area:down}.claw-controls #clawLeft{grid-area:left}.claw-controls #clawRight{grid-area:right}.claw-controls .claw-grab{grid-area:grab;height:56px;border-radius:16px;flex-direction:column;gap:2px;text-transform:uppercase}.claw-selected-card{border:1px solid rgba(148,163,184,.24);background:rgba(2,6,23,.4);border-radius:16px;padding:12px;display:grid;grid-template-columns:46px 1fr;gap:2px 12px;align-items:center;clear:both}.claw-selected-card span{grid-row:1/3;font-size:34px}.claw-selected-card b{font-size:18px;color:#fff}.claw-selected-card small{font-weight:850;color:#cbd5e1}.claw-message{min-height:48px;color:#dbeafe;font-weight:900;margin:14px 0!important}.claw-control-panel .dark-btn{width:100%;}.claw-control-panel .dark-btn:disabled,.shop-actions .gold-btn:disabled{opacity:.48;cursor:not-allowed;filter:saturate(.8);}
@media(max-width:760px){.claw-wrap{grid-template-columns:1fr;gap:14px;margin-top:8px}.claw-board-panel,.claw-control-panel{padding:12px;border-radius:18px}.claw-grid{gap:7px}.claw-cell{height:54px;border-radius:10px}.claw-emoji{font-size:25px}.rarity-pill{font-size:8px;padding:2px 5px}.claw-start{height:44px;margin-bottom:8px}.claw-limit-note{margin-bottom:10px}.claw-controls-card{padding:10px;margin-bottom:12px}.claw-controls{gap:7px;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr)}.claw-controls button{height:40px;border-radius:12px;font-size:12px;gap:3px}.claw-controls .claw-grab{height:48px}.claw-selected-card{margin-top:4px;grid-template-columns:38px 1fr;padding:10px}.claw-selected-card span{font-size:30px}.claw-selected-card b{font-size:16px}.claw-message{min-height:32px;margin:10px 0!important}}
@media(max-width:420px){.claw-wrap{gap:12px}.claw-board-panel,.claw-control-panel{padding:10px}.claw-grid{gap:6px}.claw-cell{height:49px}.claw-emoji{font-size:23px}.rarity-pill{font-size:7px;padding:2px 4px}.claw-controls button{font-size:11px}.claw-controls button span{display:none}.claw-selected-card small{font-size:11px}}


.badge-progress-empty{margin:8px 0 12px;color:#c2cada}.badge-progress-row{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 14px}.badge-chip{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--border-soft);background:#08111f;border-radius:999px;color:#f3f7ff;font-size:12px;font-weight:900;padding:7px 11px}.earned-badge-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.earned-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(247,189,67,.45);background:linear-gradient(180deg,#172235,#101827);border-radius:13px;padding:8px 11px;color:#fff;font-size:12px;font-weight:950}.earned-badge img{width:34px;height:34px;object-fit:contain;border-radius:8px}.game-coin-bar .badge-progress-row{margin:8px 0 0}.game-coin-bar .badge-chip{font-size:11px;padding:5px 8px}


/* Parent / Teacher Reward Lock */
.parent-lock-page{display:grid;gap:18px;max-width:920px;margin-top:28px;}
.lock-status-card,.lock-warning-card,.lock-action-card{border:1px solid rgba(255,255,255,.16);background:rgba(15,23,42,.74);border-radius:22px;padding:22px;box-shadow:0 18px 36px rgba(0,0,0,.22);}
.lock-status-card{display:flex;align-items:center;gap:18px;border-color:rgba(251,191,36,.45);}
.lock-status-card.unlocked{border-color:rgba(34,197,94,.65);background:linear-gradient(135deg,rgba(20,83,45,.55),rgba(15,23,42,.78));}
.lock-status-card.locked{border-color:rgba(251,191,36,.45);}
.lock-icon{font-size:54px;line-height:1;filter:drop-shadow(0 10px 20px rgba(0,0,0,.28));}
.lock-status-card h2,.lock-warning-card h2{margin:0 0 8px;font-size:30px;font-weight:950;}
.lock-status-card p,.lock-warning-card p,.lock-action-card p{color:#d8e2f1;font-weight:800;line-height:1.45;margin:8px 0;}
.lock-warning-card hr{border:0;border-top:1px solid rgba(255,255,255,.16);margin:16px 0;}
.lock-action-card{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:center;}
.lock-action-card .tiny{grid-column:1/-1;margin:0;color:#aeb8ca;}
.dark-btn{border:1px solid rgba(255,255,255,.16);border-radius:18px;background:#111827;color:#fff;font-weight:950;padding:14px 18px;cursor:pointer;}
.dark-btn:hover{filter:brightness(1.12);transform:translateY(-1px);}
@media(max-width:680px){.lock-action-card{grid-template-columns:1fr}.lock-status-card{align-items:flex-start}.lock-status-card h2,.lock-warning-card h2{font-size:24px}}


/* v45 Red vs Blue / avatar mode */
.load-grid{grid-template-columns:1fr 1fr 110px 160px}.avatar-field select{font-size:22px;text-align:center}.team-mode-card{border:1px solid var(--border);background:linear-gradient(180deg,#172235,#101827);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow)}.team-toggle{display:flex;align-items:center;gap:12px;flex-wrap:wrap;color:#fff}.team-toggle input{width:22px;height:22px;accent-color:#f43f5e}.team-toggle b{font-size:18px}.team-toggle span{color:#c2cada;font-size:12px;font-weight:800}.team-controls{display:grid;grid-template-columns:1fr 1fr 1fr 150px;gap:12px;margin-top:14px;align-items:end}.team-score-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:14px}.team-score-row span{border:1px solid var(--border-soft);border-radius:999px;background:#08111f;padding:8px 13px;font-weight:950}.red-score,.team-red{color:#fecaca}.blue-score,.team-blue{color:#bfdbfe}.team-mode-on #currencyLabel::before{content:'Team ';}.team-mode-on .profile-stats .stat:first-child span{font-size:0}.team-mode-on .profile-stats .stat:first-child span:after{content:'POINTS';font-size:8px}.team-mode-on .profile-title p:after{content:' Red vs Blue mode is active: coins are replaced by team points.';color:#fde68a}.team-mode-on .inventory-bar:before{content:'Team mode: ';color:#fde68a;font-size:13px;font-weight:950;margin-right:8px}.team-mode-on .open-shop-btn{opacity:.55}.reward-buttons button span{opacity:.85}.team-mode-on .leaderboard-section strong span{font-size:0}.team-mode-on .leaderboard-section strong span:after{content:'Points';font-size:8px;color:#fff;text-transform:uppercase}
@media(max-width:760px){.load-grid,.team-controls{grid-template-columns:1fr}.team-score-row{display:grid;grid-template-columns:1fr 1fr}}
.empty-leader{opacity:.85;padding:18px;text-align:center;}
#leaderboardList .leader strong span{display:block;font-size:.68rem;opacity:.75;text-transform:uppercase;letter-spacing:.04em;}


/* Warm-Up Slides: Streamlit-style fixed decks and category scene board */
.warmup-page{margin-top:24px}.warm-question{font-size:54px;font-weight:950;text-align:center;margin:8px 0 32px;color:var(--text)}
.warm-grid{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:14px;margin:8px 0 20px}.warm-grid.large{gap:14px}.warm-card{border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,var(--panel),#1b263a);box-shadow:var(--shadow);padding:18px 12px;text-align:center;min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:#fff}.warm-grid.large .warm-card{min-height:132px}.warm-card:hover{transform:translateY(-2px);border-color:#71809c}.warm-emoji{font-size:58px;line-height:1.05}.warm-grid.large .warm-emoji{font-size:66px}.warm-card b{font-size:21px;font-weight:900;margin-top:10px;color:#fff;line-height:1.1}.warm-grid.large .warm-card b{font-size:16px}.teacher-note{font-size:16px;color:#cbd5e1;text-align:center;margin-top:-12px;margin-bottom:12px}.scene-board{position:relative;overflow:hidden;border-radius:28px;padding:18px;background:linear-gradient(180deg,rgba(125,211,252,.28),rgba(34,197,94,.22));border:1px solid var(--border);box-shadow:0 16px 36px var(--shadow)}.scene-anchor{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:390px;line-height:1;opacity:.18;filter:saturate(1.15);z-index:0;pointer-events:none;font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji",sans-serif}.scene-label{position:relative;z-index:2;text-align:center;font-size:18px;font-weight:900;margin-bottom:10px;color:#dbe6f7;letter-spacing:.3px}.scene-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.scene-cell{min-height:86px;border-radius:18px;background:rgba(255,255,255,.34);display:flex;align-items:center;justify-content:center;font-size:54px;box-shadow:inset 0 1px 0 rgba(255,255,255,.38);font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji",sans-serif}.warm-scene-actions{display:grid;grid-template-columns:1fr 1fr 2fr;gap:14px;margin:14px 0 8px}.warm-nav{display:grid;grid-template-columns:1fr 1fr 2fr;gap:14px;align-items:center;margin-top:16px}.warm-nav small{color:#aeb8ca;font-weight:800}.warm-nav .gold-btn,.warm-scene-actions .gold-btn{height:44px;border-radius:14px}
@media(max-width:900px){.warm-question{font-size:40px}.warm-grid{grid-template-columns:repeat(3,1fr)}.scene-grid{gap:8px}.scene-cell{min-height:64px;font-size:42px}.scene-anchor{font-size:280px}.warm-nav,.warm-scene-actions{grid-template-columns:1fr 1fr}.warm-nav small{grid-column:1/-1}}
@media(max-width:560px){.warm-grid{grid-template-columns:repeat(2,1fr)}.scene-cell{min-height:50px;font-size:32px}.warm-card b{font-size:16px}.warm-emoji{font-size:46px}}

/* Parent lock: hide visible coin/reward UI while rewards are locked. */
body.rewards-locked .profile-stats .stat:first-child{display:none;}
body.rewards-locked .inventory-bar::before{content:'Rewards locked. Unlock from Parent Lock to show coins and reward controls.';color:#fde68a;font-weight:950;}
body.rewards-locked .leaderboard-section small{visibility:hidden;}
body.rewards-locked .leaderboard-section small::after{content:'Rewards locked';visibility:visible;color:#fde68a;}


/* v53 parent-lock hard hide: no Red vs Blue / coin bars while locked */
body.rewards-locked .team-mode-section,
body.rewards-locked .game-reward-row,
body.rewards-locked .reward-buttons,
body.rewards-locked .profile-stats,
body.rewards-locked .inventory-bar{display:none !important;}
body.rewards-locked .profile-title p{font-size:0;}
body.rewards-locked .profile-title p::after{content:'Rewards are locked. Student coins, inventories, leaderboards, and Red vs Blue points are hidden.';font-size:12px;color:#cbd5e1;}

/* Settings information page */
.settings-info-card{max-width:820px;margin:0 auto 44px;display:grid;gap:18px}.settings-hero-card,.settings-panel,.settings-note{border:1px solid var(--border);background:linear-gradient(180deg,var(--panel),#182338);border-radius:22px;box-shadow:var(--shadow)}.settings-hero-card{display:grid;grid-template-columns:86px 1fr;gap:18px;align-items:center;padding:24px}.settings-avatar{width:72px;height:72px;border-radius:22px;border:1px solid rgba(56,189,248,.45);background:#12314f;display:flex;align-items:center;justify-content:center;font-size:42px}.settings-hero-card h2,.settings-panel h3{margin:0 0 10px;color:#f8fafc}.settings-hero-card p,.settings-panel p,.settings-note p{margin:0;color:#cbd5e1;line-height:1.55;font-weight:700}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.settings-panel{padding:22px}.wechat-box{margin-top:16px;border:1px solid rgba(247,189,67,.5);border-radius:16px;background:rgba(247,189,67,.1);padding:14px 16px}.wechat-box span{display:block;color:#fde68a;text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:950}.wechat-box b{display:block;color:#fff;font-size:30px;letter-spacing:.02em;margin-top:5px}.settings-note{padding:20px 22px}.settings-note b{display:block;color:var(--gold);font-size:20px;margin-bottom:8px}@media(max-width:720px){.settings-hero-card,.settings-grid{grid-template-columns:1fr}.settings-hero-card{text-align:center}.settings-avatar{margin:0 auto}}

.seasonal-event-note{margin:.35rem 0 .75rem;padding:.55rem .7rem;border:1px solid rgba(255,255,255,.18);border-radius:12px;background:rgba(255,214,102,.12);font-size:.95rem;}


/* Homepage seasonal live-event stamp */
.hero{position:relative;display:flex;justify-content:center;align-items:center;margin-bottom:16px;}
.hero img{margin-bottom:0;}
.seasonal-event-stamp{position:absolute;right:4px;top:50%;transform:translateY(-50%) rotate(3deg);width:178px;min-height:132px;border:3px solid #f7bd43;border-radius:22px;background:radial-gradient(circle at 20% 18%,rgba(255,255,255,.28),transparent 28%),linear-gradient(160deg,#3b1f63,#111b2e 55%,#08111f);box-shadow:0 14px 34px rgba(0,0,0,.34),0 0 0 5px rgba(247,189,67,.16);padding:12px 12px 10px;text-align:center;color:#fff;z-index:3;overflow:hidden;animation:seasonalStampPulse 2.4s ease-in-out infinite;}
.seasonal-event-stamp[hidden]{display:none!important;}
.seasonal-event-stamp:before{content:"";position:absolute;inset:8px;border:1px dashed rgba(255,255,255,.48);border-radius:16px;pointer-events:none;}
.seasonal-event-stamp img{width:42px;height:42px;object-fit:contain;margin:6px auto 0;border-radius:50%;filter:drop-shadow(0 6px 12px rgba(0,0,0,.35));}
.seasonal-stamp-top{font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:950;color:#fde68a;}
.seasonal-stamp-main{font-size:20px;line-height:1.02;font-weight:950;margin-top:5px;text-shadow:0 2px 8px rgba(0,0,0,.35);}
.seasonal-stamp-zh{font-size:13px;font-weight:900;color:#dbeafe;margin-top:3px;}
.seasonal-stamp-bottom{font-size:11px;line-height:1.18;font-weight:900;color:#fef3c7;margin-top:7px;}
@keyframes seasonalStampPulse{0%,100%{transform:translateY(-50%) rotate(3deg) scale(1)}50%{transform:translateY(-50%) rotate(1deg) scale(1.035)}}
@media(max-width:980px){.hero{display:block}.seasonal-event-stamp{position:relative;right:auto;top:auto;transform:rotate(0);width:min(440px,92vw);min-height:0;margin:10px auto 18px;padding:12px 64px 12px 18px;text-align:left;animation:none}.seasonal-event-stamp img{position:absolute;right:18px;top:50%;transform:translateY(-50%);margin:0}.seasonal-stamp-main{font-size:19px}}
@media(max-width:520px){.seasonal-event-stamp{padding-right:58px}.seasonal-stamp-top{font-size:10px}.seasonal-stamp-main{font-size:17px}.seasonal-stamp-bottom{font-size:10px}}

/* Student backup / import controls */
.student-backup-panel{
  margin-top:18px;
}
.backup-status{
  display:inline-block;
  margin:8px 0 12px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  font-weight:700;
}
.backup-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:8px 0 6px;
}
.primary-btn,.ghost-btn{
  border:0;
  border-radius:14px;
  padding:11px 16px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.18);
}
.primary-btn{
  background:#ffe66d;
  color:#183153;
}
.ghost-btn{
  background:rgba(255,255,255,.16);
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
}
.student-backup-panel code{
  background:rgba(0,0,0,.22);
  padding:2px 6px;
  border-radius:6px;
}

/* Seasonal item labels: show festival/event name instead of rarity. */
.rarity-pill.seasonal-item-label{background:linear-gradient(135deg,#e8c85e,#dc2626);color:#fff;border-color:rgba(255,255,255,.34);box-shadow:0 0 0 2px rgba(245,158,11,.18),0 0 14px rgba(245,158,11,.25);letter-spacing:.02em;}
.rarity-pill.seasonal-childrens_day{background:linear-gradient(135deg,#38bdf8,#7c3aed);}
.rarity-pill.seasonal-dragon_boat{background:linear-gradient(135deg,#16a34a,#0f766e);}
.rarity-pill.seasonal-mid_autumn{background:linear-gradient(135deg,#e8c85e,#92400e);}
.rarity-pill.seasonal-national_day{background:linear-gradient(135deg,#ef4444,#e8c85e);}
.rarity-pill.seasonal-halloween{background:linear-gradient(135deg,#f97316,#581c87);}
.rarity-pill.seasonal-thanksgiving{background:linear-gradient(135deg,#b45309,#166534);}
.rarity-pill.seasonal-christmas{background:linear-gradient(135deg,#dc2626,#15803d);}
.rarity-pill.seasonal-spring_festival{background:linear-gradient(135deg,#dc2626,#f6dc7a);}
.rarity-pill.seasonal-easter{background:linear-gradient(135deg,#ec4899,#60a5fa);}
.rarity-pill.seasonal-summer{background:linear-gradient(135deg,#f6dc7a,#f97316);color:#111827;}
.rarity-pill.seasonal-winter{background:linear-gradient(135deg,#bfdbfe,#2563eb);}

.settings-label{display:block;margin:10px 0 6px;font-weight:800;color:#eaf3ff;}
/* Settings dropdowns need their own height. The global input/select rule uses a 36px height,
   which can clip or hide the selected student name when the select is closed. */
.settings-select{width:100%;max-width:360px;height:auto;min-height:44px;line-height:1.25;padding:10px 36px 10px 12px;border-radius:14px;border:1px solid rgba(148,163,184,.45);background:rgba(15,23,42,.92);color:#fff;font-weight:800;}
.settings-select option{background:#101827;color:#fff;}
.student-png-export-panel{border-color:rgba(250,204,21,.45)!important;box-shadow:0 0 0 1px rgba(250,204,21,.10) inset;}

/* Group Class scoring: show both Red and Blue point reward bars inside games. */
.reward-buttons.team-reward-buttons{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-bottom:34px;
}
.reward-buttons.team-reward-buttons .team-reward-group{
  border:1px solid rgba(148,163,184,.35);
  border-radius:16px;
  background:linear-gradient(180deg,#172235,#101827);
  padding:12px;
  box-shadow:0 10px 24px rgba(0,0,0,.16);
}
.reward-buttons.team-reward-buttons .team-reward-title{
  display:block;
  margin:0 0 10px;
  color:#fff;
  font-size:14px;
  font-weight:950;
}
.reward-buttons.team-reward-buttons .team-reward-actions{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
}
.reward-buttons.team-reward-buttons .team-reward-actions button{
  width:100%;
  height:40px;
  margin:0;
}
.reward-buttons.team-reward-buttons .red-team-btn{background:#f7bd43;color:#07111f;border:2px solid rgba(239,68,68,.60)}
.reward-buttons.team-reward-buttons .blue-team-btn{background:#f7bd43;color:#07111f;border:2px solid rgba(59,130,246,.60)}
body.team-mode-on.rewards-locked .game-reward-row,
body.team-mode-on.rewards-locked .reward-buttons,
body.team-mode-on.rewards-locked .team-mode-section{display:grid !important}
body.team-mode-on.rewards-locked .team-mode-section{display:block !important}
@media(max-width:760px){
  .reward-buttons.team-reward-buttons{grid-template-columns:1fr;gap:10px;margin-bottom:28px}
  .reward-buttons.team-reward-buttons .team-reward-actions{grid-template-columns:repeat(3,1fr)}
}

/* v77 parent lock maths check */
.parent-math-card { gap: 12px; }
.parent-math-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin: 12px 0;
}
.parent-math-question {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 14px;
  background: rgba(255,255,255,.06);
}
.parent-math-question input {
  font-size: 1.1rem;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.25);
}
.lockout-message {
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 100, 100, .16);
  border: 1px solid rgba(255, 100, 100, .35);
  font-weight: 800;
}


/* v78 Daily Chest and one-question parent unlock */
.daily-chest-card{display:grid;grid-template-columns:64px 1fr 220px;gap:14px;align-items:center;border:1px solid rgba(251,191,36,.45);background:linear-gradient(135deg,rgba(251,191,36,.13),rgba(15,23,42,.86));border-radius:18px;padding:16px 18px;box-shadow:var(--shadow)}
.daily-chest-icon{width:54px;height:54px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:rgba(251,191,36,.16);border:1px solid rgba(251,191,36,.38);font-size:34px;filter:drop-shadow(0 8px 16px rgba(0,0,0,.25))}
.daily-chest-copy span{display:block;color:var(--cyan);text-transform:uppercase;letter-spacing:.11em;font-size:11px;font-weight:950}
.daily-chest-copy h2{margin:2px 0 5px;font-size:26px;line-height:1;color:#fff}
.daily-chest-copy p{margin:0;color:#cbd5e1;font-size:12px;font-weight:850}.daily-chest-card .gold-btn:disabled{opacity:.65;cursor:not-allowed;filter:saturate(.8)}
.daily-reward-popup{position:fixed;left:50%;top:30%;transform:translate(-50%,-50%) scale(.72);z-index:9999;min-width:260px;max-width:90vw;text-align:center;padding:22px 26px;border-radius:28px;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.22),transparent 48%),linear-gradient(160deg,#172554,#111827);border:2px solid rgba(251,191,36,.78);box-shadow:0 28px 90px rgba(0,0,0,.55),0 0 0 9999px rgba(2,6,23,.30);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease}.daily-reward-popup.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.daily-reward-emoji{font-size:86px;line-height:1;animation:dailyRewardPop .75s ease both}.daily-reward-text{margin-top:10px;font-size:24px;font-weight:950;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.35)}@keyframes dailyRewardPop{0%{transform:scale(.35) rotate(-10deg)}60%{transform:scale(1.18) rotate(4deg)}100%{transform:scale(1) rotate(0)}}
.parent-choice-card{grid-template-columns:1fr!important}.parent-choice-question{border:1px solid rgba(255,255,255,.18);border-radius:18px;background:rgba(255,255,255,.06);padding:24px;text-align:center;font-size:34px;font-weight:950;color:#fff}.parent-choice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.parent-choice-btn{height:52px;font-size:18px;border-radius:16px}.parent-choice-btn:disabled{opacity:.55;cursor:not-allowed}.lockout-message{grid-column:1/-1}
@media(max-width:720px){.daily-chest-card{grid-template-columns:56px 1fr}.daily-chest-card .gold-btn{grid-column:1/-1}.parent-choice-grid{grid-template-columns:1fr}.parent-choice-question{font-size:28px}}


/* Reading Sage */
.reading-sage-wrap{max-width:1100px;margin:0 auto;display:grid;gap:18px}.sage-scene{display:flex;align-items:center;justify-content:center;gap:18px;background:linear-gradient(135deg,rgba(34,22,77,.92),rgba(13,72,105,.9));border:2px solid rgba(255,221,120,.65);border-radius:24px;padding:18px;box-shadow:0 14px 30px rgba(0,0,0,.22)}.sage-character{font-size:92px;filter:drop-shadow(0 8px 10px rgba(0,0,0,.35))}.sage-speech{background:rgba(255,255,255,.94);color:#18213a;border-radius:18px;padding:14px 18px;max-width:560px}.sage-speech p{margin:.3rem 0 0;line-height:1.45}.magic-book{display:grid;grid-template-columns:1fr 1fr;gap:0;filter:drop-shadow(0 16px 22px rgba(0,0,0,.28))}.book-page{min-height:360px;background:#fff8df;color:#21180b;border:3px solid #8a5b20;padding:28px}.book-left{border-radius:28px 4px 4px 28px;border-right:1px dashed #ad8848}.book-right{border-radius:4px 28px 28px 4px;border-left:1px dashed #ad8848}.book-label{display:inline-block;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:#7d5617;font-weight:800;margin-bottom:8px}.book-page h2{margin:.2rem 0 1rem;color:#3a2509}.reading-passage{font-size:1.35rem;line-height:1.65;font-weight:700}.reading-vocab-list{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0 22px}.reading-vocab-list button{border:2px solid #c9972d;background:#fff3bd;color:#2d1c00;border-radius:999px;padding:9px 13px;font-weight:800;cursor:pointer}.reading-speaker{font-size:25px;padding:0;width:56px;height:56px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.reading-actions{text-align:center;background:rgba(255,255,255,.88);border:2px solid rgba(255,221,120,.6);border-radius:20px;padding:16px;color:#102040}.reading-actions p{margin:.6rem 0 0;font-weight:700}.reading-actions button[disabled]{opacity:.7;cursor:not-allowed}@media(max-width:760px){.sage-scene{align-items:flex-start}.sage-character{font-size:64px}.magic-book{grid-template-columns:1fr}.book-left{border-radius:24px 24px 4px 4px;border-right:3px solid #8a5b20;border-bottom:1px dashed #ad8848}.book-right{border-radius:4px 4px 24px 24px;border-left:3px solid #8a5b20;border-top:1px dashed #ad8848}.reading-passage{font-size:1.08rem}.book-page{min-height:auto;padding:20px}}

/* Leaderboard overhaul: bigger student identity and collection-first ranking */
.leader-list{gap:12px;}
.leader{
  padding:16px 18px;
  grid-template-columns:42px minmax(190px,1fr) 150px minmax(270px,1.25fr);
  gap:14px;
  align-items:center;
}
.leader-rank{font-size:18px;font-weight:950;color:#ffffff;text-align:center;opacity:.95;}
.leader-student{display:flex;align-items:center;gap:12px;min-width:0;}
.leader-avatar{font-size:34px;line-height:1;display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--border-soft);border-radius:14px;background:#101827;}
.leader-student b{font-size:19px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.leader-score{font-size:28px;padding:10px 8px;min-height:58px;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.leader-score span{font-size:9px;letter-spacing:.08em;margin-top:4px;}
.leader-details{min-width:0;}
.leader-metrics{font-size:13px;font-weight:850;color:#e5edf8;line-height:1.45;}
.leader-sets{margin-top:7px;display:flex;gap:6px;flex-wrap:wrap;}
.leader-set{border:1px solid var(--border-soft);background:#101827;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900;color:#dce7f6;}
.muted-set{color:#94a3b8;}
body.rewards-locked .leader-details{visibility:hidden;}
body.rewards-locked .leader-details::after{content:'Rewards locked';visibility:visible;color:#fde68a;font-weight:900;}
@media(max-width:760px){
  .leader{grid-template-columns:38px 1fr;}
  .leader-score,.leader-details{grid-column:1 / -1;}
  .leader-student b{font-size:20px;}
  .leader-avatar{font-size:36px;width:48px;height:48px;}
}

/* Streamlit-style leaderboard and rarity item chips */
.item-chip{display:inline-flex;align-items:center;justify-content:center;gap:5px;min-width:28px;min-height:28px;padding:3px 7px;border-radius:999px;border:1px solid rgba(148,163,184,.32);background:rgba(15,23,42,.88);font-weight:950;color:#e5eefc;line-height:1;vertical-align:middle;box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);}
.item-chip-emoji{font-size:18px;line-height:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.35));}
.item-chip-name{font-size:11px;white-space:nowrap;}
.item-common{border-color:rgba(148,163,184,.28);}
.item-uncommon{border-color:rgba(34,197,94,.45);box-shadow:0 0 8px rgba(34,197,94,.18), inset 0 0 0 1px rgba(34,197,94,.08);}
.item-rare{border-color:rgba(56,189,248,.58);box-shadow:0 0 10px rgba(56,189,248,.22), inset 0 0 0 1px rgba(56,189,248,.1);}
.item-epic{border-color:rgba(168,85,247,.62);box-shadow:0 0 12px rgba(168,85,247,.28), inset 0 0 0 1px rgba(168,85,247,.1);}
.item-legendary{border-color:rgba(250,204,21,.9);background:radial-gradient(circle at 50% 50%,rgba(250,204,21,.22),rgba(15,23,42,.9) 62%);box-shadow:0 0 0 2px rgba(250,204,21,.18),0 0 16px rgba(250,204,21,.58),0 0 32px rgba(245,158,11,.22);}
.item-mythic{border-color:rgba(192,132,252,.95);background:radial-gradient(circle at 50% 50%,rgba(147,51,234,.32),rgba(15,23,42,.9) 64%);box-shadow:0 0 0 2px rgba(168,85,247,.22),0 0 18px rgba(168,85,247,.68),0 0 36px rgba(76,29,149,.34);}
.item-seasonal{border-color:rgba(251,146,60,.75);box-shadow:0 0 12px rgba(251,146,60,.28);}
.item-worthless{opacity:.62;filter:grayscale(.25);}
.item-more{color:#cbd5e1;font-size:12px;min-width:auto;}
.inventory-bar{gap:7px;overflow:hidden;flex-wrap:nowrap;font-size:initial;}
.inventory-full{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.inventory-full .item-chip{min-height:34px;border-radius:12px;padding:5px 9px;}
.inventory-full .item-chip-emoji{font-size:22px;}
.leader-list{gap:10px;}
.leader{grid-template-columns:58px minmax(210px,1fr) 150px minmax(310px,1.35fr);padding:10px 12px;border-radius:18px;background:linear-gradient(180deg,#243049,#1d2940);border-color:rgba(116,135,170,.55);}
.leader-rank{display:flex;align-items:center;justify-content:center;gap:7px;}
.leader-rank span{width:30px;height:30px;border-radius:999px;background:#ffc247;color:#122033;display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-weight:950;}
.leader-rank small{font-size:17px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35));}
.leader-student{gap:13px;}
.leader-avatar{width:46px;height:46px;font-size:28px;border-radius:13px;border-color:#138fc5;background:#123c5c;box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);}
.leader-student b{font-size:20px;font-weight:950;letter-spacing:-.02em;}
.leader-student em{display:block;margin-top:3px;font-style:normal;font-size:8px;font-weight:950;letter-spacing:.08em;color:#cbd5e1;text-transform:uppercase;}
.leader-score{border-radius:12px;background:rgba(15,23,42,.42);font-size:24px;color:#ffc247;min-height:54px;}
.leader-score span{font-size:9px;letter-spacing:.08em;color:#e8eefb;}
.leader-details{overflow:hidden;}
.leader-metrics{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#e8eefb;}
.leader-sets{display:flex;gap:6px;flex-wrap:nowrap;overflow:hidden;align-items:center;min-height:32px;}
.leader-set{border-radius:999px;background:#0f172a;font-size:11px;}
.leader-sets .item-chip{flex:0 0 auto;}
@media(max-width:760px){.leader{grid-template-columns:48px 1fr}.leader-score,.leader-details{grid-column:1 / -1}.leader-sets{flex-wrap:wrap;overflow:visible}.leader-metrics{white-space:normal}.leader-student b{font-size:20px}}
.reading-word{border-radius:6px;padding:0 2px;transition:background .12s ease,color .12s ease,box-shadow .12s ease}.reading-word.is-reading{background:#ffe16a;color:#241500;box-shadow:0 0 0 2px rgba(163,104,0,.22)}

.reading-audio-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:18px}.tts-speed-control{display:flex;align-items:center;gap:10px;background:#fff3bd;border:2px solid #c9972d;border-radius:999px;padding:9px 13px;color:#2d1c00;font-weight:900}.tts-speed-control input{width:150px;accent-color:#c9972d}.tts-speed-control b{min-width:46px;text-align:right}.reading-speaker{background:#3c465b;color:#fff;box-shadow:0 10px 24px rgba(0,0,0,.2)}
@media(max-width:760px){.reading-audio-row{align-items:flex-start}.tts-speed-control{width:100%;justify-content:space-between}.tts-speed-control input{width:45vw}}

.spinner-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.spinner-list-row{grid-template-columns:48px 1fr auto}.mic-btn{border:0;border-radius:50%;width:56px;height:56px;background:#10d0a0;color:#07111f;font-size:25px;font-weight:950;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.2)}.mic-btn.listening{animation:micPulse .72s infinite alternate;background:#ffcf3f}.selected-mic{position:absolute;left:28px;top:28px}.list-mic{flex:0 0 auto}@keyframes micPulse{from{transform:scale(1)}to{transform:scale(1.1)}}@media(max-width:760px){.spinner-list-row{grid-template-columns:42px 1fr auto}.spinner-row-actions{gap:8px}.mic-btn{width:48px;height:48px}.selected-mic{left:18px;top:28px}}

.spinner-speech-shell{position:relative;min-height:360px}.spinner-speech-shell.spinner-server-locked .spinner-stage,.spinner-speech-shell.spinner-server-locked .spinner-topic-block{filter:blur(1px);opacity:.45;pointer-events:none}.spinner-server-gate{position:absolute;inset:0;z-index:30;display:flex;align-items:flex-start;justify-content:center;padding:34px 12px;background:linear-gradient(180deg,rgba(8,17,31,.92),rgba(8,17,31,.58));border-radius:24px}.spinner-server-gate[hidden]{display:none!important}.spinner-server-card{width:min(560px,92vw);border:1px solid rgba(255,255,255,.18);border-radius:24px;background:linear-gradient(180deg,#17233a,#0c1423);box-shadow:0 18px 46px rgba(0,0,0,.34);padding:28px 24px;text-align:center;color:#eef6ff}.spinner-server-emoji{font-size:54px;line-height:1;margin-bottom:12px;display:inline-block}.spinner-server-gate[data-status="checking"] .spinner-server-emoji{animation:serverReadyPulse 1.1s ease-in-out infinite}.spinner-server-card h2{margin:0 0 6px;font-size:26px;font-weight:950}.spinner-server-card p{margin:0 auto 18px;max-width:440px;color:#d7e3f5;font-weight:800;line-height:1.45}.spinner-server-card p[hidden]{display:none!important}.spinner-server-gate[data-status="failed"] .spinner-server-card{border-color:rgba(248,113,113,.55)}@keyframes serverReadyPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}


/* Coin earning badges and teacher tools */
.game-card,.game-top-nav button{position:relative;overflow:visible;}
.coin-earn-badge{position:absolute;top:8px;right:8px;background:transparent;color:inherit;display:block;font-size:19px;font-weight:950;text-shadow:0 2px 6px rgba(0,0,0,.45);z-index:5;line-height:1;}
.game-top-nav .coin-earn-badge{top:-6px;right:-6px;font-size:15px;}
.coin-reward-complete .coin-earn-badge{background:transparent;color:#22c55e;}
.profile-stats{grid-template-columns:repeat(6,1fr);}
.teacher-tools-panel{border-color:#f7bd43;background:linear-gradient(180deg,#1f2937,#101827);}
.teacher-mode-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;margin:10px 0;}
.teacher-admin-box{border:1px solid var(--border-soft);background:rgba(8,17,31,.55);border-radius:14px;padding:14px;margin-top:12px;}
.teacher-admin-box h4{margin:14px 0 8px;}
.teacher-complete-list{display:grid;gap:8px;margin:8px 0;}
.teacher-complete-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;border:1px solid var(--border-soft);border-radius:10px;padding:8px 10px;background:#0b1220;}
.teacher-complete-row small{display:block;color:#c2cada;font-size:10px;margin-top:3px;}
.small-admin-btn{height:30px;padding:0 10px!important;font-size:11px!important;}
.danger-btn{border:1px solid #ef4444;background:#7f1d1d;color:#fff;border-radius:9px;font-weight:950;height:36px;padding:0 14px;cursor:pointer;}
@media(max-width:760px){.profile-stats{grid-template-columns:repeat(2,1fr)}.teacher-mode-row,.teacher-complete-row{grid-template-columns:1fr}.coin-earn-badge{top:5px;right:5px}}

.profile-last-class{margin:10px 0 8px;color:#cbd5e1;font-size:13px;}
.profile-last-class b{color:#fff;}


.completion-note{margin:8px 0 14px;padding:10px 12px;border:1px solid rgba(255,255,255,.14);border-radius:14px;background:rgba(255,255,255,.06);font-weight:800;color:#eaf2ff;}
.spinner-list-row.speech-done{outline:1px solid rgba(51,214,122,.45);background:rgba(51,214,122,.08);}
.word-done-mark{display:inline-block;min-width:1.2em;font-size:16px;line-height:1;}

.spinner-completion-note,
.activity-completion-note{
  display:inline-flex;
  align-items:center;
}
body.teacher-mode-on .completion-note[data-teacher-complete],
body.teacher-mode-on .completion-note [data-teacher-complete]{
  cursor:pointer;
}
body.teacher-mode-on .completion-note[data-teacher-complete]:hover,
body.teacher-mode-on .completion-note:hover [data-teacher-complete]{
  box-shadow:0 0 0 1px rgba(255,221,117,.35),0 0 14px rgba(255,221,117,.14);
}
.teacher-spinner-complete-btn,
.teacher-complete-btn{display:none !important;}


/* Profile stat layout repair */
.profile-head{
  grid-template-columns:56px minmax(230px,1fr) minmax(470px,1.05fr);
  align-items:center;
}
.profile-stats{
  display:grid;
  grid-template-columns:repeat(6,minmax(66px,1fr));
  gap:8px;
  min-width:0;
}
.stat{
  height:56px;
  min-width:0;
  padding:0 6px;
  border-radius:13px;
}
.stat b{
  display:block;
  width:100%;
  text-align:center;
  font-size:18px;
  line-height:1.05;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.stat span{
  display:block;
  width:100%;
  text-align:center;
  font-size:7.5px;
  line-height:1;
  letter-spacing:.04em;
  margin-top:6px;
  white-space:nowrap;
}
.stat:last-child b{
  font-size:15px;
}
@media(max-width:900px){
  .profile-head{grid-template-columns:56px 1fr;}
  .profile-stats{grid-column:1 / -1;grid-template-columns:repeat(3,minmax(82px,1fr));margin-top:10px;}
}
@media(max-width:560px){
  .profile-stats{grid-template-columns:repeat(2,minmax(0,1fr));}
  .stat{height:54px;}
}


.learning-journey{margin:12px 0 12px;border:1px solid var(--border-soft);background:rgba(8,17,31,.55);border-radius:14px;padding:12px 14px;}
.journey-title{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:#dbe6f7;font-size:12px;font-weight:950;margin-bottom:10px;}
.journey-title b{color:#f7bd43;font-size:14px;}
.journey-title span{margin-left:auto;color:#c2cada;font-size:11px;}
.journey-badges{display:grid;grid-template-columns:repeat(10,minmax(48px,1fr));gap:7px;}
.journey-badge{min-height:54px;border:1px solid var(--border-soft);border-radius:12px;background:#08111f;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:opacity .15s ease, transform .15s ease, box-shadow .15s ease;}
.journey-badge span{font-size:22px;line-height:1;}
.journey-badge small{font-size:8px;line-height:1;text-align:center;color:#dbe6f7;font-weight:950;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 3px;}
.journey-badge.unlocked{border-color:#f7bd43;box-shadow:0 0 12px rgba(247,189,67,.25);}
.journey-badge.locked{opacity:.32;filter:grayscale(.7);}
@media(max-width:760px){.journey-badges{grid-template-columns:repeat(5,1fr)}.journey-title span{margin-left:0;width:100%;}}

/* Profile status + clean share/export icon */
.profile-status-box{
  margin:12px 0 14px;
  border:1px solid rgba(56,189,248,.28);
  background:rgba(8,17,31,.55);
  border-radius:12px;
  padding:8px 10px;
}
.profile-status-box span{
  display:block;
  color:var(--cyan);
  text-transform:uppercase;
  letter-spacing:.1em;
  font-size:10px;
  font-weight:950;
  margin-bottom:6px;
}
.student-status-input{
  height:32px;
  border-radius:9px;
  background:#08111f;
}
.completion-share-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin:8px 0 14px;
}
.share-png-btn{
  appearance:none;
  -webkit-appearance:none;
  border:0 !important;
  outline:0;
  background:transparent !important;
  color:#e5f7ff;
  width:auto;
  height:auto;
  min-width:0;
  min-height:0;
  padding:0 0 0 2px;
  margin:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:18px;
  line-height:1;
  cursor:pointer;
  box-shadow:none !important;
  filter:none;
}
.profile-name-row .share-png-btn{ margin-left:6px; transform:translateY(-1px); }
.share-png-btn:hover{ transform:translateY(-2px); filter:brightness(1.18); }
.profile-name-row .share-png-btn:hover{ transform:translateY(-3px); }
.share-png-btn:disabled{
  opacity:.35;
  cursor:not-allowed;
  filter:grayscale(.5);
  transform:none;
  box-shadow:none;
}
@media(max-width:700px){
  .completion-share-row{ align-items:center; }
  .completion-share-row .completion-note{ flex:1 1 auto; }
  .completion-share-row .share-png-btn{ width:auto; }
}

/* Reading Sage voice recording */
.reading-recorder{
  margin-top:14px;
  padding:16px;
  border:1px solid rgba(125,211,252,.25);
  border-radius:18px;
  background:rgba(15,23,42,.45);
}
.reading-recorder h3{margin:0 0 6px;color:#e0f2fe;}
.reading-recorder-buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;}
.reading-recorder audio{border-radius:12px;}

.teacher-link-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
  margin:8px 0 10px;
}
.teacher-link-row input{
  width:100%;
  min-width:0;
  border:1px solid rgba(148,163,184,.45);
  border-radius:12px;
  padding:12px 14px;
  background:#071225;
  color:#dbeafe;
  font-weight:700;
}
@media (max-width:720px){
  .teacher-link-row{grid-template-columns:1fr;}
}

/* Compact homepage profile currency display */
.profile-head{grid-template-columns:56px 1fr auto;}
.compact-stats{display:flex;align-items:center;justify-content:flex-end;gap:18px;min-width:220px;}
.gem-coin-summary{display:flex;align-items:center;gap:18px;font-weight:950;color:#fff;}
.profile-currency{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;}
.profile-currency .currency-icon{width:48px;height:48px;border-radius:14px;border:1px solid var(--border);background:#121a2a;display:inline-flex;align-items:center;justify-content:center;font-size:28px;line-height:1;}
.profile-currency b{font-size:18px;color:#fff;min-width:24px;text-align:left;}
@media (max-width:720px){.profile-head{grid-template-columns:56px 1fr}.compact-stats{grid-column:1/-1;justify-content:flex-start}.gem-coin-summary{gap:14px}}

/* Keep compact coin/value summary on the same row as the student name except on very small screens */
.profile-head{
  grid-template-columns:56px minmax(0,1fr) auto !important;
  align-items:start !important;
}
.compact-stats{
  grid-column:auto !important;
  align-self:start !important;
  margin-top:30px !important;
  min-width:220px !important;
  justify-content:flex-end !important;
}
.gem-coin-summary{gap:18px !important;}
.profile-currency{gap:8px !important;}
.profile-currency .currency-icon{
  width:48px !important;
  height:48px !important;
  font-size:28px !important;
  flex:0 0 48px !important;
}
.profile-currency b{
  font-size:18px !important;
  line-height:1 !important;
  margin-left:2px !important;
}
@media(max-width:560px){
  .profile-head{grid-template-columns:56px 1fr !important;}
  .compact-stats{
    grid-column:1 / -1 !important;
    margin-top:10px !important;
    min-width:0 !important;
    justify-content:flex-start !important;
  }
}

/* Reading Sage recorder sits inside the right book page */
.book-right .reading-recorder{
  margin-top:16px;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.book-right .reading-recorder-buttons{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin-top:0;
}
.book-right .record-icon-btn{
  width:46px;
  height:46px;
  min-width:46px;
  min-height:46px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  line-height:1;
  border:1px solid rgba(120,53,15,.28);
  background:#fff7d6;
  color:#1f2937;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(120,53,15,.12);
}
.book-right .record-icon-btn.record-start,
.book-right .record-icon-btn.record-stop{
  font-size:0;
}
.book-right .record-icon-btn.record-start::before{
  content:"";
  width:15px;
  height:15px;
  border-radius:999px;
  background:#dc2626;
  display:block;
}
.book-right .record-icon-btn.record-stop::before{
  content:"";
  width:15px;
  height:15px;
  border-radius:2px;
  background:#6b7280;
  display:block;
}
.book-right .record-icon-btn.record-save{
  font-size:24px;
  font-weight:900;
}
.book-right .record-icon-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
  box-shadow:none;
}

.save-load-plus{width:56px;min-width:56px;padding:0;font-size:24px;display:inline-flex;align-items:center;justify-content:center;line-height:1;}

/* Coin bar: teacher reward buttons live inside the bar, not below it */
.game-coin-bar{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:14px !important;
  flex-wrap:nowrap !important;
  padding:14px 18px !important;
}
.coinbar-student{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-width:0;
  white-space:nowrap;
}
.coinbar-total{
  display:inline-flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
  margin-left:8px;
}
.coinbar-awards{
  margin-left:auto;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
  flex-wrap:nowrap;
}
.coinbar-awards.hidden{display:none !important;}
.coinbar-awards button{
  min-width:38px;
  width:38px;
  height:30px;
  border:0;
  border-radius:11px;
  background:#f6dc7a;
  color:#07111f;
  font-size:13px;
  font-weight:950;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(246,220,122,.14);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:2px;
  padding:0;
}
.coinbar-awards button span{font-size:9px;opacity:.62;}
.reward-buttons.hidden{display:none !important;}
.reward-buttons[style*="none"]{display:none !important;}
@media (max-width:760px){
  .game-coin-bar{
    flex-wrap:wrap !important;
    justify-content:center !important;
    gap:10px !important;
  }
  .coinbar-awards{margin-left:0;justify-content:center;width:100%;}
}

/* Current class completion bar */
.current-class .class-progress-wrap{margin-top:12px;display:grid;gap:7px}.current-class .class-progress-head{display:flex;align-items:center;justify-content:space-between;color:#dbe6f7;font-size:12px;font-weight:950}.current-class .class-progress-head span{text-transform:uppercase;letter-spacing:.08em;color:#7dd3fc}.current-class .class-progress-head b{color:#f6dc7a}.current-class .class-progress-track{height:9px;border-radius:999px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.14);overflow:hidden}.current-class .class-progress-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#22c55e,#f6dc7a);transition:width .25s ease}.current-class .class-progress-items{display:flex;gap:7px;align-items:center}.current-class .class-progress-items > span:not(.class-progress-share-link){width:25px;height:25px;border:1px solid rgba(255,255,255,.14);border-radius:9px;background:rgba(255,255,255,.06);display:inline-flex;align-items:center;justify-content:center;font-size:14px}.current-class .class-progress-items > span:not(.class-progress-share-link).done{background:rgba(34,197,94,.16);border-color:rgba(34,197,94,.45)}

.current-class .class-complete-row{margin-top:9px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.current-class .class-complete-message{display:inline-flex;align-items:baseline;gap:8px;color:#f6dc7a;font-weight:950;font-size:14px}
.current-class .class-complete-message em{font-style:normal;color:rgba(203,213,225,.58);font-size:12px}
.current-class .class-complete-row .share-icon-btn{width:32px;height:32px;border-radius:9px;background:#0ea5e9;border:1px solid rgba(125,211,252,.5);color:white;display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;padding:0;box-shadow:0 8px 18px rgba(14,165,233,.20)}
.current-class .class-complete-row .share-icon-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* Village is teacher-mode only. Hidden on homepage and top nav unless Teacher Mode is unlocked. */
.teacher-village-link{display:none!important;}
body.teacher-mode-on .game-card.teacher-village-link{display:flex!important;}
body.teacher-mode-on .game-top-nav .teacher-village-link{display:inline-flex!important;}


/* Profile avatar enlargement: homepage student profile only */
.profile-card .profile-head{
  grid-template-columns:96px minmax(0,1fr) auto !important;
  align-items:center !important;
  gap:18px !important;
}
.profile-card .avatar-box{
  width:88px !important;
  height:88px !important;
  min-width:88px !important;
  min-height:88px !important;
  border-radius:22px !important;
  font-size:50px !important;
  line-height:1 !important;
}
.profile-card .profile-title{
  align-self:center !important;
}
.profile-card .compact-stats{
  align-self:center !important;
  margin-top:0 !important;
}
@media(max-width:720px){
  .profile-card .profile-head{
    grid-template-columns:88px minmax(0,1fr) !important;
    align-items:center !important;
  }
  .profile-card .avatar-box{
    width:80px !important;
    height:80px !important;
    min-width:80px !important;
    min-height:80px !important;
    border-radius:20px !important;
    font-size:46px !important;
  }
  .profile-card .compact-stats{
    grid-column:1 / -1 !important;
    justify-content:flex-start !important;
    margin-top:10px !important;
  }
}

/* Leaderboards are teacher-mode homepage only */
.leaderboard-section{display:none!important;}
body.teacher-mode-on.home-view .leaderboard-section{display:block!important;}
body.game-view-on .leaderboard-section{display:none!important;}

/* Top setup card: groups student loading and class controls */
.setup-card{
  background:linear-gradient(180deg,var(--panel),#1b263a);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  border-radius:16px;
  padding:18px;
  margin:0 0 28px;
}
.setup-card .setup-student-block{
  margin-bottom:22px;
}
.setup-card h1{
  margin:0 0 18px;
}
.setup-card .current-class{
  margin:16px 0 0;
}
.setup-card .load-grid{
  grid-template-columns:1fr 1fr 110px 64px;
}
.setup-card .class-grid-2{
  grid-template-columns:1fr 172px;
}
@media(max-width:760px){
  .setup-card{
    padding:14px;
  }
  .setup-card .load-grid,
  .setup-card .class-grid-1,
  .setup-card .class-grid-2{
    grid-template-columns:1fr;
  }
}


/* Mobile game/nav buttons */
@media (max-width: 640px){
  .game-grid,.home-grid,.games-grid,.nav-grid{
    display:flex !important;
    flex-direction:column !important;
    gap:10px !important;
  }
  .game-tile,.game-card,.nav-btn,.home-btn{
    width:100% !important;
    max-width:none !important;
    min-height:52px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    padding:0 14px !important;
  }
}

@media (max-width:640px){
.game-grid,.games-grid,.home-grid,.button-grid,.nav-grid{gap:6px!important;}
.game-btn,.nav-btn,.home-btn,.game-tile{
min-height:54px!important;
padding:8px 12px!important;
}
.game-btn .icon,.nav-btn .icon,.home-btn .icon,.game-tile .icon{font-size:24px!important;}
.game-btn .label,.nav-btn .label,.home-btn .label,.game-tile .label{font-size:13px!important;}
}

/* Mobile compact horizontal game buttons */
@media (max-width: 640px) {
  .game-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
  }
  .game-card {
    width: 100% !important;
    aspect-ratio: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    height: auto !important;
    padding: 8px 12px !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    text-align: left !important;
  }
  .game-card span {
    font-size: 28px !important;
    line-height: 1 !important;
    width: 34px !important;
    min-width: 34px !important;
    text-align: center !important;
  }
  .game-card b {
    font-size: 14px !important;
    line-height: 1.1 !important;
    text-align: left !important;
    white-space: nowrap !important;
  }
  .game-card .completion-badge,
  .game-card .coin-badge,
  .game-card .game-badge {
    margin-left: auto !important;
  }
}

/* Once-per-event popup. This replaces the old permanent homepage event stamp. */
.event-popup-backdrop{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:rgba(2,6,23,.66);backdrop-filter:blur(5px);padding:18px;}
.event-popup-backdrop[hidden]{display:none!important;}
.event-popup-card{position:relative;width:min(430px,92vw);border:1px solid rgba(125,211,252,.35);border-radius:28px;background:radial-gradient(circle at 50% 0%,rgba(56,189,248,.18),transparent 38%),linear-gradient(180deg,#1e293b,#0f172a);box-shadow:0 28px 80px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.05) inset;padding:28px 24px 22px;text-align:center;color:#f8fafc;}
.event-popup-close{position:absolute;right:14px;top:12px;border:1px solid rgba(148,163,184,.35);background:rgba(15,23,42,.72);color:#cbd5e1;border-radius:999px;width:34px;height:34px;font-size:24px;font-weight:900;line-height:28px;cursor:pointer;}
.event-popup-kicker{text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:950;color:#67e8f9;margin-bottom:4px;}
.event-popup-emoji{font-size:58px;line-height:1.05;filter:drop-shadow(0 10px 24px rgba(0,0,0,.35));}
.event-popup-card h2{margin:8px 0 8px;font-size:30px;line-height:1.05;color:#fff;}
.event-popup-card p{margin:0 auto 16px;max-width:340px;color:#cbd5e1;font-weight:800;line-height:1.4;}
.event-popup-items{display:flex;justify-content:center;gap:10px;min-height:44px;margin:12px 0 18px;}
.event-popup-items span{display:grid;place-items:center;width:44px;height:44px;border-radius:15px;background:rgba(2,6,23,.46);border:1px solid rgba(148,163,184,.25);font-size:25px;}
.event-popup-ok{min-width:150px;height:46px;border-radius:16px;}

/* Code Crack: tap-to-enter number cards */
.code-number-tap{cursor:pointer;user-select:none}
.code-number-tap:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.78);box-shadow:0 16px 32px rgba(0,0,0,.30)}
.code-word-card.selected{border-color:rgba(255,255,255,.95);box-shadow:0 0 0 3px rgba(255,255,255,.18),0 16px 34px rgba(0,0,0,.32)}
.code-word-card.selected::after{content:attr(data-pick-order);position:absolute;right:-9px;top:-9px;width:28px;height:28px;border-radius:999px;background:#fff;color:#07111f;font-weight:950;font-size:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 14px rgba(0,0,0,.28)}
.code-word-card.code-pick-red{background:#7f1d1d}
.code-word-card.code-pick-blue{background:#1e3a8a}
.code-word-card.code-pick-green{background:#166534}
.code-word-card.code-pick-yellow{background:#854d0e}
.code-word-card.code-pick-purple{background:#581c87}
.code-word-card.code-pick-orange{background:#9a3412}
.code-word-card.code-pick-white{background:#f8fafc}
.code-word-card.code-pick-white b,.code-word-card.code-pick-white .number-badge{color:#07111f}


/* UI language toggle */
.section-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:0 0 18px;
}
.section-title-row h1{
  margin:0 !important;
}
.language-toggle{
  border:1px solid rgba(255,255,255,.18);
  background:#0b1220;
  color:#eaf4ff;
  border-radius:999px;
  padding:8px 14px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 6px 14px rgba(0,0,0,.18);
  white-space:nowrap;
}
.language-toggle:hover{
  transform:translateY(-1px);
  border-color:rgba(125,211,252,.55);
}
.language-toggle .active-lang{
  color:#fde68a;
}

.floating-language-toggle{
  position:fixed;
  top:14px;
  right:14px;
  z-index:6000;
}
@media(max-width:640px){
  .floating-language-toggle{top:8px;right:8px;}
}
@media(max-width:640px){
  .section-title-row{align-items:flex-start;}
  .language-toggle{padding:7px 11px;font-size:12px;}
}


/* Teacher Mode payment box */
.teacher-payment-box{
  border:1px solid rgba(247,189,67,.45);
  background:linear-gradient(180deg,rgba(247,189,67,.14),rgba(8,17,31,.62));
  border-radius:16px;
  padding:14px;
  margin:12px 0;
}
.teacher-payment-box h4{margin:0 0 8px;font-size:18px;}
.teacher-price{font-size:18px;font-weight:900;color:#ffd166;margin:10px 0;}
.teacher-pay-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;margin:4px 0 8px;}

/* Mobile shop list layout: shop stock becomes compact horizontal rows instead of square cards. */
@media(max-width:640px){
  .shop-wrap{margin-bottom:40px;}
  .shop-section{padding:20px 0;}
  .shop-section h2{font-size:26px;}
  .shop-grid{display:grid;grid-template-columns:1fr;gap:10px;}
  .shop-card{
    min-height:0;
    text-align:left;
    display:grid;
    grid-template-columns:58px 1fr auto;
    grid-template-areas:
      "emoji title button"
      "emoji meta button";
    align-items:center;
    column-gap:12px;
    row-gap:4px;
    padding:12px;
    border-radius:14px;
  }
  .shop-emoji{grid-area:emoji;font-size:42px;line-height:1;margin:0;text-align:center;}
  .shop-card h3{grid-area:title;font-size:17px;line-height:1.15;margin:0;}
  .shop-meta{grid-area:meta;justify-content:flex-start;gap:8px;margin:0;flex-wrap:wrap;}
  .shop-meta b{white-space:nowrap;}
  .shop-card .gold-btn{grid-area:button;min-width:86px;height:42px;padding:0 12px;border-radius:13px;white-space:nowrap;}
}

@media(max-width:420px){
  .shop-card{grid-template-columns:48px 1fr;grid-template-areas:"emoji title" "emoji meta" "button button";}
  .shop-emoji{font-size:36px;}
  .shop-card .gold-btn{width:100%;margin-top:6px;}
}

/* Mobile shop controls and sell-list cleanup */
@media(max-width:640px){
  .shop-actions{
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin:12px 0 20px;
  }
  .shop-actions .gold-btn{
    min-height:42px;
    padding:10px 8px;
    border-radius:12px;
    font-size:14px;
    white-space:nowrap;
  }
  .sell-list{gap:10px;}
  .sell-row{
    min-height:0;
    text-align:left;
    display:grid;
    grid-template-columns:58px 1fr auto;
    grid-template-areas:
      "sellEmoji sellTitle sellButton"
      "sellEmoji sellMeta sellButton";
    align-items:center;
    column-gap:12px;
    row-gap:4px;
    padding:12px;
    border-radius:14px;
  }
  .sell-main{display:contents;}
  .sell-main>span{
    grid-area:sellEmoji;
    font-size:42px;
    line-height:1;
    min-width:0;
    text-align:center;
  }
  .sell-main>div{display:contents;}
  .sell-main b{grid-area:sellTitle;font-size:17px;line-height:1.15;margin:0;}
  .sell-main small{grid-area:sellMeta;font-size:12px;line-height:1.25;}
  .sell-price{
    grid-area:sellMeta;
    justify-self:start;
    margin-top:18px;
    border:0;
    background:transparent;
    padding:0;
    text-align:left;
  }
  .sell-price b{display:inline;font-size:14px;color:#ffe87a;}
  .sell-price small{display:none;}
  .sell-row .sell-inv-item{
    grid-area:sellButton;
    min-width:86px;
    height:42px;
    padding:0 12px;
    border-radius:13px;
    white-space:nowrap;
  }
}

@media(max-width:420px){
  .shop-actions{grid-template-columns:1fr 1fr;}
  .shop-actions .gold-btn{font-size:13px;}
  .sell-row{
    grid-template-columns:48px 1fr;
    grid-template-areas:
      "sellEmoji sellTitle"
      "sellEmoji sellMeta"
      "sellButton sellButton";
  }
  .sell-main>span{font-size:36px;}
  .sell-row .sell-inv-item{width:100%;margin-top:6px;}
}

/* Refine mobile sell rows: keep original value and sell price readable without stacked boxes. */
@media(max-width:640px){
  .sell-row{
    grid-template-areas:
      "sellEmoji sellTitle sellButton"
      "sellEmoji sellOrig sellButton"
      "sellEmoji sellPrice sellButton";
  }
  .sell-main small{grid-area:sellOrig;}
  .sell-price{grid-area:sellPrice;margin-top:0;}
}
@media(max-width:420px){
  .sell-row{
    grid-template-areas:
      "sellEmoji sellTitle"
      "sellEmoji sellOrig"
      "sellEmoji sellPrice"
      "sellButton sellButton";
  }
}

/* Contact QR inside Teacher Mode payment card */
.teacher-contact-qr{margin:14px 0;border:1px solid rgba(148,163,184,.32);border-radius:16px;background:rgba(15,23,42,.42);padding:12px;display:grid;grid-template-columns:96px 1fr;gap:12px;align-items:center;}
.teacher-contact-qr img{width:96px;height:96px;object-fit:cover;border-radius:12px;background:#fff;border:4px solid #fff;}
.teacher-contact-qr .tiny{margin:0!important;}
.settings-panel button:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.25);}
@media(max-width:520px){.teacher-contact-qr{grid-template-columns:1fr;text-align:center}.teacher-contact-qr img{margin:0 auto}}

.teacher-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:14px 0;}
.teacher-contact-grid .teacher-contact-qr{margin:0;}
.teacher-contact-grid .teacher-contact-qr b{color:#fff;font-size:18px;}
.teacher-intro-card{grid-template-columns:86px 1fr;}
.teacher-intro-photo{width:72px;height:72px;object-fit:cover;border-radius:22px;border:1px solid rgba(56,189,248,.45);background:#fff;}
@media(max-width:720px){.teacher-intro-card{grid-template-columns:1fr}.teacher-intro-photo{margin:0 auto}}
@media(max-width:620px){.teacher-contact-grid{grid-template-columns:1fr}}

/* Emoji English settings usage flow */
.emoji-flow-section{overflow:hidden;}
.emoji-flow-list{
  margin:16px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  counter-reset:emoji-flow;
}
.emoji-flow-list li{
  counter-increment:emoji-flow;
  display:grid;
  grid-template-columns:38px 40px 1fr;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border:1px solid rgba(56,189,248,.24);
  background:linear-gradient(180deg,rgba(15,23,42,.78),rgba(15,23,42,.48));
  border-radius:16px;
}
.emoji-flow-list li::before{
  content:counter(emoji-flow);
  width:30px;
  height:30px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(251,191,36,.16);
  border:1px solid rgba(251,191,36,.42);
  color:#fde68a;
  font-size:13px;
  font-weight:950;
}
.flow-step-icon{font-size:26px;line-height:1;text-align:center;}
.emoji-flow-list strong{display:block;color:#f8fafc;font-size:15px;line-height:1.15;}
.emoji-flow-list small{display:block;color:#cbd5e1;font-size:12px;line-height:1.3;margin-top:3px;font-weight:800;}
@media(max-width:720px){
  .emoji-flow-list{grid-template-columns:1fr;gap:8px;}
  .emoji-flow-list li{grid-template-columns:34px 34px 1fr;padding:10px 12px;border-radius:14px;}
  .emoji-flow-list li::before{width:28px;height:28px;font-size:12px;}
  .flow-step-icon{font-size:23px;}
  .emoji-flow-list strong{font-size:14px;}
  .emoji-flow-list small{font-size:11px;}
}
@media(max-width:420px){
  .emoji-flow-list li{grid-template-columns:30px 30px 1fr;gap:8px;padding:9px 10px;}
  .emoji-flow-list li::before{width:26px;height:26px;}
  .flow-step-icon{font-size:21px;}
  .emoji-flow-list small{display:none;}
}
}

/* Teacher-only links: final override, including mobile compact button rules. */
body:not(.teacher-mode-on) [data-game="warmup"],
body:not(.teacher-mode-on) .teacher-village-link{
  display:none !important;
}
body.teacher-mode-on .game-card[data-game="warmup"]{
  display:flex !important;
}
body.teacher-mode-on .game-top-nav [data-game="warmup"],
body.teacher-mode-on .game-top-nav .teacher-village-link{
  display:inline-flex !important;
}
body.teacher-mode-on .game-card.teacher-village-link{
  display:flex !important;
}

/* Current class emojis: inline with title, no boxes */
.current-class .current-class-emojis{
  display:inline;
  margin-left:6px;
  font-size:1em;
  line-height:1;
  vertical-align:baseline;
}
.current-class .current-class-emojis span{
  display:inline;
  margin-left:3px;
  font-size:1em;
  line-height:1;
}
@media (max-width: 680px){
  .current-class .current-class-emojis{display:none;}
}
.teacher-complete-dropdown{margin:8px 0 14px;}
.teacher-complete-dropdown-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;}
.teacher-complete-dropdown .settings-select{width:100%;}
@media(max-width:760px){.teacher-complete-dropdown-row{grid-template-columns:1fr}.teacher-complete-dropdown-row .small-admin-btn{width:100%;}}

/* v41: compact sell dropdown for large inventories and inline mobile buy buttons. */
.sell-compact{
  background:rgba(8,14,32,.58);
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  padding:14px;
}
.sell-compact-row{
  display:grid;
  grid-template-columns:1fr 135px;
  gap:12px;
  align-items:center;
}
.sell-compact .select-label{margin-top:0;}
.sell-compact-note{margin-top:8px;color:#aeb8cf;font-size:12px;font-weight:800;}
.sell-select{height:46px;min-height:46px;}
@media(max-width:640px){
  .sell-compact-row{grid-template-columns:1fr auto;gap:8px;}
  .sell-compact-row .gold-btn{min-width:78px;height:42px;padding:0 12px;border-radius:13px;}
  .sell-compact-note{font-size:11px;}
}
@media(max-width:420px){
  .shop-card{
    grid-template-columns:48px 1fr auto;
    grid-template-areas:
      "emoji title button"
      "emoji meta button";
  }
  .shop-card .gold-btn{width:auto;margin-top:0;min-width:78px;}
}


/* Mobile homepage header */
@media (max-width: 768px){
  body.home-page .site-header img,
  .home-page .site-header img,
  body.home .site-header img{
    content:url('assets/images/mobile_header.png');
  }
}

/* v42: mobile homepage header sizing */
@media (max-width: 768px){
  .app{
    padding-top:0;
  }
  .hero{
    margin:0 0 14px;
    height:190px;
    overflow:hidden;
    border-radius:0;
  }
  .hero picture{
    display:block;
    width:100%;
    height:100%;
  }
  .hero img{
    width:100% !important;
    max-width:none !important;
    height:100% !important;
    margin:0 !important;
    border-radius:0 !important;
    object-fit:cover;
    object-position:center center;
  }
}

/* v43: mobile header should show the full banner without cropping words */
@media (max-width: 768px){
  .hero{
    height:auto !important;
    overflow:visible !important;
    margin:0 0 14px !important;
  }
  .hero picture{
    display:block !important;
    width:100% !important;
    height:auto !important;
  }
  .hero img{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    height:auto !important;
    margin:0 auto 12px !important;
    object-fit:contain !important;
    object-position:center center !important;
    border-radius:0 !important;
  }
}

/* v21 Tic Tac Toss mobile word-card fix */
@media(max-width:760px){
  .ttt-modal{padding:14px;align-items:center;}
  .ttt-modal-card{width:min(92vw,520px);padding:20px;border-radius:24px;}
  .ttt-modal-card h3{font-size:24px;line-height:1.15;margin-bottom:12px;}
  .ttt-word-card{
    min-height:220px;
    padding:18px 16px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:10px;
  }
  .ttt-word-emoji{font-size:42px;line-height:1;order:1;}
  .ttt-word-card b{
    order:2;
    font-size:26px;
    line-height:1.08;
    max-width:100%;
    overflow-wrap:break-word;
    word-break:normal;
    hyphens:none;
    text-align:center;
  }
  .ttt-word-speaker{
    order:3;
    position:static;
    transform:none;
    right:auto;
    top:auto;
    margin-top:2px;
    width:54px;
    height:54px;
  }
  .ttt-modal-actions{gap:10px;margin-top:16px;}
  .ttt-modal-actions button{width:100%;font-size:18px;padding:14px 16px;border-radius:18px;}
  .ttt-cancel{min-width:0;max-width:260px;}
}
@media(max-width:420px){
  .ttt-modal-card{padding:18px 16px;}
  .ttt-modal-card h3{font-size:23px;}
  .ttt-word-card{min-height:205px;}
  .ttt-word-card b{font-size:24px;}
  .ttt-word-emoji{font-size:38px;}
}

/* Emoji Hunt mobile compact layout */
@media (max-width: 700px){
  .memory-match-wrap{
    margin-top:12px;
    gap:12px;
  }
  .memory-match-grid{
    width:100%;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
  }
  .memory-card{
    min-height:88px;
  }
  .memory-face{
    border-radius:14px;
  }
  .memory-front{
    padding:14px 8px 10px;
  }
  .memory-back{
    min-height:88px;
  }
  .memory-index{
    width:26px;
    height:26px;
    right:6px;
    top:6px;
    font-size:14px;
  }
  .memory-question{
    font-size:34px;
  }
  .memory-label{
    display:none;
  }
  .memory-content{
    flex-direction:column;
    gap:3px;
  }
  .match-emoji{
    font-size:32px;
  }
  .match-word{
    font-size:16px;
    line-height:1.05;
  }
  .match-speaker{
    position:static;
    width:28px;
    height:28px;
    min-width:28px;
    margin-top:3px;
    font-size:14px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  .match-actions{
    gap:8px;
  }
  .match-actions .dark-action,
  .match-actions .gray-action{
    font-size:14px;
    padding:10px 14px;
    border-radius:16px;
  }
}

@media (max-width: 420px){
  .memory-card{
    min-height:78px;
  }
  .match-emoji{
    font-size:28px;
  }
  .match-word{
    font-size:14px;
  }
  .memory-question{
    font-size:30px;
  }
}

/* Patch 23: lesson completion icons and Emoji Hunt reward badge */
.game-card, .game-top-nav button{position:relative;}
.class-progress-items{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.class-progress-link{position:relative;width:42px;height:42px;border-radius:13px;border:1px solid rgba(255,255,255,.18);background:rgba(15,23,42,.6);display:inline-flex;align-items:center;justify-content:center;padding:0;cursor:pointer;box-shadow:none;}
.class-progress-link:hover{transform:translateY(-1px);filter:brightness(1.1);}
.class-progress-link.done{border-color:rgba(34,197,94,.55);background:rgba(34,197,94,.12);}
.class-progress-main-emoji{font-size:21px;line-height:1;}
.class-progress-mini-badge{position:absolute;top:-7px;right:-7px;font-size:14px;line-height:1;text-shadow:0 2px 5px rgba(0,0,0,.45);}
.class-progress-share-link{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;}
.class-progress-share-link .share-png-btn{font-size:20px;}
/* Clean single-layer progress icons: the activity button owns the only box.
   The main emoji and coin/tick marker stay unboxed. */
.current-class .class-progress-link .class-progress-main-emoji,
.current-class .class-progress-link .class-progress-mini-badge{
  width:auto !important;
  height:auto !important;
  min-width:0 !important;
  min-height:0 !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  display:block !important;
  padding:0 !important;
}
.current-class .class-progress-link .class-progress-main-emoji{
  position:static !important;
}
.current-class .class-progress-link .class-progress-mini-badge{
  position:absolute !important;
  top:-6px !important;
  right:-6px !important;
}
.current-class .class-progress-share-link{
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
@media(max-width:700px){.class-progress-link,.class-progress-share-link{width:38px;height:38px}.class-progress-main-emoji{font-size:19px}.class-progress-mini-badge{font-size:13px}}

/* v20 mobile layout correction: shrink problem pages instead of hiding overflow */
@media (max-width: 760px){
  html, body{
    width:100%;
    max-width:100%;
    overflow-x:hidden;
  }
  body{
    min-width:0;
  }
  .app{
    width:100%;
    max-width:100%;
    min-width:0;
    padding-left:10px;
    padding-right:10px;
    margin-left:0;
    margin-right:0;
  }
  #gameView,
  #gameContent,
  .game-page,
  .section,
  .simple-game,
  .spinner-stage,
  .spinner-topic-block,
  .reading-sage-wrap,
  .magic-book,
  .claw-wrap{
    width:100%;
    max-width:100%;
    min-width:0;
    overflow:visible;
  }

  /* Top game navigation: fixed mobile grid, no sideways page width */
  .game-top-nav{
    display:grid;
    grid-template-columns:repeat(5, minmax(0, 1fr));
    gap:8px;
    width:100%;
    max-width:100%;
    justify-items:center;
    margin-left:0;
    margin-right:0;
  }
  .game-top-nav button{
    width:100%;
    max-width:48px;
    min-width:0;
  }

  /* Coin bar may be wider than the phone when kept on one line */
  .game-coin-bar{
    width:100%;
    max-width:100%;
    min-width:0;
    flex-wrap:wrap !important;
    justify-content:flex-start !important;
    padding:12px 14px !important;
    overflow:hidden;
  }
  .coinbar-student,
  .coinbar-total{
    min-width:0;
    max-width:100%;
    white-space:normal;
    overflow-wrap:anywhere;
    line-height:1.15;
  }
  .coinbar-awards{
    width:100%;
    margin-left:0;
    justify-content:flex-start;
    flex-wrap:wrap;
  }

  .game-title,
  #gameContent h1,
  #gameContent h2{
    max-width:100%;
    overflow-wrap:anywhere;
    word-break:normal;
  }

  /* Completion/share row must shrink inside the phone width */
  .completion-share-row{
    display:flex;
    flex-wrap:nowrap;
    align-items:center;
    width:100%;
    max-width:100%;
    min-width:0;
    gap:8px;
  }
  .completion-share-row .completion-note{
    flex:1 1 auto;
    min-width:0;
    max-width:100%;
    overflow-wrap:anywhere;
    font-size:clamp(14px, 4.5vw, 18px);
    line-height:1.2;
  }
  .completion-share-row .share-png-btn{
    flex:0 0 auto;
  }

  /* Spinner: selected card and rows now fit narrow screens */
  .spinner-selected-card{
    width:100%;
    max-width:100%;
    min-width:0;
    padding:28px 58px 26px;
    border-radius:22px;
  }
  .selected-main{
    max-width:100%;
    overflow-wrap:anywhere;
    font-size:clamp(26px, 8vw, 34px);
  }
  .selected-main span{font-size:.95em;}
  .selected-speaker{right:14px;top:14px;}
  .selected-mic{left:14px;top:14px;}
  .spinner-topic-block{margin-top:40px;}
  .spinner-topic-block h2{
    font-size:clamp(22px, 7vw, 30px);
    overflow-wrap:anywhere;
  }
  .spinner-list{
    width:100%;
    max-width:100%;
    min-width:0;
  }
  .spinner-list-row{
    width:100%;
    max-width:100%;
    min-width:0;
    grid-template-columns:42px minmax(0,1fr) auto !important;
    gap:10px;
    padding:12px 10px;
    align-items:center;
    border-radius:18px;
  }
  .spinner-list-row b{
    min-width:0;
    max-width:100%;
    overflow-wrap:anywhere;
    word-break:break-word;
    font-size:clamp(22px, 7vw, 30px);
    line-height:1.05;
  }
  .row-emoji{
    margin-right:4px;
  }
  .spinner-row-actions{
    flex:0 0 auto;
    gap:6px;
  }
  .spinner-row-actions .speaker-btn,
  .spinner-row-actions .mic-btn{
    width:44px;
    height:44px;
    min-width:44px;
  }

  /* Reading Sage: no speech bubble or book page can force horizontal scroll */
  .reading-sage-wrap{
    margin-left:0;
    margin-right:0;
  }
  .sage-scene{
    width:100%;
    max-width:100%;
    min-width:0;
    gap:10px;
    padding:14px 12px;
    border-radius:22px;
    align-items:flex-start;
  }
  .sage-character{
    flex:0 0 auto;
    font-size:clamp(52px, 17vw, 68px);
  }
  .sage-speech{
    flex:1 1 auto;
    min-width:0;
    max-width:100%;
    padding:12px 14px;
    overflow-wrap:anywhere;
    font-size:clamp(16px, 4.7vw, 20px);
  }
  .book-page{
    width:100%;
    max-width:100%;
    min-width:0;
    padding:18px 14px;
  }
  .reading-passage{
    max-width:100%;
    overflow-wrap:anywhere;
    font-size:clamp(17px, 5vw, 22px);
    line-height:1.55;
  }
  .reading-vocab-list{
    max-width:100%;
    gap:8px;
  }
  .reading-vocab-list button{
    max-width:100%;
    min-width:0;
    white-space:normal;
    overflow-wrap:anywhere;
  }
  .reading-audio-row,
  .tts-speed-control,
  .reading-recorder,
  .reading-recorder-buttons{
    width:100%;
    max-width:100%;
    min-width:0;
  }
  .tts-speed-control{
    display:grid;
    grid-template-columns:auto minmax(0,1fr) auto;
    border-radius:16px;
    gap:8px;
  }
  .tts-speed-control input{
    width:100%;
    min-width:0;
  }
  #readingPlaybackAudio{
    max-width:100%;
  }

  /* Claw Machine: board and controls remain inside phone width */
  .claw-wrap{
    display:grid;
    grid-template-columns:minmax(0,1fr) !important;
    gap:12px;
  }
  .claw-board-panel,
  .claw-control-panel{
    width:100%;
    max-width:100%;
    min-width:0;
    padding:10px;
    overflow:hidden;
  }
  .claw-grid{
    width:100%;
    max-width:100%;
    min-width:0;
    grid-template-columns:repeat(5, minmax(0,1fr));
    gap:6px;
  }
  .claw-cell{
    width:100%;
    min-width:0;
    height:50px;
    padding:2px;
    overflow:hidden;
  }
  .claw-emoji{
    font-size:22px;
  }
  .rarity-pill{
    max-width:100%;
    font-size:7px;
    padding:2px 3px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .claw-controls{
    width:100%;
    max-width:100%;
    min-width:0;
    grid-template-columns:repeat(3, minmax(0,1fr));
  }
  .claw-controls button{
    min-width:0;
    width:100%;
    padding:0 4px;
  }
  .claw-selected-card{
    width:100%;
    max-width:100%;
    min-width:0;
  }
}

@media (max-width: 420px){
  .app{padding-left:8px;padding-right:8px;}
  .game-top-nav{grid-template-columns:repeat(4, minmax(0,1fr));}
  .spinner-selected-card{padding-left:48px;padding-right:48px;}
  .spinner-list-row{grid-template-columns:38px minmax(0,1fr) auto !important;gap:8px;}
  .spinner-row-actions .speaker-btn,
  .spinner-row-actions .mic-btn{width:40px;height:40px;min-width:40px;font-size:20px;}
  .number-badge{width:38px;height:38px;font-size:20px;}
  .sage-scene{padding:12px 10px;}
  .sage-speech{font-size:16px;}
  .book-page{padding:16px 12px;}
  .claw-grid{gap:5px;}
  .claw-cell{height:46px;}
}

/* v42: Clean Crafting Cauldron layout.
   Recipe Helper is now its own simple selector section, and Crafting Cauldron
   title sits directly above the two crafting item selectors. */
.cauldron-section .recipe-helper-title{
  margin-top:0;
}
.cauldron-section .crafting-cauldron-title{
  margin-top:26px;
  margin-bottom:12px;
}
.cauldron-section .helper-results{
  margin:18px 0 24px;
}


/* Homepage/student action popup notice */
.notice{
  position:fixed !important;
  top:18px !important;
  left:50% !important;
  transform:translateX(-50%) translateY(-8px) !important;
  z-index:1000000 !important;
  width:max-content !important;
  max-width:min(92vw, 520px) !important;
  margin:0 !important;
  text-align:center !important;
  box-shadow:0 18px 38px rgba(0,0,0,.35) !important;
  opacity:0;
  transition:opacity .18s ease, transform .18s ease;
  pointer-events:none;
}
.notice.ee-notice-show{
  opacity:1;
  transform:translateX(-50%) translateY(0) !important;
}
@media(max-width:640px){
  .notice{
    top:12px !important;
    width:calc(100vw - 24px) !important;
    max-width:calc(100vw - 24px) !important;
    font-size:14px;
  }
}

/* Compact top game navigation: only class-completion activities stay visible; extras live inside More. */
.game-top-nav .game-more-nav{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:42px;
  max-width:48px;
  min-width:0;
  overflow:visible;
  z-index:30;
}
.game-top-nav .game-more-nav > summary{
  list-style:none;
  width:48px;
  height:42px;
  border-radius:9px;
  border:1px solid var(--border);
  background:#121a2a;
  color:#fff;
  font-size:24px;
  font-weight:950;
  line-height:1;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  user-select:none;
}
.game-top-nav .game-more-nav > summary::-webkit-details-marker{display:none;}
.game-top-nav .game-more-nav > summary:hover{transform:translateY(-2px);border-color:#71809c;}
.game-top-nav .game-more-panel{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  width:max-content;
  max-width:min(520px, calc(100vw - 28px));
  padding:10px;
  border:1px solid rgba(148,163,184,.28);
  border-radius:18px;
  background:rgba(7,17,31,.97);
  box-shadow:0 18px 42px rgba(0,0,0,.38);
  display:none;
  grid-template-columns:repeat(6, 48px);
  gap:9px;
}
.game-top-nav .game-more-nav[open] .game-more-panel{display:grid;}
.game-top-nav .game-more-panel button{margin:0;}
@media(max-width:760px){
  .game-top-nav .game-more-nav{
    width:100%;
    max-width:48px;
    height:38px;
  }
  .game-top-nav .game-more-nav > summary{
    width:100%;
    max-width:48px;
    height:38px;
    font-size:22px;
  }
  .game-top-nav .game-more-panel{
    right:50%;
    transform:translateX(50%);
    grid-template-columns:repeat(4, 42px);
    gap:8px;
    max-width:calc(100vw - 24px);
    padding:9px;
  }
  .game-top-nav .game-more-panel button{
    width:42px;
    height:38px;
    max-width:42px;
  }
}

/* Mobile homepage compression: student controls use two compact rows only on phones. */
@media (max-width: 760px){
  .setup-card .load-grid{
    grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
    gap:12px !important;
    align-items:end !important;
  }
  .setup-card .load-grid .field{
    min-width:0 !important;
  }
  .setup-card .load-grid input,
  .setup-card .load-grid select{
    min-width:0 !important;
  }
  .setup-card .load-grid .save-load-plus{
    width:100% !important;
    min-width:0 !important;
    align-self:end !important;
  }

  /* On mobile, show only the student's current journey level and the next level. */
  .learning-journey .journey-badges{
    grid-template-columns:repeat(2,minmax(88px,1fr)) !important;
    gap:10px !important;
  }
  .learning-journey .journey-badge{
    display:none !important;
  }
  .learning-journey .journey-badge.current-stage,
  .learning-journey .journey-badge.next-stage{
    display:flex !important;
  }
  .learning-journey .journey-badge.current-stage{
    opacity:1 !important;
    filter:none !important;
    border-color:#f7bd43 !important;
    box-shadow:0 0 12px rgba(247,189,67,.22) !important;
  }
}

/* Keep the floating language selector on the homepage only. */
body.game-view-on .floating-language-toggle{
  display:none !important;
}


/* v61: Put the coin bar inline with each game page title */
.game-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin:32px 0 18px;
}
.game-title-row .game-title{
  margin:0;
  flex:1 1 auto;
  min-width:0;
}
.game-title-row .game-coin-bar{
  flex:0 1 auto;
  width:auto;
  min-height:46px;
  margin:0;
  padding:10px 14px !important;
  border-radius:15px;
}
.game-title-row .game-coin-bar b{
  font-size:18px;
}
.game-title-row .mini-avatar{
  font-size:19px;
}
.game-title-row .coinbar-awards button{
  width:34px;
  min-width:34px;
  height:28px;
  font-size:12px;
}
@media(max-width:860px){
  .game-title-row{
    align-items:flex-start;
    flex-direction:column;
    gap:12px;
    margin-top:24px;
  }
  .game-title-row .game-coin-bar{
    width:100%;
  }
}

/* Guided website intro tour */
.ee-intro-launcher{
  position:fixed;
  right:14px;
  bottom:14px;
  z-index:90;
  border:2px solid rgba(60,39,16,.32);
  border-radius:999px;
  background:linear-gradient(180deg,#fff6d8,#ffd166);
  color:#3b260f;
  font-weight:900;
  padding:10px 14px;
  box-shadow:0 10px 26px rgba(50,31,8,.22);
  cursor:pointer;
}
.ee-intro-launcher:hover{ transform:translateY(-1px); }
.ee-intro-active .ee-intro-launcher{ display:none; }
.ee-intro-highlight{
  position:fixed;
  z-index:9998;
  border:4px solid #ffd166;
  border-radius:18px;
  background:transparent;
  box-shadow:0 0 0 9999px rgba(9,18,36,.74), 0 0 0 8px rgba(255,209,102,.22), 0 18px 48px rgba(0,0,0,.35);
  pointer-events:none;
  transition:top .18s ease,left .18s ease,width .18s ease,height .18s ease;
}
.ee-intro-card{
  position:fixed;
  z-index:9999;
  width:min(360px, calc(100vw - 28px));
  background:#fffaf0;
  color:#2c1d0d;
  border:3px solid #f7bd43;
  border-radius:20px;
  padding:18px;
  box-shadow:0 18px 50px rgba(0,0,0,.32);
}
.ee-intro-card h3{
  margin:0 0 8px;
  font-size:20px;
  line-height:1.2;
}
.ee-intro-card p{
  margin:0 0 14px;
  font-size:15px;
  line-height:1.45;
  font-weight:700;
}
.ee-intro-count{
  display:block;
  margin-bottom:12px;
  color:#725022;
  font-size:13px;
  font-weight:900;
}
.ee-intro-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.ee-intro-actions button{
  border:0;
  border-radius:999px;
  padding:9px 13px;
  font-weight:900;
  cursor:pointer;
}
.ee-intro-skip,.ee-intro-back{
  background:#f0e7d7;
  color:#4a3216;
}
.ee-intro-next{
  background:#2f2415;
  color:#fff7df;
}
@media(max-width:640px){
  .ee-intro-launcher{
    right:10px;
    bottom:10px;
    padding:9px 12px;
    font-size:13px;
  }
  .ee-intro-card{
    padding:15px;
    border-radius:17px;
  }
  .ee-intro-card h3{ font-size:18px; }
  .ee-intro-card p{ font-size:14px; }
}


/* Simplified teacher leaderboard: coins, rarest item, total item value */
.leaderboard-section .field{max-width:100%;}
.leader{grid-template-columns:58px minmax(210px,1fr) 140px minmax(260px,1fr);}
.leader-score .item-chip{min-width:38px;min-height:38px;padding:4px 8px;background:rgba(15,23,42,.72);}
.leader-score .item-chip-emoji{font-size:25px;}
.leader-mode-rare .leader-score{padding:7px 8px;}
.leader-mode-rare .leader-metrics .item-chip{margin:0 4px;vertical-align:middle;}
@media(max-width:760px){
  .leaderboard-section{margin-top:18px;}
  .leaderboard-section h1{font-size:22px;margin-bottom:12px;}
  .leaderboard-section p{display:none;}
  .leaderboard-section .field{margin-bottom:10px;}
  .leader-list{gap:6px;}
  .leader{
    grid-template-columns:28px minmax(0,1fr) auto !important;
    gap:8px;
    padding:7px 9px;
    border-radius:12px;
    min-height:42px;
  }
  .leader-rank{gap:0;}
  .leader-rank span{width:24px;height:24px;font-size:12px;}
  .leader-rank small,.leader-avatar,.leader-student em,.leader-details{display:none!important;}
  .leader-student{min-width:0;gap:0;}
  .leader-student b{font-size:15px;line-height:1.05;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .leader-score{
    grid-column:auto!important;
    min-height:0;
    border:0;
    background:transparent;
    padding:0;
    font-size:16px;
    min-width:38px;
    text-align:right;
    box-shadow:none;
  }
  .leader-score span{display:none!important;}
  .leader-score .item-chip{min-width:28px;min-height:28px;padding:2px 5px;}
  .leader-score .item-chip-emoji{font-size:21px;}
}


@media(max-width:720px){
  .recipe-book-modal-backdrop{padding:12px;align-items:flex-start;overflow:auto;}
  .recipe-book-modal{width:calc(100vw - 24px);max-height:calc(100vh - 24px);padding:18px 14px;border-radius:20px;margin:8px 0;}
  .recipe-book-modal-head{padding-right:58px;margin-bottom:14px;}
  .recipe-book-modal-head h2{font-size:25px;}
  .recipe-book-modal-head p{font-size:13px;}
  .recipe-book-close{right:10px;top:10px;width:48px;height:48px;border-radius:16px;font-size:34px;line-height:40px;}
  .recipe-modal-grid{max-height:calc(100vh - 155px);grid-template-columns:1fr;}
}

/* Teacher whiteboard: teacher-only top-nav button plus persistent student board modal. */
.teacher-whiteboard-link{display:none!important;}
body.teacher-mode-on .game-top-nav .teacher-whiteboard-link{display:inline-flex!important;}
body:not(.teacher-mode-on) .teacher-whiteboard-link{display:none!important;}

.teacher-whiteboard-overlay{
  position:fixed;
  inset:0;
  z-index:2800;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:28px;
  background:rgba(2,6,23,.68);
  backdrop-filter:blur(3px);
}
.teacher-whiteboard-modal{
  position:relative;
  width:min(1040px, calc(100vw - 36px));
  height:min(76vh, 720px);
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  gap:14px;
  border:1px solid rgba(125,211,252,.45);
  border-radius:26px;
  background:radial-gradient(circle at top left, rgba(56,189,248,.16), transparent 34%), linear-gradient(145deg,#0d1b34,#07111f);
  box-shadow:0 30px 85px rgba(0,0,0,.66),0 0 0 1px rgba(255,255,255,.08) inset;
  padding:24px;
}
.teacher-whiteboard-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding-right:70px;
}
.teacher-whiteboard-head h2{
  margin:0 0 6px;
  font-size:32px;
  line-height:1.05;
  color:#f8fafc;
}
.teacher-whiteboard-head p{
  margin:0;
  color:#cbd5e1;
  font-weight:850;
}
.teacher-whiteboard-close{
  position:absolute;
  right:16px;
  top:14px;
  width:56px;
  height:56px;
  border-radius:18px;
  border:2px solid rgba(255,255,255,.84);
  background:linear-gradient(180deg,#f87171,#dc2626);
  color:#fff;
  font-size:40px;
  font-weight:950;
  line-height:48px;
  cursor:pointer;
  box-shadow:0 8px 0 rgba(127,29,29,.62),0 16px 30px rgba(0,0,0,.36);
  text-shadow:0 2px 0 rgba(0,0,0,.28);
}
.teacher-whiteboard-close:hover{transform:translateY(-1px);filter:brightness(1.06);}
.teacher-whiteboard-close:active{transform:translateY(4px);box-shadow:0 4px 0 rgba(127,29,29,.62),0 10px 20px rgba(0,0,0,.28);}
.teacher-whiteboard-clear{
  border:1px solid rgba(251,191,36,.55);
  border-radius:16px;
  background:linear-gradient(180deg,#fde68a,#f59e0b);
  color:#07111f;
  font-weight:950;
  padding:12px 18px;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.22);
}
.teacher-whiteboard-body{
  min-height:0;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(220px,280px);
  gap:14px;
  align-items:stretch;
}
.teacher-whiteboard-text{
  width:100%;
  height:100%;
  min-height:0;
  resize:none;
  border:8px solid #e2e8f0;
  border-radius:24px;
  background:#f8fafc;
  color:#111827;
  box-shadow:0 16px 32px rgba(0,0,0,.24) inset,0 12px 30px rgba(0,0,0,.32);
  padding:24px 28px;
  font-family:Arial, Helvetica, sans-serif;
  font-size:clamp(28px, 4.2vw, 56px);
  line-height:1.12;
  font-weight:950;
  letter-spacing:.01em;
  outline:none;
}
.teacher-whiteboard-text::placeholder{color:#94a3b8;}
.teacher-whiteboard-grammar{
  min-height:0;
  overflow:auto;
  border:2px solid rgba(251,191,36,.68);
  border-radius:20px;
  background:linear-gradient(180deg,#fffbeb,#fef3c7);
  color:#111827;
  box-shadow:0 12px 26px rgba(0,0,0,.24);
  padding:14px 14px 12px;
}
.teacher-whiteboard-grammar-kicker{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-bottom:8px;
  border-radius:999px;
  background:#111827;
  color:#fef3c7;
  padding:5px 10px;
  font-size:12px;
  font-weight:950;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.teacher-whiteboard-grammar-title{
  margin:0 0 10px;
  color:#78350f;
  font-size:14px;
  font-weight:950;
  line-height:1.25;
}
.teacher-whiteboard-grammar ul{
  margin:0;
  padding-left:20px;
}
.teacher-whiteboard-grammar li{
  margin:0 0 8px;
  font-size:17px;
  line-height:1.28;
  font-weight:900;
}
.teacher-whiteboard-grammar-empty{
  margin:0;
  color:#92400e;
  font-size:15px;
  line-height:1.35;
  font-weight:850;
}
.teacher-whiteboard-status{
  color:#cbd5e1;
  font-weight:850;
  font-size:14px;
  text-align:right;
}
@media(max-width:760px){
  .teacher-whiteboard-overlay{padding:12px;align-items:flex-start;overflow:auto;}
  .teacher-whiteboard-modal{width:calc(100vw - 24px);height:calc(100vh - 24px);padding:16px 12px;border-radius:22px;gap:10px;}
  .teacher-whiteboard-head{padding-right:62px;display:grid;grid-template-columns:1fr;gap:10px;}
  .teacher-whiteboard-head h2{font-size:25px;}
  .teacher-whiteboard-head p{font-size:13px;}
  .teacher-whiteboard-clear{width:max-content;padding:10px 16px;}
  .teacher-whiteboard-close{right:12px;top:10px;width:50px;height:50px;font-size:36px;line-height:42px;border-radius:16px;}
  .teacher-whiteboard-body{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) auto;gap:10px;}
  .teacher-whiteboard-text{border-width:6px;border-radius:20px;padding:16px 14px;font-size:clamp(24px, 7vw, 40px);}
  .teacher-whiteboard-grammar{max-height:28vh;border-radius:18px;padding:12px;}
  .teacher-whiteboard-grammar-title{font-size:13px;margin-bottom:8px;}
  .teacher-whiteboard-grammar li{font-size:15px;margin-bottom:6px;}
  .teacher-whiteboard-status{text-align:left;font-size:13px;}
}


/* Teacher parent message: WeChat-ready class summary overlay. */
.teacher-parent-message-btn{display:none!important;}
body.teacher-mode-on .teacher-parent-message-btn{display:inline-flex!important;}
.class-progress-parent-message{
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  border-radius:13px;
  border:1px solid rgba(251,191,36,.5);
  background:linear-gradient(180deg,rgba(251,191,36,.22),rgba(146,64,14,.24));
  color:#fff7ed;
  font-size:20px;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.2);
}
.class-progress-parent-message:hover{transform:translateY(-1px);filter:brightness(1.08);}
.parent-message-overlay{
  position:fixed;
  inset:0;
  z-index:2850;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:28px;
  background:rgba(2,6,23,.70);
  backdrop-filter:blur(3px);
}
.parent-message-modal{
  position:relative;
  width:min(820px, calc(100vw - 36px));
  max-height:min(86vh, 760px);
  display:grid;
  grid-template-rows:auto auto minmax(260px,1fr) auto;
  gap:14px;
  border:1px solid rgba(251,191,36,.48);
  border-radius:26px;
  background:radial-gradient(circle at top left, rgba(251,191,36,.16), transparent 34%), linear-gradient(145deg,#0d1b34,#07111f);
  box-shadow:0 30px 85px rgba(0,0,0,.66),0 0 0 1px rgba(255,255,255,.08) inset;
  padding:24px;
}
.parent-message-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding-right:70px;}
.parent-message-head h2{margin:0 0 6px;font-size:30px;line-height:1.05;color:#f8fafc;}
.parent-message-head p{margin:0;color:#cbd5e1;font-weight:850;}
.parent-message-close{
  position:absolute;
  right:16px;
  top:14px;
  width:54px;
  height:54px;
  border-radius:18px;
  border:2px solid rgba(255,255,255,.84);
  background:linear-gradient(180deg,#f87171,#dc2626);
  color:#fff;
  font-size:38px;
  font-weight:950;
  line-height:46px;
  cursor:pointer;
  box-shadow:0 8px 0 rgba(127,29,29,.62),0 16px 30px rgba(0,0,0,.36);
  text-shadow:0 2px 0 rgba(0,0,0,.28);
}
.parent-message-toolbar{display:flex;gap:8px;flex-wrap:wrap;}
.parent-message-lang-btn{
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(15,23,42,.72);
  color:#dbe6f7;
  padding:9px 14px;
  font-weight:950;
  cursor:pointer;
}
.parent-message-lang-btn.active{background:linear-gradient(180deg,#fde68a,#f59e0b);color:#07111f;border-color:rgba(251,191,36,.75);}
.parent-message-text{
  width:100%;
  min-height:300px;
  height:100%;
  resize:vertical;
  border:1px solid rgba(148,163,184,.38);
  border-radius:18px;
  background:#f8fafc;
  color:#0f172a;
  box-shadow:0 12px 28px rgba(0,0,0,.20) inset;
  padding:18px 20px;
  font-family:Arial, Helvetica, sans-serif;
  font-size:17px;
  line-height:1.45;
  font-weight:700;
  outline:none;
}
.parent-message-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;}
@media(max-width:760px){
  .class-progress-parent-message{width:38px;height:38px;font-size:19px;}
  .parent-message-overlay{padding:12px;align-items:flex-start;overflow:auto;}
  .parent-message-modal{width:calc(100vw - 24px);max-height:none;min-height:calc(100vh - 24px);padding:16px 12px;border-radius:22px;gap:10px;grid-template-rows:auto auto minmax(300px,1fr) auto;}
  .parent-message-head{padding-right:60px;}
  .parent-message-head h2{font-size:25px;}
  .parent-message-head p{font-size:13px;}
  .parent-message-close{right:12px;top:10px;width:50px;height:50px;font-size:36px;line-height:42px;border-radius:16px;}
  .parent-message-text{min-height:360px;font-size:16px;padding:16px;}
  .parent-message-actions{justify-content:stretch;}
  .parent-message-actions button{flex:1 1 160px;}
}


/* Large Baidu fallback handover prompt shown after browser speech fails. */
.baidu-fallback-prompt{
  position:fixed;
  inset:0;
  z-index:1000002;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  pointer-events:none;
  opacity:0;
  transform:scale(.98);
  transition:opacity .22s ease, transform .22s ease;
}
.baidu-fallback-prompt.show{
  opacity:1;
  transform:scale(1);
}
.baidu-fallback-card{
  width:min(520px, calc(100vw - 30px));
  border:3px solid rgba(251,191,36,.95);
  border-radius:28px;
  background:linear-gradient(145deg,#fff8dc,#ffffff 48%,#e9f7ff);
  color:#0f172a;
  text-align:center;
  padding:28px 24px 24px;
  box-shadow:0 28px 75px rgba(0,0,0,.48), 0 0 0 8px rgba(251,191,36,.15);
}
.baidu-fallback-emoji{
  font-size:74px;
  line-height:1;
  margin-bottom:10px;
  animation:baiduFallbackSpin 1.35s linear infinite;
}
.baidu-fallback-card strong{
  display:block;
  font-size:42px;
  line-height:1.05;
  font-weight:950;
  letter-spacing:-.04em;
}
.baidu-fallback-card p{
  margin:12px auto 0;
  max-width:420px;
  font-size:20px;
  line-height:1.32;
  font-weight:900;
}
.baidu-fallback-card small{
  display:block;
  margin-top:14px;
  color:#334155;
  font-size:17px;
  font-weight:950;
}
@keyframes baiduFallbackSpin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
@media(max-width:640px){
  .baidu-fallback-card{padding:24px 18px 22px;border-radius:24px;}
  .baidu-fallback-emoji{font-size:64px;}
  .baidu-fallback-card strong{font-size:34px;}
  .baidu-fallback-card p{font-size:18px;}
}
