@import"https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Literata:ital,wght@0,400;0,500;1,400&family=Outfit:wght@400;500;600&display=swap";:root{--bg: #0F0F13;--hero: #13131A;--hero2: #1A1A26;--card: #FAFAF7;--card2: #F2F0EB;--card3: #E8E5DE;--ink: #0F0F13;--ink2: #3A3A45;--ink3: #6E6E7E;--ink4: #A0A0B0;--ghost: rgba(255,255,255,.06);--ghost2: rgba(255,255,255,.1);--ghost3: rgba(255,255,255,.16);--border-dark: rgba(255,255,255,.09);--border-dark2: rgba(255,255,255,.15);--accent: #6366F1;--accent-h: #4F52E0;--accent-lt: #EEF2FF;--accent-md: #C7D2FE;--accent-glow: rgba(99,102,241,.25);--ok: #059669;--ok-bg: #D1FAE5;--ok-dark: #34D399;--warn: #B45309;--warn-bg: #FEF3C7;--warn-dark: #FBBF24;--err: #DC2626;--err-bg: #FEE2E2;--err-dark: #F87171;--font-disp: "Cabinet Grotesk", "Syne", sans-serif;--font-body: "Geist", "Outfit", sans-serif;--font-prose: "Instrument Serif", "Literata", Georgia, serif;--r: 16px;--r-sm: 10px;--r-lg: 24px;--r-xl: 32px;--sh-card: 0 2px 8px rgba(0,0,0,.18), 0 8px 32px rgba(0,0,0,.14);--sh-lift: 0 6px 20px rgba(0,0,0,.24), 0 20px 48px rgba(0,0,0,.18);--sh-glow: 0 0 0 1px var(--accent-glow), 0 4px 24px var(--accent-glow);--hero-text: #FFFFFF;--hero-text-2: rgba(255,255,255,.65);--hero-text-3: rgba(255,255,255,.42);--page-text: #FFFFFF;--page-text-2: rgba(255,255,255,.55);--nav-icon: rgba(255,255,255,.45);--nav-logout: rgba(255,255,255,.38)}[data-theme=light]{--bg: #F5F3EE;--hero: #EDEAE3;--hero2: #E4E1D8;--card: #FFFFFF;--card2: #F5F3EE;--card3: #DDD9D0;--ink: #1A1A2A;--ink2: #3D3D4D;--ink3: #6B6B7B;--ink4: #9B9BAB;--ghost: rgba(0,0,0,.04);--ghost2: rgba(0,0,0,.07);--ghost3: rgba(0,0,0,.11);--border-dark: rgba(0,0,0,.09);--border-dark2: rgba(0,0,0,.15);--ok-dark: #059669;--warn-dark: #B45309;--err-dark: #DC2626;--sh-card: 0 1px 4px rgba(0,0,0,.07), 0 4px 16px rgba(0,0,0,.06);--sh-lift: 0 4px 12px rgba(0,0,0,.1), 0 12px 32px rgba(0,0,0,.08)}[data-theme=light] .t-display,[data-theme=light] .on-dark{color:var(--ink)}[data-theme=light] .on-dark-2{color:var(--ink3)}[data-theme=light] .on-dark-3{color:var(--ink4)}[data-theme=light] body,[data-theme=light] .app{color:var(--ink)}[data-theme=light] .nav{background:#f5f3eef7;border:1px solid var(--card3);box-shadow:0 -4px 20px #0000000f,0 4px #0000}[data-theme=light] .nav-btn{color:var(--ink3)}[data-theme=light] .nav-btn[aria-current=page]{color:#fff}[data-theme=light]{--hero-text: #1A1A2A;--hero-text-2: #4A4A5A;--hero-text-3: #6B6B7B;--page-text: #1A1A2A;--page-text-2: #4A4A5A;--nav-icon: #6B6B7B;--nav-logout: #9B9BAB}[data-theme=light] .home-hero,[data-theme=light] .detail-hero,[data-theme=light] .dash-hero,[data-theme=light] .diag-hero{background:var(--hero);border-bottom:1px solid var(--card3)}[data-theme=light] .home-hero:after,[data-theme=light] .dash-hero:after,[data-theme=light] .diag-hero:after{opacity:.4}[data-theme=light] .home-hero .t-display,[data-theme=light] .detail-hero h1,[data-theme=light] .dash-hero .t-display{color:var(--ink)!important}[data-theme=light] .hero-sub{color:var(--ink3)!important}[data-theme=light] .hero-streak-strong{color:var(--ink)!important}[data-theme=light] .xp-pill{background:#fff;border:1.5px solid var(--card3)}[data-theme=light] .xp-num{color:var(--warn)}[data-theme=light] .back-btn{background:#fff;border-color:var(--card3);color:var(--ink2)}[data-theme=light] .back-btn:hover{border-color:var(--ink3);color:var(--ink)}[data-theme=light] .detail-category,[data-theme=light] .detail-tagline{color:var(--ink3)!important}[data-theme=light] .tablist{background:var(--card2);border-color:var(--card3)}[data-theme=light] .tab-btn{color:var(--ink3)}[data-theme=light] .tab-btn[aria-selected=true]{background:#fff;color:var(--ink);box-shadow:0 1px 4px #0000001a}[data-theme=light] .filter-pill{background:#fff;color:var(--ink2);border-color:var(--card3)}[data-theme=light] .filter-pill:hover:not(.active){border-color:var(--ink3);color:var(--ink)}[data-theme=light] .sec-label{color:var(--ink)!important}[data-theme=light] .see-all-btn{color:var(--accent)}[data-theme=light] .stat-box,[data-theme=light] .stat-tile{border:1.5px solid var(--card3)}[data-theme=light] .session-divider{background:var(--card3)}[data-theme=light] .pg-track-dark{background:#0000001f}[data-theme=light] .badge-ico{border-color:var(--card3);background:var(--card2)}[data-theme=light] .badge-ico.earned{border-color:#fcd34d;background:#fffbeb;box-shadow:none}[data-theme=light] .badge-ico:not(.earned){opacity:.3}[data-theme=light] .badge-lbl{color:var(--ink3)}[data-theme=light] .subject-name{color:var(--ink)!important}[data-theme=light] .subject-pct{color:var(--ink3)!important}[data-theme=light] .diag-result-sub{color:var(--ink2)!important}.theme-toggle{width:36px;height:36px;border-radius:50%;background:var(--ghost2);border:1px solid var(--border-dark2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;color:#ffffffa6}.theme-toggle:hover{background:var(--ghost3);color:#fff}[data-theme=light] .theme-toggle{color:var(--ink3)}[data-theme=light] .theme-toggle:hover{color:var(--ink);background:var(--card3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{background:var(--bg);color:var(--hero-text);font-family:var(--font-body);line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:var(--font-body);cursor:pointer}input{font-family:var(--font-body)}svg{display:block;flex-shrink:0}*:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:4px}.skip-link{position:fixed;top:-9999px;left:20px;z-index:9999;background:var(--accent);color:#fff;padding:12px 20px;border-radius:var(--r-sm);font-weight:600;font-size:15px;text-decoration:none;transition:top .15s}.skip-link:focus{top:16px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.app{min-height:100dvh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;background:var(--bg);position:relative}.nav{position:fixed;bottom:16px;left:50%;transform:translate(-50%);width:calc(100% - 32px);max-width:448px;background:var(--hero2);border:1px solid var(--border-dark2);border-radius:var(--r-xl);display:flex;z-index:200;padding:8px;gap:4px;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;padding:10px 4px;color:var(--ink4);min-height:56px;border-radius:calc(var(--r-xl) - 12px);transition:color .2s,background .2s}.nav-btn[aria-current=page]{color:#fff;background:var(--accent);box-shadow:0 2px 12px var(--accent-glow)}.nav-icon-wrap{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.nav-label{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}.page{flex:1;overflow-y:auto;padding-bottom:calc(96px + env(safe-area-inset-bottom));scroll-behavior:smooth}.page::-webkit-scrollbar{width:3px}.page::-webkit-scrollbar-track{background:transparent}.page::-webkit-scrollbar-thumb{background:var(--ghost3);border-radius:2px}.t-display{font-family:var(--font-disp);font-size:clamp(28px,7vw,38px);font-weight:800;line-height:1.05;letter-spacing:-.6px;color:var(--hero-text)}.t-heading{font-family:var(--font-disp);font-size:clamp(20px,5vw,26px);font-weight:700;line-height:1.15;color:var(--ink)}.t-subhead{font-family:var(--font-disp);font-size:17px;font-weight:700;color:var(--ink)}.t-body{font-family:var(--font-body);font-size:16px;line-height:1.65;color:var(--ink2)}.t-body-sm{font-family:var(--font-body);font-size:14px;line-height:1.6;color:var(--ink2)}.t-prose{font-family:var(--font-prose);font-size:17px;line-height:1.82;color:var(--ink)}.t-label{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase}.t-caption{font-size:13px;color:var(--ink3);line-height:1.5}.on-dark{color:#fff}.on-dark-2{color:#ffffff8c}.on-dark-3{color:#ffffff59}.px{padding-left:20px;padding-right:20px}.stack{display:flex;flex-direction:column}.row{display:flex;align-items:center}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.card{background:var(--card);border-radius:var(--r);border:none;box-shadow:var(--sh-card);overflow:hidden}.cp{padding:20px}.chip{display:inline-flex;align-items:center;gap:5px;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:700;letter-spacing:.2px}.chip-blue{background:var(--accent-lt);color:var(--accent-h)}.chip-green{background:var(--ok-bg);color:#065f46}.chip-amber{background:var(--warn-bg);color:#92400e}.chip-red{background:var(--err-bg);color:#991b1b}.chip-neutral{background:var(--card2);color:var(--ink2)}.chip-dark{background:var(--ghost2);color:#ffffffbf;border:1px solid var(--border-dark)}.pg-track{height:8px;border-radius:4px;overflow:hidden}.pg-track-dark{background:var(--ghost)}.pg-track-light{background:var(--card3)}.pg-fill{height:100%;border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}.pg-fill-accent{background:linear-gradient(90deg,var(--accent),#818CF8)}.pg-fill-ok{background:linear-gradient(90deg,var(--ok),#34D399)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--r-sm);font-weight:700;font-size:15px;padding:14px 22px;transition:all .18s;line-height:1;cursor:pointer;letter-spacing:.1px}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.btn-primary:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow)}.btn-primary:active{transform:none;box-shadow:none}.btn-ghost{background:transparent;color:var(--ink2);border:1.5px solid var(--card3)}.btn-ghost:hover{border-color:var(--ink3);color:var(--ink)}.btn-ghost-dark{background:var(--ghost);color:#ffffffb3;border:1px solid var(--border-dark)}.btn-ghost-dark:hover{background:var(--ghost2);color:#fff;border-color:var(--border-dark2)}.btn-full{width:100%}.btn-sm{font-size:13px;padding:10px 16px}.search-wrap{position:relative;margin:16px 20px 0}.search-input{width:100%;background:var(--card);border:1.5px solid var(--card3);border-radius:var(--r);padding:14px 16px 14px 50px;font-size:16px;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;box-shadow:var(--sh-card)}.search-input:focus{border-color:var(--accent);box-shadow:var(--sh-glow)}.search-input::placeholder{color:var(--ink4)}.search-ico{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--ink3);pointer-events:none}.filter-row{display:flex;gap:8px;padding:14px 20px 0;overflow-x:auto}.filter-row::-webkit-scrollbar{display:none}.filter-pill{white-space:nowrap;padding:9px 18px;border-radius:100px;font-size:13px;font-weight:700;background:var(--ghost);color:#ffffff80;border:1px solid var(--border-dark);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:7px}.filter-pill:hover:not(.active){background:var(--ghost2);color:#fffc;border-color:var(--border-dark2)}.filter-pill.active{background:var(--accent);border-color:transparent;color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.hscroll{display:flex;gap:14px;padding:0 20px 6px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.hscroll::-webkit-scrollbar{display:none}.tip-mini{min-width:200px;flex-shrink:0;background:var(--card);border-radius:var(--r);border:none;box-shadow:var(--sh-card);overflow:hidden;cursor:pointer;scroll-snap-align:start;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s}.tip-mini:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--sh-lift)}.tip-mini:focus-visible{outline:2px solid var(--accent);outline-offset:2px;transform:translateY(-2px)}.tip-mini-accent{height:4px}.tip-mini-body{padding:16px}.tip-mini-icon-wrap{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.tip-mini-cat{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--ink3);margin-bottom:5px}.tip-mini-title{font-family:var(--font-disp);font-size:14px;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:6px}.tip-mini-tagline{font-family:var(--font-prose);font-size:12px;color:var(--ink3);font-style:italic}.tip-row{background:var(--card);border-radius:var(--r);padding:16px 18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .18s;margin:0 20px;box-shadow:var(--sh-card)}.tip-row+.tip-row{margin-top:10px}.tip-row:hover{transform:translate(4px);box-shadow:var(--sh-lift)}.tip-row:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.tip-row-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tip-row-title{font-family:var(--font-disp);font-size:15px;font-weight:700;color:var(--ink);margin-bottom:3px}.tip-row-sub{font-size:13px;color:var(--ink3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.tip-row-meta{display:flex;gap:6px;align-items:center;margin-bottom:4px}.home-hero{padding:56px 20px 28px;background:var(--hero);position:relative;overflow:hidden}.home-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 80% 20%,rgba(99,102,241,.15) 0%,transparent 60%);pointer-events:none}.logo-mark{font-family:var(--font-disp);font-size:20px;font-weight:800;color:var(--hero-text);letter-spacing:-.2px}.logo-mark span{color:var(--accent)}.xp-pill{background:var(--ghost2);border:1px solid var(--border-dark2);border-radius:100px;padding:7px 14px;display:inline-flex;align-items:center;gap:7px}.xp-num{font-size:13px;font-weight:700;color:var(--warn-dark)}.stat-strip{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 20px}.stat-box{background:var(--card);border-radius:var(--r);padding:18px 18px 16px;box-shadow:var(--sh-card)}.stat-box-icon{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-box-n{font-family:var(--font-disp);font-size:32px;font-weight:800;line-height:1;color:var(--ink)}.stat-box-lbl{font-size:13px;color:var(--ink3);margin-top:5px}.sec-row{display:flex;align-items:center;justify-content:space-between;padding:28px 20px 12px}.sec-row-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-right:8px}.sec-label{font-family:var(--font-disp);font-size:16px;font-weight:700;color:var(--page-text)}.see-all-btn{font-size:13px;font-weight:600;color:var(--page-text-2);background:none;border:none;padding:4px 0;cursor:pointer;display:flex;align-items:center;gap:4px;transition:color .15s}.see-all-btn:hover{color:var(--page-text)}.challenge-card{margin:0 20px 24px;border-radius:var(--r-lg);overflow:hidden;position:relative;box-shadow:var(--sh-lift)}.challenge-card-inner{padding:22px 22px 20px;position:relative;z-index:1}.challenge-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#6366f1,#8b5cf6,#06b6d4)}.challenge-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 100% 80% at 100% 0%,rgba(255,255,255,.12) 0%,transparent 60%)}.detail-hero{padding:56px 20px 24px;background:var(--hero);position:relative;overflow:hidden}.detail-hero:before{content:"";position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;pointer-events:none}.back-btn{display:inline-flex;align-items:center;gap:6px;background:var(--ghost);border:1px solid var(--border-dark);border-radius:var(--r-sm);padding:9px 16px;font-size:14px;font-weight:600;color:#ffffffa6;transition:all .15s;margin-bottom:20px}.back-btn:hover{background:var(--ghost2);color:#fff;border-color:var(--border-dark2)}.detail-icon{width:64px;height:64px;border-radius:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}.tablist{display:flex;background:var(--ghost);border:1px solid var(--border-dark);border-radius:var(--r-sm);padding:4px;margin:16px 20px 0;gap:2px}.tab-btn{flex:1;border:none;background:none;border-radius:7px;padding:10px 6px;font-size:13px;font-weight:700;color:#fff6;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}.tab-btn[aria-selected=true]{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.block{background:var(--card);border-radius:var(--r);padding:22px;margin:14px 20px 0;box-shadow:var(--sh-card)}.block-lbl{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink3);margin-bottom:14px}.alert{border-radius:var(--r-sm);padding:16px;display:flex;gap:12px;align-items:flex-start;margin:12px 20px 0}.alert-warn{background:var(--warn-bg);border-left:4px solid #F59E0B}.alert-warn .alert-body{font-size:15px;color:#78350f;line-height:1.7}.alert-ok{background:var(--ok-bg);border-left:4px solid var(--ok)}.alert-ok .alert-body{font-size:15px;color:#065f46;line-height:1.7}.alert-err{background:var(--err-bg);border-left:4px solid var(--err)}.alert-err .alert-body{font-size:15px;color:#991b1b;line-height:1.7}.alert-info{background:var(--accent-lt);border-left:4px solid var(--accent)}.alert-info .alert-body{font-size:15px;color:#3730a3;line-height:1.7}.q-block{background:var(--card2);border-radius:var(--r-sm);padding:18px 20px;font-family:var(--font-prose);font-size:17px;color:var(--ink);line-height:1.82;border-left:4px solid var(--accent)}.choice-static{padding:13px 16px;border-radius:10px;border:1.5px solid var(--card3);font-size:15px;color:var(--ink2);display:flex;align-items:center;gap:12px}.choice-static.correct{border-color:var(--ok);background:var(--ok-bg);color:#065f46;font-weight:600}.choice-ltr{width:30px;height:30px;border-radius:8px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;font-family:var(--font-disp);color:var(--ink2)}.choice-static.correct .choice-ltr{background:var(--ok);color:#fff}.step-item{display:flex;gap:14px;align-items:flex-start}.step-num{min-width:28px;height:28px;border-radius:8px;background:var(--accent);color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;font-family:var(--font-disp)}.step-text{font-size:15px;color:var(--ink);line-height:1.7}.pq-card{background:var(--card);border-radius:var(--r);padding:22px 20px;margin:14px 20px 0;box-shadow:var(--sh-card)}.q-text{font-family:var(--font-prose);font-size:18px;line-height:1.82;color:var(--ink);margin-bottom:24px}.p-choices{display:flex;flex-direction:column;gap:10px}.p-choice{display:flex;align-items:center;gap:14px;padding:15px 17px;border-radius:var(--r-sm);border:1.5px solid var(--card3);background:var(--card);font-size:15px;color:var(--ink2);text-align:left;width:100%;transition:all .15s cubic-bezier(.4,0,.2,1);cursor:pointer}.p-choice:hover:not(:disabled){border-color:var(--accent-md);background:var(--accent-lt);color:var(--ink);transform:translate(2px)}.p-choice:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.p-choice:disabled{cursor:default}.p-choice.is-correct{border-color:var(--ok);background:var(--ok-bg);color:#065f46;font-weight:600}.p-choice.is-wrong{border-color:var(--err);background:var(--err-bg);color:#991b1b;font-weight:600}.p-choice.show-correct{border-color:var(--ok);background:var(--ok-bg);color:#065f46;font-weight:600}.p-choice .choice-ltr{background:var(--card2);color:var(--ink2)}.p-choice.is-correct .choice-ltr,.p-choice.show-correct .choice-ltr{background:var(--ok);color:#fff}.p-choice.is-wrong .choice-ltr{background:var(--err);color:#fff}.session-bar{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:center;margin:16px 20px 0;background:var(--card);border-radius:var(--r);padding:16px 10px;box-shadow:var(--sh-card)}.session-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.session-stat-val{font-family:var(--font-disp);font-size:22px;font-weight:800;line-height:1;color:var(--ink)}.session-stat-lbl{font-size:9px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--ink3)}.session-divider{width:1px;height:32px;background:var(--card3);margin:0 6px}.ai-spinner{width:48px;height:48px;margin:0 auto}.spinner-ring{width:48px;height:48px;border:3px solid var(--card3);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.mastery-toast,.streak-toast{display:flex;align-items:center;gap:10px;margin:12px 20px 0;padding:14px 16px;border-radius:var(--r-sm);font-size:14px;font-weight:600;line-height:1.4}.mastery-toast{background:var(--accent-lt);border-left:4px solid var(--accent);color:#3730a3}.streak-toast{background:var(--warn-bg);border-left:4px solid #F59E0B;color:#78350f}.dash-hero{padding:56px 20px 28px;background:var(--hero);position:relative;overflow:hidden}.dash-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 50% at 20% 80%,rgba(99,102,241,.12) 0%,transparent 60%);pointer-events:none}.level-banner{margin:0 20px;background:var(--card);border-radius:var(--r-lg);padding:22px;display:flex;align-items:center;gap:18px;box-shadow:var(--sh-card)}.level-circle{width:68px;height:68px;border-radius:50%;background:linear-gradient(135deg,var(--accent) 0%,#8B5CF6 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 16px var(--accent-glow)}.level-n{font-family:var(--font-disp);font-size:26px;font-weight:800;color:#fff;line-height:1}.level-lbl-sm{font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:#fff9}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 20px}.stat-tile{background:var(--card);border-radius:var(--r);padding:18px;box-shadow:var(--sh-card)}.stat-tile-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}.stat-val{font-family:var(--font-disp);font-size:32px;font-weight:800;line-height:1;color:var(--ink)}.stat-lbl{font-size:14px;color:var(--ink3);margin-top:5px}.stat-sub{font-size:12px;color:var(--ink4);margin-top:4px}.badge-row{display:flex;gap:14px;overflow-x:auto;padding:0 20px}.badge-row::-webkit-scrollbar{display:none}.badge-item{display:flex;flex-direction:column;align-items:center;gap:7px;min-width:68px}.badge-ico{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-dark2);background:var(--ghost)}.badge-ico.earned{border-color:#fbbf24;background:#fbbf241f;box-shadow:0 0 16px #fbbf2433}.badge-ico:not(.earned){opacity:.3;filter:grayscale(1)}.badge-lbl{font-size:11px;font-weight:600;color:var(--page-text-2);text-align:center;line-height:1.3;max-width:66px}.subject-bar{margin-bottom:18px}.subject-name{font-size:14px;font-weight:600;color:#fff}.subject-pct{font-size:14px;font-weight:700;color:var(--page-text-2)}.diag-hero{padding:56px 20px 28px;background:var(--hero);position:relative;overflow:hidden}.diag-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle 200px at 50% 100%,rgba(99,102,241,.18) 0%,transparent 70%);pointer-events:none}.diag-feat{background:var(--card);border-radius:var(--r);padding:18px;display:flex;gap:16px;box-shadow:var(--sh-card)}.diag-feat-ico{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}[data-theme=light] .diag-quiz-header{background:var(--hero)!important}[data-theme=light] .diag-heading{color:var(--ink)!important}[data-theme="light"] header[style*="background:"var(--hero)""]{border-bottom:1px solid var(--card3)}[data-theme=light] [id=stats-h],[data-theme=light] [id=mastery-h],[data-theme=light] [id=badges-h],[data-theme=light] [id=perf-h]{color:var(--ink)!important}[data-theme=light] .badge-lbl{color:var(--ink3)!important}[data-theme=light] .nav-btn:not([aria-current=page]){color:var(--ink3)}.app,.app *{transition:background-color .25s ease,border-color .2s ease,color .15s ease,box-shadow .2s ease}.app .fade-up,.app .pop-in,.app .slide-in,.app .spinner-ring{transition:none}.theme-toggle-btn{color:#ffffff73}.theme-toggle-btn:hover{color:#fffc!important}[data-theme=light] .theme-toggle-btn{color:var(--ink3)!important}[data-theme=light] .theme-toggle-btn:hover{color:var(--ink)!important;background:var(--card3)!important}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes glow{0%,to{box-shadow:0 0 12px var(--accent-glow)}50%{box-shadow:0 0 28px var(--accent-glow),0 0 48px var(--accent-glow)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.fade-up{animation:fadeUp .3s cubic-bezier(.4,0,.2,1) both}.pop-in{animation:popIn .26s cubic-bezier(.34,1.56,.64,1) both}.slide-in{animation:slideIn .24s ease both}.auth-shell{min-height:100dvh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;background:var(--bg);position:relative;overflow:hidden}.auth-shell:before{content:"";position:absolute;top:-120px;left:-80px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.18) 0%,transparent 70%);pointer-events:none}.auth-shell:after{content:"";position:absolute;bottom:-100px;right:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.12) 0%,transparent 70%);pointer-events:none}.auth-card{background:var(--card);border-radius:var(--r-lg);margin:auto 20px;padding:32px 28px;box-shadow:var(--sh-lift);position:relative;z-index:1}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-mark{font-family:var(--font-disp);font-size:30px;font-weight:800;color:var(--ink);letter-spacing:-.5px}.auth-logo-mark span{color:var(--accent)}.auth-logo-sub{font-size:13px;color:var(--ink3);margin-top:4px}.auth-tabs{display:flex;background:var(--card2);border-radius:10px;padding:3px;margin-bottom:24px;gap:2px}.auth-tab{flex:1;padding:9px;border:none;background:none;border-radius:8px;font-size:14px;font-weight:700;color:var(--ink3);cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:7px}.auth-tab.active{background:var(--card);color:var(--ink);box-shadow:0 1px 4px #0000001a}.field{margin-bottom:16px}.field-label{display:block;font-size:12px;font-weight:700;color:var(--ink2);margin-bottom:6px;letter-spacing:.3px}.field-wrap{position:relative}.field-input{width:100%;background:var(--card2);border:1.5px solid var(--card3);border-radius:var(--r-sm);padding:13px 16px;font-size:15px;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;font-family:var(--font-body)}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.field-input::placeholder{color:var(--ink4)}.field-eye{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--ink3);cursor:pointer;padding:2px;display:flex}.auth-btn{width:100%;background:var(--accent);color:#fff;border:none;border-radius:var(--r-sm);padding:15px;font-size:16px;font-weight:700;cursor:pointer;margin-top:8px;transition:all .18s;font-family:var(--font-body);display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 2px 12px #6366f14d}.auth-btn:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 6px 20px #6366f159}.auth-btn:disabled{opacity:.6;transform:none;cursor:not-allowed}.auth-error{background:var(--err-bg);border-left:3px solid var(--err);border-radius:var(--r-sm);padding:12px 14px;font-size:14px;color:#991b1b;margin-bottom:16px;display:flex;align-items:flex-start;gap:8px}.auth-divider{text-align:center;font-size:12px;color:var(--ink4);margin:16px 0;position:relative}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--card3)}.auth-divider:before{left:0}.auth-divider:after{right:0}.switcher-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;max-height:260px;overflow-y:auto}.switcher-list::-webkit-scrollbar{width:3px}.switcher-list::-webkit-scrollbar-thumb{background:var(--card3);border-radius:2px}.switcher-row{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--card2);border:1.5px solid var(--card3);border-radius:var(--r);cursor:pointer;transition:all .15s}.switcher-row:hover{border-color:var(--accent-md);background:var(--accent-lt)}.switcher-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-size:18px;font-weight:800;color:#fff}.switcher-name{font-family:var(--font-disp);font-size:15px;font-weight:700;color:var(--ink)}.switcher-meta{font-size:12px;color:var(--ink3);margin-top:2px}.switcher-arrow{margin-left:auto;color:var(--ink4)}.profile-header{display:flex;align-items:center;gap:14px;padding:16px 20px;cursor:pointer;transition:all .15s}.profile-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-size:14px;font-weight:800;color:#fff;border:2px solid rgba(255,255,255,.2)}.profile-name{font-size:14px;font-weight:700;color:#ffffffd9;flex:1}.profile-logout{background:none;border:none;color:#fff6;cursor:pointer;padding:6px;display:flex;border-radius:8px;transition:all .15s}.profile-logout:hover{color:#ffffffd9;background:var(--ghost2)}[data-theme=light] .profile-name{color:var(--ink)!important}[data-theme=light] .profile-logout{color:var(--ink3)}[data-theme=light] .profile-logout:hover{color:var(--ink)}.student-card{margin:0 20px 20px;background:var(--card);border-radius:var(--r-lg);padding:22px;display:flex;align-items:center;gap:18px;box-shadow:var(--sh-card)}.student-avatar-lg{width:64px;height:64px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-size:26px;font-weight:800;color:#fff;box-shadow:0 4px 16px #6366f14d}.an-section{padding:0 20px 24px}.an-title{font-family:var(--font-disp);font-size:16px;font-weight:700;color:var(--page-text);margin-bottom:14px;display:flex;align-items:center;gap:8px}.an-card{background:var(--card);border-radius:var(--r);box-shadow:var(--sh-card);overflow:hidden}.an-card+.an-card{margin-top:10px}.tip-perf-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--card3)}.tip-perf-row:last-child{border-bottom:none}.tip-perf-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tip-perf-body{flex:1;min-width:0}.tip-perf-name{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tip-perf-sub{font-size:12px;color:var(--ink3);margin-top:2px}.tip-perf-right{text-align:right;flex-shrink:0}.tip-perf-pct{font-family:var(--font-disp);font-size:17px;font-weight:800}.tip-perf-attempts{font-size:11px;color:var(--ink4);margin-top:1px}.mini-bar-wrap{height:5px;background:var(--card3);border-radius:3px;overflow:hidden;margin-top:6px}.mini-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.insight-card{background:var(--card);border-radius:var(--r);box-shadow:var(--sh-card);padding:16px;display:flex;gap:14px;align-items:flex-start}.insight-card+.insight-card{margin-top:10px}.insight-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.insight-title{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:4px}.insight-text{font-size:13px;color:var(--ink2);line-height:1.6}.insight-cta{margin-top:8px;font-size:12px;font-weight:700;color:var(--accent);display:inline-flex;align-items:center;gap:4px}.ai-insight-loading{display:flex;align-items:center;gap:12px;padding:16px;background:var(--card);border-radius:var(--r);box-shadow:var(--sh-card)}.ai-insight-text{font-size:13px;color:var(--ink3)}.gauge-wrap{padding:20px 0 8px;display:flex;flex-direction:column;align-items:center}.gauge-arc{width:180px;height:90px;position:relative;overflow:visible}.score-range-label{font-family:var(--font-disp);font-size:26px;font-weight:800;color:var(--accent);text-align:center;margin-top:8px}.score-range-sub{font-size:12px;color:var(--ink3);text-align:center;margin-top:3px}.trend-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:700}.trend-up{background:var(--ok-bg);color:var(--ok)}.trend-down{background:var(--err-bg);color:var(--err)}.trend-flat{background:var(--card2);color:var(--ink3)}.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.cat-cell{background:var(--card);border-radius:var(--r-sm);padding:12px 14px;box-shadow:var(--sh-card)}.cat-cell-name{font-size:11px;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.cat-cell-pct{font-family:var(--font-disp);font-size:22px;font-weight:800;line-height:1}.cat-cell-bar{height:4px;border-radius:2px;margin-top:8px;overflow:hidden;background:var(--card3)}.cat-cell-fill{height:100%;border-radius:2px}.accordion-btn{width:100%;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;font-family:var(--font-body)}.accordion-body{padding:0 16px 14px}.sparkline-wrap{display:flex;align-items:flex-end;gap:4px;height:36px}.spark-bar{flex:1;border-radius:3px 3px 0 0;min-height:3px;transition:height .4s ease}.spark-day{font-size:9px;color:var(--ink4);text-align:center;margin-top:4px}
