:root{--bg:#0b0e1a;--bg2:#11152a;--card:#161b33;--card2:#1d2342;--ink:#e8ecff;--muted:#8b93b8;--accent:#7c5cff;--accent2:#00d4ff;--good:#2dd4a0;--bad:#ff5c7a;--gold:#ffc94d;--grad:linear-gradient(135deg,#7c5cff,#00d4ff);--radius:16px;--font:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;--mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{background:var(--bg);color:var(--ink);font-family:var(--font);overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:radial-gradient(60vw 40vh at 80% -10%,rgba(124,92,255,.18),transparent),radial-gradient(50vw 35vh at 10% 110%,rgba(0,212,255,.12),transparent);pointer-events:none;z-index:0}#app{position:relative;z-index:1;max-width:1060px;margin:0 auto;padding:0 20px 80px}header{position:-webkit-sticky;position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:14px;padding:14px 4px;background:rgba(11,14,26,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06)}.logo{font-weight:800;font-size:18px;letter-spacing:.3px;cursor:pointer;white-space:nowrap}.logo span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.hud{gap:14px;margin-left:auto;flex-wrap:wrap}.hud,.hud-pill{display:flex;align-items:center}.hud-pill{gap:7px;background:var(--card);border:1px solid rgba(255,255,255,.07);padding:6px 12px;border-radius:99px;font-size:13px;font-weight:600}.hud-pill .ico{font-size:15px}.xpbar-wrap{display:flex;flex-direction:column;gap:3px;min-width:150px}.xpbar-label{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);font-weight:600}.xpbar{height:8px;background:var(--card);border-radius:99px;overflow:hidden;border:1px solid rgba(255,255,255,.07)}.xpbar i{display:block;height:100%;background:var(--grad);border-radius:99px;transition:width .6s cubic-bezier(.2,.8,.2,1)}.hero{text-align:center;padding:42px 0 10px}.hero h1{font-size:clamp(26px,4.5vw,40px);font-weight:800;line-height:1.15}.hero h1 span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.hero p{color:var(--muted);margin-top:10px;font-size:15px;max-width:560px;margin-left:auto;margin-right:auto}.world{margin-top:36px}.world-head{display:flex;align-items:baseline;gap:12px;margin-bottom:14px}.world-head h2{font-size:20px;font-weight:800}.world-head .wprog{color:var(--muted);font-size:13px;font-weight:600}.lessons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(228px,1fr));grid-gap:14px;gap:14px}.lcard{position:relative;background:var(--card);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);padding:16px;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s;overflow:hidden}.lcard:hover{transform:translateY(-3px);border-color:rgba(124,92,255,.5);box-shadow:0 8px 28px rgba(0,0,0,.35)}.lcard .lemoji{font-size:26px}.lcard h3{font-size:15px;margin-top:8px;line-height:1.3}.lcard .lsub{color:var(--muted);font-size:12px;margin-top:5px;line-height:1.45}.lcard .lmeta{display:flex;gap:8px;margin-top:11px;align-items:center}.tag{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:99px;background:rgba(124,92,255,.16);color:#b9a8ff}.tag.done{background:rgba(45,212,160,.16);color:var(--good)}.tag.xp{background:rgba(255,201,77,.13);color:var(--gold)}.tag.weak{background:rgba(255,92,122,.15);color:#ff9db1}.lcard.locked{opacity:.45;cursor:not-allowed;filter:saturate(.4)}.lcard.locked:hover{transform:none;border-color:rgba(255,255,255,.07);box-shadow:none}.lcard.done-card{border-color:rgba(45,212,160,.35)}.lcard .check{width:24px;height:24px;border-radius:50%;background:var(--good);color:#06251c;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900}.lcard .check,.lcard .lock{position:absolute;top:12px;right:12px}.lcard .lock{font-size:16px}.lesson-top{display:flex;align-items:center;gap:12px;padding:18px 0 6px}.backbtn{background:var(--card);border:1px solid rgba(255,255,255,.1);color:var(--ink);border-radius:10px;padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font)}.backbtn:hover{border-color:var(--accent)}.lesson-title{font-size:clamp(20px,3vw,27px);font-weight:800;display:flex;align-items:center;gap:10px}.steps{display:flex;gap:6px;margin:14px 0 22px}.step-dot{flex:1 1;height:5px;border-radius:99px;background:var(--card2);transition:background .3s}.step-dot.active{background:var(--grad);background-size:200%}.step-dot.done{background:var(--good)}.panel{background:var(--card);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);padding:24px;margin-bottom:18px}.panel h2{font-size:17px;font-weight:800;margin-bottom:12px;display:flex;align-items:center;gap:8px}.learn-body{line-height:1.75;font-size:15px;color:#cdd4f0}.learn-body p{margin-bottom:12px}.learn-body strong{color:var(--ink)}.learn-body .formula{display:block;text-align:center;font-family:var(--mono);font-size:16.5px;background:var(--bg2);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:13px;margin:14px 0;color:#aee8ff;overflow-x:auto}.mlnote{margin-top:16px;background:linear-gradient(135deg,rgba(124,92,255,.12),rgba(0,212,255,.08));border:1px solid rgba(124,92,255,.3);border-radius:12px;padding:14px 16px;font-size:14px;line-height:1.65}.mlnote .mltitle{font-weight:800;color:#b9a8ff;font-size:12.5px;letter-spacing:.7px;margin-bottom:5px}.btn{background:var(--grad);border:none;color:#fff;font-weight:800;font-size:14px;padding:12px 26px;border-radius:12px;cursor:pointer;font-family:var(--font);transition:transform .12s,box-shadow .12s}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(124,92,255,.4)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn.ghost{background:var(--card2);border:1px solid rgba(255,255,255,.12)}.btn-row{display:flex;gap:10px;justify-content:flex-end;margin-top:6px;flex-wrap:wrap}.lab{display:grid;grid-template-columns:1fr 270px;grid-gap:18px;gap:18px}@media(max-width:760px){.lab{grid-template-columns:1fr}}.canvas-wrap{position:relative;background:var(--bg2);border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden}.canvas-wrap canvas{display:block;width:100%;height:auto;touch-action:none;cursor:crosshair}.readout{position:absolute;top:10px;left:10px;background:rgba(11,14,26,.82);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:8px 12px;font-family:var(--mono);font-size:12.5px;line-height:1.65;pointer-events:none;color:#aee8ff}.controls{display:flex;flex-direction:column;gap:12px}.ctrl{background:var(--bg2);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 14px}.ctrl label{display:flex;justify-content:space-between;font-size:12.5px;font-weight:700;color:var(--muted);margin-bottom:7px}.ctrl label .val{color:var(--accent2);font-family:var(--mono)}input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer}.chipbtns{display:flex;gap:7px;flex-wrap:wrap}.chip{background:var(--card2);border:1px solid rgba(255,255,255,.12);color:var(--ink);border-radius:9px;padding:7px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font);transition:all .12s}.chip.on,.chip:hover{border-color:var(--accent)}.chip.on{background:var(--accent)}.missions{background:var(--bg2);border:1px solid rgba(255,201,77,.25);border-radius:12px;padding:14px}.missions h3{font-size:12.5px;letter-spacing:.8px;color:var(--gold);margin-bottom:10px;font-weight:800}.mission{display:flex;gap:10px;align-items:flex-start;padding:7px 0;font-size:13.5px;line-height:1.45;color:#cdd4f0}.mission .mcheck{flex:0 0 20px;height:20px;border-radius:50%;border:2px solid var(--muted);margin-top:1px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;transition:all .25s}.mission.done{color:var(--muted);text-decoration:line-through}.mission.done .mcheck{background:var(--good);border-color:var(--good);color:#06251c}.mission .mxp{margin-left:auto;font-size:11px;font-weight:800;color:var(--gold);white-space:nowrap;padding-left:6px}.quiz-q{font-size:16.5px;font-weight:700;line-height:1.55;margin-bottom:16px}.learn-body code,.quiz-q code{font-family:var(--mono);background:var(--bg2);padding:2px 7px;border-radius:6px;font-size:.92em;color:#aee8ff}.opts{display:flex;flex-direction:column;gap:9px}.opt{text-align:left;background:var(--bg2);border:1.5px solid rgba(255,255,255,.1);color:var(--ink);border-radius:11px;padding:13px 16px;font-size:14.5px;cursor:pointer;font-family:var(--font);transition:all .15s;line-height:1.45}.opt:hover:not(:disabled){border-color:var(--accent);background:var(--card2)}.opt.correct{border-color:var(--good);background:rgba(45,212,160,.12)}.opt.wrong{border-color:var(--bad);background:rgba(255,92,122,.1);animation:shake .35s}.opt:disabled{cursor:default}@keyframes shake{20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}.explain{margin-top:14px;background:rgba(45,212,160,.08);border:1px solid rgba(45,212,160,.3);border-radius:11px;padding:13px 16px;font-size:13.5px;line-height:1.6;color:#cdebdf}.wrongex{background:rgba(255,92,122,.08);border:1px solid rgba(255,92,122,.35);border-left:3px solid var(--bad);border-radius:10px;padding:11px 14px;font-size:13px;line-height:1.6;color:#f3cdd6;animation:expand .3s ease-out}.wrongex b{color:#ff9db1}@keyframes expand{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.quiz-prog{font-size:12px;color:var(--muted);font-weight:700;margin-bottom:10px}.complete{text-align:center;padding:46px 20px}.complete .big{font-size:60px;animation:pop .5s cubic-bezier(.2,1.6,.4,1)}@keyframes pop{0%{transform:scale(0)}to{transform:scale(1)}}.complete h2{font-size:26px;margin:12px 0 6px}.complete .gain{font-size:15px;color:var(--gold);font-weight:800;margin-bottom:22px}#toasts{position:fixed;top:70px;right:18px;z-index:200;flex-direction:column}#toasts,.toast{display:flex;gap:10px}.toast{background:var(--card2);border:1px solid rgba(124,92,255,.45);border-radius:13px;padding:13px 18px;font-size:13.5px;font-weight:700;box-shadow:0 10px 30px rgba(0,0,0,.5);align-items:center;animation:slidein .35s cubic-bezier(.2,1.2,.3,1);max-width:300px}.toast.gold{border-color:var(--gold)}.toast .tico{font-size:21px}.toast .tsub{font-size:11.5px;color:var(--muted);font-weight:600;margin-top:2px}@keyframes slidein{0%{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}.toast.out{animation:slideout .3s forwards}@keyframes slideout{to{transform:translateX(120%);opacity:0}}#fx{inset:0;z-index:300}#fx,.xpfloat{position:fixed;pointer-events:none}.xpfloat{font-weight:900;color:var(--gold);font-size:15px;z-index:250;animation:floatup 1.1s ease-out forwards;text-shadow:0 2px 8px rgba(0,0,0,.6)}@keyframes floatup{to{transform:translateY(-55px);opacity:0}}.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:12px;gap:12px;margin-top:14px}.ach{background:var(--card);border:1px solid rgba(255,255,255,.07);border-radius:13px;padding:14px;display:flex;gap:11px;align-items:center}.ach.locked{opacity:.38;filter:grayscale(1)}.ach .aico{font-size:25px}.ach .aname{font-size:13px;font-weight:800}.ach .adesc{font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.4}.section-toggle{margin-top:34px;text-align:center}.modal-back{position:fixed;inset:0;background:rgba(5,7,15,.72);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:400;display:flex;align-items:center;justify-content:center;animation:fadein .25s}@keyframes fadein{0%{opacity:0}to{opacity:1}}.modal{background:var(--card);border:1px solid rgba(124,92,255,.4);border-radius:18px;padding:30px 32px;max-width:380px;width:calc(100% - 40px);box-shadow:0 24px 70px rgba(0,0,0,.6);animation:pop .35s cubic-bezier(.2,1.4,.4,1)}.modal h2{font-size:19px;margin-bottom:8px}.modal p{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:18px}.modal input{width:100%;background:var(--bg2);border:1.5px solid rgba(255,255,255,.15);border-radius:11px;padding:12px 14px;font-size:15px;color:var(--ink);font-family:var(--font);outline:none;margin-bottom:16px}.modal input:focus{border-color:var(--accent)}.modal .btn{width:100%}details.deep{background:var(--bg2);border:1px solid rgba(124,92,255,.25);border-radius:12px;margin-top:12px;overflow:hidden}details.deep summary{cursor:pointer;padding:13px 16px;font-size:13.5px;font-weight:800;color:#b9a8ff;list-style:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}details.deep summary:before{content:"▸ ";color:var(--accent2)}details.deep[open] summary:before{content:"▾ "}details.deep summary::-webkit-details-marker{display:none}details.deep .deep-body{padding:2px 16px 14px;font-size:13.5px;line-height:1.7;color:#cdd4f0;border-top:1px solid rgba(255,255,255,.06)}.assess{background:var(--bg2);border:1px solid rgba(255,201,77,.3);border-radius:13px;padding:16px 18px;margin-top:8px;text-align:left}.assess.clean{border-color:rgba(45,212,160,.35)}.assess h3{font-size:13px;letter-spacing:.6px;color:var(--gold);margin-bottom:10px;font-weight:800}.assess.clean h3{color:var(--good)}.focus-item{padding:9px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:13.5px;line-height:1.55}.focus-item b{color:#ff9db1;display:block;margin-bottom:2px}.focus-item:last-of-type{border-bottom:none}.focus-tip{font-size:12.5px;color:var(--muted);margin-top:10px;line-height:1.6}.auth-back,.auth-back .modal{animation-iteration-count:1;animation-fill-mode:both}.auth-back.settled,.auth-back.settled .modal{animation:none}.pw-meter{height:6px;border-radius:99px;background:var(--bg2);margin:-8px 0 6px;overflow:hidden}.pw-meter i{display:block;height:100%;border-radius:99px;transition:width .25s ease,background .25s ease}.pw-hint{font-size:11.5px;text-align:left;margin:0 0 14px;line-height:1.5}.pw-hint,footer{color:var(--muted)}footer{text-align:center;font-size:12px;margin-top:50px;line-height:1.7}