:root{color:#183153;background:linear-gradient(#f6fff5,#eef8ff);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:linear-gradient(#f6fff5,#eef8ff)}button,input{font:inherit}button{cursor:pointer;color:#183153;background:#eef4ff;border:none;border-radius:18px;padding:.9rem 1.1rem;font-weight:700;transition:transform .15s,box-shadow .2s,opacity .2s}button:hover{transform:translateY(-1px);box-shadow:0 10px 22px #0a32641f}button:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}button.primary{color:#fff;background:linear-gradient(135deg,#31b45d,#1f8b45)}button.danger{color:#a11;background:#ffe6e6}button.ghost{background:#fff;border:1px solid #dde8f4}input{border:2px solid #dbe7ff;border-radius:18px;width:100%;padding:1rem}input:focus{border-color:#31b45d;outline:none;box-shadow:0 0 0 4px #31b45d1f}.app-shell{min-height:100vh;padding:18px;position:relative;overflow:hidden}.background-orb{filter:blur(10px);opacity:.25;pointer-events:none;border-radius:999px;position:fixed}.orb-1{background:#9af0b1;width:280px;height:280px;top:-40px;left:-40px}.orb-2{background:#9cd2ff;width:320px;height:320px;bottom:-80px;right:-40px}.app-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe0;border:1px solid #fffc;border-radius:32px;width:min(1180px,100%);margin:0 auto;padding:24px;box-shadow:0 20px 60px #285a781f}.topbar,.section-title-row,.player-strip,.play-head,.result-actions,.topbar-actions{align-items:center;gap:12px;display:flex}.topbar{justify-content:space-between;margin-bottom:18px}.brand{align-items:center;gap:16px;display:flex}.brand-logo{object-fit:contain;background:#fff;border-radius:22px;width:92px;height:92px;padding:8px;box-shadow:0 8px 24px #31b45d2e}.eyebrow{text-transform:uppercase;letter-spacing:.1em;color:#2b8f4d;margin:0 0 4px;font-size:.82rem;font-weight:800}h1,h2,h3,p{margin-top:0}h1{margin-bottom:6px;font-size:clamp(2rem,4vw,3rem)}.subtext{color:#58708b;max-width:720px}.pill{background:#fff;border:1px solid #dfe9f6}.pill.active{color:#156f38;background:#ddf7e6}.player-strip{flex-wrap:wrap;justify-content:flex-start;margin:12px 0 20px}.panel{background:linear-gradient(#fffffff5,#f7fbfff5);border:1px solid #e8eff9;border-radius:28px;padding:24px}.profile-grid,.module-grid,.level-grid,.category-grid,.dashboard-grid,.avatar-grid{gap:16px;display:grid}.profile-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.module-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.level-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.category-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.avatar-grid{grid-template-columns:repeat(5,minmax(0,1fr));margin:14px 0}.player-card,.module-card,.level-card,.category-card,.dashboard-card,.op-card{text-align:left;background:#fff;border:1px solid #e4edf8;border-radius:24px;padding:18px}.player-card.compact{align-items:center;gap:12px;padding:12px 16px;display:flex}.profile-select{background:0 0;flex-direction:column;align-items:flex-start;gap:8px;width:100%;padding:0;display:flex;box-shadow:none!important}.card-actions{gap:8px;margin-top:12px;display:flex}.avatar{background:#f4fbf6;border-radius:18px;place-items:center;width:64px;height:64px;font-size:2rem;display:grid}.avatar.big{width:52px;height:52px;font-size:1.7rem}.small-muted{color:#71839a;font-size:.92rem}.module-card{flex-direction:column;gap:12px;min-height:180px;display:flex}.module-emoji{font-size:2.2rem}.operation-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px;display:grid}.op-card{flex-direction:column;align-items:flex-start;gap:6px;display:flex}.op-card.selected,.level-card.selected,.avatar-choice.selected{background:#f5fff8;border:2px solid #31b45d}.level-card.locked{opacity:.6}.play-panel{text-align:center}.play-head{justify-content:space-between;align-items:flex-start}.question-box{background:#f7fbff;border:1px solid #e3eef9;border-radius:28px;margin:12px 0 18px;padding:30px 20px}.math-question{letter-spacing:.04em;font-size:clamp(2rem,6vw,4rem);font-weight:800}.answer-row{gap:12px;max-width:420px;margin:0 auto;display:flex}.answer-row input{text-align:center;font-size:1.2rem}.spelling-card{background:linear-gradient(#fff,#f6fbff);border:1px solid #e4edf8;border-radius:28px;padding:24px}.emoji-picture{margin-bottom:8px;font-size:4.5rem}.spelling-word{letter-spacing:.24em;color:#1b3550;margin-bottom:16px;font-size:clamp(2rem,5vw,3.6rem);font-weight:900}.clue,.sentence{color:#597088;margin-bottom:10px}.choices{grid-template-columns:repeat(4,minmax(0,90px));justify-content:center;gap:12px;margin-top:16px;display:grid}.choice-btn{background:#eef8ff;padding:1rem 0;font-size:1.4rem}.feedback{color:#1d6f3b;background:#f6fff8;border:1px solid #d8f0e0;border-radius:18px;margin-top:16px;padding:14px 16px;font-weight:700}.stars{gap:6px;font-size:1.5rem;display:flex}.result-panel{text-align:center}.confetti-line{margin-bottom:8px;font-size:1.6rem}.big-score{color:#173454;font-size:1.5rem;font-weight:800}.footer-note{text-align:right;color:#7991a8;margin-top:16px;font-size:.88rem}.modal-backdrop{z-index:20;background:#0f19235c;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:28px;width:min(520px,100%);padding:24px;box-shadow:0 20px 60px #0000002e}.modal.wide{width:min(900px,100%)}.toggle-row{border-bottom:1px solid #edf2f8;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.avatar-choice{background:#fff;border:1px solid #e3edf8;font-size:1.8rem}.dashboard-head{align-items:center;gap:12px;margin-bottom:12px;display:flex}@media (width<=900px){.topbar,.play-head{flex-direction:column;align-items:flex-start}.operation-row{grid-template-columns:repeat(2,minmax(0,1fr))}.topbar-actions{flex-wrap:wrap}}@media (width<=640px){.app-card{border-radius:24px;padding:16px}.brand{align-items:flex-start}.brand-logo{width:72px;height:72px}.answer-row{flex-direction:column}.choices{grid-template-columns:repeat(2,minmax(0,1fr))}.avatar-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.hero-onboard,.welcome-grid{gap:18px;margin-bottom:18px;display:grid}.mode-chip{color:#1b7a3e;background:#f4fbf6;border:1px solid #d9f0e1;border-radius:999px;padding:.7rem 1rem;font-weight:800}.mode-toggle{flex-wrap:wrap;gap:8px;display:flex}.welcome-main{gap:16px;display:grid}.action-bar{z-index:5;padding-top:10px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));background:linear-gradient(#fff0,#fffffff5 34%,#fff);position:sticky;bottom:0}.compact-actions{justify-content:center;display:flex}.vertical-math{flex-direction:column;align-items:flex-end;min-width:5ch;font-family:Courier New,monospace;font-size:clamp(2rem,6vw,3.6rem);font-weight:800;line-height:1.1;display:inline-flex}.math-line{white-space:pre}.bottom-line{padding-left:1ch;position:relative}.operator{position:absolute;top:0;left:0}.math-divider{border-top:4px solid #183153;width:100%;margin:8px 0}.answer-slot{color:#5c738a}.question-box{place-items:center;min-height:220px;display:grid}.feedback{max-width:700px;margin-left:auto;margin-right:auto}.donation-card{margin:16px 0}.speak-row{justify-content:center;display:flex}@media (width<=900px){.question-box{min-height:180px}}@media (width<=640px){.play-panel{padding-bottom:8px}.question-box{min-height:150px;padding:20px 14px}.action-bar{margin:0 -6px;padding-left:6px;padding-right:6px}}.practice-helper{text-align:center;margin-top:8px}.donation-highlight{color:#8a4b08;background:linear-gradient(135deg,#fff3bf,#ffd8a8 55%,#ffe8cc);border:1px solid #ffc078;border-radius:16px;padding:10px 14px;font-weight:800;display:inline-block;box-shadow:0 10px 24px #ffc1072e}.mode-choice-row{flex-wrap:wrap;gap:10px;display:flex}.feedback.warning{color:#8a5b00;background:#fff9db;border-color:#ffe08a}.feedback.success{color:#1d6f3b;background:#f6fff8;border-color:#d8f0e0}.feedback.error{color:#8a5b00;background:#fff3bf;border-color:#ffd43b}.choice-instruction{text-align:center;margin-top:12px}.level-card,.category-card{flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:6px;min-height:132px;display:flex}.tile-title{color:#1c3551;font-size:1.2rem;font-weight:800;line-height:1.25;display:block}.tile-subtitle{color:#2b8f4d;font-size:.98rem;font-weight:700;line-height:1.25;display:block}.tile-score{letter-spacing:.02em;text-transform:uppercase;color:#7b8ea6;margin-top:4px;font-size:.86rem;font-weight:700;display:block}.tile-score-value{color:#5e6fe6;font-size:1.05rem;font-weight:800;line-height:1.2;display:block}.picture-image{object-fit:contain;width:112px;height:112px;margin:0 auto 12px;display:block}.tile-badge{border-radius:999px;margin-top:6px;padding:6px 10px;font-size:.84rem;font-weight:800;display:inline-block}.tile-badge.done{color:#1b7a3e;background:#e8fbef;border:1px solid #b8e7c8}.tile-badge.pending{color:#976400;background:#fff8dd;border:1px solid #ffe08a}.tile-action{color:#4e64d8;margin-top:auto;font-weight:800;display:inline-block}.question-stage{scroll-margin-top:18px;position:relative;overflow:hidden}.stage-correct{border-color:#7cd49a;animation:.9s popGlow;box-shadow:0 0 0 4px #31b45d1f,0 18px 40px #31b45d2e}.stage-wrong{border-color:#ffd166;animation:.55s wrongShake;box-shadow:0 0 0 4px #ffd1662e,0 18px 40px #ffc1071f}.burst{text-align:center;margin-top:10px;font-size:1.7rem;font-weight:800;animation:.9s burstFade}.burst-correct{color:#1b7a3e}.burst-wrong{color:#a56a00}@keyframes popGlow{0%{transform:scale(.98)}25%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes wrongShake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@keyframes burstFade{0%{opacity:0;transform:translateY(6px)scale(.95)}20%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-8px)scale(1.03)}}.install-pill{color:#5f3b00;background:linear-gradient(135deg,#ffe082,#ffb74d)}.update-pill{color:#7a1240;background:linear-gradient(135deg,#ffd1dc,#f6a6c1)}.update-banner{background:linear-gradient(135deg,#fff6fa,#ffe9f1);border:1px solid #ffd8e4;border-radius:20px;justify-content:space-between;align-items:center;gap:1rem;margin:0 0 1rem;padding:1rem 1.1rem;display:flex;box-shadow:0 10px 24px #a32c5f14}.update-banner p{color:#6e3652;margin:.35rem 0 0}@media (width<=720px){.update-banner{flex-direction:column;align-items:stretch}}.grammar-card{text-align:left;align-items:flex-start;gap:.85rem}.grammar-badge{color:#166534;background:#22c55e1f;border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .65rem;font-size:.9rem;font-weight:700;display:inline-flex}.grammar-prompt{color:#123c66;font-size:clamp(1.15rem,2vw,1.45rem);font-weight:800}.grammar-sentence{width:100%;font-size:1.08rem}.grammar-choices{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));width:100%}.grammar-choice-btn{text-transform:none;min-height:56px;padding-inline:1rem;font-size:1rem}.brand{align-items:flex-start}.brand-copy{flex-direction:column;gap:8px;display:flex}.tagline{color:#2b8f4d;margin:0;font-size:1.05rem;font-weight:800}.caution-card{color:#8a4b08;background:linear-gradient(135deg,#fff4e6,#fff9db);border:1px solid #ffd8a8;border-radius:18px;max-width:760px;margin-top:6px;padding:14px 16px;box-shadow:0 10px 24px #ffc1071f}.caution-card strong{margin-bottom:8px;font-size:1rem;display:block}.caution-card p{margin:4px 0;font-weight:700}.top-donation{margin-top:4px}.grammar-prompt{color:#123c66;text-align:center;font-size:clamp(1.25rem,2.3vw,1.7rem);font-weight:900}.grammar-sentence{text-align:center;width:100%;font-size:clamp(1.4rem,3vw,2rem);line-height:1.35}.grammar-sentence-highlight{color:#7a4b00;background:linear-gradient(135deg,#fff7cc,#ffe7a3);border:2px solid #ffd166;border-radius:22px;margin:.5rem auto .75rem;padding:.9rem 1rem;font-weight:800;box-shadow:0 10px 22px #ffd16640}.grammar-speak-row{margin-top:.2rem;margin-bottom:.35rem}.grammar-speak-row button{font-size:1rem;font-weight:800}.offline-banner{background:linear-gradient(135deg,#f4f9ff,#e9f2ff);border:1px solid #d7e7ff;border-radius:20px;justify-content:space-between;align-items:center;gap:1rem;margin:0 0 1rem;padding:1rem 1.1rem;display:flex;box-shadow:0 10px 24px #20589614}.offline-banner p{color:#33567c;margin:.35rem 0 0}@media (width<=720px){.offline-banner{flex-direction:column;align-items:stretch}}
