:root{color:#f4fbf7;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#10243a;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100%;margin:0}body{overflow-x:hidden}button,select,input,textarea{font:inherit}button:focus-visible,select:focus-visible,input:focus-visible,textarea:focus-visible{outline-offset:2px;outline:3px solid #f5c95dbf}.app-shell{color:#f4fbf7;background:linear-gradient(135deg,#18515ee0,#20173deb),#10243a;grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid}.app-shell.adventure-shell{background:#05080d;min-height:100dvh;display:block}.adventure-shell .sidebar,.adventure-shell .topbar{display:none}.adventure-shell .main-stage{min-height:100dvh}.adventure-exit-button{z-index:80;color:#f8f5dc;cursor:pointer;min-height:42px;font:inherit;background:#07101cc2;border:1px solid #f5c95d8c;border-radius:10px;padding:0 16px;font-weight:900;position:fixed;top:16px;right:18px;box-shadow:0 14px 34px #00000059}.adventure-exit-button:hover{background:#f5c95d2e}.sidebar{background:#081925eb;border-right:1px solid #ffffff1f;flex-direction:column;min-height:100vh;display:flex}.brand-block{border-bottom:1px solid #ffffff1f;align-items:center;gap:12px;padding:22px 20px;display:flex}.brand-mark,.crest{color:#10243a;place-items:center;font-weight:900;display:grid;box-shadow:0 14px 32px #00000040}.brand-mark{background:linear-gradient(135deg,#f5c95d,#6fe0d1);border-radius:13px;width:46px;height:46px}.brand-block h1,.topbar h2,.quest-detail h3,.lesson-card h3{letter-spacing:0;margin:0}.brand-block h1{font-size:1.15rem}.brand-block p,.eyebrow,.status-label,.card-label{color:#a7d8ce;text-transform:uppercase;letter-spacing:0;margin:0;font-size:.75rem;font-weight:800}.mode-list{gap:8px;padding:16px;display:grid}.mode-list button,.top-actions button,.action-row button,.answer-grid button,.lesson-card button,.soft-button,.next-button{color:#f4fbf7;font:inherit;cursor:pointer;background:#ffffff12;border:1px solid #ffffff24;border-radius:10px;font-weight:800;transition:border-color .16s,background .16s,transform .12s}.mode-list button{text-align:left;align-items:center;gap:10px;min-height:42px;padding:0 12px;display:flex}.mode-list button:hover,.mode-list button.active,.top-actions button:hover,.action-row button:hover,.answer-grid button:hover,.lesson-card button:hover,.soft-button:hover,.next-button:hover{background:#f5c95d21;border-color:#f5c95dc7}.mode-list button:active,.top-actions button:active,.action-row button:active,.answer-grid button:active,.lesson-card button:active,.soft-button:active,.next-button:active{transform:translateY(1px)}.mode-glyph{color:#bdfaf1;background:#6fe0d12b;border-radius:8px;place-items:center;width:24px;height:24px;font-size:.78rem;display:grid}.status-panel{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:14px;margin:auto 16px 16px;padding:16px}.status-panel strong{color:#fff;margin-top:4px;display:block}.meter{background:#00000047;border-radius:999px;height:10px;margin:14px 0;overflow:hidden}.meter span{border-radius:inherit;background:linear-gradient(90deg,#f5c95d,#6fe0d1,#f47c9d);height:100%;display:block}.status-grid,.progress-metrics{color:#a7d8ce;grid-template-columns:1fr auto;gap:8px 12px;font-size:.9rem;display:grid}.status-grid strong{margin:0}.cloud-sync{color:#c5e4dd;background:#6fe0d114;border:1px solid #6fe0d138;border-radius:10px;margin-top:12px;padding:9px 10px;font-size:.8rem;font-weight:800;line-height:1.35}.cloud-sync.error{color:#ffd0c0;background:#ff8b5c1f;border-color:#ff8b5c6b}.main-stage{flex-direction:column;min-width:0;min-height:100vh;display:flex}.topbar{background:#0819258c;border-bottom:1px solid #ffffff1f;justify-content:space-between;align-items:center;gap:16px;min-height:76px;padding:16px 22px;display:flex}.topbar h2{font-size:1.35rem}.top-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.top-actions select{color:#f4fbf7;min-width:220px;min-height:38px;font:inherit;background:#10243a;border:1px solid #ffffff29;border-radius:10px;padding:0 12px}.top-actions select.voice-select{min-width:180px}.top-actions select.voice-style-select{min-width:150px}.voice-status{color:#a7d8ce;max-width:340px;font-size:.76rem;font-weight:900;line-height:1.25}.voice-status.matched{color:#bdfaf1}.voice-status.fallback{color:#ffd9a6}.top-actions button,.lesson-card button,.soft-button,.next-button{min-height:38px;padding:0 13px}.quest-view,.activity-grid,.progress-view{flex:1;gap:18px;padding:22px;display:grid}.quest-view{grid-template-columns:minmax(0,1.35fr) minmax(330px,.65fr)}.activity-grid,.progress-view{grid-template-columns:minmax(0,1fr) minmax(280px,.42fr);align-items:stretch}.realm-map,.quest-detail,.lesson-card,.npc-portrait{background:#07141fa8;border:1px solid #ffffff24;border-radius:16px;box-shadow:0 22px 60px #00000038}.realm-map{min-height:420px;padding:16px}.realm-map svg{border-radius:12px;width:100%;height:100%;min-height:420px;display:block}.map-node{cursor:pointer;transition:opacity .16s,transform .16s}.map-node:hover{opacity:.86;transform:translateY(-3px)}.quest-detail,.lesson-card{padding:22px}.quest-detail{flex-direction:column;justify-content:center;gap:14px;display:flex}.quest-detail h3,.lesson-card h3{font-size:1.65rem;line-height:1.15}.quest-detail p,.lesson-card p,.npc-portrait p,.roadmap-card li{color:#c5e4dd;line-height:1.55}.crest{color:#fff;border-radius:16px;width:58px;height:58px}.pill-row,.action-row{flex-wrap:wrap;gap:8px;display:flex}.pill-row span{color:#e9fff8;background:#ffffff14;border-radius:999px;padding:6px 10px;font-size:.82rem;font-weight:800}.action-row button{min-height:40px;padding:0 14px}.primary-card{flex-direction:column;justify-content:center;gap:16px;display:flex}.answer-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.answer-grid button{text-align:left;min-height:64px;padding:12px}.answer-grid button strong,.answer-grid button span{display:block}.answer-grid button span{color:#a7d8ce;margin-top:4px;font-size:.85rem}.feedback{background:#6fe0d11a;border-radius:10px;min-height:30px;padding:10px 12px}.spell-card{text-align:center;place-content:center;gap:12px;display:grid}.spell-card strong,.progress-metrics strong{color:#fff;font-size:2rem;line-height:1}.npc-portrait{grid-template-rows:90px 1fr auto;place-items:center;min-height:430px;padding:24px;display:grid;overflow:hidden}.npc-head{background:linear-gradient(145deg,#f5c95d,#ff8b5c);border-radius:26px 26px 30px 30px;width:86px;height:86px;box-shadow:0 16px 30px #0000003d}.npc-body{background:linear-gradient(160deg,#6fe0d1a6,#8b5fbfd9),#3b2f62;border-radius:90px 90px 18px 18px;width:min(78%,260px);height:240px;position:relative}.npc-body:before,.npc-body:after{content:"";background:#f47c9db8;border-radius:40px;width:62px;height:150px;position:absolute;top:42px}.npc-body:before{left:-34px;transform:rotate(15deg)}.npc-body:after{right:-34px;transform:rotate(-15deg)}.progress-view .lesson-card{gap:18px;display:grid}.progress-metrics{grid-template-columns:repeat(4,minmax(0,1fr))}.progress-metrics div{text-align:center;background:#ffffff12;border-radius:14px;place-content:center;gap:8px;min-height:112px;display:grid}.progress-metrics span{color:#a7d8ce;font-weight:800}.adventure-view{flex:1;min-height:640px;padding:0;position:relative}.game-shell{grid-template-columns:minmax(0,1fr) minmax(310px,.38fr);align-items:stretch;gap:18px;display:grid}.game-canvas-frame{background:radial-gradient(circle at 18% 24%,#f5c95d24,#0000 32%),radial-gradient(circle at 78% 18%,#f47c9d21,#0000 34%),#07141fbd;border:1px solid #ffffff24;border-radius:16px;grid-template-rows:minmax(0,1fr) auto;min-height:690px;display:grid;overflow:hidden;box-shadow:0 22px 60px #00000038}.phaser-stage{place-items:center;min-height:620px;display:grid}.phaser-stage canvas{image-rendering:auto;max-width:100%;max-height:100%;display:block}.world-message{color:#d8fff4;border-top:1px solid #ffffff1f;align-items:center;min-height:50px;padding:12px 16px;font-weight:900;display:flex}.adventure-panel{align-content:start;gap:14px;display:grid}.avatar-preview{background:linear-gradient(#ffffff14,#0000),#0000002e;border:1px solid #6fe0d13d;border-radius:16px;place-items:end center;width:116px;height:136px;padding:12px;display:grid}.avatar-preview span:first-child{z-index:2;border-radius:18px 18px 10px 10px;width:52px;height:24px;margin-bottom:-4px}.avatar-preview span:nth-child(2){z-index:1;border-radius:20px 20px 24px 24px;width:54px;height:54px;margin-bottom:-2px}.avatar-preview span:nth-child(3){border:4px solid;border-radius:18px 18px 10px 10px;width:66px;height:52px}.swatch-row{gap:8px;display:grid}.swatch-row span{color:#a7d8ce;text-transform:uppercase;font-size:.78rem;font-weight:900}.swatch-row div,.companion-row{flex-wrap:wrap;gap:8px;display:flex}.swatch-row button{border:2px solid #ffffff2e;border-radius:9px;width:32px;height:32px;min-height:32px;padding:0}.swatch-row button.active{border-color:#f5c95d;box-shadow:0 0 0 3px #f5c95d2e}.companion-row button{text-transform:capitalize;flex:1;min-width:84px}.companion-row button.active{background:#6fe0d129;border-color:#6fe0d1cc}.adventure-actions button{color:#10243a;background:linear-gradient(135deg,#f5c95deb,#6fe0d1e0);width:100%;min-height:46px}.realm-track{gap:9px;margin-top:4px;display:grid}.realm-track button{text-align:left;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:4px 10px;min-height:62px;padding:10px 12px;display:grid}.realm-track button.active{background:#f5c95d21;border-color:#f5c95dc7}.realm-track span{color:#a7d8ce;font-size:.8rem;font-weight:900}.battle-overlay{z-index:20;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#050a129e;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.battle-card{background:linear-gradient(145deg,#122f46fa,#1e1e37fa),#10243a;border:1px solid #ffffff29;border-radius:16px;gap:16px;width:min(760px,100%);padding:22px;display:grid;box-shadow:0 30px 90px #0000006b}.battle-header{justify-content:space-between;align-items:start;gap:14px;display:flex}.battle-header h3,.battle-card h4{margin:0}.battle-card h4{color:#fff;font-size:1.25rem}.battle-meter{background:#0000004d;border-radius:999px;height:14px;overflow:hidden}.battle-meter span{border-radius:inherit;background:linear-gradient(90deg,#f47c9d,#f5c95d);height:100%;transition:width .2s;display:block}.roadmap-card ol{gap:12px;margin:0;padding-left:20px;display:grid}button:disabled{cursor:not-allowed;opacity:.56}.login-shell{color:#f4fbf7;background:linear-gradient(135deg,#18515ee6,#20173df0),#10243a;grid-template-columns:minmax(0,1fr) minmax(360px,520px);min-height:100vh;display:grid}.login-art{place-items:center;min-height:100vh;padding:40px;display:grid;position:relative;overflow:hidden}.login-orbit{aspect-ratio:1;border:1px solid #6fe0d133;border-radius:50%;width:min(72vw,620px);position:absolute}.login-orbit span{color:#e9fff8;background:#07141fb3;border:1px solid #f5c95d42;border-radius:999px;padding:8px 12px;font-weight:900;position:absolute}.login-orbit span:first-child{top:21%;left:13%}.login-orbit span:nth-child(2){top:30%;right:14%}.login-orbit span:nth-child(3){bottom:18%;left:21%}.login-orbit span:nth-child(4){bottom:24%;right:18%}.login-castle{z-index:1;grid-template-columns:1fr 1.35fr 1fr;align-items:end;gap:12px;width:min(50vw,420px);min-width:260px;min-height:300px;display:grid}.login-castle div{background:linear-gradient(160deg,#6fe0d133,#f47c9d42),#07141fb8;border:1px solid #ffffff2e;border-radius:18px 18px 8px 8px;box-shadow:0 28px 80px #00000052}.login-castle div:first-child,.login-castle div:nth-child(3){height:220px}.login-castle div:nth-child(2){height:300px}.login-panel{background:#081925eb;border-left:1px solid #ffffff21;flex-direction:column;justify-content:center;gap:18px;min-height:100vh;padding:38px;display:flex}.compact-login{border:1px solid #ffffff21;border-radius:16px;max-width:420px;min-height:auto;margin:auto}.brand-row{align-items:center;gap:12px;display:flex}.brand-row h1,.brand-row p{margin:0}.brand-row p{color:#a7d8ce;font-weight:800}.segmented-control{background:#00000029;border:1px solid #ffffff1f;border-radius:12px;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:5px;display:grid}.segmented-control button,.primary-auth-button,.class-list button{color:#f4fbf7;font:inherit;cursor:pointer;border:0;border-radius:9px;font-weight:900}.segmented-control button{background:0 0;min-height:38px}.segmented-control button.active,.primary-auth-button{color:#10243a;background:linear-gradient(135deg,#f5c95d,#6fe0d1)}.role-control button.active{background:linear-gradient(135deg,#6fe0d1,#f47c9d)}.auth-form,.teacher-form{gap:12px;display:grid}.auth-form label,.teacher-form label{color:#a7d8ce;text-transform:uppercase;gap:7px;font-size:.78rem;font-weight:900;display:grid}.auth-form input,.teacher-form input{color:#f4fbf7;min-height:42px;font:inherit;background:#0000002e;border:1px solid #ffffff29;border-radius:10px;padding:0 12px}.primary-auth-button{min-height:46px}.form-notice{color:#ffd0c0;background:#ff8b5c1f;border:1px solid #ff8b5c6b;border-radius:10px;margin:0;padding:10px 12px;font-weight:800}.teacher-view{flex:1;grid-template-columns:minmax(280px,.75fr) minmax(360px,1.25fr);gap:18px;padding:22px;display:grid}.teacher-hero-card,.roster-card{grid-column:1/-1}.teacher-summary-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;display:grid}.teacher-summary-grid div{text-align:center;background:#ffffff12;border-radius:14px;place-content:center;gap:8px;min-height:98px;display:grid}.teacher-summary-grid strong{font-size:2rem}.teacher-summary-grid span,.student-row span,.class-list em{color:#a7d8ce;font-size:.82rem;font-style:normal;font-weight:800}.class-list{gap:10px;display:grid}.class-list button{text-align:left;background:#ffffff12;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:4px 10px;min-height:76px;padding:12px;display:grid}.class-list button.active{background:#f5c95d21;outline:2px solid #f5c95dc7}.class-list button span,.class-code-badge{color:#bdfaf1;background:#6fe0d129;border-radius:999px;padding:5px 8px;font-size:.78rem;font-weight:900}.class-list button em{grid-column:1/-1}.roster-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.student-table{gap:9px;display:grid}.student-row{background:#ffffff12;border-radius:12px;grid-template-columns:minmax(170px,1fr) repeat(4,minmax(96px,auto));align-items:center;gap:12px;padding:12px;display:grid}.student-row div{gap:3px;display:grid}@media (width<=1060px){.app-shell{grid-template-columns:1fr}.sidebar{min-height:auto}.mode-list{grid-template-columns:repeat(auto-fit,minmax(142px,1fr))}.status-panel{margin-top:0}.quest-view,.activity-grid,.progress-view,.game-shell,.login-shell,.teacher-view{grid-template-columns:1fr}.login-art{display:none}.login-panel{border-left:0;min-height:100vh}.teacher-summary-grid,.student-row{grid-template-columns:1fr 1fr}}@media (width<=720px){.topbar{flex-direction:column;align-items:stretch}.top-actions,.top-actions select{width:100%}.mode-list,.answer-grid,.progress-metrics{grid-template-columns:1fr}.quest-view,.activity-grid,.progress-view,.adventure-view,.teacher-view{padding:14px}.game-canvas-frame,.phaser-stage{min-height:460px}.teacher-summary-grid,.student-row{grid-template-columns:1fr}}.voxel-world{width:100%;height:calc(100vh - 76px);min-height:640px;image-rendering:pixelated;background:linear-gradient(#8cc9e6 0%,#69a9cf 40%,#23354b 100%);border-radius:0 0 14px 14px;position:relative;overflow:hidden}.adventure-shell .voxel-world{border-radius:0;height:100dvh;min-height:100dvh}.voxel-canvas{width:100%;height:100%;display:block}.voxel-minimap{pointer-events:none;image-rendering:pixelated;background:#050a12c7;border:3px solid #ecfff975;border-radius:3px;position:absolute;bottom:18px;right:18px;box-shadow:0 0 0 3px #050a12b8,0 8px 20px #00000080}.voxel-controls-hint{color:#f5f3dc;pointer-events:none;white-space:nowrap;background:#050a12d1;border:2px solid #f5c95d7a;border-radius:3px;padding:9px 18px;font-size:.84rem;font-weight:800;position:absolute;bottom:22px;left:50%;transform:translate(-50%);box-shadow:0 16px 40px #00000057}.voxel-controls-hint kbd{background:#ffffff26;border:2px solid #ffffff4d;border-radius:2px;margin:0 2px;padding:1px 6px;font-family:monospace;font-size:.8em;display:inline-block}.voxel-world-title{z-index:30;background:#050c14b8;border:2px solid #ecfff947;border-radius:3px;gap:2px;padding:11px 14px;display:grid;position:absolute;top:18px;left:18px;box-shadow:0 18px 44px #00000052}.voxel-world-title span{color:#a7d8ce;text-transform:uppercase;font-size:.7rem;font-weight:900}.voxel-world-title strong{color:#fff;font-size:1.05rem}.voxel-quest-hud{-webkit-backdrop-filter:none;backdrop-filter:none;color:#e8e8f0;background:#050a12d1;border:3px solid #fff2;border-radius:3px;width:260px;padding:0;font-size:.82rem;position:absolute;top:18px;left:200px;overflow:hidden;box-shadow:0 6px 24px #0009}.voxel-quest-zone{letter-spacing:.08em;text-transform:uppercase;color:#fff;opacity:.9;padding:6px 12px;font-size:.7rem;font-weight:700}.voxel-quest-title{color:#fff;padding:4px 12px 2px;font-size:.9rem;font-weight:800;line-height:1.2}.voxel-quest-focus{color:#aab;border-bottom:1px solid #ffffff14;padding:0 12px 8px;font-size:.72rem}.voxel-quest-objectives{padding:8px 12px}.voxel-obj-label{text-transform:uppercase;letter-spacing:.1em;color:#778;margin-bottom:5px;font-size:.65rem;font-weight:700}.voxel-obj-item{color:#bbc;align-items:baseline;gap:6px;padding:2px 0;font-size:.75rem;transition:color .3s;display:flex}.voxel-obj-item.done{color:#6ee78a;opacity:.7;text-decoration:line-through}.voxel-obj-check{color:#6ee78a;flex-shrink:0;font-size:.7rem}.voxel-obj-item em{color:#f5c95d;font-style:normal}.voxel-xp-row{color:#889;border-top:1px solid #ffffff14;justify-content:space-between;padding:6px 12px 8px;font-size:.7rem;display:flex}.voxel-encounter-backdrop{z-index:100;background:#000000b8;justify-content:center;align-items:center;animation:.15s voxelFadeIn;display:flex;position:absolute;inset:0}@keyframes voxelFadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.voxel-encounter-modal{background:#0e1320;border:3px solid #ccc;border-radius:4px;width:min(480px,92vw);overflow:hidden;box-shadow:0 20px 60px #000c}.voxel-encounter-header{justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.voxel-encounter-realm{color:#fff;letter-spacing:.04em;font-size:.85rem;font-weight:700}.voxel-encounter-cefr{color:#fff;background:#ffffff2e;border-radius:3px;padding:2px 8px;font-size:.7rem;font-weight:800}.voxel-encounter-prompt{color:#bbc;padding:18px 20px 6px;font-size:.88rem;line-height:1.45}.voxel-encounter-spanish{color:#f5c95d;letter-spacing:.02em;padding:6px 20px 18px;font-size:2rem;font-weight:900}.voxel-encounter-options{grid-template-columns:1fr 1fr;gap:10px;padding:0 20px 22px;display:grid}.voxel-opt-btn{color:#e8e8f0;cursor:pointer;background:#ffffff0f;border:2px solid #444;border-radius:3px;padding:14px 10px;font-size:.95rem;font-weight:700;transition:background .15s,border-color .15s,transform .1s}.voxel-opt-btn:hover{background:#ffffff24;transform:translateY(-2px)}.voxel-opt-btn:active{transform:translateY(0)}.voxel-encounter-result{text-align:center;padding:10px 20px 22px}.voxel-result-msg{margin-bottom:8px;font-size:1.5rem;font-weight:900}.voxel-result-msg.correct{color:#6ee78a}.voxel-result-msg.wrong{color:#f06060}.voxel-result-detail{color:#99a;margin:0 0 14px;font-size:.82rem}.voxel-speak-btn{color:#ccc;cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:3px;margin:0 auto 10px;padding:7px 18px;font-size:.82rem;display:block}.voxel-continue-btn{color:#000;cursor:pointer;border:none;border-radius:3px;width:100%;padding:14px;font-size:1rem;font-weight:800;transition:opacity .15s,transform .1s;display:block}.voxel-continue-btn:hover{opacity:.88;transform:translateY(-1px)}@media (width<=600px){.voxel-quest-hud{width:180px;font-size:.74rem}.voxel-minimap{width:110px;height:110px}.voxel-encounter-spanish{font-size:1.5rem}.voxel-encounter-options{grid-template-columns:1fr}}
