:root{--bg:#060815;--bg-card:#0d1025;--bg-card-hover:#111430;--purple:#a45dff;--violet:#6d67ff;--violet-dim:#6d67ff26;--purple-dim:#a45dff1f;--purple-glow:#a45dff4d;--text:#fff;--textbtn:#f0ecff;--text-muted:#ffffff8c;--text-sub:#ffffff59;--border:#6d67ff33;--border-bright:#a45dff66;--font-heading:"Sora", sans-serif;--font-body:"Inter", sans-serif;--font-accent:"Space Grotesk", sans-serif;--radius:14px;--radius-sm:8px;--radius-lg:20px;--radius-pill:100px;--transition:.25s cubic-bezier(.4, 0, .2, 1)}html{scroll-behavior:smooth}body:before{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");position:fixed;inset:0}.stars-bg{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.star{opacity:0;width:2px;height:2px;animation:twinkle var(--dur,4s) var(--delay,0s) infinite;background:#fff;border-radius:50%;position:absolute}@keyframes twinkle{0%,to{opacity:0}50%{opacity:var(--max-opacity,.6)}}.container{z-index:1;max-width:1200px;margin:0 auto;padding:0 24px;position:relative}.navbar{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background var(--transition);background:#060815b3;justify-content:space-between;align-items:center;padding:16px 40px;display:flex;position:fixed;top:0;left:0;right:0}.navbar.scrolled{background:#060815f2}.navbar__logo{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;align-items:center;gap:8px;font-size:22px;font-weight:700;text-decoration:none;display:flex}.spark{color:var(--purple);font-size:14px}.navbar__links{align-items:center;gap:36px;list-style:none;display:flex}.navbar__links a{color:var(--text-muted);font-size:14px;font-family:var(--font-accent);letter-spacing:.01em;transition:color var(--transition);text-decoration:none}.navbar__links a:hover{color:var(--text)}.btn-nav{font-size:14px;font-family:var(--font-accent);color:var(--textbtn);background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition);border:none;padding:10px 22px;font-weight:600;box-shadow:0 0 20px #a45dff40}.btn-nav:hover{transform:translateY(-1px);box-shadow:0 0 30px #a45dff73}.btn-nav:active{transform:translateY(0)}.hero{text-align:center;padding:160px 0 100px;position:relative;overflow:hidden}.hero__glow{pointer-events:none;z-index:0;background:radial-gradient(#6d67ff2e 0%,#a45dff14 40%,#0000 70%);width:800px;height:500px;position:absolute;top:50%;left:50%;transform:translate(-50%,-60%)}.hero__content{z-index:1;position:relative}.hero__badge{font-size:12px;font-family:var(--font-accent);letter-spacing:.12em;color:var(--purple);background:var(--purple-dim);border:1px solid var(--border-bright);border-radius:var(--radius-pill);align-items:center;gap:8px;margin-bottom:28px;padding:8px 18px;font-weight:600;animation:.8s both fadeInDown;display:inline-flex}.hero__title{font-family:var(--font-heading);letter-spacing:-.03em;color:var(--text);max-width:820px;margin:0 auto 20px;font-size:clamp(40px,6vw,72px);font-weight:700;line-height:1.1;animation:.9s .1s both fadeInUp}.hero__title .gradient-text{background:linear-gradient(135deg, var(--violet) 0%, var(--purple) 60%, #ff6bff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero__sub{color:var(--text-muted);max-width:520px;margin:0 auto 44px;font-size:18px;line-height:1.7;animation:.9s .2s both fadeInUp}.hero__cta-group{flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;margin-bottom:72px;animation:.9s .3s both fadeInUp;display:flex}.btn-primary{font-size:15px;font-family:var(--font-accent);color:var(--textbtn);background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:8px;padding:14px 30px;font-weight:700;text-decoration:none;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 4px 30px #a45dff59}.btn-primary:before{content:"";opacity:0;transition:opacity var(--transition);background:linear-gradient(135deg,#ffffff26,#0000);position:absolute;inset:0}.btn-primary:hover:before{opacity:1}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 40px #a45dff80}.btn-primary:active{transform:translateY(0)}.btn-secondary{font-size:15px;font-family:var(--font-accent);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition);background:0 0;align-items:center;gap:8px;padding:14px 28px;font-weight:600;text-decoration:none;display:inline-flex}.btn-secondary:hover{color:var(--text);border-color:var(--border-bright);background:var(--violet-dim)}.waitlist-form{border:1px solid var(--border);border-radius:var(--radius-pill);max-width:440px;transition:border-color var(--transition);background:#ffffff0a;align-items:center;gap:10px;margin:0 auto 72px;padding:6px 6px 6px 20px;animation:.9s .3s both fadeInUp;display:flex}.waitlist-form:focus-within{border-color:var(--border-bright);background:#6d67ff0f}.waitlist-form input{font-size:14px;font-family:var(--font-body);color:var(--text);background:0 0;border:none;outline:none;flex:1;min-width:0}.waitlist-form input::placeholder{color:var(--text-sub)}.waitlist-form .btn-primary{flex-shrink:0;padding:11px 24px;font-size:14px}.hero__preview{max-width:900px;margin:0 auto;animation:.9s .4s both fadeInUp;position:relative}.preview-glow{pointer-events:none;z-index:0;background:radial-gradient(#6d67ff26 0%,#0000 70%);position:absolute;inset:-40px}.preview-card{z-index:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);position:relative;overflow:hidden;box-shadow:0 40px 80px #00000080,0 0 0 1px #ffffff08}.preview-card__bar{border-bottom:1px solid var(--border);background:#ffffff08;align-items:center;gap:8px;padding:12px 16px;display:flex}.dot{border-radius:50%;width:10px;height:10px}.dot--red{background:#ff5f56}.dot--yellow{background:#ffbd2e}.dot--green{background:#27c93f}.preview-card__inner{grid-template-columns:1fr 1fr;gap:0;display:grid}.preview-panel{padding:28px}.preview-panel:first-child{border-right:1px solid var(--border)}.preview-label{font-size:11px;font-family:var(--font-accent);letter-spacing:.1em;color:var(--purple);text-transform:uppercase;align-items:center;gap:6px;margin-bottom:16px;font-weight:600;display:flex}.input-mock{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:default;font-size:13px;font-family:var(--font-body);background:#ffffff0a;justify-content:space-between;align-items:center;margin-bottom:10px;padding:10px 14px;display:flex}.input-mock .arrow{color:var(--text-sub);font-size:10px}.input-mock.textarea{white-space:normal;word-break:break-word;align-items:flex-start;min-height:70px;font-size:12px;line-height:1.5}.generate-mock-btn{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-sm);width:100%;color:var(--textbtn);font-size:14px;font-family:var(--font-accent);cursor:pointer;transition:opacity var(--transition);border:none;margin-top:8px;padding:12px;font-weight:700}.generate-mock-btn:hover{opacity:.9}.day-badge{font-size:11px;font-family:var(--font-accent);color:var(--violet);background:var(--violet-dim);border-radius:var(--radius-pill);border:1px solid #6d67ff4d;align-items:center;gap:6px;margin-bottom:14px;padding:4px 12px;font-weight:700;display:inline-flex}.output-title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;margin-bottom:6px;font-size:22px;font-weight:700}.output-sub{color:var(--text-muted);margin-bottom:18px;font-size:13px;line-height:1.5}.lesson-chip{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);background:#ffffff0a;margin-bottom:10px;padding:10px 14px;font-size:12px;line-height:1.5}.lesson-chip code{color:var(--purple);background:var(--purple-dim);border-radius:4px;padding:1px 5px;font-family:Courier New,monospace;font-size:11px}.task-chip{border:1px solid var(--border-bright);border-radius:var(--radius-sm);color:var(--text-muted);background:linear-gradient(135deg,#a45dff14,#6d67ff14);padding:10px 14px;font-size:12px;line-height:1.5}.task-chip strong{color:var(--purple);font-weight:600}.section{z-index:1;padding:100px 0;position:relative}.section__header{text-align:center;margin-bottom:60px}.section__label{font-size:12px;font-family:var(--font-accent);letter-spacing:.12em;color:var(--purple);text-transform:uppercase;margin-bottom:14px;font-weight:600;display:block}.section__title{font-family:var(--font-heading);letter-spacing:-.02em;color:var(--text);max-width:600px;margin:0 auto 16px;font-size:clamp(30px,4vw,48px);font-weight:700;line-height:1.15}.section__title .accent{color:var(--violet)}.section__desc{color:var(--text-muted);max-width:480px;margin:0 auto;font-size:16px;line-height:1.7}.steps-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.step-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);padding:32px 28px;position:relative;overflow:hidden}.step-card:before{content:"";background:linear-gradient(90deg, var(--violet), var(--purple));opacity:0;height:2px;transition:opacity var(--transition);position:absolute;top:0;left:0;right:0}.step-card:hover:before{opacity:1}.step-card:hover{background:var(--bg-card-hover);border-color:var(--border-bright);transform:translateY(-4px)}.step-number{font-family:var(--font-heading);background:linear-gradient(135deg, var(--violet), var(--purple));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:16px;font-size:48px;font-weight:800;line-height:1;display:block}.step-title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;margin-bottom:10px;font-size:18px;font-weight:700}.step-text{color:var(--text-muted);font-size:14px;line-height:1.6}.features-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);padding:28px 24px;position:relative;overflow:hidden}.feature-card__icon{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--violet-dim), var(--purple-dim));border:1px solid var(--border);justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:16px;font-size:18px;display:flex}.feature-card__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;margin-bottom:4px;font-size:17px;font-weight:700}.feature-card__sub{font-size:12px;font-family:var(--font-accent);color:var(--purple);letter-spacing:.04em;margin-bottom:10px;font-weight:600}.feature-card__text{color:var(--text-muted);font-size:13px;line-height:1.6}.feature-card:hover{border-color:var(--border-bright);background:var(--bg-card-hover);transform:translateY(-3px)}.feature-card:after{content:"";opacity:0;height:60px;transition:opacity var(--transition);pointer-events:none;background:linear-gradient(#0000,#a45dff0a);position:absolute;bottom:0;left:0;right:0}.feature-card:hover:after{opacity:1}.pricing-grid{grid-template-columns:repeat(2,1fr);gap:24px;max-width:780px;margin:0 auto;display:grid}.pricing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);padding:36px 32px;position:relative;overflow:hidden}.pricing-card--pro{border-color:var(--border-bright);background:linear-gradient(160deg, #6d67ff1a, #a45dff0f, var(--bg-card) 60%)}.pricing-card--pro:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);height:1px;position:absolute;top:0;left:0;right:0}.pricing-badge{font-size:10px;font-family:var(--font-accent);letter-spacing:.12em;text-transform:uppercase;color:var(--textbtn);background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-pill);align-items:center;margin-bottom:20px;padding:4px 12px;font-weight:700;display:inline-flex}.pricing-price{align-items:baseline;gap:4px;margin-bottom:6px;display:flex}.pricing-currency{font-size:20px;font-family:var(--font-heading);color:var(--text-muted);font-weight:700}.pricing-amount{font-family:var(--font-heading);color:var(--text);letter-spacing:-.04em;font-size:52px;font-weight:800;line-height:1}.pricing-period{color:var(--text-muted);margin-bottom:24px;font-size:14px}.pricing-title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;margin-bottom:6px;font-size:22px;font-weight:700}.pricing-desc{color:var(--text-muted);margin-bottom:24px;font-size:13px;line-height:1.5}.pricing-features{flex-direction:column;gap:12px;margin-bottom:32px;list-style:none;display:flex}.pricing-features li{color:var(--text-muted);align-items:center;gap:10px;font-size:14px;display:flex}.pricing-features li:before{content:"✦";color:var(--purple);flex-shrink:0;font-size:10px}.pricing-card:hover{transform:translateY(-4px)}.pricing-cta{border-radius:var(--radius-pill);width:100%;font-family:var(--font-accent);cursor:pointer;transition:all var(--transition);text-align:center;border:1px solid var(--border);color:var(--text-muted);background:0 0;padding:14px;font-size:15px;font-weight:700}.pricing-cta--pro{background:linear-gradient(135deg, var(--violet), var(--purple));color:var(--textbtn);border:none;box-shadow:0 4px 20px #a45dff4d}.pricing-cta:hover{border-color:var(--border-bright);color:var(--text);background:var(--violet-dim)}.pricing-cta--pro:hover{color:var(--textbtn);background:linear-gradient(135deg,#7d78ff,#b56aff);border:none;box-shadow:0 6px 30px #a45dff73}.cta-section{text-align:center;z-index:1;padding:100px 0 120px;position:relative}.cta-glow{pointer-events:none;background:radial-gradient(#6d67ff33 0%,#0000 70%);width:600px;height:300px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.cta-title{font-family:var(--font-heading);letter-spacing:-.03em;color:var(--text);max-width:640px;margin:0 auto 16px;font-size:clamp(32px,4.5vw,54px);font-weight:700;line-height:1.1;position:relative}.cta-sub{color:var(--text-muted);margin-bottom:44px;font-size:17px;position:relative}.footer{border-top:1px solid var(--border);z-index:1;justify-content:space-between;align-items:center;padding:32px 0;display:flex;position:relative}.footer__copy{color:var(--text-sub);font-size:13px;font-family:var(--font-accent)}.footer__links{gap:28px;list-style:none;display:flex}.footer__links a{color:var(--text-sub);font-size:13px;font-family:var(--font-accent);transition:color var(--transition);text-decoration:none}.footer__links a:hover{color:var(--text-muted)}.divider{background:linear-gradient(90deg, transparent, var(--border), transparent);width:100%;height:1px;margin:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media (width<=768px){.navbar{padding:14px 20px}.navbar__links{display:none}.preview-card__inner{grid-template-columns:1fr}.preview-panel:first-child{border-right:none;border-bottom:1px solid var(--border)}.steps-grid{grid-template-columns:1fr}.features-grid{grid-template-columns:repeat(2,1fr)}.pricing-grid{grid-template-columns:1fr}.footer{text-align:center;flex-direction:column;gap:16px}}@media (width<=480px){.features-grid{grid-template-columns:1fr}.hero__cta-group{flex-direction:column;width:100%}.btn-primary,.btn-secondary{justify-content:center;width:100%}.waitlist-form{border-radius:var(--radius);flex-direction:column;padding:12px}.waitlist-form .btn-primary{justify-content:center;width:100%}}.auth-page{background:var(--bg);min-height:100vh;font-family:var(--font-body);justify-content:center;align-items:center;padding:24px;display:flex;position:relative;overflow:hidden}.auth-page__glow{pointer-events:none;z-index:0;background:radial-gradient(#6d67ff24 0%,#a45dff0f 40%,#0000 70%);width:900px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.auth-stars{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.auth-star{opacity:0;animation:authTwinkle var(--s-dur,4s) var(--s-delay,0s) infinite;background:#fff;border-radius:50%;position:absolute}@keyframes authTwinkle{0%,to{opacity:0}50%{opacity:var(--s-op,.4)}}.auth-branding{z-index:1;flex-direction:column;justify-content:center;padding:60px 48px;display:flex;position:relative}.auth-branding__logo{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;align-items:center;gap:10px;margin-bottom:52px;font-size:26px;font-weight:700;text-decoration:none;display:inline-flex}.auth-branding__logo .spark{color:var(--purple);font-size:16px}.auth-branding__headline{font-family:var(--font-heading);letter-spacing:-.03em;color:var(--text);margin-bottom:18px;font-size:clamp(32px,3.5vw,44px);font-weight:700;line-height:1.15}.auth-branding__headline .grad{background:linear-gradient(135deg, var(--violet) 0%, var(--purple) 60%, #ff6bff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.auth-branding__sub{color:var(--text-muted);max-width:360px;margin-bottom:48px;font-size:16px;line-height:1.7}.auth-branding__pills{flex-direction:column;gap:12px;display:flex}.auth-pill{border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);background:#ffffff08;align-items:center;gap:12px;padding:14px 18px;display:flex}.auth-pill:hover{border-color:var(--border-bright);background:#6d67ff12;transform:translate(4px)}.auth-pill__icon{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--violet-dim), var(--purple-dim));border:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.auth-pill__text{font-size:13px;font-family:var(--font-accent);color:var(--text-muted);font-weight:500}.auth-divider{background:linear-gradient(to bottom, transparent, var(--border), transparent);flex-shrink:0;align-self:stretch;width:1px}.auth-form-col{z-index:1;flex-direction:column;justify-content:center;min-width:0;padding:60px 48px;display:flex;position:relative}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;padding:44px 40px;position:relative;overflow:hidden;box-shadow:0 40px 80px #0006,0 0 0 1px #ffffff05}.auth-card:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);height:1px;position:absolute;top:0;left:0;right:0}.auth-card:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(#6d67ff1f 0%,#0000 70%);width:300px;height:120px;position:absolute;top:-60px;left:50%;transform:translate(-50%)}.auth-card__header{text-align:center;z-index:1;margin-bottom:32px;position:relative}.auth-card__icon{border-radius:var(--radius);background:linear-gradient(135deg, var(--violet-dim), var(--purple-dim));border:1px solid var(--border-bright);justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 20px;font-size:22px;display:flex}.auth-card__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;margin-bottom:8px;font-size:26px;font-weight:700}.auth-card__subtitle{color:var(--text-muted);font-size:14px;line-height:1.5}.auth-tabs{border:1px solid var(--border);border-radius:var(--radius-pill);z-index:1;background:#ffffff08;margin-bottom:28px;padding:4px;display:flex;position:relative}.auth-tab{border-radius:var(--radius-pill);font-size:14px;font-family:var(--font-accent);color:var(--text-sub);cursor:pointer;transition:all var(--transition);background:0 0;border:none;flex:1;padding:10px;font-weight:600}.auth-tab--active{background:linear-gradient(135deg, var(--violet), var(--purple));color:var(--textbtn);box-shadow:0 2px 12px #a45dff4d}.auth-tab:not(.auth-tab--active):hover{color:var(--text-muted)}.auth-form{z-index:1;flex-direction:column;gap:16px;display:flex;position:relative}.auth-field{flex-direction:column;gap:7px;display:flex}.auth-label{font-size:12px;font-family:var(--font-accent);letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase;font-weight:600}.auth-input-wrap{align-items:center;display:flex;position:relative}.auth-input-icon{color:var(--text-sub);pointer-events:none;transition:color var(--transition);z-index:1;font-size:14px;position:absolute;left:14px}.auth-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:14px;font-family:var(--font-body);color:var(--text);transition:all var(--transition);-webkit-appearance:none;background:#ffffff0a;outline:none;padding:13px 14px 13px 40px}.auth-input::placeholder{color:var(--text-sub)}.auth-input:focus{border-color:var(--purple);background:#a45dff0f;box-shadow:0 0 0 3px #a45dff26}.auth-input:focus~.auth-input-icon,.auth-input-wrap:focus-within .auth-input-icon{color:var(--purple)}.auth-input:hover:not(:focus){background:#ffffff0d;border-color:#6d67ff59}.auth-pw-toggle{color:var(--text-sub);cursor:pointer;font-size:13px;font-family:var(--font-accent);letter-spacing:.04em;border-radius:var(--radius-sm);transition:color var(--transition);z-index:2;background:0 0;border:none;padding:4px 6px;font-weight:600;position:absolute;right:14px}.auth-pw-toggle:hover{color:var(--text-muted)}.auth-error{border-radius:var(--radius-sm);color:#ff7070;font-size:13px;font-family:var(--font-body);background:#ff3c3c14;border:1px solid #ff3c3c40;align-items:center;gap:8px;padding:10px 14px;line-height:1.4;animation:.35s shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.auth-submit{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-pill);width:100%;font-family:var(--font-accent);color:var(--textbtn);cursor:pointer;transition:all var(--transition);border:none;margin-top:4px;padding:14px;font-size:15px;font-weight:700;position:relative;overflow:hidden;box-shadow:0 4px 24px #a45dff4d}.auth-submit:before{content:"";opacity:0;transition:opacity var(--transition);background:linear-gradient(135deg,#ffffff26,#0000);position:absolute;inset:0}.auth-submit:hover:before{opacity:1}.auth-submit:hover{transform:translateY(-2px);box-shadow:0 8px 36px #a45dff80}.auth-submit:active{transform:translateY(0)scale(.98);box-shadow:0 2px 12px #a45dff4d}.auth-submit--loading{pointer-events:none;opacity:.7}.auth-submit--loading:after{content:"";vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;margin-left:10px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.auth-toggle{text-align:center;color:var(--text-muted);z-index:1;margin-top:20px;font-size:14px;position:relative}.auth-toggle button{color:var(--purple);font-family:var(--font-body);cursor:pointer;transition:color var(--transition);text-underline-offset:3px;background:0 0;border:none;padding:0;font-size:14px;font-weight:600;-webkit-text-decoration:underline #a45dff66;text-decoration:underline #a45dff66}.auth-toggle button:hover{color:var(--textbtn);-webkit-text-decoration-color:var(--purple);text-decoration-color:var(--purple)}.auth-or{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.auth-or:before,.auth-or:after{content:"";background:var(--border);flex:1;height:1px}.auth-or span{font-size:12px;font-family:var(--font-accent);color:var(--text-sub);letter-spacing:.06em;white-space:nowrap;font-weight:600}.auth-form-enter{animation:.3s both formFadeIn}@keyframes formFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-outer{z-index:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);grid-template-columns:1fr auto 1fr;align-items:center;gap:0;width:100%;max-width:960px;display:grid;position:relative;overflow:hidden;box-shadow:0 60px 120px #00000080,0 0 0 1px #ffffff05}.auth-outer:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);z-index:1;pointer-events:none;height:1px;position:absolute;top:0;left:0;right:0}@media (width<=800px){.auth-outer{grid-template-columns:1fr;max-width:460px}.auth-branding,.auth-divider{display:none}.auth-form-col{padding:40px 32px}}@media (width<=480px){.auth-page{align-items:flex-start;padding:40px 16px 16px}.auth-form-col{padding:32px 24px}.auth-card{padding:36px 24px}}.onboarding-page{background:var(--bg);min-height:100vh;font-family:var(--font-body);flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex;position:relative;overflow:hidden}.onboarding-page__glow{pointer-events:none;z-index:0;background:radial-gradient(#6d67ff29 0%,#a45dff12 45%,#0000 70%);width:900px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-55%)}.onboarding-stars{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.ob-star{opacity:0;animation:obTwinkle var(--sd,4s) var(--dl,0s) infinite;background:#fff;border-radius:50%;position:absolute}@keyframes obTwinkle{0%,to{opacity:0}50%{opacity:var(--op,.4)}}.onboarding-logo{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;z-index:10;align-items:center;gap:8px;font-size:20px;font-weight:700;text-decoration:none;display:flex;position:absolute;top:28px;left:40px}.onboarding-progress{z-index:1;flex-direction:column;gap:10px;width:100%;max-width:520px;margin-bottom:32px;display:flex;position:relative}.progress-meta{justify-content:space-between;align-items:center;display:flex}.progress-label{font-size:12px;font-family:var(--font-accent);letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;font-weight:600}.progress-step-count{font-size:12px;font-family:var(--font-accent);color:var(--purple);letter-spacing:.04em;font-weight:700}.progress-track{border-radius:var(--radius-pill);background:#ffffff12;width:100%;height:4px;overflow:hidden}.progress-fill{border-radius:var(--radius-pill);background:linear-gradient(90deg, var(--violet), var(--purple));height:100%;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px #a45dff80}.progress-dots{justify-content:center;align-items:center;gap:8px;display:flex}.progress-dot{border:1px solid var(--border);background:#ffffff1f;border-radius:50%;width:8px;height:8px;transition:all .3s}.progress-dot--active{background:var(--purple);border-color:var(--purple);transform:scale(1.2);box-shadow:0 0 8px #a45dff99}.progress-dot--done{background:var(--violet);border-color:var(--violet)}.step-card{z-index:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:520px;padding:44px 40px 36px;position:relative;overflow:hidden;box-shadow:0 40px 80px #0006,0 0 0 1px #ffffff05}.step-card:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);height:1px;position:absolute;top:0;left:0;right:0}.step-enter{animation:.38s cubic-bezier(.4,0,.2,1) both slideInRight}.step-exit{animation:.28s cubic-bezier(.4,0,.2,1) both slideOutLeft}.step-enter-back{animation:.38s cubic-bezier(.4,0,.2,1) both slideInLeft}.step-exit-back{animation:.28s cubic-bezier(.4,0,.2,1) both slideOutRight}@keyframes slideInRight{0%{opacity:0;transform:translate(48px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-48px)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-48px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(48px)}}.step-card__icon{border-radius:var(--radius);background:linear-gradient(135deg, var(--violet-dim), var(--purple-dim));border:1px solid var(--border-bright);justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:20px;font-size:22px;display:flex}.step-card__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;margin-bottom:6px;font-size:24px;font-weight:700}.step-card__subtitle{color:var(--text-muted);margin-bottom:28px;font-size:14px;line-height:1.5}.ob-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-size:15px;font-family:var(--font-body);color:var(--text);transition:all var(--transition);-webkit-appearance:none;background:#ffffff0a;outline:none;padding:14px 16px}.ob-input::placeholder{color:var(--text-sub)}.ob-input:focus{border-color:var(--purple);background:#a45dff0f;box-shadow:0 0 0 3px #a45dff26}.ob-input:hover:not(:focus){border-color:#6d67ff59}.ob-textarea{resize:none;min-height:110px;line-height:1.6}.ob-time-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px;display:grid}.ob-time-btn{border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-accent);color:var(--text-muted);cursor:pointer;transition:all var(--transition);text-align:center;background:#ffffff0a;flex-direction:column;align-items:center;gap:4px;padding:14px 10px;font-size:14px;font-weight:600;display:flex}.ob-time-btn .time-value{font-family:var(--font-heading);color:var(--text);font-size:22px;font-weight:700;line-height:1}.ob-time-btn .time-unit{color:var(--text-sub);letter-spacing:.06em;text-transform:uppercase;font-size:11px}.ob-time-btn:hover{border-color:var(--border-bright);background:var(--violet-dim);color:var(--text)}.ob-time-btn--selected{border-color:var(--purple);color:var(--text);box-shadow:0 0 0 1px var(--purple), 0 4px 16px #a45dff33;background:linear-gradient(135deg,#6d67ff26,#a45dff1a)}.ob-time-btn--selected .time-unit{color:var(--purple)}.ob-section-label{font-size:12px;font-family:var(--font-accent);letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;font-weight:600;display:block}.ob-field-gap{margin-top:20px}.pet-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.pet-card{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);text-align:center;background:#ffffff08;flex-direction:column;align-items:center;gap:10px;padding:18px 16px;display:flex;position:relative}.pet-card:hover{border-color:var(--border-bright);background:#6d67ff12;transform:translateY(-2px)}.pet-card--selected{border-color:var(--purple);box-shadow:0 0 0 1px var(--purple), 0 6px 20px #a45dff2e;background:linear-gradient(135deg,#6d67ff1f,#a45dff14)}.pet-card--selected:after{content:"✓";background:var(--purple);color:#fff;text-align:center;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;line-height:20px;display:flex;position:absolute;top:10px;right:10px}.pet-sprite{filter:drop-shadow(0 4px 12px #a45dff4d);justify-content:center;align-items:center;width:64px;height:64px;font-size:42px;animation:3s ease-in-out infinite petFloat;display:flex}@keyframes petFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.pet-name{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;font-size:15px;font-weight:700}.pet-desc{color:var(--text-muted);font-size:11px;line-height:1.4}.step-card__actions{align-items:center;gap:12px;margin-top:32px;display:flex}.ob-btn-back{border:1px solid var(--border);border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;flex-shrink:0;padding:13px 20px;font-size:14px;font-weight:600}.ob-btn-back:hover{color:var(--text);border-color:var(--border-bright);background:var(--violet-dim)}.ob-btn-next{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--textbtn);cursor:pointer;transition:all var(--transition);border:none;flex:1;padding:14px;font-size:15px;font-weight:700;position:relative;overflow:hidden;box-shadow:0 4px 20px #a45dff4d}.ob-btn-next:before{content:"";opacity:0;transition:opacity var(--transition);background:linear-gradient(135deg,#ffffff24,#0000);position:absolute;inset:0}.ob-btn-next:hover:before{opacity:1}.ob-btn-next:hover{transform:translateY(-2px);box-shadow:0 8px 32px #a45dff73}.ob-btn-next:active{transform:translateY(0)scale(.98)}.ob-btn-next:disabled{opacity:.4;pointer-events:none;box-shadow:none}.loading-card{z-index:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:520px;padding:44px 40px;animation:.38s cubic-bezier(.4,0,.2,1) both slideInRight;position:relative;overflow:hidden;box-shadow:0 40px 80px #0006}.loading-card:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);height:1px;position:absolute;top:0;left:0;right:0}.loading-card__orb{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 24px;font-size:26px;animation:1.8s ease-in-out infinite orbPulse;display:flex;box-shadow:0 0 #a45dff66}@keyframes orbPulse{0%{transform:scale(1);box-shadow:0 0 #a45dff80}50%{transform:scale(1.06);box-shadow:0 0 0 16px #a45dff00}to{transform:scale(1);box-shadow:0 0 #a45dff00}}.loading-card__status{text-align:center;font-family:var(--font-accent);color:var(--text-muted);min-height:24px;margin-bottom:32px;font-size:15px;font-weight:600;transition:opacity .3s}.skeleton-lines{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.skeleton-line{border-radius:var(--radius-pill);background:linear-gradient(90deg,#ffffff0a 0%,#6d67ff26 40%,#ffffff0a 80%) 0 0/200% 100%;height:14px;animation:1.8s linear infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line--w100{width:100%}.skeleton-line--w80{width:80%}.skeleton-line--w90{width:90%}.skeleton-line--w60{width:60%}.skeleton-line--w70{width:70%}.skeleton-blocks{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.skeleton-block{border-radius:var(--radius-sm);background:linear-gradient(90deg,#ffffff0a 0%,#6d67ff1f 40%,#ffffff0a 80%) 0 0/200% 100%;height:60px;animation:1.8s linear infinite shimmer}.skeleton-block:nth-child(2){animation-delay:.2s}.skeleton-block:nth-child(3){animation-delay:.4s}@media (width<=580px){.onboarding-page{padding:72px 16px 16px}.step-card{padding:32px 24px 28px}.loading-card{padding:36px 24px}.pet-grid{grid-template-columns:repeat(2,1fr)}.ob-time-grid{gap:8px}}@media (width<=360px){.pet-grid{grid-template-columns:1fr}}:root{--bg:#060815;--bg-card:#0d1025;--bg-card-hover:#111430;--purple:#a45dff;--violet:#6d67ff;--violet-dim:#6d67ff26;--purple-dim:#a45dff1f;--text:#fff;--textbtn:#f0ecff;--text-muted:#ffffff8c;--text-sub:#ffffff59;--border:#6d67ff33;--border-bright:#a45dff66;--font-heading:"Sora", sans-serif;--font-body:"Inter", sans-serif;--font-accent:"Space Grotesk", sans-serif;--radius:14px;--radius-sm:8px;--radius-lg:20px;--radius-pill:100px;--transition:.25s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.6;overflow-x:hidden}.dashboard{background:var(--bg);flex-direction:column;min-height:100vh;display:flex;position:relative;overflow:hidden}.dashboard:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(#6d67ff1a 0%,#a45dff0a 50%,#0000 70%);width:1000px;height:600px;position:fixed;top:-200px;left:50%;transform:translate(-50%)}.topbar{z-index:50;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#060815cc;justify-content:space-between;align-items:center;gap:16px;height:64px;padding:0 32px;display:flex;position:sticky;top:0}.topbar__logo{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;flex-shrink:0;align-items:center;gap:8px;font-size:20px;font-weight:700;text-decoration:none;display:flex}.topbar__logo .spark{color:var(--purple);font-size:13px}.topbar__center{flex:1;align-items:center;gap:20px;max-width:420px;margin:0 auto;display:flex}.streak-pill{border-radius:var(--radius-pill);background:#ffa0321a;border:1px solid #ffa03240;flex-shrink:0;align-items:center;gap:5px;padding:6px 14px;display:flex}.streak-pill__icon{font-size:16px;line-height:1}.streak-pill__count{font-family:var(--font-heading);color:#fa3;letter-spacing:-.01em;font-size:15px;font-weight:700}.xp-bar-wrap{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.xp-bar-track{border-radius:var(--radius-pill);background:#ffffff12;border:1px solid #ffffff0f;flex:1;height:10px;overflow:hidden}.xp-bar-fill{background:linear-gradient(90deg, var(--violet), var(--purple), #c87dff);border-radius:var(--radius-pill);height:100%;transition:width 1s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.xp-bar-shine{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:60%;height:100%;animation:2.5s ease-in-out infinite barShine;position:absolute;top:0;left:-100%}@keyframes barShine{0%{left:-100%}60%,to{left:150%}}.xp-bar-text{font-size:11px;font-family:var(--font-accent);color:var(--text-sub);white-space:nowrap;flex-shrink:0;font-weight:600}.topbar__user{border:1px solid var(--border);border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition);background:#ffffff0a;flex-shrink:0;align-items:center;gap:10px;padding:6px 14px 6px 8px;display:flex}.topbar__user:hover{border-color:var(--border-bright);background:#6d67ff1a}.topbar__avatar{background:linear-gradient(135deg, var(--violet), var(--purple));width:30px;height:30px;color:var(--textbtn);font-size:13px;font-weight:700;font-family:var(--font-heading);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.topbar__username{font-family:var(--font-accent);color:var(--text);font-size:14px;font-weight:600}.dashboard__main{z-index:1;flex:1;display:flex;position:relative}.lesson-map{flex-direction:column;flex:1;align-items:center;padding:48px 24px 80px;display:flex;position:relative}.map-section-header{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius);justify-content:space-between;align-items:center;width:100%;max-width:520px;margin-bottom:40px;padding:16px 28px;display:flex;box-shadow:0 8px 32px #6d67ff4d}.map-section-header__info{flex-direction:column;gap:2px;display:flex}.map-section-header__label{font-size:11px;font-family:var(--font-accent);letter-spacing:.1em;color:#ffffffb3;text-transform:uppercase;font-weight:600}.map-section-header__title{font-family:var(--font-heading);color:#fff;letter-spacing:-.01em;font-size:18px;font-weight:700}.map-section-header__guide{border-radius:var(--radius-pill);font-family:var(--font-accent);color:#fff;cursor:pointer;transition:background var(--transition);background:#ffffff26;border:none;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:700;display:flex}.map-section-header__guide:hover{background:#ffffff38}.path-container{flex-direction:column;align-items:center;gap:0;width:340px;display:flex;position:relative}.lesson-node-wrap{flex-direction:column;align-items:center;width:100%;margin-bottom:8px;display:flex;position:relative}.lesson-node-wrap:first-child{transform:translate(0)}.lesson-node-wrap:nth-child(2){transform:translate(60px)}.lesson-node-wrap:nth-child(3){transform:translate(90px)}.lesson-node-wrap:nth-child(4){transform:translate(20px)}.lesson-node-wrap:nth-child(5){transform:translate(-60px)}.lesson-node-wrap:nth-child(6){transform:translate(-80px)}.lesson-node-wrap:nth-child(7){transform:translate(0)}.lesson-node-wrap:nth-child(8){margin-top:24px;transform:translate(0)}.path-svg{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0;overflow:visible}.path-line{fill:none;stroke:#6d67ff4d;stroke-width:3px;stroke-dasharray:8 6;stroke-linecap:round;animation:2s linear infinite dashFlow}.path-line--completed{stroke:#6d67ff99;stroke-dasharray:none}@keyframes dashFlow{0%{stroke-dashoffset:0}to{stroke-dashoffset:-28px}}.lesson-node-center{z-index:2;justify-content:center;align-items:center;display:flex;position:relative}.lesson-node{cursor:pointer;width:72px;height:72px;transition:all var(--transition);-webkit-appearance:none;border:none;border-radius:50%;outline:none;justify-content:center;align-items:center;font-size:24px;display:flex;position:relative}.lesson-node--completed{background:linear-gradient(135deg, var(--violet), var(--purple));color:#fff;border:3px solid #6d67ff99;box-shadow:0 6px 24px #6d67ff59,0 0 0 4px #6d67ff1a}.lesson-node--completed:hover{transform:scale(1.08);box-shadow:0 8px 32px #6d67ff80,0 0 0 6px #6d67ff26}.lesson-node--current{background:linear-gradient(135deg, var(--purple), #c87dff);border:3px solid var(--purple);color:#fff;box-shadow:0 6px 28px #a45dff73,0 0 0 6px #a45dff26}.lesson-node--current:hover{transform:scale(1.08)}.lesson-node--locked{color:#ffffff40;cursor:not-allowed;box-shadow:none;background:#ffffff0a;border:3px solid #ffffff1a}.lesson-node__pulse{border:2px solid var(--purple);pointer-events:none;border-radius:50%;animation:1.8s ease-out infinite pulseRing;position:absolute;inset:-6px}@keyframes pulseRing{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}.lesson-node__pulse:after{content:"";border:2px solid #a45dff66;border-radius:50%;animation:1.8s ease-out .6s infinite pulseRing;position:absolute;inset:-8px}.lesson-node__icon{z-index:1;font-size:22px;font-style:normal;line-height:1;position:relative}.lesson-node__label{font-family:var(--font-accent);text-align:center;max-width:100px;margin-top:10px;font-size:12px;font-weight:600;line-height:1.3}.lesson-node__label--completed{color:#6d67ffcc}.lesson-node__label--current{color:var(--purple);text-shadow:0 0 12px #a45dff66}.lesson-node__label--locked{color:var(--text-sub)}.lesson-tooltip{background:var(--bg-card);border:1px solid var(--border-bright);border-radius:var(--radius-sm);pointer-events:none;z-index:20;white-space:normal;flex-direction:column;gap:4px;min-width:160px;max-width:220px;padding:10px 14px;animation:.18s both tooltipIn;display:flex;position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0006}.lesson-tooltip:after{content:"";border:6px solid #0000;border-top-color:var(--bg-card);position:absolute;top:100%;left:50%;transform:translate(-50%)}@keyframes tooltipIn{0%{opacity:0;transform:translate(-50%)translateY(6px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.lesson-tooltip__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;font-size:13px;font-weight:700}.lesson-tooltip__desc{color:var(--text-muted);font-size:11px;line-height:1.4}.lesson-node__pet{z-index:10;pointer-events:none;position:absolute;top:-72px;left:50%;transform:translate(-50%)}.pet-avatar{flex-direction:column;align-items:center;gap:2px;display:flex;position:relative}.pet-avatar__sprite{filter:drop-shadow(0 4px 16px #a45dff80);font-size:40px;line-height:1;animation:3s ease-in-out infinite petIdle;display:block}@keyframes petIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.pet-avatar__level{font-family:var(--font-accent);color:#fff;border-radius:var(--radius-pill);letter-spacing:.04em;padding:2px 6px;font-size:9px;font-weight:700;line-height:1.4}.pet-avatar__shadow{background:radial-gradient(#a45dff4d 0%,#0000 70%);border-radius:50%;width:32px;height:8px;margin-top:-4px;animation:3s ease-in-out infinite shadowPulse}@keyframes shadowPulse{0%,to{opacity:.8;transform:scaleX(1)}50%{opacity:.4;transform:scaleX(.6)}}.pro-chat-btn-wrap{z-index:5;position:absolute;top:50%;left:-56px;transform:translateY(-50%)}.pro-chat-btn{background:linear-gradient(135deg, var(--violet-dim), var(--purple-dim));border:1px solid var(--border-bright);width:32px;height:32px;color:var(--purple);cursor:pointer;transition:all var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:13px;line-height:1;display:flex}.pro-chat-btn:hover{border-color:var(--purple);background:linear-gradient(135deg,#6d67ff4d,#a45dff33);transform:scale(1.12);box-shadow:0 0 12px #a45dff4d}.pro-chat-btn--active{background:linear-gradient(135deg, var(--violet), var(--purple));color:#fff;border-color:#0000;box-shadow:0 4px 16px #a45dff66}.ai-chat-panel{background:var(--bg-card);border:1px solid var(--border-bright);border-radius:var(--radius);z-index:50;width:260px;animation:.2s both chatSlideIn;position:absolute;top:50%;left:calc(100% + 10px);overflow:hidden;transform:translateY(-50%);box-shadow:0 16px 48px #00000080}@keyframes chatSlideIn{0%{opacity:0;transform:translateY(-50%)translate(-10px)}to{opacity:1;transform:translateY(-50%)translate(0)}}.ai-chat-panel__header{border-bottom:1px solid var(--border);background:linear-gradient(135deg,#6d67ff33,#a45dff26);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.ai-chat-panel__title{font-family:var(--font-accent);color:var(--purple);letter-spacing:.02em;font-size:13px;font-weight:700}.ai-chat-panel__close{width:22px;height:22px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:#ffffff12;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:10px;display:flex}.ai-chat-panel__close:hover{color:#ff7070;background:#ff3c3c26}.ai-chat-panel__messages{min-height:80px;padding:14px}.ai-chat-bubble{color:var(--text-muted);border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff0a;padding:10px 12px;font-size:13px;line-height:1.5}.ai-chat-bubble--ai strong{color:var(--purple)}.ai-chat-panel__input-row{border-top:1px solid var(--border);gap:8px;padding:10px;display:flex}.ai-chat-input{border:1px solid var(--border);border-radius:var(--radius-pill);font-size:12px;font-family:var(--font-body);color:var(--text);background:#ffffff0a;outline:none;flex:1;min-width:0;padding:8px 12px}.ai-chat-input::placeholder{color:var(--text-sub)}.ai-chat-send{background:linear-gradient(135deg, var(--violet), var(--purple));color:#fff;cursor:pointer;width:30px;height:30px;transition:opacity var(--transition);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.ai-chat-send:hover{opacity:.85}.boss-node-wrap{flex-direction:column;align-items:center;width:100%;padding-top:16px;display:flex;position:relative}.boss-divider{background:linear-gradient(90deg,#0000,#ff50504d,#0000);width:80%;height:1px;margin-bottom:24px}.boss-label-chip{border-radius:var(--radius-pill);font-size:11px;font-family:var(--font-accent);color:#ff7070;letter-spacing:.08em;text-transform:uppercase;background:#ff50501a;border:1px solid #ff50504d;align-items:center;gap:6px;margin-bottom:16px;padding:5px 14px;font-weight:700;display:inline-flex}.boss-node{background:radial-gradient(135deg at 30% 30%, #ff50504d, #b41e1e80);cursor:pointer;width:88px;height:88px;transition:all var(--transition);border:3px solid #ff505080;border-radius:50%;outline:none;justify-content:center;align-items:center;font-size:32px;animation:4s ease-in-out infinite bossFlicker;display:flex;position:relative;box-shadow:0 0 0 6px #ff50501a,0 8px 32px #ff32324d}.boss-node:hover{transform:scale(1.06);box-shadow:0 0 0 8px #ff505026,0 12px 40px #ff323273}@keyframes bossFlicker{0%,90%,to{box-shadow:0 0 0 6px #ff50501a,0 8px 32px #ff32324d}92%{box-shadow:0 0 0 10px #ff505033,0 8px 40px #ff323299}95%{box-shadow:0 0 0 6px #ff50501a,0 8px 32px #ff32324d}}.boss-node__label{font-family:var(--font-heading);color:#ff7070;letter-spacing:-.01em;margin-top:12px;font-size:14px;font-weight:700}.boss-node__sub{color:#ff707099;font-size:12px;font-family:var(--font-accent);margin-top:4px}.dashboard__sidebar{border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:20px;width:300px;height:calc(100vh - 64px);padding:32px 24px;display:flex;position:sticky;top:64px;overflow-y:auto}.dashboard__sidebar::-webkit-scrollbar{width:4px}.dashboard__sidebar::-webkit-scrollbar-track{background:0 0}.dashboard__sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-pill)}.sidebar-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition);padding:18px 16px}.sidebar-card:hover{border-color:var(--border-bright)}.sidebar-card__title{font-family:var(--font-accent);color:var(--text);letter-spacing:.02em;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:13px;font-weight:700;display:flex}.sidebar-card__title .view-all{color:var(--purple);cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:color var(--transition);background:0 0;border:none;padding:0;font-size:11px;font-weight:600}.sidebar-card__title .view-all:hover{color:var(--textbtn)}.quest-item{border-bottom:1px solid #ffffff0a;align-items:center;gap:12px;padding:10px 0;display:flex}.quest-item:last-child{border-bottom:none;padding-bottom:0}.quest-icon{border-radius:var(--radius-sm);background:#ffc8001a;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.quest-info{flex:1;min-width:0}.quest-name{color:var(--text);font-size:13px;font-weight:600;font-family:var(--font-accent);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;overflow:hidden}.quest-progress-bar{border-radius:var(--radius-pill);background:#ffffff12;height:6px;overflow:hidden}.quest-progress-fill{border-radius:var(--radius-pill);background:linear-gradient(90deg,gold,#fa3);height:100%;transition:width 1s}.quest-reward{color:#fa3;font-size:11px;font-family:var(--font-accent);flex-shrink:0;font-weight:700}.pro-banner{border:1px solid var(--border-bright);border-radius:var(--radius);background:linear-gradient(135deg,#6d67ff33,#a45dff1a);padding:18px 16px;position:relative;overflow:hidden}.pro-banner:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);height:1px;position:absolute;top:0;left:0;right:0}.pro-banner__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;margin-bottom:6px;font-size:16px;font-weight:700}.pro-banner__desc{color:var(--text-muted);margin-bottom:14px;font-size:12px;line-height:1.5}.pro-banner__btn{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-pill);width:100%;font-family:var(--font-accent);color:var(--textbtn);cursor:pointer;transition:all var(--transition);border:none;padding:11px;font-size:13px;font-weight:700;box-shadow:0 4px 16px #a45dff4d}.pro-banner__btn:hover{opacity:.9;transform:translateY(-1px)}@media (width<=1024px){.dashboard__sidebar{display:none}}@media (width<=640px){.topbar{padding:0 16px}.topbar__center{display:none}.lesson-node-wrap:first-child,.lesson-node-wrap:nth-child(2),.lesson-node-wrap:nth-child(3),.lesson-node-wrap:nth-child(4),.lesson-node-wrap:nth-child(5),.lesson-node-wrap:nth-child(6),.lesson-node-wrap:nth-child(7),.lesson-node-wrap:nth-child(8){transform:translate(0)}.path-container{width:280px}.pro-chat-btn-wrap{left:-44px}.ai-chat-panel{width:230px;left:auto;right:calc(100% + 8px)}.lesson-map{padding:32px 16px 60px}}.lesson-page{background:var(--bg);min-height:100vh;font-family:var(--font-body);flex-direction:column;display:flex;position:relative;overflow-x:hidden}.lesson-page:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(#6d67ff17 0%,#a45dff0a 50%,#0000 70%);width:900px;height:500px;position:fixed;top:-200px;left:50%;transform:translate(-50%)}.lesson-topbar{z-index:40;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#060815d9;align-items:center;gap:20px;height:60px;padding:0 32px;display:flex;position:sticky;top:0}.lesson-topbar__back{color:var(--text-muted);font-family:var(--font-accent);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;flex-shrink:0;align-items:center;gap:6px;padding:6px 10px;font-size:13px;font-weight:600;display:flex}.lesson-topbar__back:hover{color:var(--text);background:#ffffff0d}.lesson-topbar__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;flex:1;font-size:15px;font-weight:700}.lesson-topbar__phases{flex-shrink:0;align-items:center;gap:6px;display:flex}.phase-dot{border:1px solid var(--border);background:#ffffff1f;border-radius:50%;width:8px;height:8px;transition:all .3s}.phase-dot--active{background:var(--purple);border-color:var(--purple);transform:scale(1.2);box-shadow:0 0 8px #a45dff80}.phase-dot--done{background:var(--violet);border-color:var(--violet)}.phase-label{font-family:var(--font-accent);color:var(--text-sub);letter-spacing:.06em;text-transform:uppercase;margin-left:4px;font-size:11px;font-weight:600}.phase-label--active{color:var(--purple)}.lesson-main{z-index:1;flex-direction:column;flex:1;align-items:center;padding:48px 24px 120px;display:flex;position:relative}.phase-enter{animation:.4s cubic-bezier(.4,0,.2,1) both phaseIn}@keyframes phaseIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lesson-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:680px;position:relative;overflow:hidden;box-shadow:0 32px 64px #0006,0 0 0 1px #ffffff05}.lesson-card:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);z-index:1;pointer-events:none;height:1px;position:absolute;top:0;left:0;right:0}.material-card__body{padding:40px 40px 32px}.material-card__phase-badge{background:var(--violet-dim);border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--violet);letter-spacing:.08em;text-transform:uppercase;border:1px solid #6d67ff4d;align-items:center;gap:7px;margin-bottom:20px;padding:5px 14px;font-size:11px;font-weight:700;display:inline-flex}.material-card__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;margin-bottom:24px;font-size:clamp(22px,3vw,30px);font-weight:700;line-height:1.2}.material-card__paragraphs{flex-direction:column;gap:16px;margin-bottom:28px;display:flex}.material-card__p{color:var(--text-muted);font-size:15px;line-height:1.75}.material-card__summary{border:1px solid var(--border-bright);border-radius:var(--radius);background:linear-gradient(135deg,#6d67ff1a,#a45dff0f);padding:18px 20px;position:relative;overflow:hidden}.material-card__summary:before{content:"";background:linear-gradient(to bottom, var(--violet), var(--purple));width:3px;position:absolute;top:0;bottom:0;left:0}.material-card__summary-label{font-family:var(--font-accent);letter-spacing:.1em;color:var(--purple);text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:700}.material-card__summary-text{color:var(--text);font-size:14px;line-height:1.6;font-family:var(--font-accent);font-weight:500}.lesson-card__footer{border-top:1px solid #ffffff0a;justify-content:flex-end;padding:20px 40px 32px;display:flex}.lesson-btn-primary{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--textbtn);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:8px;padding:13px 28px;font-size:14px;font-weight:700;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #a45dff4d}.lesson-btn-primary:before{content:"";opacity:0;transition:opacity var(--transition);background:linear-gradient(135deg,#ffffff24,#0000);position:absolute;inset:0}.lesson-btn-primary:hover:before{opacity:1}.lesson-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px #a45dff73}.lesson-btn-primary:active{transform:translateY(0)scale(.98)}.lesson-btn-primary:disabled{opacity:.4;pointer-events:none;box-shadow:none}.quiz-card__header{padding:32px 40px 0}.quiz-progress{align-items:center;gap:14px;margin-bottom:28px;display:flex}.quiz-progress__track{border-radius:var(--radius-pill);background:#ffffff12;flex:1;height:6px;overflow:hidden}.quiz-progress__fill{background:linear-gradient(90deg, var(--violet), var(--purple));border-radius:var(--radius-pill);height:100%;transition:width .5s cubic-bezier(.4,0,.2,1);box-shadow:0 0 10px #a45dff66}.quiz-progress__label{font-family:var(--font-accent);color:var(--purple);white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:700}.quiz-card__question{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;margin-bottom:28px;font-size:clamp(18px,2.5vw,24px);font-weight:700;line-height:1.3}.quiz-card__options{flex-direction:column;gap:10px;margin-bottom:8px;padding:0 40px;display:flex}.quiz-option{border:1px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--font-body);color:var(--text-muted);cursor:pointer;text-align:left;transition:all var(--transition);background:#ffffff08;align-items:center;gap:14px;padding:15px 20px;font-size:14px;font-weight:500;display:flex;position:relative}.quiz-option__num{border:1px solid var(--border);width:24px;height:24px;font-family:var(--font-accent);color:var(--text-sub);transition:all var(--transition);background:#ffffff0f;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.quiz-option:hover:not(:disabled){border-color:var(--border-bright);color:var(--text);background:#6d67ff14;transform:translate(4px)}.quiz-option:hover:not(:disabled) .quiz-option__num{background:var(--violet-dim);border-color:var(--violet);color:var(--violet)}.quiz-option:disabled{cursor:default}.quiz-option--correct{animation:.5s correctGlow;color:#4dff91!important;background:#4dff9114!important;border-color:#4dff9180!important}.quiz-option--correct .quiz-option__num{color:#4dff91!important;background:#4dff9126!important;border-color:#4dff91!important}@keyframes correctGlow{0%{box-shadow:none}40%{box-shadow:0 0 0 4px #4dff9140,0 0 20px #4dff9133}to{box-shadow:0 0 0 2px #4dff9126}}.quiz-option--wrong{animation:.4s wrongShake;color:#ff7070!important;background:#ff505014!important;border-color:#ff505080!important}.quiz-option--wrong .quiz-option__num{color:#ff7070!important;background:#ff505026!important;border-color:#ff7070!important}@keyframes wrongShake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(7px)}45%{transform:translate(-6px)}60%{transform:translate(5px)}75%{transform:translate(-3px)}90%{transform:translate(2px)}}.quiz-option--dimmed{opacity:.35}.quiz-card__footer{border-top:1px solid #ffffff0a;justify-content:flex-end;align-items:center;min-height:84px;padding:20px 40px 32px;display:flex}.quiz-feedback{font-family:var(--font-accent);flex:1;font-size:13px;font-weight:600}.quiz-feedback--correct{color:#4dff91}.quiz-feedback--wrong{color:#ff7070}.question-enter{animation:.3s cubic-bezier(.4,0,.2,1) both phaseIn}.task-card__body{padding:40px 40px 32px}.task-card__phase-badge{border-radius:var(--radius-pill);font-family:var(--font-accent);color:#ffc83c;letter-spacing:.08em;text-transform:uppercase;background:#ffc83c14;border:1px solid #ffc83c40;align-items:center;gap:7px;margin-bottom:20px;padding:5px 14px;font-size:11px;font-weight:700;display:inline-flex}.task-card__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;margin-bottom:12px;font-size:clamp(20px,2.8vw,28px);font-weight:700;line-height:1.2}.task-card__desc{color:var(--text-muted);margin-bottom:28px;font-size:15px;line-height:1.7}.task-card__textarea-label{font-size:12px;font-family:var(--font-accent);letter-spacing:.07em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;font-weight:600;display:block}.task-card__textarea{border:1px solid var(--border);border-radius:var(--radius);width:100%;min-height:130px;font-family:var(--font-body);color:var(--text);resize:vertical;transition:all var(--transition);box-sizing:border-box;background:#ffffff08;outline:none;padding:14px 16px;font-size:14px;line-height:1.6}.task-card__textarea::placeholder{color:var(--text-sub)}.task-card__textarea:focus{border-color:var(--purple);background:#a45dff0d;box-shadow:0 0 0 3px #a45dff1f}.task-card__textarea:hover:not(:focus){border-color:#6d67ff59}.task-card__footer{border-top:1px solid #ffffff0a;justify-content:space-between;align-items:center;gap:16px;padding:20px 40px 32px;display:flex}.task-card__hint{color:var(--text-sub);font-size:12px;font-family:var(--font-accent);flex:1}.pro-tutor-trigger{z-index:100;background:linear-gradient(135deg, var(--violet), var(--purple));color:#fff;cursor:pointer;width:52px;height:52px;transition:all var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 24px #a45dff73,0 0 0 1px #a45dff33}.pro-tutor-trigger:hover{transform:scale(1.1)translateY(-2px);box-shadow:0 8px 36px #a45dff99,0 0 0 2px #a45dff4d}.pro-tutor-trigger:active{transform:scale(.96)}.pro-tutor-trigger:after{content:"";border:2px solid #a45dff66;border-radius:50%;animation:2.5s ease-out infinite tutorPulse;position:absolute;inset:-4px}@keyframes tutorPulse{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}.pro-tutor-trigger__tooltip{background:var(--bg-card);border:1px solid var(--border-bright);border-radius:var(--radius-sm);font-family:var(--font-accent);color:var(--text);white-space:nowrap;pointer-events:none;opacity:0;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s;position:absolute;bottom:calc(100% + 10px);right:0;transform:translateY(4px)}.pro-tutor-trigger:hover .pro-tutor-trigger__tooltip{opacity:1;transform:translateY(0)}.pro-chat-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background:#0006;animation:.25s both overlayIn;position:fixed;inset:0}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.pro-chat-panel{z-index:95;background:var(--bg-card);border-top:1px solid var(--border-bright);border-radius:20px 20px 0 0;flex-direction:column;max-width:680px;height:480px;margin:0 auto;animation:.35s cubic-bezier(.4,0,.2,1) both chatSlideUp;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -20px 60px #00000080}.pro-chat-panel:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);border-radius:20px 20px 0 0;height:1px;position:absolute;top:0;left:0;right:0}@keyframes chatSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.pro-chat-panel__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 24px 14px;display:flex}.pro-chat-panel__title-group{align-items:center;gap:10px;display:flex}.pro-chat-panel__avatar{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.pro-chat-panel__name{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;font-size:15px;font-weight:700}.pro-chat-panel__status{color:#4dff91;font-size:11px;font-family:var(--font-accent);align-items:center;gap:5px;font-weight:600;display:flex}.pro-chat-panel__status:before{content:"";background:#4dff91;border-radius:50%;width:6px;height:6px;display:block}.pro-chat-panel__close{width:30px;height:30px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:#ffffff0f;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.pro-chat-panel__close:hover{color:#ff7070;background:#ff3c3c26}.pro-chat-panel__messages{flex-direction:column;flex:1;gap:14px;padding:20px 24px;display:flex;overflow-y:auto}.pro-chat-panel__messages::-webkit-scrollbar{width:4px}.pro-chat-panel__messages::-webkit-scrollbar-track{background:0 0}.pro-chat-panel__messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-pill)}.chat-msg{gap:10px;max-width:88%;animation:.25s both msgIn;display:flex}@keyframes msgIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-msg--ai{align-self:flex-start}.chat-msg--user{flex-direction:row-reverse;align-self:flex-end}.chat-msg__bubble{font-size:14px;line-height:1.55;font-family:var(--font-body);border-radius:14px;padding:11px 15px}.chat-msg--ai .chat-msg__bubble{border:1px solid var(--border);color:var(--text-muted);background:#ffffff0d;border-bottom-left-radius:4px}.chat-msg--user .chat-msg__bubble{background:linear-gradient(135deg, var(--violet-dim), var(--purple-dim));border:1px solid var(--border-bright);color:var(--text);border-bottom-right-radius:4px}.chat-quick-chips{flex-wrap:wrap;flex-shrink:0;gap:8px;padding:0 24px 12px;display:flex}.chat-chip{border:1px solid var(--border);border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--text-muted);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:#6d67ff14;padding:7px 14px;font-size:12px;font-weight:600}.chat-chip:hover{border-color:var(--border-bright);color:var(--text);background:#6d67ff26}.pro-chat-panel__input-row{border-top:1px solid var(--border);flex-shrink:0;gap:10px;padding:12px 20px 20px;display:flex}.pro-chat-input{border:1px solid var(--border);border-radius:var(--radius-pill);font-size:14px;font-family:var(--font-body);color:var(--text);transition:all var(--transition);background:#ffffff0a;outline:none;flex:1;min-width:0;padding:11px 18px}.pro-chat-input::placeholder{color:var(--text-sub)}.pro-chat-input:focus{border-color:var(--purple);background:#a45dff0d;box-shadow:0 0 0 2px #a45dff1a}.pro-chat-send{background:linear-gradient(135deg, var(--violet), var(--purple));color:#fff;cursor:pointer;width:42px;height:42px;transition:all var(--transition);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 2px 12px #a45dff4d}.pro-chat-send:hover{transform:scale(1.08);box-shadow:0 4px 20px #a45dff80}.pro-chat-send:disabled{opacity:.4;pointer-events:none}.lesson-complete{text-align:center;padding:60px 40px}.lesson-complete__icon{background:linear-gradient(135deg,#4dff9133,#4dc8641a);border:2px solid #4dff9166;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 24px;animation:.5s cubic-bezier(.34,1.56,.64,1) both completePop;display:flex}@keyframes completePop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.lesson-complete__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;margin-bottom:10px;font-size:28px;font-weight:700}.lesson-complete__sub{color:var(--text-muted);margin-bottom:36px;font-size:15px;line-height:1.6}.xp-gained-badge{border:1px solid var(--border-bright);border-radius:var(--radius-pill);font-family:var(--font-heading);color:var(--purple);background:linear-gradient(135deg,#6d67ff26,#a45dff1a);align-items:center;gap:8px;margin-bottom:32px;padding:10px 24px;font-size:18px;font-weight:700;display:inline-flex}@media (width<=640px){.lesson-topbar{padding:0 16px}.lesson-topbar__phases{display:none}.lesson-main{padding:28px 16px 100px}.material-card__body,.quiz-card__header,.task-card__body{padding:28px 24px 20px}.quiz-card__options{padding:0 24px}.lesson-card__footer,.quiz-card__footer,.task-card__footer{padding:16px 24px 24px}.pro-chat-panel{border-radius:16px 16px 0 0;height:65vh}.pro-tutor-trigger{bottom:20px;right:20px}.task-card__footer{flex-direction:column;align-items:stretch}.task-card__hint{text-align:center}}.boss-page{background:var(--bg);min-height:100vh;font-family:var(--font-body);flex-direction:column;display:flex;position:relative;overflow:hidden}.boss-page:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(#ff323212 0%,#c81e1e08 50%,#0000 70%);width:800px;height:400px;position:fixed;bottom:-100px;left:50%;transform:translate(-50%)}.boss-page__flash{pointer-events:none;z-index:200;opacity:0;border-radius:0;position:fixed;inset:0}.boss-page__flash--correct{animation:.7s both flashCorrect;box-shadow:inset 0 0 80px #4dff9159,inset 0 0 160px #4dff9126}@keyframes flashCorrect{0%{opacity:0}20%{opacity:1}to{opacity:0}}.boss-page__flash--wrong{animation:.7s both flashWrong;box-shadow:inset 0 0 80px #ff3c3c59,inset 0 0 160px #ff3c3c26}@keyframes flashWrong{0%{opacity:0}20%{opacity:1}to{opacity:0}}.boss-topbar{z-index:40;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#060815d9;border-bottom:1px solid #ff3c3c26;justify-content:space-between;align-items:center;gap:16px;height:56px;padding:0 32px;display:flex;position:sticky;top:0}.boss-topbar__back{color:var(--text-muted);font-family:var(--font-accent);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;flex-shrink:0;align-items:center;gap:6px;padding:6px 10px;font-size:13px;font-weight:600;display:flex}.boss-topbar__back:hover{color:var(--text);background:#ffffff0d}.boss-topbar__title{font-family:var(--font-heading);color:#ff7070;letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.boss-topbar__question-count{font-family:var(--font-accent);color:var(--text-sub);letter-spacing:.04em;flex-shrink:0;font-size:12px;font-weight:700}.boss-main{z-index:1;flex-direction:column;flex:1;align-items:center;gap:28px;width:100%;max-width:860px;margin:0 auto;padding:32px 24px 60px;display:flex;position:relative}.battle-arena{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;width:100%;padding:28px 32px;display:grid;position:relative;overflow:hidden}.battle-arena:before{content:"";background:linear-gradient(90deg, var(--violet), transparent, #ff3c3c80);height:1px;position:absolute;top:0;left:0;right:0}.combatant{flex-direction:column;gap:12px;display:flex}.combatant--pet{align-items:flex-start}.combatant--boss{align-items:flex-end}.combatant__header{align-items:center;gap:12px;display:flex}.combatant--boss .combatant__header{flex-direction:row-reverse}.combatant__sprite{flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.combatant__sprite .pet-avatar{transform-origin:bottom;transform:scale(.85)}.combatant__sprite .pet-avatar__shadow{display:none}.boss-sprite{filter:drop-shadow(0 4px 16px #ff3c3c66);animation:3s ease-in-out infinite bossIdle}@keyframes bossIdle{0%,to{transform:translateY(0)rotate(-2deg)}33%{transform:translateY(-6px)rotate(1deg)}66%{transform:translateY(-3px)rotate(-1deg)}}.combatant__info{flex-direction:column;gap:2px;display:flex}.combatant--boss .combatant__info{align-items:flex-end}.combatant__name{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;font-size:15px;font-weight:700;line-height:1.2}.combatant__label{font-family:var(--font-accent);letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-weight:700}.combatant__label--pet{color:var(--violet)}.combatant__label--boss{color:#ff7070}.hp-bar-wrap{flex-direction:column;gap:6px;width:100%;display:flex}.hp-bar-meta{justify-content:space-between;align-items:center;display:flex}.combatant--boss .hp-bar-meta{flex-direction:row-reverse}.hp-label{font-family:var(--font-accent);letter-spacing:.08em;text-transform:uppercase;color:var(--text-sub);font-size:10px;font-weight:700}.hp-value{font-family:var(--font-heading);letter-spacing:-.01em;font-size:13px;font-weight:700}.hp-value--pet{color:var(--violet)}.hp-value--boss{color:#ff7070}.hp-track{border-radius:var(--radius-pill);background:#ffffff0f;border:1px solid #ffffff0d;width:100%;height:12px;overflow:hidden}.hp-fill--pet{background:linear-gradient(90deg, var(--violet), var(--purple), #c87dff);border-radius:var(--radius-pill);height:100%;transition:width .8s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.hp-fill--boss{border-radius:var(--radius-pill);background:linear-gradient(90deg,#f33,#ff6060,#ff8080);height:100%;margin-left:auto;transition:width .8s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.hp-fill--pet:after,.hp-fill--boss:after{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:40%;height:100%;animation:2s ease-in-out infinite hpShine;position:absolute;top:0;left:0}@keyframes hpShine{0%{transform:translate(-150%)}60%,to{transform:translate(350%)}}.hp-fill--taking-damage{animation:.4s takeDamage}@keyframes takeDamage{0%,to{filter:brightness()}30%{filter:brightness(2.5)}60%{filter:brightness(.7)}}.vs-divider{flex-direction:column;flex-shrink:0;align-items:center;gap:6px;display:flex}.vs-text{font-family:var(--font-heading);background:linear-gradient(135deg, var(--violet), #ff5050);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:800;line-height:1}.vs-line{background:linear-gradient(to bottom, var(--violet), #ff505066);width:1px;height:24px}.question-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;animation:.35s cubic-bezier(.4,0,.2,1) both cardIn;position:relative;overflow:hidden;box-shadow:0 24px 48px #00000059}@keyframes cardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.question-card:before{content:"";background:linear-gradient(90deg, transparent, #ff505080, var(--violet), transparent);height:1px;position:absolute;top:0;left:0;right:0}.question-card__body{padding:36px 40px 28px}.question-card__text{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;text-align:center;margin-bottom:32px;font-size:clamp(18px,2.8vw,26px);font-weight:700;line-height:1.3}.answer-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.answer-btn{border:1px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--font-body);color:var(--text-muted);cursor:pointer;text-align:left;transition:all var(--transition);background:#ffffff08;align-items:center;gap:12px;padding:16px 18px;font-size:14px;font-weight:500;line-height:1.4;display:flex}.answer-btn__num{border:1px solid var(--border);width:26px;height:26px;font-family:var(--font-accent);color:var(--text-sub);transition:all var(--transition);background:#ffffff0f;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.answer-btn:hover:not(:disabled){border-color:var(--border-bright);color:var(--text);background:#6d67ff14;transform:translateY(-2px)}.answer-btn:hover:not(:disabled) .answer-btn__num{background:var(--violet-dim);border-color:var(--violet);color:var(--violet)}.answer-btn:disabled{cursor:default}.answer-btn--correct{animation:.5s both answerCorrect;color:#4dff91!important;background:#4dff9114!important;border-color:#4dff9180!important;transform:translateY(0)!important}.answer-btn--correct .answer-btn__num{color:#4dff91!important;background:#4dff9126!important;border-color:#4dff91!important}@keyframes answerCorrect{0%{box-shadow:none}40%{box-shadow:0 0 0 4px #4dff9133,0 0 24px #4dff9126}to{box-shadow:0 0 0 2px #4dff911a}}.answer-btn--wrong{animation:.45s both answerWrong;color:#ff7070!important;background:#ff505014!important;border-color:#ff505080!important;transform:translateY(0)!important}.answer-btn--wrong .answer-btn__num{color:#ff7070!important;background:#ff505026!important;border-color:#ff7070!important}@keyframes answerWrong{0%,to{transform:translate(0)}15%{transform:translate(-7px)}30%{transform:translate(6px)}45%{transform:translate(-5px)}60%{transform:translate(4px)}75%{transform:translate(-2px)}}.answer-btn--dimmed{opacity:.3}.question-card__footer{border-top:1px solid #ffffff0a;justify-content:space-between;align-items:center;gap:16px;min-height:76px;padding:16px 40px 28px;display:flex}.answer-feedback{font-family:var(--font-accent);flex:1;align-items:center;gap:7px;font-size:13px;font-weight:600;display:flex}.answer-feedback--correct{color:#4dff91}.answer-feedback--wrong{color:#ff7070}.boss-btn-next{background:linear-gradient(135deg, var(--violet), var(--purple));border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--textbtn);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;flex-shrink:0;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:700;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 4px 16px #a45dff4d}.boss-btn-next:before{content:"";opacity:0;transition:opacity var(--transition);background:linear-gradient(135deg,#ffffff24,#0000);position:absolute;inset:0}.boss-btn-next:hover:before{opacity:1}.boss-btn-next:hover{transform:translateY(-2px);box-shadow:0 8px 28px #a45dff73}.boss-btn-next:active{transform:translateY(0)scale(.98)}.answer-placeholder{color:var(--text-sub);font-size:13px;font-family:var(--font-accent)}.boss-progress{align-items:center;gap:16px;width:100%;display:flex}.boss-progress__track{border-radius:var(--radius-pill);background:#ffffff0f;flex:1;height:5px;overflow:hidden}.boss-progress__fill{background:linear-gradient(90deg, var(--violet), var(--purple));border-radius:var(--radius-pill);height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.boss-progress__label{font-family:var(--font-accent);color:var(--text-sub);white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:700}.boss-progress__label span{color:var(--purple)}@media (width<=700px){.boss-topbar{padding:0 16px}.battle-arena{gap:10px;padding:20px 18px}.combatant__name{font-size:13px}.vs-text{font-size:18px}.vs-line{height:16px}.boss-main{gap:20px;padding:20px 16px 40px}.question-card__body{padding:28px 22px 22px}.answer-grid{grid-template-columns:1fr}.question-card__footer{flex-direction:column;align-items:stretch;min-height:auto;padding:14px 22px 22px}.boss-btn-next{justify-content:center}}@media (width<=420px){.combatant__sprite{width:40px;height:40px}.hp-track{height:10px}.question-card__text{font-size:17px}}.profile-page{background:var(--bg);min-height:100vh;font-family:var(--font-body);flex-direction:column;display:flex;position:relative;overflow-x:hidden}.profile-page:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(#6d67ff1a 0%,#a45dff0a 50%,#0000 70%);width:800px;height:500px;position:fixed;top:-150px;left:50%;transform:translate(-50%)}.profile-topbar{z-index:40;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#060815d9;justify-content:space-between;align-items:center;gap:16px;height:56px;padding:0 32px;display:flex;position:sticky;top:0}.profile-topbar__back{color:var(--text-muted);font-family:var(--font-accent);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);background:0 0;border:none;flex-shrink:0;align-items:center;gap:6px;padding:6px 10px;font-size:13px;font-weight:600;display:flex}.profile-topbar__back:hover{color:var(--text);background:#ffffff0d}.profile-topbar__title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.01em;font-size:15px;font-weight:700}.pro-badge{background:linear-gradient(135deg, var(--violet-dim), var(--purple-dim));border:1px solid var(--border-bright);border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--purple);letter-spacing:.06em;text-transform:uppercase;flex-shrink:0;align-items:center;gap:5px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-flex}.profile-main{z-index:1;flex-direction:column;flex:1;align-items:center;gap:28px;width:100%;padding:48px 24px 80px;display:flex;position:relative}.profile-inner{flex-direction:column;gap:24px;width:100%;max-width:640px;display:flex}.profile-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);position:relative;overflow:hidden}.profile-section:before{content:"";background:linear-gradient(90deg, transparent, var(--violet), var(--purple), transparent);pointer-events:none;height:1px;position:absolute;top:0;left:0;right:0}.section-header{align-items:center;gap:8px;padding:22px 28px 0;display:flex}.section-header__title{font-family:var(--font-accent);color:var(--text-sub);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:700}.profile-hero{text-align:center;flex-direction:column;align-items:center;gap:0;padding:48px 28px 36px;display:flex}.profile-hero__avatar{margin-bottom:20px;position:relative}.profile-hero__avatar .pet-avatar__sprite{font-size:72px}.profile-hero__avatar .pet-avatar__sprite svg{width:72px;height:72px}.profile-hero__edit-pet{background:var(--bg-card);border:1px solid var(--border-bright);width:26px;height:26px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:11px;display:flex;position:absolute;bottom:8px;right:-4px}.profile-hero__edit-pet:hover{background:var(--violet-dim);border-color:var(--violet);color:var(--violet)}.profile-hero__name{font-family:var(--font-heading);color:var(--text);letter-spacing:-.03em;margin-bottom:6px;font-size:clamp(28px,4vw,38px);font-weight:700;line-height:1.1}.profile-hero__joined{color:var(--text-sub);font-size:13px;font-family:var(--font-accent);letter-spacing:.04em;align-items:center;gap:6px;margin-bottom:24px;font-weight:600;display:flex}.profile-hero__badges{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.hero-badge{border-radius:var(--radius-pill);font-family:var(--font-accent);letter-spacing:.01em;align-items:center;gap:7px;padding:9px 18px;font-size:13px;font-weight:700;display:inline-flex}.hero-badge--streak{color:#fa3;background:#ffa0321a;border:1px solid #ffa03240}.hero-badge--xp{background:linear-gradient(135deg, var(--violet-dim), var(--purple-dim));border:1px solid var(--border-bright);color:var(--purple)}.stats-grid{background:var(--border);border-radius:var(--radius-lg);grid-template-columns:1fr 1fr;gap:1px;display:grid;overflow:hidden}.stat-card{background:var(--bg-card);transition:background var(--transition);flex-direction:column;gap:6px;padding:28px 24px;display:flex;position:relative;overflow:hidden}.stat-card:hover{background:var(--bg-card-hover)}.stat-card:after{content:"";pointer-events:none;opacity:0;width:80px;height:80px;transition:opacity var(--transition);background:radial-gradient(at 100% 100%,#6d67ff14 0%,#0000 70%);position:absolute;bottom:0;right:0}.stat-card:hover:after{opacity:1}.stat-card__number{font-family:var(--font-heading);background:linear-gradient(135deg, var(--violet), var(--purple));-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;font-size:clamp(32px,5vw,44px);font-weight:800;line-height:1}.stat-card__label{font-family:var(--font-accent);color:var(--text-sub);letter-spacing:.05em;text-transform:uppercase;font-size:12px;font-weight:600}.stat-card__icon{color:var(--border-bright);opacity:.5;position:absolute;top:20px;right:20px}.settings-body{padding:8px 0 16px}.setting-row{transition:background var(--transition);border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;gap:20px;padding:18px 28px;display:flex}.setting-row:last-child{border-bottom:none}.setting-row:hover{background:#ffffff05}.setting-row__left{flex-direction:column;gap:3px;min-width:0;display:flex}.setting-row__label{font-family:var(--font-accent);color:var(--text);font-size:14px;font-weight:600}.setting-row__sub{color:var(--text-sub);font-size:12px;font-family:var(--font-body)}.setting-row__right{flex-shrink:0;align-items:center;gap:8px;display:flex}.goal-pills{border:1px solid var(--border);border-radius:var(--radius-pill);background:#ffffff08;gap:6px;padding:3px;display:flex}.goal-pill{border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--text-sub);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:0 0;border:none;padding:7px 14px;font-size:12px;font-weight:700}.goal-pill:hover:not(.goal-pill--active){color:var(--text-muted)}.goal-pill--active{background:linear-gradient(135deg, var(--violet), var(--purple));color:var(--textbtn);box-shadow:0 2px 10px #a45dff4d}.toggle-wrap{align-items:center;gap:10px;display:flex}.toggle{flex-shrink:0;width:44px;height:24px;position:relative}.toggle__input{opacity:0;width:0;height:0;position:absolute}.toggle__slider{border:1px solid var(--border);border-radius:var(--radius-pill);cursor:pointer;background:#ffffff1a;transition:all .3s;position:absolute;inset:0}.toggle__slider:before{content:"";background:var(--text-sub);border-radius:50%;width:16px;height:16px;transition:all .3s;position:absolute;top:50%;left:3px;transform:translateY(-50%)}.toggle__input:checked+.toggle__slider{background:linear-gradient(135deg, var(--violet), var(--purple));border-color:var(--purple);box-shadow:0 0 10px #a45dff4d}.toggle__input:checked+.toggle__slider:before{background:#fff;transform:translateY(-50%)translate(20px)}.toggle--disabled .toggle__slider,.toggle__input:disabled+.toggle__slider{opacity:.35;cursor:not-allowed}.pro-lock-badge{border:1px solid var(--border);border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--text-sub);letter-spacing:.05em;text-transform:uppercase;background:#ffffff0a;align-items:center;gap:4px;padding:3px 9px;font-size:10px;font-weight:700;display:inline-flex}.goal-text{color:var(--text-muted);font-size:13px;font-family:var(--font-body);text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.edit-btn{border:1px solid var(--border);border-radius:var(--radius-pill);font-family:var(--font-accent);color:var(--text-muted);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:#6d67ff14;align-items:center;gap:5px;padding:6px 14px;font-size:12px;font-weight:600;display:flex}.edit-btn:hover{background:var(--violet-dim);border-color:var(--border-bright);color:var(--text)}.danger-zone{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid #ff3c3c26;position:relative;overflow:hidden}.danger-zone:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#ff3c3c66,#0000);height:1px;position:absolute;top:0;left:0;right:0}.danger-zone__header{align-items:center;gap:7px;padding:20px 28px 0;display:flex}.danger-zone__title{font-family:var(--font-accent);color:#ff505099;letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:700}.danger-zone__body{flex-direction:column;gap:10px;padding:16px 28px 24px;display:flex}.btn-danger{border-radius:var(--radius-pill);width:100%;font-family:var(--font-accent);color:#ff6060;cursor:pointer;transition:all var(--transition);background:0 0;border:1px solid #ff3c3c59;justify-content:center;align-items:center;gap:8px;padding:13px 20px;font-size:14px;font-weight:700;display:flex}.btn-danger:hover{color:#ff7070;background:#ff3c3c14;border-color:#ff3c3c99}.btn-logout{border:1px solid var(--border);border-radius:var(--radius-pill);width:100%;font-family:var(--font-accent);color:var(--text-sub);cursor:pointer;transition:all var(--transition);background:#ffffff08;justify-content:center;align-items:center;gap:8px;padding:13px 20px;font-size:14px;font-weight:600;display:flex}.btn-logout:hover{color:var(--text-muted);background:#ffffff0f;border-color:#ffffff1f}@media (width<=600px){.profile-topbar{padding:0 16px}.profile-main{padding:28px 16px 60px}.profile-hero{padding:36px 20px 28px}.section-header{padding:18px 20px 0}.setting-row{flex-wrap:wrap;gap:12px;padding:16px 20px}.setting-row__right{width:100%}.goal-pills{justify-content:space-between;width:100%}.goal-pill{text-align:center;flex:1}.goal-text{max-width:120px}.danger-zone__header{padding:16px 20px 0}.danger-zone__body{padding:14px 20px 20px}.stats-grid{grid-template-columns:1fr 1fr}.stat-card{padding:22px 18px}.stat-card__number{font-size:clamp(26px,8vw,36px)}}
