:root{--teal:#2fd5c6;--teal-deep:#25b3a7;--cyan:#69f2f9;--blue:#09f;--coral:#ff7a59;--amber:#f0a132;--violet:#8b7bf0;--danger:#ff5d6c;--bg:#0a111e;--bg-1:#0d1422;--surface:#141e32;--surface-2:#1a2740;--surface-3:#1f2e49;--border:#233350;--border-2:#33476b;--text:#eef2f8;--text-2:#aab7c9;--muted:#7c8aa1;--on-accent:#08111f;--canvas:var(--bg-1);--canvas-2:#0b1322;--bone:var(--text);--line:var(--border);--s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;--s8:64px;--r1:8px;--r2:12px;--r3:16px;--r4:22px;--rpill:999px;--sh1:0 1px 2px #0000004d;--sh2:0 10px 28px #03081266;--sh3:0 22px 56px #03081285;--glow:0 8px 20px #0000004d;--grad-primary:var(--teal);--grad-brand:var(--teal);--dur:.18s;--ease:cubic-bezier(.4, 0, .2, 1);--maxw:1160px}.page,.auth-wrap{-webkit-font-smoothing:antialiased}::selection{color:#fff;background:#69f2f947}*{scrollbar-color:var(--border-2) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:var(--rpill);background-clip:padding-box;border:2px solid #0000}:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:6px}.page{min-height:100vh;color:var(--text);background:radial-gradient(900px 460px at 6% -12%, #2fd5c60d, transparent 60%), var(--bg-1);padding:var(--s6) var(--s5) var(--s8);font-family:Poppins,system-ui,sans-serif}.page.center{place-items:center;gap:var(--s3);text-align:center;display:grid}.container{max-width:var(--maxw);margin:0 auto}.page>.container>h1{margin:0 0 var(--s2)}.page .sub,.page>.container>p.muted{margin-top:0}h1,h2,h3,h4{letter-spacing:.2px;color:var(--text);font-family:Fredoka,Inter,sans-serif;line-height:1.15}h1{font-size:clamp(26px,3.2vw,36px);font-weight:700}h2{margin:0 0 var(--s3);font-size:21px;font-weight:600}h3{margin:0 0 var(--s2);font-size:16px;font-weight:600}a{color:var(--cyan);text-decoration:none}a:hover{text-decoration:underline}.muted{color:var(--muted)}.text-2{color:var(--text-2)}.error{color:var(--danger);font-size:14px}.success{color:var(--teal);font-size:14px}.link{color:var(--cyan);cursor:pointer}.row{gap:var(--s3);flex-wrap:wrap;align-items:center;display:flex}.stack{gap:var(--s3);flex-direction:column;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);padding:var(--s5);box-shadow:var(--sh2);transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease)}.card+.card{margin-top:var(--s4)}.card.narrow{width:100%;max-width:400px}.card.hover:hover,a.card:hover,button.card:hover{border-color:var(--border-2);box-shadow:var(--sh3);transform:translateY(-3px)}.card h2:first-child,.card h3:first-child{margin-top:0}.btn{justify-content:center;align-items:center;gap:var(--s2);border-radius:var(--r2);cursor:pointer;white-space:nowrap;color:var(--on-accent);background:var(--surface-3);transition:transform var(--dur) var(--ease), filter var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur) var(--ease), opacity var(--dur);border:1px solid #0000;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:700;line-height:1;display:inline-flex}.btn span{font-size:.85em}.btn:hover:not(:disabled){filter:brightness(1.07);transform:translateY(-1px)}.btn:active:not(:disabled){filter:brightness(.97);transform:translateY(0)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary,.btn.start{background:var(--teal);color:var(--on-accent);box-shadow:var(--glow)}.btn.primary:hover:not(:disabled),.btn.start:hover:not(:disabled){background:var(--cyan)}.btn.cyan{background:var(--cyan);color:var(--on-accent)}.btn.stop,.btn.danger{background:var(--coral);color:#2a0d05;box-shadow:var(--glow)}.btn.danger.outline{border-color:var(--danger);color:var(--danger);box-shadow:none;background:0 0}.btn.ghost{color:var(--text-2);border-color:var(--border);background:0 0}.btn.ghost:hover:not(:disabled){color:var(--text);border-color:var(--border-2);background:#ffffff08}.btn.block{width:100%}.btn.sm{border-radius:var(--r1);padding:7px 11px;font-size:13px}.btn.lg{border-radius:var(--r3);padding:13px 22px;font-size:15px}.field{margin-bottom:var(--s4);flex-direction:column;gap:6px;display:flex}.field label,.label{color:var(--text-2);font-size:13px;font-weight:600}.input,input[type=text],input[type=email],input[type=password],input[type=number],select,textarea{border:1px solid var(--border);width:100%;color:var(--text);border-radius:var(--r2);transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur);background:#081325;outline:none;padding:11px 13px;font-family:inherit;font-size:15px}.input::placeholder,input::placeholder,textarea::placeholder{color:#5d6f8a}.input:hover,input:hover,select:hover,textarea:hover{border-color:var(--border-2)}.input:focus,input:focus,select:focus,textarea:focus{border-color:var(--cyan);background:#091a30;box-shadow:0 0 0 3px #69f2f92e}textarea{resize:vertical;min-height:90px;line-height:1.5}select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%);background-position:calc(100% - 18px) 1.1em,calc(100% - 13px) 1.1em;background-repeat:no-repeat;background-size:5px 5px;padding-right:34px}.field .error,.field-error{margin-top:2px}.input.invalid,input.invalid{border-color:var(--danger);box-shadow:0 0 0 3px #ff5d6c26}.seg{border:1px solid var(--border);border-radius:var(--r2);background:#081325;display:inline-flex;overflow:hidden}.seg button{color:var(--muted);cursor:pointer;font:inherit;transition:background var(--dur), color var(--dur);background:0 0;border:0;padding:9px 16px;font-weight:600}.seg button:hover{color:var(--text)}.seg button.on{background:var(--grad-primary);color:var(--on-accent);font-weight:700}.nav{z-index:40;align-items:center;gap:var(--s5);padding:0 var(--s5);-webkit-backdrop-filter:blur(14px)saturate(1.2);backdrop-filter:blur(14px)saturate(1.2);border-bottom:1px solid var(--border);background:#08101ec7;height:60px;display:flex;position:sticky;top:0}.nav-brand{align-items:center;gap:var(--s2);color:var(--text);font-family:Fredoka,sans-serif;font-size:16px;font-weight:700;display:inline-flex}.nav-brand:hover{text-decoration:none}.mark,.nav-brand .mark{background:var(--grad-brand);width:32px;height:32px;color:var(--on-accent);box-shadow:var(--glow);border-radius:10px;place-items:center;font-family:Fredoka,sans-serif;font-weight:800;display:grid}.nav-links{gap:var(--s1);display:flex}.nav-links a{color:var(--text-2);border-radius:var(--r1);transition:background var(--dur), color var(--dur);padding:7px 12px;font-size:14px;font-weight:600}.nav-links a:hover{color:var(--text);background:#ffffff0d;text-decoration:none}.nav-links a.active{color:var(--cyan);background:#69f2f91a}.nav-spacer{flex:1}.nav-user{color:var(--text);align-items:center;gap:var(--s2);font-size:14px;display:inline-flex}.role-pill{text-transform:uppercase;letter-spacing:.06em;border-radius:var(--rpill);color:var(--cyan);background:#69f2f91f;border:1px solid #69f2f940;padding:3px 9px;font-size:10px;font-weight:700}.role-pill.teacher{color:var(--amber);background:#f0a1321f;border-color:#f0a1324d}.role-pill.admin{color:var(--coral);background:#ff7a591f;border-color:#ff7a594d}.auth-wrap{min-height:100vh;padding:var(--s5);background:radial-gradient(900px 500px at 50% -10%, #2fd5c624, transparent 60%), radial-gradient(700px 500px at 90% 110%, #0099ff1f, transparent 55%), var(--bg);place-items:center;display:grid}.auth-wrap .card{box-shadow:var(--sh3)}.grid{gap:var(--s4);display:grid}.grid.cols-2{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid.cols-3{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.section{margin-top:var(--s6)}.section-head{margin-bottom:var(--s3);justify-content:space-between;align-items:center;gap:var(--s3);display:flex}.section-head h2{margin:0}.stat-tile{flex-direction:column;gap:2px;display:flex}.stat-tile .n{color:var(--text);font-family:Fredoka,sans-serif;font-size:30px;font-weight:700}.stat-tile .l{color:var(--muted);font-size:13px}.stat-tile .n.teal{color:var(--teal)}.stat-tile .n.amber{color:var(--amber)}.stat-tile .n.coral{color:var(--coral)}.tbl{border-collapse:separate;border-spacing:0;width:100%;font-size:14px}.tbl th,.tbl td{text-align:left;border-bottom:1px solid var(--border);padding:12px 14px}.tbl thead th{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.tbl tbody tr{transition:background var(--dur)}.tbl tbody tr:hover{background:#ffffff06}.tbl tbody tr:last-child td{border-bottom:0}.card.flush{padding:var(--s2) var(--s2);overflow:hidden}.pill{border-radius:var(--rpill);background:var(--surface-3);color:var(--cyan);letter-spacing:.02em;align-items:center;padding:3px 9px;font-size:11px;font-weight:700;display:inline-flex}.pill.diff1{color:var(--teal);background:#2fd5c61f}.pill.diff2{color:var(--amber);background:#f0a1321f}.pill.diff3,.pill.diff4,.pill.diff5{color:var(--coral);background:#ff7a591f}.code-chip{letter-spacing:.12em;border:1px dashed var(--cyan);color:var(--cyan);border-radius:var(--r1);background:#081325;padding:5px 11px;font-family:ui-monospace,SF Mono,monospace;font-size:15px}.badge-done{color:var(--teal);align-items:center;gap:4px;font-weight:700;display:inline-flex}.badge-todo{color:var(--muted);align-items:center;gap:4px;display:inline-flex}.tag{color:var(--muted);font-size:11px}.bar{background:var(--surface-3);border-radius:var(--rpill);height:8px;overflow:hidden}.bar>i{background:var(--grad-primary);border-radius:var(--rpill);height:100%;transition:width .4s var(--ease);display:block}.tiles{gap:var(--s5);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.tile{gap:var(--s3);min-height:184px;padding:var(--s5);border-radius:var(--r4);cursor:pointer;border:1px solid var(--border);color:var(--text);text-align:left;background:var(--surface);transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);flex-direction:column;display:flex}.tile:hover{box-shadow:var(--sh3);text-decoration:none;transform:translateY(-5px)}.tile:active{transform:translateY(-1px)}.tile-ico{font-size:46px;line-height:1}.tile-title{font-family:Fredoka,sans-serif;font-size:23px;font-weight:700}.tile-sub{color:var(--text-2);flex:1;font-size:14px}.tile-cta{color:var(--cyan);margin-top:auto;font-weight:700}.tile.teal{border-color:#2fd5c673;box-shadow:0 12px 34px #2fd5c621}.tile.teal:hover{border-color:var(--teal)}.tile.blue{border-color:#0099ff73;box-shadow:0 12px 34px #0099ff21}.tile.blue:hover{border-color:var(--blue)}.tile.coral{border-color:#ff7a5973;box-shadow:0 12px 34px #ff7a5921}.tile.coral:hover{border-color:var(--coral)}.tile.amber{border-color:#f0a13273;box-shadow:0 12px 34px #f0a13221}.tile.amber:hover{border-color:var(--amber)}.tile.violet{border-color:#8b7bf073;box-shadow:0 12px 34px #8b7bf021}.tile.violet:hover{border-color:var(--violet)}.hero-greet{margin-bottom:var(--s2);font-size:clamp(28px,4vw,44px)}.hero-sub{color:var(--text-2);margin:0 0 var(--s6);font-size:17px}.launch-grid{gap:var(--s6) var(--s5);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));max-width:820px;display:grid}.launch{align-items:center;gap:var(--s3);color:var(--text);cursor:pointer;flex-direction:column;display:flex}.launch:hover{text-decoration:none}.launch-ico{width:116px;height:116px;box-shadow:var(--sh2);transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);border-radius:30px;place-items:center;font-size:54px;display:grid}.launch:hover .launch-ico{box-shadow:var(--sh3);transform:translateY(-5px)scale(1.04)}.launch:active .launch-ico{transform:translateY(-1px)scale(1)}.launch-label{text-align:center;font-family:Fredoka,sans-serif;font-size:19px;font-weight:600}.launch-ico{background:var(--surface-2);border:1px solid var(--border)}.launch-ico.teal{background:#2fd5c61f;border-color:#2fd5c64d}.launch-ico.blue{background:#0099ff1f;border-color:#0099ff4d}.launch-ico.coral{background:#ff7a591f;border-color:#ff7a594d}.launch-ico.amber{background:#f0a1321f;border-color:#f0a1324d}.launch-ico.violet{background:#8b7bf01f;border-color:#8b7bf04d}.spinner{vertical-align:middle;border:3px solid var(--surface-3);border-top-color:var(--cyan);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg, var(--surface) 25%, var(--surface-2) 37%, var(--surface) 63%);border-radius:var(--r2);background-size:400% 100%;animation:1.3s infinite shimmer}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.empty{text-align:center;padding:var(--s7) var(--s5);color:var(--muted)}.empty .emoji{margin-bottom:var(--s3);font-size:40px;display:block}.empty h3{color:var(--text)}.drawer-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:50;animation:fade .15s var(--ease);background:#030810a8;position:fixed;inset:0}@keyframes fade{0%{opacity:0}}.drawer{z-index:51;background:linear-gradient(180deg, var(--surface), #0b1626);border-left:1px solid var(--border);width:380px;height:100vh;padding:var(--s5);box-shadow:var(--sh3);animation:slideIn .22s var(--ease);position:fixed;top:0;right:0;overflow-y:auto}@keyframes slideIn{0%{opacity:0;transform:translate(24px)}}.drawer h3{color:var(--cyan)}.list-row{align-items:center;gap:var(--s3);border:1px solid var(--border);border-radius:var(--r2);margin-bottom:var(--s2);transition:border-color var(--dur), background var(--dur);padding:12px;display:flex}.list-row:hover{border-color:var(--border-2);background:#ffffff06}.list-row .title{cursor:pointer;flex:1;font-weight:600}.modal{z-index:70;width:min(620px,92vw);max-height:86vh;padding:var(--s6);background:linear-gradient(180deg, var(--surface), #0b1626);border:1px solid var(--border-2);border-radius:var(--r4);box-shadow:var(--sh3);animation:pop .2s var(--ease);position:fixed;top:50%;left:50%;overflow:auto;transform:translate(-50%,-50%)}@keyframes pop{0%{transform:scale(.7)}60%{transform:scale(1.12)}to{transform:scale(1)}}.modal h2{color:var(--cyan);margin-top:0}.modal h3{margin:var(--s4) 0 var(--s2)}.toast{bottom:var(--s5);z-index:60;align-items:center;gap:var(--s3);border-radius:var(--r3);background:linear-gradient(180deg, var(--surface-2), var(--surface));border:1px solid var(--teal);color:var(--text);box-shadow:var(--sh3);animation:toastUp .26s var(--ease);padding:12px 18px;display:flex;position:fixed;left:50%;transform:translate(-50%)}@keyframes toastUp{0%{opacity:0;transform:translate(-50%,16px)}}.lesson-layout{gap:var(--s5);grid-template-columns:340px 1fr;align-items:start;display:grid}@media (width<=900px){.lesson-layout{grid-template-columns:1fr}}.instructions{color:var(--text-2);line-height:1.65}.instructions h1,.instructions h2,.instructions h3{color:var(--text);font-family:Fredoka,sans-serif}.instructions code{color:var(--cyan);background:#081325;border-radius:6px;padding:2px 7px;font-size:.9em}.instructions strong{color:var(--text)}.hint{border-left:3px solid var(--amber);border-radius:0 var(--r1) var(--r1) 0;color:#f3e2b8;background:#f0a13214;margin:8px 0;padding:8px 12px}.stat{border:1px solid var(--border);border-radius:var(--r1);background:#081325;align-items:center;gap:6px;margin:0 8px 8px 0;padding:5px 11px;font-size:13px;display:inline-flex}.stat b{color:var(--cyan)}.timer{color:var(--cyan);border-radius:var(--r1);background:#69f2f91a;border:1px solid #69f2f940;padding:5px 12px;font-family:ui-monospace,monospace;font-size:18px;font-weight:700}.timer.low{color:var(--danger);background:#ff5d6c1f;border-color:#ff5d6c66;animation:1s infinite pulse}@keyframes pulse{50%{opacity:.55}}.score-big{font-family:Fredoka,sans-serif;font-size:52px;font-weight:800;line-height:1}.score-pass{color:var(--teal)}.score-fail{color:var(--danger)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important}}:root{--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--dur-2:.3s;--dur-3:.5s;--maxw-wide:1200px}.ambient{z-index:0;pointer-events:none;background:radial-gradient(820px 520px at 6% -10%,#2fd5c60d,#0000 62%),radial-gradient(720px 520px at 100% -2%,#0099ff0b,#0000 60%);position:fixed;inset:0;overflow:hidden}.ambient .orb,.ambient .mesh-grid{display:none}.page,.nav,.auth-split,.landing{z-index:2;position:relative}.grain:after{content:none}.reveal{opacity:0;transition:opacity var(--dur-3) var(--ease-out), transform var(--dur-3) var(--ease-out);transition-delay:calc(var(--i,0) * 55ms);will-change:opacity, transform;transform:translateY(16px)}.reveal.left{transform:translate(-20px)}.reveal.right{transform:translate(20px)}.reveal.scale{transform:scale(.98)}.reveal.in{opacity:1;transform:none}.gradient-text{color:var(--teal)}.kicker{letter-spacing:.16em;text-transform:uppercase;color:var(--teal);align-items:center;gap:8px;font-family:Fredoka,sans-serif;font-size:12.5px;font-weight:600;display:inline-flex}.kicker .dot{background:var(--teal);border-radius:50%;width:6px;height:6px}.glass{-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--r3);box-shadow:var(--sh2);background:#141e32b3}.card.glow{position:relative}.card.glow:hover{border-color:var(--border-2);box-shadow:var(--sh3);transform:translateY(-3px)}.tilt{position:relative}.tilt .sheen{display:none}.btn.shine:after{content:none}.float{animation:6s ease-in-out infinite float}.float-slow{animation:9s ease-in-out infinite float}@keyframes float{50%{transform:translateY(-7px)}}.tnum{font-variant-numeric:tabular-nums}.logo-img{width:auto;height:30px;display:block}.brand-word{color:var(--teal);letter-spacing:.2px;font-family:Fredoka,sans-serif;font-size:19px;font-weight:700}.launch-glyph{object-fit:contain;filter:drop-shadow(0 10px 20px #00000057);width:108px;height:108px;transition:transform var(--dur-2) var(--ease-out)}.launch:hover .launch-glyph{transform:translateY(-6px)scale(1.04)}.landing{min-height:100vh;color:var(--text);background:radial-gradient(900px 560px at 12% -6%, #2fd5c60f, transparent 60%), radial-gradient(820px 560px at 92% 2%, #0099ff0d, transparent 58%), var(--bg-1);font-family:Poppins,system-ui,sans-serif;overflow-x:clip}.landing .wrap{max-width:var(--maxw-wide);padding:0 var(--s5);margin:0 auto}.lnav{z-index:30;align-items:center;gap:var(--s5);height:70px;padding:0 var(--s6);transition:background var(--dur-2), border-color var(--dur-2);border-bottom:1px solid #0000;display:flex;position:fixed;top:0;left:0;right:0}.lnav.scrolled{-webkit-backdrop-filter:blur(14px)saturate(1.1);backdrop-filter:blur(14px)saturate(1.1);border-bottom-color:var(--border);background:#0d1422d9}.lnav .spacer{flex:1}.lnav .llinks{gap:var(--s2);display:flex}.lnav .llinks a{color:var(--text-2);border-radius:var(--r1);transition:color var(--dur), background var(--dur);padding:8px 12px;font-size:14.5px;font-weight:500}.lnav .llinks a:hover{color:var(--text);background:#ffffff0d;text-decoration:none}@media (width<=760px){.lnav .llinks{display:none}.lnav{padding:0 var(--s4)}}.hero{align-items:center;gap:var(--s7);grid-template-columns:1.04fr .96fr;min-height:100vh;padding:124px 0 84px;display:grid;position:relative}@media (width<=940px){.hero{gap:var(--s6);text-align:center;grid-template-columns:1fr;padding-top:108px}.hero .hero-cta,.hero .hero-stats{justify-content:center}}.hero h1{margin:var(--s4) 0;letter-spacing:-1px;font-size:clamp(40px,6.2vw,76px);font-weight:700;line-height:1.02}.hero p.lead{color:var(--text-2);max-width:46ch;margin:0 0 var(--s6);font-size:clamp(16px,1.6vw,20px);line-height:1.6}@media (width<=940px){.hero p.lead{margin-left:auto;margin-right:auto}}.hero-cta{gap:var(--s3);flex-wrap:wrap;display:flex}.hero-stats{gap:var(--s7);margin-top:var(--s7);display:flex}@media (width<=940px){.hero-stats{gap:var(--s6)}}.hero-stats .n{color:var(--text);font-family:Fredoka,sans-serif;font-size:clamp(26px,3vw,34px);font-weight:700}.hero-stats .l{color:var(--muted);font-size:13px}.hero-stage{aspect-ratio:1;border:1px solid var(--border);box-shadow:var(--sh3);background:#0b1626;border-radius:24px;position:relative;overflow:hidden}.hero-stage canvas{display:block;width:100%!important;height:100%!important}.hero-stage .badge{z-index:3;position:absolute;bottom:14px;left:14px}.hero-stage .ring{pointer-events:none;border-radius:inherit;position:absolute;inset:0;box-shadow:inset 0 0 0 1px #ffffff0a}@media (width<=940px){.hero-stage{width:100%;max-width:440px;margin:0 auto}}.section-xl{padding:var(--s8) 0;position:relative}.section-head-c{text-align:center;max-width:660px;margin:0 auto var(--s7)}.section-head-c h2{margin:var(--s3) 0;font-size:clamp(28px,3.6vw,42px)}.section-head-c p{color:var(--text-2);font-size:17px;line-height:1.6}.feat-grid,.role-grid{gap:var(--s5);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=900px){.feat-grid,.role-grid{grid-template-columns:1fr}}.feat{padding:var(--s6);border-radius:var(--r3);background:var(--surface);border:1px solid var(--border);transition:transform var(--dur-2) var(--ease-out), border-color var(--dur-2), box-shadow var(--dur-2);position:relative}.feat:hover{border-color:var(--border-2);box-shadow:var(--sh3);transform:translateY(-4px)}.feat .ico-wrap{width:56px;height:56px;margin-bottom:var(--s4);color:var(--teal);background:#2fd5c61a;border:1px solid #2fd5c638;border-radius:16px;place-items:center;display:grid}.feat .ico-glyph{object-fit:contain;width:60px;height:60px;margin-bottom:var(--s3);display:block}.feat h3{margin-bottom:var(--s2);font-size:19px}.feat p{color:var(--text-2);font-size:15px;line-height:1.6}.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000);mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000)}.marquee .track{gap:var(--s3);width:max-content;animation:34s linear infinite march;display:flex}.marquee:hover .track{animation-play-state:paused}@keyframes march{to{transform:translate(-50%)}}.type-card{align-items:center;gap:var(--s2);border-radius:var(--rpill);background:var(--surface);border:1px solid var(--border);white-space:nowrap;color:var(--text-2);padding:10px 18px;font-size:14px;font-weight:500;display:flex}.type-card .e{background:var(--teal);border-radius:50%;flex:none;width:7px;height:7px}.steps{gap:var(--s5);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=900px){.steps{grid-template-columns:1fr}}.step{padding:var(--s6) var(--s5);border-radius:var(--r3);background:var(--surface);border:1px solid var(--border);position:relative}.step .num{color:var(--teal);margin-bottom:var(--s3);font-family:Fredoka,sans-serif;font-size:14px;font-weight:700}.step .step-glyph{object-fit:contain;width:54px;height:54px;margin-bottom:var(--s3);display:block}.step h3{margin-bottom:var(--s2)}.step p{color:var(--text-2);font-size:15px;line-height:1.6}.modal.wide{width:min(840px,94vw)}.modal-head{justify-content:space-between;align-items:flex-start;gap:var(--s3);margin-bottom:var(--s4);display:flex}.modal-head h2{color:var(--text);margin:0}.modal-x{color:var(--muted);cursor:pointer;border-radius:var(--r1);width:34px;height:34px;transition:color var(--dur), background var(--dur);background:0 0;border:0;flex:none;place-items:center;display:grid}.modal-x:hover{color:var(--text);background:#ffffff0f}.modal-foot{justify-content:flex-end;gap:var(--s2);margin-top:var(--s5);display:flex}.showcase{position:relative}.showcase-frame{border-radius:var(--r4);border:1px solid var(--border);box-shadow:var(--sh3);background:var(--surface);overflow:hidden}.showcase-frame .winbar{border-bottom:1px solid var(--border);background:var(--bg);align-items:center;gap:7px;padding:11px 15px;display:flex}.showcase-frame .winbar i{background:var(--border-2);border-radius:50%;width:11px;height:11px;display:block}.showcase-frame img{width:100%;height:auto;display:block}.cta-band{text-align:center;padding:var(--s8) var(--s5);border-radius:var(--r4);background:#2fd5c612;border:1px solid #2fd5c633}.cta-band h2{margin-bottom:var(--s3);font-size:clamp(28px,3.6vw,42px)}.cta-band p{color:var(--text-2);margin-bottom:var(--s6);font-size:17px}.lfoot{border-top:1px solid var(--border);margin-top:var(--s8);padding:var(--s7) 0 var(--s6);color:var(--muted)}.lfoot .row-between{justify-content:space-between;align-items:center;gap:var(--s4);flex-wrap:wrap;display:flex}.nav-burger{border:1px solid var(--border);border-radius:var(--r1);cursor:pointer;width:40px;height:40px;color:var(--text);background:0 0;justify-content:center;align-items:center;display:none}.nav-burger svg{width:20px;height:20px}.nav-mobile{display:none}@media (width<=860px){.nav-links,.nav .nav-user .uname{display:none}.nav-burger{display:inline-flex}.nav-spacer{flex:1}.nav .btn.logout-desktop{display:none}.nav-mobile{z-index:39;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:var(--s3) var(--s4) var(--s4);transform-origin:top;animation:drop .22s var(--ease-out);background:#0d1422fa;display:block;position:fixed;top:60px;left:0;right:0}.nav-mobile a,.nav-mobile button{text-align:left;width:100%;color:var(--text);border-radius:var(--r1);cursor:pointer;background:0 0;border:0;padding:13px 12px;font-size:16px;font-weight:600;display:block}.nav-mobile a:hover,.nav-mobile button:hover{background:#ffffff0d;text-decoration:none}.nav-mobile a.active{color:var(--teal);background:#2fd5c61a}.nav-mobile .divider{background:var(--border);height:1px;margin:var(--s2) 0}}@keyframes drop{0%{opacity:0;transform:translateY(-8px)}}.dash-hero{justify-content:space-between;align-items:center;gap:var(--s5);margin-bottom:var(--s6);flex-wrap:wrap;display:flex}.avatar{width:50px;height:50px;color:var(--on-accent);background:var(--teal);border-radius:14px;flex:none;place-items:center;font-family:Fredoka,sans-serif;font-size:20px;font-weight:700;display:grid}.stat-card{position:relative;overflow:hidden}.stat-card .spark{opacity:.1;position:absolute;bottom:-6px;right:-6px}.divider-soft{background:var(--border);height:1px;margin:var(--s6) 0}.ring-wrap{flex:none;width:56px;height:56px;position:relative}.ring-wrap svg{transform:rotate(-90deg)}.ring-wrap .pct{color:var(--teal);place-items:center;font-family:Fredoka,sans-serif;font-size:13px;font-weight:700;display:grid;position:absolute;inset:0}.lessoncard{transition:transform var(--dur-2) var(--ease-out), border-color var(--dur-2), box-shadow var(--dur-2)}.lessoncard:hover{border-color:var(--border-2);box-shadow:var(--sh2);transform:translate(3px)}@keyframes pop-in{0%{opacity:0;transform:scale(.7)}60%{transform:scale(1.06)}to{opacity:1;transform:scale(1)}}.pop-in{animation:pop-in .4s var(--ease-spring)}.auth-split{background:var(--bg-1);min-height:100vh;color:var(--text);grid-template-columns:1.05fr 1fr;font-family:Poppins,system-ui,sans-serif;display:grid}.auth-brandside{padding:var(--s8) clamp(var(--s6), 5vw, 72px);border-right:1px solid var(--border);background:var(--bg);background-image:radial-gradient(720px 540px at 82% 12%,#2fd5c614,#0000 60%);flex-direction:column;justify-content:center;display:flex;position:relative;overflow:hidden}.auth-brandside:before{content:"";pointer-events:none;opacity:.5;background-image:linear-gradient(#69f2f90a 1px,#0000 1px),linear-gradient(90deg,#69f2f90a 1px,#0000 1px);background-size:56px 56px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(130% 100% at 24% 6%,#000 30%,#0000 80%);mask-image:radial-gradient(130% 100% at 24% 6%,#000 30%,#0000 80%)}.auth-brand-inner{z-index:2;align-items:flex-start;gap:var(--s5);flex-direction:column;width:100%;max-width:460px;display:flex;position:relative}.auth-headline{letter-spacing:-.5px;margin:0;font-size:clamp(30px,3.2vw,44px);line-height:1.08}.auth-lead{color:var(--text-2);max-width:44ch;margin:0;font-size:16.5px;line-height:1.6}.auth-points{width:100%;margin-top:var(--s2);gap:var(--s4);flex-direction:column;display:flex}.auth-point{align-items:flex-start;gap:var(--s3);display:flex}.auth-point .ico{width:42px;height:42px;color:var(--teal);background:#2fd5c61a;border:1px solid #2fd5c638;border-radius:12px;flex:none;place-items:center;display:grid}.auth-point .pt-title{color:var(--text);font-size:15px;font-weight:600}.auth-point .pt-sub{color:var(--text-2);margin-top:2px;font-size:13.5px;line-height:1.5}.chip-float,.auth-chip-a,.auth-chip-b,.auth-chip-c{display:none!important}.auth-formside{z-index:2;padding:var(--s7) var(--s6);background:var(--bg-1);place-items:center;display:grid;position:relative}.auth-formcard{width:100%;max-width:420px}.auth-formcard h1{margin:0}.auth-form-sub{margin:var(--s2) 0 var(--s6)}.auth-alt{margin-top:var(--s5);text-align:center}.auth-mobile-brand{margin-bottom:var(--s6);align-items:center;gap:var(--s2);display:none}@media (width<=860px){.auth-split{grid-template-columns:1fr}.auth-brandside{display:none}.auth-mobile-brand{display:inline-flex}}@media (width<=480px){.auth-formside{padding:var(--s6) var(--s4)}}@media (prefers-reduced-motion:reduce){.float,.float-slow,.marquee .track{animation:none!important}.reveal{opacity:1!important;transform:none!important}}:root{--teal:#2fd5c6;--cyan:#69f2f9;--blue:#09f;--amber:#f0a132;--coral:#ff7a59;--canvas:#07101f;--canvas-2:#0b1a30;--surface:#122036;--line:#1b3142;--bone:#f3f1e7;--muted:#8b99af}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--canvas);color:var(--bone);font-family:Poppins,system-ui,sans-serif}.app{flex-direction:column;height:100vh;display:flex}.topbar{background:linear-gradient(180deg, var(--canvas-2), var(--canvas));border-bottom:1px solid var(--line);flex:0 0 62px;align-items:center;gap:18px;height:62px;padding:0 18px;display:flex}.brand{align-items:center;gap:11px;display:flex}.brand .mark{color:#06222a;background:linear-gradient(140deg, var(--cyan), var(--teal));border-radius:11px;place-items:center;width:38px;height:38px;font-family:Fredoka,sans-serif;font-size:22px;font-weight:700;display:grid;box-shadow:0 4px 14px #2fd5c659}.brand-txt{flex-direction:column;line-height:1.12;display:flex}.brand-txt strong{letter-spacing:.2px;font-family:Fredoka,sans-serif;font-size:17px}.brand-txt span{color:var(--teal);letter-spacing:1.5px;text-transform:uppercase;font-size:11px;font-weight:600}.proj{color:var(--bone);align-items:center;gap:9px;font-size:15px;font-weight:600;display:flex}.proj-badge{letter-spacing:1px;text-transform:uppercase;color:var(--cyan);background:#69f2f91a;border:1px solid #69f2f940;border-radius:999px;padding:3px 8px;font-size:10px}.spacer{flex:1}.workspace{flex:1;min-height:0;display:flex}.pane-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);padding:10px 14px 8px;font-size:11px;font-weight:700}.editor-pane{border-right:1px solid var(--line);flex-direction:column;flex:1;min-width:0;display:flex}.editor-host{flex:1;min-height:0}.pg-pane{background:radial-gradient(120% 80% at 70% 0%, #0c1c34, var(--canvas));flex-direction:column;min-width:0;padding:0 18px 16px;display:flex}.divider{cursor:col-resize;background:var(--canvas-2);border-left:1px solid var(--line);border-right:1px solid var(--line);touch-action:none;flex:0 0 10px;justify-content:center;align-items:center;display:flex;position:relative}.divider:hover{background:#15263f}.divider-grip{background:var(--line);border-radius:3px;width:3px;height:36px;transition:background .15s}.divider:hover .divider-grip{background:var(--cyan)}.pg{border:1px solid var(--line);border-radius:16px;flex:1;min-height:0;position:relative;overflow:hidden}.pg-canvas{width:100%;height:100%;display:block}.pg-fallback{background:var(--canvas-2);place-items:center;padding:24px;display:grid}.pg-fallback-inner{text-align:center;max-width:360px}.pg-fallback-inner strong{color:var(--cyan);margin-bottom:8px;font-family:Fredoka,sans-serif;font-size:17px;display:block}.pg-fallback-inner p{color:var(--muted);font-size:13px;line-height:1.5}.pg-cams{gap:6px;display:flex;position:absolute;top:12px;right:12px}.pg-cams button{cursor:pointer;color:var(--muted);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);background:#07101fb3;border-radius:8px;padding:6px 11px;font-family:inherit;font-size:12px;font-weight:700}.pg-cams button.on{color:#06222a;background:var(--cyan);border-color:var(--cyan)}.pg-hud{color:var(--bone);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);background:#07101fb8;border-radius:10px;align-items:center;gap:8px;padding:7px 12px;font-size:13px;font-weight:600;display:flex;position:absolute;bottom:12px;left:12px}.pg-hud b{color:var(--cyan);font-variant-numeric:tabular-nums}.pg-hud .dot{background:var(--cyan);width:8px;height:8px;box-shadow:0 0 8px var(--cyan);border-radius:50%}.coach{border:1px solid var(--line);background:var(--surface);border-radius:16px;align-items:center;gap:13px;margin-top:12px;padding:10px 14px 10px 10px;transition:border-color .2s,background .2s;display:flex}.coach-av{object-fit:cover;object-position:50% 18%;background:var(--canvas);border-radius:14px;flex:0 0 54px;width:54px;height:54px;box-shadow:inset 0 0 0 1px #ffffff12}.coach.win .coach-av{animation:.5s pop}.bubble{flex-direction:column;gap:2px;display:flex;position:relative}.bubble-tag{letter-spacing:1px;text-transform:uppercase;color:var(--teal);font-family:Fredoka,sans-serif;font-size:11px;font-weight:700}.bubble-text{color:var(--bone);font-size:14px;font-weight:600;line-height:1.25}.coach.run{border-color:var(--blue)}.coach.run .bubble-tag{color:var(--cyan)}.coach.win{border-color:var(--teal);background:#2fd5c61f}.coach.err{border-color:var(--coral)}.coach.err .bubble-tag{color:var(--coral)}@media (width<=1024px){.pg-pane{flex-basis:460px;width:460px}}@media (width<=860px){.topbar{flex-wrap:wrap;gap:8px;height:auto;min-height:56px;padding:8px 12px}.topbar .brand-txt{display:none}.workspace{flex-direction:column}.editor-pane{border-right:0;border-bottom:1px solid var(--line);min-height:46vh;flex:auto!important;width:100%!important}.pg-pane{min-width:0;min-height:54vh;flex:auto!important;width:100%!important}.divider{display:none}}.blocklyToolboxDiv,.blocklyToolbox{min-width:196px;background:var(--canvas-2)!important;border-right:1px solid var(--line)!important;padding:12px 9px!important}.blocklyToolboxCategoryContainer:first-of-type{--cat:0,153,255;--icon:url(/icons/drivetrain.svg)}.blocklyToolboxCategoryContainer:nth-of-type(2){--cat:255,122,89;--icon:url(/icons/pen.svg)}.blocklyToolboxCategoryContainer:nth-of-type(3){--cat:47,213,198;--icon:url(/icons/sensing.svg)}.blocklyToolboxCategoryContainer:nth-of-type(4){--cat:240,161,50;--icon:url(/icons/control.svg)}.blocklyToolboxCategoryContainer:nth-of-type(5){--cat:108,75,214;--icon:url(/icons/operators.svg)}.blocklyToolboxCategory{align-items:center;transition:background .14s,transform 80ms;position:relative;background:0 0!important;border-left:0!important;border-radius:13px!important;margin:7px 4px!important;padding:8px 12px!important;display:flex!important}.blocklyToolboxCategory:hover{transform:translate(2px);background:rgba(var(--cat,140,150,170),.12)!important}.blocklyTreeSelected .blocklyToolboxCategory,.blocklyToolboxCategoryContainer[aria-selected=true] .blocklyToolboxCategory,.blocklyToolboxSelected{box-shadow:inset 0 0 0 1px rgba(var(--cat,140,150,170),.45);background:rgba(var(--cat,140,150,170),.18)!important}.blocklyToolboxCategoryLabel{letter-spacing:.2px;color:var(--bone)!important;font-family:Fredoka,sans-serif!important;font-size:15px!important;font-weight:600!important}.blocklyTreeSelected .blocklyToolboxCategoryLabel,.blocklyToolboxCategoryContainer[aria-selected=true] .blocklyToolboxCategoryLabel{color:#fff!important}.blocklyToolboxCategoryIcon{background-color:rgb(var(--cat,140,150,170));width:28px;height:28px;box-shadow:0 1px 4px rgba(var(--cat,140,150,170),.4), inset 0 0 0 1px #ffffff38;border-radius:50%;margin-right:12px;transition:transform .12s;position:relative;visibility:visible!important;display:inline-block!important}.blocklyToolboxCategory:hover .blocklyToolboxCategoryIcon,.blocklyTreeSelected .blocklyToolboxCategoryIcon,.blocklyToolboxCategoryContainer[aria-selected=true] .blocklyToolboxCategoryIcon{transform:scale(1.08)}.blocklyToolboxCategoryIcon:before{content:"";-webkit-mask:var(--icon,none) center / 17px 17px no-repeat;-webkit-mask:var(--icon,none) center / 17px 17px no-repeat;mask:var(--icon,none) center / 17px 17px no-repeat;background-color:#fff;position:absolute;inset:0}.blocklyFlyoutBackground{fill:var(--canvas)!important;fill-opacity:.96!important}.editor-wrap{width:100%;height:100%;position:relative}.be-canvas{width:100%;height:100%}.palette-toggle{z-index:6;color:var(--bone);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);cursor:pointer;background:#07101fd1;border-radius:9px;padding:6px 11px;font-family:Fredoka,sans-serif;font-size:12px;font-weight:600;transition:color .15s,border-color .15s;position:absolute;top:8px;right:8px}.palette-toggle:hover{color:var(--cyan);border-color:var(--cyan)}.editor-wrap.collapsed .blocklyToolboxDiv,.editor-wrap.collapsed .blocklyFlyout,.editor-wrap.collapsed .blocklyFlyoutScrollbar,.be-canvas.flyout-auto-hidden .blocklyFlyout,.be-canvas.flyout-auto-hidden .blocklyFlyoutScrollbar{display:none!important}
