:root{--bg:#0f172a;--bg2:#1a2847;--card:#1e293b;--card2:#273449;--line:rgba(148,163,184,.15);--line2:rgba(148,163,184,.25);--txt:#e2e8f0;--fg:#e2e8f0;--muted:#94a3b8;--muted2:#64748b;--blue:#3b82f6;--blue2:#60a5fa;--teal:#14b8a6;--amber:#f59e0b;--purple:#a855f7;--green:#22c55e;--red:#ef4444;--grad:linear-gradient(135deg,#3b82f6,#8b5cf6 50%,#ec4899);--grad2:linear-gradient(135deg,#f59e0b,#ef4444);--grad3:linear-gradient(135deg,#a855f7,#3b82f6);--radius:14px;--radius-sm:10px;--shadow:0 20px 40px -20px rgba(0,0,0,.6),0 2px 8px rgba(0,0,0,.3);--shadow-glow:0 0 20px rgba(59,130,246,.4),0 0 40px rgba(168,85,247,.2);--font:"Inter","Segoe UI",Tahoma,system-ui,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);color:var(--txt);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:before{inset:-20% -20% auto -20%;height:70vh;z-index:-2;background:radial-gradient(50vw 50vw at 10% 5%,rgba(59,130,246,.12),transparent 50%),radial-gradient(55vw 55vw at 90% 10%,rgba(168,85,247,.1),transparent 50%),radial-gradient(50vw 50vw at 50% 40%,rgba(236,72,153,.08),transparent 50%);filter:blur(80px);animation:aurora 20s ease-in-out infinite alternate}body:after,body:before{content:"";position:fixed}body:after{inset:0;z-index:-3;background:var(--bg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}@keyframes aurora{0%{transform:translate3d(-2%,-1%,0) scale(1)}to{transform:translate3d(3%,2%,0) scale(1.08)}}@keyframes colorMorph{0%,to{filter:hue-rotate(0deg)}50%{filter:hue-rotate(15deg)}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px rgba(59,130,246,.3)}50%{box-shadow:0 0 40px rgba(59,130,246,.5)}}.fade-in{animation:fadeIn 1s ease-out both}.slide-left{animation:slideInLeft .8s ease-out both}.slide-right{animation:slideInRight .8s ease-out both}.scale-in{animation:scaleIn .7s ease-out both}.float{animation:float 6s ease-in-out infinite}.glow-pulse{animation:glowPulse 3s ease-in-out infinite}.fade-in:first-child{animation-delay:0s}.fade-in:nth-child(2){animation-delay:.1s}.fade-in:nth-child(3){animation-delay:.2s}.fade-in:nth-child(4){animation-delay:.3s}.fade-in:nth-child(5){animation-delay:.4s}a{color:inherit;text-decoration:none}img,svg{display:block;max-width:100%}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.muted{color:var(--muted)}.small{font-size:.82rem}.center{text-align:center}.hidden{display:none!important}.wrap{max-width:1180px;margin:0 auto;padding:0 22px}.grid{display:grid;grid-gap:20px;gap:20px}.row{display:flex;gap:14px;align-items:center;flex-wrap:wrap}.spread{justify-content:space-between}.stack{display:flex;flex-direction:column;gap:14px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);position:relative;transition:transform .3s ease,border-color .3s ease,box-shadow .3s,filter .3s;will-change:transform}.card.hover:hover{transform:translateY(-6px) scale(1.01);border-color:var(--line2);box-shadow:var(--shadow-glow);filter:brightness(1.1)}.card.tilt:hover{transform:perspective(1200px) rotateX(4deg) rotateY(4deg) translateY(-6px)}.card.glow-pulse{animation:glowPulse 3s ease-in-out infinite}.blob{position:absolute;border-radius:50%;filter:blur(44px);pointer-events:none;z-index:0}.btn{display:inline-flex;align-items:center;gap:9px;justify-content:center;padding:11px 19px;border-radius:10px;font-weight:600;font-size:.93rem;background:var(--grad);color:#fff;box-shadow:0 12px 30px -15px rgba(59,130,246,.6);transition:transform .2s ease,box-shadow .2s ease,filter .2s,background .3s ease;white-space:nowrap;will-change:transform;background-size:200% 200%;animation:gradientShift 4s ease infinite}.btn:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 20px 50px -20px rgba(59,130,246,.8),var(--shadow-glow);filter:brightness(1.15)}.btn:active{transform:translateY(-1px) scale(1.03)}.btn.ghost{background:#1e293b;box-shadow:none;border:1.5px solid var(--line2);color:var(--txt);animation:none}.btn.ghost:hover{background:var(--card2);border-color:var(--blue2);transform:translateY(-3px);box-shadow:0 12px 30px rgba(59,130,246,.3)}.btn.amber{background:var(--grad2);box-shadow:0 12px 30px -15px rgba(245,158,11,.5);animation:none}.btn.amber:hover{box-shadow:0 20px 50px -20px rgba(245,158,11,.7),var(--shadow-glow)}.btn.sm{padding:8px 13px;font-size:.84rem}.btn.full{width:100%}.btn.shine{position:relative;overflow:hidden}.btn.shine:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shine 3s infinite}@keyframes shine{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.btn.glow-pulse{animation:glowPulse 3s ease-in-out infinite!important}.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;font-size:.74rem;font-weight:600;letter-spacing:.3px;background:var(--card2);border:1px solid var(--line);color:var(--muted);transition:all .25s ease}.pill:hover{transform:scale(1.08);border-color:var(--blue2)}.pill.blue{color:var(--blue2);background:rgba(59,130,246,.15);border-color:rgba(59,130,246,.35)}.pill.teal{color:var(--teal);background:rgba(20,184,166,.15);border-color:rgba(20,184,166,.35)}.pill.amber{color:var(--amber);background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.35)}.pill.purple{color:var(--purple);background:rgba(168,85,247,.15);border-color:rgba(168,85,247,.35)}.pill.green{color:var(--green);background:rgba(34,197,74,.15);border-color:rgba(34,197,74,.35)}.pill.red{color:var(--red);background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.35)}.gtext{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}h1,h2,h3{line-height:1.2;font-weight:800;color:var(--txt);letter-spacing:-.01em}.section-title{font-size:1.4rem;margin-bottom:4px}.eyebrow{font-size:.78rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--blue2)}input,select,textarea{background:var(--card2);border:1px solid var(--line2);border-radius:10px;color:var(--txt);padding:10px 14px;font-family:inherit;font-size:inherit;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue2);box-shadow:0 0 0 3px rgba(59,130,246,.2);background:var(--card)}.bar{height:6px}.bar i{transition:width .4s ease}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--line2);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--line)}@media (max-width:768px){.grid{gridTemplateColumns:1fr!important}.row{flex-direction:column}.card{padding:16px}.btn{width:100%}}.fade-in-stagger>*{animation:fadeIn .8s ease-out backwards}.fade-in-stagger>:first-child{animation-delay:.1s}.fade-in-stagger>:nth-child(2){animation-delay:.2s}.fade-in-stagger>:nth-child(3){animation-delay:.3s}.fade-in-stagger>:nth-child(4){animation-delay:.4s}.fade-in-stagger>:nth-child(5){animation-delay:.5s}.fade-in-stagger>:nth-child(n+6){animation-delay:.6s}section{transition:background-color .8s ease,border-color .8s ease}@keyframes wobble{0%,to{transform:translateX(0)}15%{transform:translateX(-5px)}30%{transform:translateX(5px)}45%{transform:translateX(-5px)}60%{transform:translateX(5px)}}.wobble{animation:wobble .5s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.bounce{animation:bounce 1s ease-in-out infinite}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:40;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:rgba(15,23,42,.85);border-bottom:1px solid var(--line)}.nav .wrap{justify-content:space-between;height:64px}.brand,.nav .wrap{display:flex;align-items:center}.brand{gap:12px;font-weight:800;font-size:1.05rem;color:var(--txt)}.brand .logo{width:36px;height:36px}.nav-links{display:flex;gap:6px;align-items:center}.nav-links a{padding:8px 14px;border-radius:9px;font-size:.9rem;color:var(--muted);font-weight:600;transition:.18s}.nav-links a.active,.nav-links a:hover{color:var(--blue2);background:rgba(59,130,246,.12)}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-weight:800;background:var(--grad);color:#fff;font-size:.9rem;box-shadow:0 6px 16px -8px rgba(59,130,246,.7)}.avatar.teal{background:var(--grad3)}.login-shell{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}.login-hero{padding:54px 56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;background:linear-gradient(160deg,var(--card),var(--bg2))}.login-hero .blob{position:absolute;border-radius:50%;filter:blur(46px);opacity:.4;z-index:0}.login-aside{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg2);border-left:1px solid var(--line)}.hero-badge{display:inline-flex;gap:8px;align-items:center;padding:7px 14px;border-radius:999px;background:var(--card);border:1px solid var(--line2);font-size:.8rem;font-weight:600;width:max-content;box-shadow:var(--shadow)}.hero-title{font-size:clamp(2.2rem,4.5vw,3.4rem);margin:22px 0 14px;letter-spacing:-1.5px}.hero-sub{font-size:1.08rem;color:var(--muted);max-width:34ch}.hero-stats{display:flex;gap:26px;margin-top:30px}.hero-stat b{font-size:1.7rem;display:block;color:var(--txt)}.hero-stat span{color:var(--muted);font-size:.82rem}.feature-row{display:flex;flex-direction:column;gap:14px;margin-top:30px;position:relative;z-index:1}.feature{display:flex;gap:13px;align-items:center;font-size:.94rem}.feature .fi{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;flex:0 0 auto;background:var(--card2);border:1px solid var(--line);box-shadow:var(--shadow)}.role-card{width:100%;max-width:420px}.role-toggle{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin:18px 0 22px}.role-opt{padding:18px 14px;border-radius:14px;border:1.5px solid var(--line);background:var(--card2);cursor:pointer;transition:.2s;position:relative}.role-opt:hover{border-color:var(--line2)}.role-opt.active{border-color:var(--blue2);background:rgba(59,130,246,.12);box-shadow:0 0 0 3px rgba(59,130,246,.18)}.role-opt.active.instr{border-color:var(--purple);background:rgba(168,85,247,.12);box-shadow:0 0 0 3px rgba(168,85,247,.18)}.role-opt .ri{width:46px;height:46px;margin:0 auto 8px}.role-opt b{display:block;font-size:.98rem}.role-opt span{font-size:.76rem;color:var(--muted)}.field{margin-bottom:14px}.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px;color:var(--muted)}.field input{width:100%;padding:13px 15px;border-radius:11px;border:1.5px solid var(--line2);font-size:.95rem;transition:.18s}.field input::placeholder{color:var(--muted2)}.field input:focus{outline:none;border-color:var(--blue2);box-shadow:0 0 0 3px rgba(59,130,246,.2)}.hint{font-size:.78rem;color:var(--muted2);text-align:center}.err,.hint{margin-top:8px}.err{color:var(--red);font-size:.82rem;min-height:18px}.tiles{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px}.tile{padding:18px;border-radius:var(--radius);border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow);position:relative;overflow:hidden}.tile .ti{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;margin-bottom:12px}.tile b{font-size:1.9rem;display:block;line-height:1;color:var(--txt)}.tile span{color:var(--muted);font-size:.84rem}.tile .spark{position:absolute;right:-6px;bottom:-6px;opacity:.1;font-size:4rem}.bar{height:9px;background:var(--card2);overflow:hidden}.bar,.bar i{border-radius:999px}.bar i{display:block;height:100%;background:var(--grad);transition:width .8s cubic-bezier(.2,.8,.2,1)}.bar.teal i{background:linear-gradient(90deg,#14b8a6,#06b6d4)}.bar.amber i{background:var(--grad2)}.ring{--p:0;width:140px;height:140px;border-radius:50%;display:grid;place-items:center;position:relative;background:conic-gradient(var(--blue2) calc(var(--p)*1%),rgba(148,163,184,.15) 0)}.ring:before{content:"";position:absolute;inset:12px;border-radius:50%;background:var(--card)}.ring .ring-txt{position:relative;text-align:center}.ring .ring-txt b{font-size:1.9rem;display:block;line-height:1;color:var(--txt)}.ring .ring-txt span{font-size:.74rem;color:var(--muted)}.phase-card{padding:0;overflow:hidden}.phase-head{padding:20px 22px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--line)}.phase-ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;flex:0 0 auto}.phase-body{padding:18px 22px}.day-list{display:flex;flex-direction:column;gap:9px}.day-item{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:12px;background:var(--card2);border:1px solid var(--line);cursor:pointer;transition:.18s;text-align:left}.day-item:hover{background:var(--card);border-color:var(--blue2);transform:translateX(3px)}.day-num{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:800;font-size:.85rem;flex:0 0 auto;background:var(--card);border:1px solid var(--line);color:var(--txt)}.day-item.done .day-num{background:var(--green);color:#fff;border-color:transparent}.day-item.done .day-title{color:var(--muted);text-decoration:line-through;-webkit-text-decoration-color:rgba(148,163,184,.4);text-decoration-color:rgba(148,163,184,.4)}.day-title{font-weight:600;font-size:.92rem;flex:1 1;color:var(--txt)}.day-meta{font-size:.74rem;color:var(--muted2)}.check{margin-left:auto;color:var(--green)}.course-layout{display:grid;grid-template-columns:300px 1fr;grid-gap:26px;gap:26px;align-items:start;margin-top:26px}.sidebar{position:-webkit-sticky;position:sticky;top:88px;max-height:calc(100vh - 110px);overflow:auto;padding:18px}.sb-phase{margin-bottom:18px}.sb-phase h4{font-size:.74rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted2);margin-bottom:9px;padding-left:4px}.sb-day{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;cursor:pointer;transition:.16s;font-size:.88rem;color:var(--txt)}.sb-day:hover{background:var(--card2)}.sb-day.active{background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.3);color:var(--blue2);font-weight:600}.sb-dot{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;font-size:.72rem;font-weight:800;flex:0 0 auto;background:var(--card2);color:var(--muted)}.sb-day.done .sb-dot{background:var(--green);color:#fff}.lesson-hero{padding:30px;border-radius:var(--radius);position:relative;overflow:hidden;margin-bottom:22px;background:linear-gradient(135deg,rgba(59,130,246,.12),rgba(20,184,166,.08));border:1px solid var(--line)}.lesson-hero .em{font-size:3rem;margin-bottom:10px}.lesson-hero h1{font-size:2rem;letter-spacing:-.5px}.lesson-block{margin-bottom:20px}.lesson-block h3{display:flex;align-items:center;gap:9px;font-size:1.05rem;margin-bottom:12px}.lesson-block h3 .lb-ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:.9rem}.tasklist{list-style:none;display:flex;flex-direction:column;gap:10px}.tasklist li{display:flex;gap:11px;padding:12px 14px;border-radius:12px;background:var(--card2);border:1px solid var(--line)}.tasklist li .ck{width:22px;height:22px;border-radius:6px;border:2px solid var(--blue2);flex:0 0 auto;display:grid;place-items:center;font-size:.7rem;color:var(--blue2)}.exercise-box{padding:16px 18px;border-radius:14px;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.25)}.goal-box{padding:14px 18px;border-radius:14px;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.25);display:flex;gap:11px;align-items:center}.scenario-card{padding:22px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(168,85,247,.1),rgba(59,130,246,.07));border:1px solid rgba(168,85,247,.25)}.scenario-q{font-size:1.05rem;font-weight:600;margin:10px 0 16px}.reveal{max-height:0;overflow:hidden;transition:max-height .5s ease,opacity .4s;opacity:0}.reveal.open{max-height:400px;opacity:1;margin-top:14px}.expert-box{padding:16px 18px;border-radius:13px;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3)}.tabs{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}.tab{padding:9px 16px;border-radius:10px;font-weight:600;font-size:.88rem;color:var(--muted);background:var(--card2);border:1px solid var(--line);cursor:pointer;transition:.16s}.tab:hover{color:var(--blue2);border-color:var(--line2)}.tab.active{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 8px 18px -10px rgba(59,130,246,.5)}.bool-pg{display:flex;flex-direction:column;gap:12px}.bool-out{padding:14px 16px;border-radius:12px;background:#0b1220;border:1px solid #1e293b;font-family:Courier New,monospace;color:#67e8f9;font-size:.9rem;word-break:break-word;min-height:54px}.chip-row{display:flex;gap:8px;flex-wrap:wrap}.chip{padding:7px 13px;border-radius:9px;background:var(--card2);border:1px solid var(--line2);font-size:.82rem;cursor:pointer;transition:.15s;font-family:Courier New,monospace;color:var(--txt)}.chip:hover{background:rgba(59,130,246,.15);border-color:var(--blue2)}.gloss-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:14px;gap:14px}.gloss{padding:16px;border-radius:14px;background:var(--card2);border:1px solid var(--line);transition:.2s}.gloss:hover{border-color:var(--blue2);transform:translateY(-3px);box-shadow:var(--shadow)}.gloss b{font-size:1.05rem;color:var(--blue2)}.gloss .full{font-size:.74rem;color:var(--muted2);margin-bottom:6px}.scn-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:18px;gap:18px}.scn{padding:22px;border-radius:var(--radius);border:1px solid var(--line);position:relative;overflow:hidden;background:var(--card);cursor:pointer;transition:.25s;box-shadow:var(--shadow)}.scn:hover{transform:translateY(-4px);border-color:var(--line2);box-shadow:var(--shadow-glow)}.scn .scn-em{font-size:2.4rem;margin-bottom:8px}.matrix-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px}.gauge{text-align:center;padding:18px}.gauge .ring{width:108px;height:108px;margin:0 auto 10px}.gauge .ring:before{inset:10px}.gauge .ring-txt b{font-size:1.5rem}table.cohort{width:100%;border-collapse:collapse;font-size:.9rem}table.cohort th{text-align:left;padding:12px 14px;color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.5px}table.cohort td,table.cohort th{border-bottom:1px solid var(--line)}table.cohort td{padding:13px 14px}table.cohort tr:hover td{background:var(--card2)}.mini-avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:.74rem;background:var(--grad3);color:#fff}.stage-card{padding:0;overflow:hidden}.stage-top{padding:18px 20px;display:flex;align-items:center;gap:13px}.stage-num{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;font-size:1.4rem;flex:0 0 auto}.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120%);background:var(--card);border:1px solid var(--line2);padding:14px 22px;border-radius:14px;color:var(--txt);box-shadow:var(--shadow);z-index:90;display:flex;gap:11px;align-items:center;transition:transform .4s cubic-bezier(.2,.9,.3,1);font-weight:600}.toast.show{transform:translateX(-50%) translateY(0)}.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:80;display:grid;place-items:center;opacity:0;pointer-events:none;transition:.25s;padding:20px}.modal-bg.show{opacity:1;pointer-events:auto}.modal{max-width:480px;width:100%;transform:scale(.94);transition:.25s}.modal-bg.show .modal{transform:scale(1)}.confetti{position:fixed;top:-12px;width:11px;height:14px;z-index:95;border-radius:2px;pointer-events:none;animation:fall linear forwards}@keyframes fall{to{transform:translateY(105vh) rotate(680deg);opacity:.9}}.fade-up{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.fade-up.in{opacity:1;transform:none}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:100%;max-width:440px}.seg{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;background:var(--card2);padding:5px;border-radius:12px;margin-bottom:16px}.seg button{padding:10px;border-radius:9px;font-weight:600;font-size:.88rem;color:var(--muted);transition:.16s}.seg button.active{background:var(--grad);color:#fff}.chat{display:flex;flex-direction:column;height:460px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg)}.chat-log{flex:1 1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}.bubble{max-width:80%;padding:11px 15px;border-radius:14px;font-size:.92rem;line-height:1.5}.bubble.user{align-self:flex-end;background:var(--grad);color:#fff;border-bottom-right-radius:4px}.bubble.ai{align-self:flex-start;border:1px solid var(--line);color:var(--txt);border-bottom-left-radius:4px;box-shadow:var(--shadow)}.bubble.ai,.chat-input{background:var(--card2)}.chat-input{display:flex;gap:10px;padding:14px;border-top:1px solid var(--line)}.chat-input input{flex:1 1}.typing{font-size:.8rem;color:var(--muted);font-style:italic}.mock-q{padding:16px 18px;border-radius:13px;background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.25);margin-bottom:12px}textarea.answer{width:100%;min-height:120px;padding:14px;border-radius:12px;border:1px solid var(--line2);color:var(--txt);font-family:inherit;font-size:.92rem;resize:vertical}.score-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px;margin:14px 0}.score-box{text-align:center;padding:14px;border-radius:12px;background:var(--card2);border:1px solid var(--line)}.score-box b{font-size:1.6rem;display:block}.queue-item{padding:18px;border-radius:14px;border:1px solid var(--line);background:var(--card2);margin-bottom:14px}.diff{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;margin:12px 0}.diff-col{padding:12px;border-radius:10px;font-size:.85rem;line-height:1.5}.diff-col.old{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25)}.diff-col.new{background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.25)}.diff-col h5{font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.spin{width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite;display:inline-block}.btn.ghost .spin,.tab .spin{border-color:rgba(59,130,246,.3);border-top-color:var(--blue2)}@keyframes sp{to{transform:rotate(1turn)}}.badge-live{position:fixed;bottom:14px;right:14px;z-index:60;font-size:.72rem;padding:6px 12px;border-radius:999px;border:1px solid var(--line2);background:rgba(15,23,42,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--muted);box-shadow:var(--shadow)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}@keyframes flashIn{0%{background:rgba(34,197,94,.14);border-radius:10px}to{background:transparent}}@keyframes floatSlow{0%,to{transform:translateY(0)}50%{transform:translateY(-26px)}}.float-slow{animation:floatSlow 9s ease-in-out infinite}.float-fast{animation:float 3s ease-in-out infinite}.drift{animation:aurora 16s ease-in-out infinite alternate}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.caret:after{content:"▋";margin-left:2px;animation:blink 1s step-end infinite;color:var(--teal)}@keyframes shimmer{0%{background-position:0 50%}to{background-position:200% 50%}}.shimmer{background:linear-gradient(90deg,#3b82f6,#14b8a6,#a855f7,#f59e0b,#3b82f6);background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 4s linear infinite}@keyframes popIn{0%{opacity:0;transform:scale(.85) translateY(10px)}to{opacity:1;transform:none}}.pop{animation:popIn .5s cubic-bezier(.2,.9,.3,1.4) both}.shine{position:relative;overflow:hidden}.shine:after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.15),transparent);transform:skewX(-20deg);transition:none;pointer-events:none}.shine:hover:after{animation:sweep .8s ease}@keyframes sweep{to{left:130%}}.tilt{transition:transform .25s ease,box-shadow .25s}.tilt:hover{transform:perspective(800px) rotateX(3deg) rotateY(-3deg) translateY(-6px);box-shadow:var(--shadow-glow)}@keyframes bob{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-8px) rotate(2deg)}}.bob{animation:bob 3.5s ease-in-out infinite}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-6deg)}75%{transform:rotate(6deg)}}.wiggle:hover{animation:wiggle .4s ease}.flip{perspective:1000px;cursor:pointer}.flip-inner{position:relative;width:100%;height:100%;transition:transform .6s;transform-style:preserve-3d}.flip.flipped .flip-inner{transform:rotateY(180deg)}.flip-face{position:absolute;inset:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:16px;display:grid;place-items:center;padding:18px;text-align:center}.flip-back{transform:rotateY(180deg)}@keyframes stampIn{0%{opacity:0;transform:scale(2.4) rotate(-25deg)}60%{opacity:1}to{opacity:1;transform:scale(1) rotate(-14deg)}}.stamp{animation:stampIn .7s cubic-bezier(.2,.8,.2,1.2) both}.counter{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.ribbon{position:fixed;top:16px;left:-46px;z-index:55;transform:rotate(-45deg);background:var(--grad2);color:#fff;font-weight:800;font-size:.72rem;letter-spacing:1px;padding:5px 60px;box-shadow:0 6px 18px -6px rgba(0,0,0,.4);pointer-events:none}.glow{animation:glowPulse 2.4s ease-out infinite}.fade-pop{opacity:0;transform:scale(.94);transition:opacity .6s,transform .6s}.fade-pop.in{opacity:1;transform:none}.mesh{position:absolute;inset:0;z-index:-1;filter:blur(60px);opacity:.35;background:radial-gradient(30% 30% at 20% 30%,#3b82f6,transparent),radial-gradient(30% 30% at 80% 20%,#14b8a6,transparent),radial-gradient(30% 30% at 60% 80%,#a855f7,transparent);animation:aurora 16s ease-in-out infinite alternate}@media(max-width:980px){.login-shell{grid-template-columns:1fr}.login-aside{border-left:none;border-top:1px solid var(--line)}.course-layout{grid-template-columns:1fr}.sidebar{position:static;max-height:none}.matrix-grid,.tiles{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.grid{grid-template-columns:1fr!important}.row{flex-direction:column}.card{padding:16px}.btn{width:100%}.hero-stats{flex-wrap:wrap;gap:16px}}@media(max-width:620px){.nav-links a{padding:8px 9px;font-size:.82rem}.tiles{grid-template-columns:1fr}.nav-links .label-hide{display:none}}@media(prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.card:not(.sidebar):not(.phase-card):not(.stage-card){transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.card:not(.sidebar):not(.phase-card):not(.stage-card):hover{transform:translateY(-3px);border-color:var(--line2);box-shadow:0 24px 48px -20px rgba(0,0,0,.5),0 4px 12px rgba(0,0,0,.2)}.scn-grid .scn{animation:popIn .5s cubic-bezier(.2,.9,.3,1.4) backwards}.scn-grid .scn:first-child{animation-delay:.05s}.scn-grid .scn:nth-child(2){animation-delay:.12s}.scn-grid .scn:nth-child(3){animation-delay:.19s}.scn-grid .scn:nth-child(4){animation-delay:.26s}.scn-grid .scn:nth-child(5){animation-delay:.33s}.scn-grid .scn:nth-child(n+6){animation-delay:.38s}.tiles .tile{animation:scaleIn .5s ease backwards}.tiles .tile:first-child{animation-delay:.05s}.tiles .tile:nth-child(2){animation-delay:.12s}.tiles .tile:nth-child(3){animation-delay:.19s}.tiles .tile:nth-child(4){animation-delay:.26s}.phase-card{transition:transform .3s ease,box-shadow .3s ease}.phase-card:hover{transform:translateY(-4px);box-shadow:0 28px 56px -24px rgba(0,0,0,.55)}.lesson-hero .em{display:inline-block}.tab{transition:background .18s ease,color .18s ease,border-color .18s ease,transform .15s ease,box-shadow .18s ease}.tab:hover{transform:translateY(-2px)}.tab.active{transform:translateY(-1px)}.btn:not(.ghost):not(.amber){background:linear-gradient(135deg,#3b82f6,#8b5cf6 50%,#ec4899,#3b82f6);background-size:300% 300%}@keyframes glowGreen{0%,to{box-shadow:0 0 0 0 rgba(34,197,94,.5)}50%{box-shadow:0 0 0 10px rgba(34,197,94,0)}}.glow-pulse.green{animation:glowGreen 2s ease-out infinite}.sb-day{transition:background .16s,border-color .16s,transform .16s,color .16s}.sb-day:hover{transform:translateX(4px)}.pop,.scale-in,.slide-left{animation-fill-mode:both}.hero-badge:hover{box-shadow:0 0 0 3px rgba(59,130,246,.25);transition:box-shadow .25s}.pill:hover{box-shadow:0 0 0 2px rgba(59,130,246,.2)}.role-opt{text-align:center}.gloss{transition:border-color .2s,transform .2s,box-shadow .2s}.gloss:hover{box-shadow:0 12px 28px -12px rgba(0,0,0,.4)}details>summary{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}details>summary::-webkit-details-marker{display:none}.bar i{transition:width 1.2s cubic-bezier(.2,.8,.2,1)}.pill.amber{animation:none}.course-layout,.login-shell,main{animation:fadeIn .35s ease both}@keyframes marquee-ltr{0%{transform:translateX(-50%)}to{transform:translateX(0)}}.marquee-track-ltr{animation:marquee-ltr 28s linear infinite!important}