*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand: #16a34a;--brand-light:#22c55e;--brand-dark: #166534;--bg: #0c1220;--surface: #162032;--surface2: #1e2e42;--border: #243448;--text: #f0f6ff;--text2: #c8d8ed;--text-muted: #8ba0b8;--correct: #22c55e;--wrong: #ef4444;--warn: #f59e0b;--radius: 14px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--shadow: 0 4px 24px rgba(0,0,0,.5);--shadow-brand: 0 4px 20px rgba(22,163,74,.3);--tab-bar-bg: rgba(12,18,32,.88)}[data-theme=light]{--bg: #eef2f7;--surface: #ffffff;--surface2: #dde5f0;--border: #b8cade;--text: #0a1628;--text2: #263952;--text-muted: #4a6585;--shadow: 0 4px 24px rgba(0,0,0,.1);--shadow-brand: 0 4px 20px rgba(22,163,74,.2);--tab-bar-bg: rgba(238,242,247,.95)}[data-theme=ocean]{--brand: #0891b2;--brand-light:#22d3ee;--brand-dark: #155e75;--bg: #071a26;--surface: #0c2537;--surface2: #112f45;--border: #1a4060;--text: #e0f4ff;--text2: #b0d8f0;--text-muted: #5a9ab8;--correct: #22d3ee;--shadow: 0 4px 24px rgba(0,0,0,.5);--shadow-brand: 0 4px 20px rgba(8,145,178,.35);--tab-bar-bg: rgba(7,26,38,.88)}[data-theme=purple]{--brand: #7c3aed;--brand-light:#a78bfa;--brand-dark: #4c1d95;--bg: #0f0c1f;--surface: #1a1535;--surface2: #231c48;--border: #2d2558;--text: #f0eeff;--text2: #c4b8f0;--text-muted: #7a6aaa;--shadow: 0 4px 24px rgba(0,0,0,.5);--shadow-brand: 0 4px 20px rgba(124,58,237,.35);--tab-bar-bg: rgba(15,12,31,.88)}[data-theme=amber]{--brand: #d97706;--brand-light:#fbbf24;--brand-dark: #92400e;--bg: #180e00;--surface: #261600;--surface2: #321d00;--border: #452a00;--text: #fff8e8;--text2: #f0d890;--text-muted: #a07838;--shadow: 0 4px 24px rgba(0,0,0,.5);--shadow-brand: 0 4px 20px rgba(217,119,6,.35);--tab-bar-bg: rgba(24,14,0,.88)}html,body{height:100%;background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;font-size:16px;line-height:1.5}#root{height:100%}.app-shell{min-height:100vh;max-width:680px;margin:0 auto;padding:0 16px 48px;display:flex;flex-direction:column}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:.95rem;font-weight:700;padding:13px 28px;border:none;border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-brand);transition:filter .15s,transform .1s,box-shadow .15s;letter-spacing:.01em}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 24px #16a34a73}.btn-primary:active{transform:translateY(0);filter:brightness(.95)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;background:var(--surface2);color:var(--text);font-size:.95rem;font-weight:600;padding:13px 28px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:background .15s,border-color .15s}.btn-secondary:hover{background:var(--surface);border-color:var(--text-muted)}.btn-ghost{background:transparent;border:none;color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;padding:6px 10px;border-radius:var(--r-sm);transition:color .15s,background .15s}.btn-ghost:hover{color:var(--text);background:var(--surface2)}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:48px 32px;text-align:center;width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:12px}.login-tagline{font-size:.9rem;color:var(--text-muted);margin-bottom:8px;line-height:1.5}.btn-google{display:flex;align-items:center;gap:12px;background:#fff;color:#3c4043;font-size:.95rem;font-weight:600;padding:12px 24px;border:none;border-radius:var(--radius);cursor:pointer;margin-top:8px;transition:box-shadow .15s;width:100%;justify-content:center}.btn-google:hover{box-shadow:0 2px 12px #0000004d}.loading-shell{display:flex;align-items:center;justify-content:center}.loading-dot{width:10px;height:10px;background:var(--brand);border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.onboard-screen{display:flex;flex-direction:column;gap:20px;padding:28px 20px 40px;min-height:100%;overflow-y:auto;animation:fade-up .3s ease}.onboard-header{display:flex;align-items:center;gap:16px;padding:20px;border-radius:var(--r-xl);background:linear-gradient(135deg,var(--brand) 0%,var(--brand-light) 100%);color:#fff}.onboard-header-text{flex:1;min-width:0}.onboard-title{font-size:1.3rem;font-weight:800;margin:0 0 4px;color:#fff}.onboard-subtitle{font-size:.85rem;margin:0;opacity:.85;color:#fff}.onboard-suggestions{display:flex;flex-direction:column;gap:12px;padding:18px;border-radius:var(--r-xl);background:var(--surface);border:1px solid rgba(99,102,241,.3);box-shadow:0 0 0 4px #6366f10f}.onboard-suggestions-header{display:flex;align-items:flex-start;gap:12px}.onboard-suggestions-icon{font-size:1.6rem;flex-shrink:0}.onboard-suggestions-title{font-size:.78rem;color:var(--text-muted);margin:0 0 2px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.onboard-suggestions-district{font-size:1rem;font-weight:700;color:var(--text);margin:0}.onboard-suggestions-list{display:flex;flex-direction:column;gap:8px}.onboard-suggestion-btn{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:var(--r-lg);border:1px solid var(--brand);background:#6366f10f;cursor:pointer;font-family:inherit;text-align:left;transition:background .15s,transform .1s;gap:10px}.onboard-suggestion-btn:hover{background:#6366f124;transform:translate(2px)}.onboard-suggestion-name{font-size:.95rem;font-weight:600;color:var(--text);flex:1}.onboard-suggestion-arrow{font-size:1rem;color:var(--brand);font-weight:700;flex-shrink:0}.onboard-browse-link{background:none;border:none;font-family:inherit;font-size:.83rem;color:var(--text-muted);cursor:pointer;padding:4px 0;text-align:left;text-decoration:underline;text-underline-offset:3px;transition:color .15s}.onboard-browse-link:hover{color:var(--brand)}.onboard-picker{display:flex;flex-direction:column;gap:10px}.onboard-picker-label{font-size:.85rem;font-weight:700;color:var(--text);margin:0}.onboard-school-list{display:flex;flex-direction:column;gap:4px;max-height:380px;overflow-y:auto;border-radius:var(--r-lg);border:1px solid var(--border);padding:6px;background:var(--surface)}.onboard-skip-btn{background:none;border:none;font-family:inherit;font-size:.82rem;color:var(--text-muted);cursor:pointer;padding:6px;text-align:center;align-self:center;opacity:.6;transition:opacity .15s}.onboard-skip-btn:hover{opacity:1}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.home-screen{padding-top:0;padding-bottom:72px;min-height:100vh;display:flex;flex-direction:column}.home-header--compact{padding:12px 16px 10px;border-bottom:1px solid var(--border);margin-bottom:0;text-align:left}.home-title-row{display:flex;align-items:center;gap:8px}.home-header{text-align:center;margin-bottom:32px}.app-title{font-size:1.4rem;font-weight:900;background:linear-gradient(120deg,#4ade80,#22c55e 50%,#86efac);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.01em}.app-subtitle{font-size:.75rem;font-weight:600;color:var(--text-muted);letter-spacing:.03em;text-transform:uppercase}.app-tagline{font-size:.9rem;color:var(--text-muted);margin-top:8px}.xp-badge-header{font-size:.75rem;font-weight:700;color:#fbbf24;background:#1a1200;border:1px solid #78350f;border-radius:99px;padding:2px 10px;margin-left:auto}.tab-panel{padding:14px 16px;flex:1;overflow-y:auto;animation:fade-up .18s ease both;display:flex;flex-direction:column;gap:12px}.avatar-img{border-radius:50%;object-fit:cover;flex-shrink:0}.avatar-placeholder{border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--text-muted);flex-shrink:0}.user-bar{display:flex;align-items:center;gap:8px;margin-bottom:4px}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-name{font-size:.9rem;font-weight:600;color:var(--text-muted)}.logout-btn{font-size:.8rem;margin-left:auto}.stats-bar{display:flex;justify-content:center;gap:12px;margin-top:16px}.stat-chip{display:flex;flex-direction:column;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 20px;min-width:80px}.stat-value{font-size:1.3rem;font-weight:800;color:var(--brand-light)}.stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.recent-section{margin-top:24px}.recent-title{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.recent-list{display:flex;flex-direction:column;gap:8px}.recent-row{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 16px}.recent-topic{flex:1;font-size:.85rem;color:var(--text-muted)}.recent-fraction{font-size:.82rem;color:var(--text-muted)}.recent-pct{font-size:.9rem;font-weight:700;width:44px;text-align:right}.topic-grid-section{display:grid;grid-template-columns:1fr 1fr;gap:10px}.topic-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 16px;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s,background .2s;text-align:left}.topic-card:hover:not(.topic-card--locked){border-color:var(--brand);transform:translateY(-2px);background:#16a34a0d;box-shadow:0 8px 28px #16a34a33}.topic-card:active:not(.topic-card--locked){transform:translateY(0)}.topic-card--all{grid-column:1 / -1;flex-direction:row;align-items:center;gap:14px;background:linear-gradient(135deg,#0d3520,#134d2a);border-color:#22c55e66;padding:20px}.topic-card--all:hover{border-color:var(--brand-light)!important;box-shadow:0 8px 28px #22c55e4d!important}.topic-icon{font-size:1.9rem;line-height:1}.topic-name{font-size:.95rem;font-weight:700;color:var(--text)}.topic-count{font-size:.75rem;color:var(--text-muted)}.topic-card--all .topic-name{font-size:1.05rem}.topic-card--all .topic-count{margin-left:auto}.quiz-screen{padding-top:20px;display:flex;flex-direction:column;gap:16px;animation:fade-up .2s ease both}.quiz-topbar{display:flex;align-items:center;justify-content:space-between}.timer{position:relative;height:8px;background:var(--surface2);border-radius:99px;overflow:hidden}.timer-bar{height:100%;background:var(--brand);border-radius:99px;transition:width 1s linear,background .3s}.timer-bar--urgent{background:var(--wrong)}.timer-label{position:absolute;right:0;top:-20px;font-size:.75rem;color:var(--text-muted)}.timer-label--urgent{color:var(--wrong);font-weight:700}.score-display{display:flex;align-items:center;gap:12px}.score-block{display:flex;align-items:baseline;gap:4px}.score-value{font-size:1.5rem;font-weight:800;color:var(--brand-light)}.score-label{font-size:.8rem;color:var(--text-muted)}.streak-block{display:flex;align-items:center;gap:4px}.streak-fire{font-size:1.1rem}.streak-count{font-size:1.1rem;font-weight:700}.streak-multiplier{font-size:.75rem;font-weight:700;background:var(--warn);color:#000;padding:1px 6px;border-radius:99px}.progress-bar-wrapper{display:flex;flex-direction:column;gap:6px}.progress-meta{display:flex;justify-content:space-between;font-size:.8rem}.progress-topic{color:var(--text-muted);font-weight:500}.progress-count{color:var(--text-muted)}.progress-track{height:6px;background:var(--surface2);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-light));border-radius:99px;transition:width .4s ease}.question-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px 20px;box-shadow:var(--shadow)}.question-topic-tag{display:inline-block;font-size:.72rem;font-weight:700;color:var(--brand-light);background:#22c55e1a;border:1px solid rgba(34,197,94,.2);padding:3px 10px;border-radius:99px;margin-bottom:12px;letter-spacing:.02em}.question-text{font-size:1.1rem;font-weight:600;line-height:1.55;margin-bottom:20px;color:var(--text)}.choices{display:flex;flex-direction:column;gap:8px}.choice{display:flex;align-items:flex-start;gap:12px;background:var(--surface2);border:1.5px solid transparent;border-radius:var(--r-md);padding:13px 15px;cursor:pointer;font-size:.95rem;text-align:left;color:var(--text);transition:border-color .15s,background .15s,transform .12s}.choice:hover:not(:disabled){border-color:var(--brand);background:#16a34a1a;transform:translate(3px)}.choice:active:not(:disabled){transform:translate(1px)}.choice:disabled{cursor:default}.choice--correct{border-color:var(--correct);background:#22c55e1f}.choice--wrong{border-color:var(--wrong);background:#ef44441a}.choice--dim{opacity:.4}.choice-label{flex-shrink:0;width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:#ffffff12;border-radius:var(--r-sm);font-size:.78rem;font-weight:700;color:var(--text-muted)}.choice--correct .choice-label{background:var(--correct);color:#fff}.choice--wrong .choice-label{background:var(--wrong);color:#fff}.choice-text{line-height:1.45;padding-top:1px;font-size:.93rem}.feedback-banner{margin-top:16px;padding:14px 16px;border-radius:10px;font-size:.9rem;line-height:1.5;animation:slideUp .2s ease}.feedback-banner--correct{background:#22c55e26;border:1px solid var(--correct);color:var(--correct);font-weight:600}.feedback-banner--wrong{background:#ef444414;border:1px solid var(--wrong);display:flex;flex-direction:column;gap:8px}.feedback-wrong-header{font-weight:700;color:var(--wrong);font-size:.9rem}.feedback-correct-line{font-size:.88rem;color:var(--text)}.feedback-correct-line strong{color:var(--correct)}.feedback-explanation{font-size:.85rem;color:var(--text-muted);line-height:1.55;padding-top:4px;border-top:1px solid rgba(255,255,255,.06)}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.next-btn{width:100%;padding:14px;font-size:1rem}.results-screen{padding-top:32px;display:flex;flex-direction:column;gap:24px;animation:fade-up .22s ease both}.results-hero{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:36px 24px 28px;display:flex;flex-direction:column;align-items:center;gap:4px}.results-emoji{font-size:3.5rem;line-height:1;margin-bottom:6px}.results-grade{font-size:1.7rem;font-weight:900;letter-spacing:-.02em}.results-score{font-size:2.6rem;font-weight:900;color:var(--brand-light);letter-spacing:-.02em;line-height:1.1}.results-fraction{font-size:.95rem;color:var(--text-muted)}.results-streak{font-size:.9rem;color:var(--warn);font-weight:600}.topic-breakdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px}.breakdown-title{font-size:1rem;font-weight:700;margin-bottom:16px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.breakdown-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.breakdown-icon{font-size:1.1rem;flex-shrink:0}.breakdown-topic{font-size:.85rem;width:160px;flex-shrink:0;color:var(--text-muted)}.breakdown-bar-track{flex:1;height:8px;background:var(--surface2);border-radius:99px;overflow:hidden}.breakdown-bar-fill{height:100%;border-radius:99px;transition:width .6s ease}.breakdown-pct{font-size:.8rem;color:var(--text-muted);width:36px;text-align:right}.results-actions{display:flex;gap:12px}.results-actions .btn-primary,.results-actions .btn-secondary{flex:1;padding:14px}.review-section{display:flex;flex-direction:column;gap:12px}.review-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 20px;color:var(--text);font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s}.review-toggle:hover{border-color:var(--brand);background:#16a34a0a}.review-toggle-sub{font-size:.8rem;font-weight:400;color:var(--text-muted)}.review-list{display:flex;flex-direction:column;gap:12px}.review-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 20px;display:flex;flex-direction:column;gap:8px}.review-item--correct{border-left:3px solid var(--correct)}.review-item--wrong{border-left:3px solid var(--wrong)}.review-item-header{display:flex;align-items:center;justify-content:space-between}.review-num{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.review-status{font-size:.8rem;font-weight:600}.review-item--correct .review-status{color:var(--correct)}.review-item--wrong .review-status{color:var(--wrong)}.review-question{font-size:.9rem;font-weight:500;line-height:1.5;color:var(--text)}.review-your-answer,.review-correct-answer{font-size:.82rem;color:var(--text-muted)}.review-wrong-text{color:var(--wrong);font-weight:600}.review-correct-text{color:var(--correct);font-weight:600}.review-explanation{font-size:.82rem;color:var(--text-muted);line-height:1.5;background:#ffffff0a;border-radius:8px;padding:8px 12px}.streak-card{display:flex;flex-direction:column;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;transition:border-color .25s,background .25s}.streak-card--done{border-color:#f59e0b66;background:#f59e0b0a}.streak-card-top{display:flex;align-items:center;justify-content:space-between}.streak-card-left{display:flex;align-items:center;gap:12px;flex-shrink:0}.xp-badge{font-size:.8rem;font-weight:700;color:#c4b5fd;background:#8b5cf626;border:1px solid rgba(139,92,246,.35);border-radius:99px;padding:5px 12px;letter-spacing:.01em}.buy-streak-btn{width:100%;background:#a78bfa1a;border:1px dashed rgba(167,139,250,.5);border-radius:10px;color:#c4b5fd;font-size:.85rem;padding:10px 14px;cursor:pointer;transition:background .15s,border-color .15s;text-align:center}.buy-streak-btn:hover:not(:disabled){background:#a78bfa33;border-color:#a78bfa}.buy-streak-btn--disabled{opacity:.5;cursor:not-allowed}.buy-streak-hint{font-size:.75rem;opacity:.7}.streak-card-flame{font-size:1.8rem}.streak-card-count{font-size:1.2rem;font-weight:800;color:#f59e0b;line-height:1}.streak-card-status{font-size:.72rem;color:var(--text-muted);margin-top:3px}.streak-week{display:flex;gap:6px}.streak-day{display:flex;flex-direction:column;align-items:center;gap:4px}.streak-dot{width:26px;height:26px;border-radius:50%;background:var(--surface2);border:2px solid transparent;transition:background .2s,border-color .2s,box-shadow .2s}.streak-dot--studied{background:#f59e0b;box-shadow:0 2px 8px #f59e0b66}.streak-dot--today{border-color:#f59e0b}.streak-dot--studied.streak-dot--today{background:#f59e0b;border-color:#fbbf24;box-shadow:0 2px 10px #f59e0b80}.streak-day-label{font-size:.62rem;color:var(--text-muted);font-weight:500}.streak-day-label--today{color:#f59e0b;font-weight:700}.unlock-path{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px}.unlock-path-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.unlock-path-label{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.unlock-path-count{font-size:.75rem;color:var(--brand-light);font-weight:600}.unlock-path-track{display:flex;align-items:center}.unlock-step{display:flex;align-items:center;flex:1}.unlock-step:last-child{flex:none}.unlock-node{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0;border:2px solid;transition:background .2s,border-color .2s}.unlock-node--passed{background:var(--brand);border-color:var(--brand);color:#fff}.unlock-node--open{background:#16a34a26;border-color:var(--brand);color:var(--brand-light)}.unlock-node--locked{background:var(--surface2);border-color:var(--surface2);color:var(--text-muted);font-size:.9rem}.unlock-connector{flex:1;height:2px;background:var(--surface2);transition:background .3s}.unlock-connector--passed{background:var(--brand)}.topic-card--locked{opacity:.55;cursor:not-allowed;filter:grayscale(.4)}.topic-card--locked:hover{border-color:var(--surface2)!important;transform:none!important;box-shadow:none!important}.topic-locked-hint{font-size:.72rem;color:var(--text-muted);line-height:1.3}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.quick-practice{grid-column:1 / -1;display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#132d52,#1a3d6e);border:1px solid #2d5a9e;border-radius:var(--radius);padding:18px 20px;cursor:pointer;text-align:left;color:var(--text);transition:border-color .15s,transform .1s,box-shadow .15s}.quick-practice:hover{border-color:#4d8ed4;transform:translateY(-1px);box-shadow:0 6px 20px #2d5a9e59}.quick-diagnostic{display:flex;flex-direction:column;align-items:flex-start;gap:4px;background:linear-gradient(135deg,#1a1942,#231e5c);border:1px solid #3730a3;border-radius:var(--radius);padding:16px;cursor:pointer;color:var(--text);transition:border-color .15s,transform .1s}.quick-diagnostic:hover{border-color:#6366f1;transform:translateY(-1px)}.quick-analytics{display:flex;flex-direction:column;align-items:flex-start;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;color:var(--text);transition:border-color .15s,transform .1s}.quick-analytics:hover{border-color:var(--brand);transform:translateY(-1px)}.quick-icon{font-size:1.7rem;line-height:1}.quick-name{font-size:.95rem;font-weight:700;margin:0}.quick-sub{font-size:.75rem;color:var(--text-muted);margin:0}.mastery-badge{display:inline-block;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:99px;border:1px solid}.streak-badge{font-size:.8rem;font-weight:700;color:#f59e0b;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:99px;padding:2px 10px}.topic-card-header{display:flex;justify-content:space-between;align-items:flex-start;width:100%;margin-bottom:4px}.practice-screen{display:flex;flex-direction:column;min-height:100vh}.practice-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--surface2);margin-bottom:12px}.practice-exit{color:var(--wrong)!important;font-weight:600}.practice-label{font-size:.75rem;font-weight:800;color:var(--text-muted);letter-spacing:.08em}.practice-timer{font-size:.85rem;color:var(--text-muted)}.dot-nav{display:flex;flex-wrap:wrap;gap:6px;padding-bottom:14px;border-bottom:1px solid var(--surface2);margin-bottom:16px}.dot{width:30px;height:30px;border-radius:6px;background:var(--surface2);border:none;color:var(--text-muted);font-size:.75rem;font-weight:600;cursor:pointer;transition:background .12s}.dot--answered{background:#16a34a66;color:var(--text)}.dot--current{background:var(--brand);color:#fff}.practice-body{display:flex;flex-direction:column;gap:16px}.practice-q-number{font-size:.75rem;font-weight:700;color:var(--text-muted);letter-spacing:.05em}.practice-q-text{font-size:1.05rem;font-weight:500;line-height:1.6}.choice--selected{border-color:var(--brand);background:#16a34a1f}.choice--selected .choice-label{background:var(--brand);color:#fff}.btn-disabled{opacity:.45;cursor:not-allowed}.practice-review{padding-top:32px;display:flex;flex-direction:column;gap:20px}.practice-hero{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:4px}.practice-big-score{font-size:4rem;font-weight:900;color:var(--text);line-height:1}.practice-out-of{font-size:1rem;color:var(--text-muted)}.practice-passing{font-size:.85rem;color:var(--correct);font-weight:600;margin-top:4px}.practice-failing{font-size:.85rem;color:var(--wrong);text-align:center;margin-top:4px}.review-section-label{font-size:.75rem;font-weight:700;color:var(--text-muted);letter-spacing:.08em}.practice-review-list{display:flex;flex-direction:column;gap:8px}.practice-review-row{background:var(--surface);border:1px solid var(--surface2);border-radius:10px;padding:12px 16px;display:flex;flex-direction:column;gap:6px}.practice-review-row.review-item--correct{border-left:3px solid var(--correct)}.practice-review-row.review-item--wrong{border-left:3px solid var(--wrong)}.analytics-screen{padding-top:20px;display:flex;flex-direction:column;gap:16px;animation:fade-up .2s ease both}.analytics-topbar{display:flex;align-items:center;justify-content:space-between}.analytics-title{font-size:1.1rem;font-weight:800}.analytics-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.analytics-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:4px}.analytics-stat-card--highlight{border-color:var(--brand);background:#16a34a14}.analytics-stat-value{font-size:1.2rem;font-weight:800}.analytics-stat-value--highlight{color:var(--brand-light)}.analytics-stat-label{font-size:.65rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;text-align:center}.analytics-insight{display:flex;align-items:center;gap:12px;border-radius:10px;padding:14px 16px;border:1px solid}.analytics-insight--weak{background:#ef444414;border-color:#ef444466}.analytics-insight--strong{background:#22c55e14;border-color:#22c55e66}.analytics-insight-icon{font-size:1.5rem}.analytics-insight-label{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.analytics-insight-value{font-size:.9rem;color:var(--text);font-weight:600;margin-top:2px}.analytics-section-label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}.analytics-topic-row{display:flex;align-items:center;gap:10px}.analytics-topic-icon{font-size:1.1rem;width:28px;flex-shrink:0}.analytics-topic-info{flex:1;display:flex;flex-direction:column;gap:4px}.analytics-topic-meta{display:flex;justify-content:space-between}.analytics-topic-name{font-size:.85rem;font-weight:600}.analytics-topic-stat{font-size:.75rem;color:var(--text-muted)}.analytics-bar-track{height:7px;background:var(--surface2);border-radius:99px;overflow:hidden}.analytics-bar-fill{height:100%;border-radius:99px;transition:width .5s ease}.analytics-pct{font-size:.85rem;font-weight:700;width:38px;text-align:right;flex-shrink:0}.analytics-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:40px 0;color:var(--text-muted);font-size:.9rem}.diagram-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-align:center;margin-bottom:8px;letter-spacing:.04em}.diagram-punnett{display:flex;flex-direction:column;align-items:center;margin-bottom:16px}.punnett-grid{display:grid;grid-template-columns:repeat(3,52px);border:1px solid var(--surface2);border-radius:8px;overflow:hidden}.punnett-cell{height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:.5px solid var(--surface2);font-size:1rem;font-weight:700;color:var(--text)}.punnett-header{background:var(--surface2);font-size:1rem;font-weight:800;color:var(--brand-light)}.diagram-foodweb{margin-bottom:16px}.foodweb-level{display:flex;flex-direction:column;align-items:center}.foodweb-card{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid transparent;border-radius:10px;padding:10px 14px;width:100%}.foodweb-card--highlight{border-color:var(--brand-light);background:#16a34a26}.foodweb-emoji{font-size:1.4rem}.foodweb-label{font-size:.85rem;font-weight:700;color:var(--text)}.foodweb-label--highlight{color:var(--brand-light)}.foodweb-examples{font-size:.72rem;color:var(--text-muted);margin-top:1px}.foodweb-arrow{font-size:.75rem;color:var(--text-muted);padding:2px 0}.diag-results{padding-top:32px;display:flex;flex-direction:column;gap:24px}.diag-hero{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 20px;display:flex;flex-direction:column;align-items:center;gap:6px}.diag-hero-emoji{font-size:2.8rem}.diag-hero-label{font-size:1.5rem;font-weight:800;margin:0}.diag-hero-score{font-size:1rem;color:var(--text-muted)}.diag-hero-sub{font-size:.75rem;color:var(--text-muted);margin-top:2px}.diag-section{display:flex;flex-direction:column;gap:10px}.diag-section-label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.diag-weak-list{display:flex;flex-direction:column;gap:10px}.diag-weak-card{background:#ef44440f;border:1px solid rgba(239,68,68,.35);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:12px}.diag-weak-header{display:flex;align-items:center;gap:12px}.diag-topic-icon{font-size:1.4rem;flex-shrink:0}.diag-weak-info{flex:1}.diag-topic-name{font-size:.95rem;font-weight:700}.diag-topic-score{font-size:.78rem;color:var(--text-muted);margin-top:2px}.diag-bar-wrap{width:80px;flex-shrink:0}.diag-bar-track{height:7px;background:var(--surface2);border-radius:99px;overflow:hidden}.diag-bar-fill{height:100%;border-radius:99px;transition:width .5s ease}.diag-bar-fill--weak{background:#ef4444}.diag-bar-fill--passing{background:#f59e0b}.diag-bar-fill--strong{background:#22c55e}.diag-practice-btn{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:10px 16px;font-size:.88rem;font-weight:600;cursor:pointer;text-align:left;transition:background .15s}.diag-practice-btn:hover{background:var(--brand-light)}.diag-breakdown{display:flex;flex-direction:column;gap:10px}.diag-row{display:flex;align-items:center;gap:10px}.diag-row-icon{font-size:1.1rem;width:26px;flex-shrink:0}.diag-row-name{font-size:.82rem;color:var(--text-muted);width:150px;flex-shrink:0}.diag-row-bar-track{flex:1;height:7px;background:var(--surface2);border-radius:99px;overflow:hidden}.diag-row-bar-fill{height:100%;border-radius:99px;transition:width .5s ease}.diag-row-pct{font-size:.82rem;font-weight:700;width:36px;text-align:right;flex-shrink:0}.diag-legend{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;font-size:.72rem}.diag-legend-item{color:var(--text-muted)}.diag-legend--strong{color:#22c55e}.diag-legend--passing{color:#f59e0b}.diag-legend--weak{color:#ef4444}.quick-achievements{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#1a1a2e;border:1px solid #4a3f6b;border-radius:var(--radius);padding:14px 10px;cursor:pointer;color:var(--text);transition:border-color .15s,transform .1s;text-align:center}.quick-achievements:hover{border-color:gold;transform:translateY(-1px)}.achievements-screen{padding:16px;max-width:600px;margin:0 auto}.achievements-header{margin-bottom:24px}.achievements-title{font-size:1.4rem;font-weight:800;margin:8px 0 4px}.achievements-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:10px}.achievements-progress-bar{height:6px;background:var(--surface2);border-radius:99px;overflow:hidden}.achievements-progress-fill{height:100%;background:linear-gradient(90deg,gold,#f59e0b);border-radius:99px;transition:width .5s ease}.achievements-tier-section{margin-bottom:24px}.achievements-tier-heading{font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.achievement-card{position:relative;background:var(--surface);border:1px solid var(--surface2);border-radius:var(--radius);padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:transform .1s}.achievement-card--earned{cursor:default}.achievement-card--earned:hover{transform:translateY(-2px)}.achievement-card--locked{opacity:.55}.achievement-card-emoji{font-size:1.8rem}.achievement-card-name{font-size:.78rem;font-weight:700;line-height:1.2}.achievement-card-desc{font-size:.68rem;color:var(--text-muted);line-height:1.3}.achievement-card-check{position:absolute;top:6px;right:8px;font-size:.7rem;color:#22c55e;font-weight:700}@keyframes toast-in{0%{transform:translateY(80px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.achievement-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:1000;background:#1a1a2e;border:2px solid #ffd700;border-radius:var(--radius);padding:14px 18px;display:flex;align-items:center;gap:14px;box-shadow:0 8px 32px #0009;cursor:pointer;animation:toast-in .35s cubic-bezier(.34,1.56,.64,1) both;max-width:340px;width:calc(100% - 32px)}.achievement-toast-emoji{font-size:2.2rem;flex-shrink:0}.achievement-toast-body{flex:1}.achievement-toast-unlocked{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}.achievement-toast-name{font-size:1rem;font-weight:800;line-height:1.2}.achievement-toast-desc{font-size:.72rem;color:var(--text-muted);margin-top:2px}.achievement-toast-tier{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}.question-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.bookmark-btn{display:flex;align-items:center;gap:4px;background:none;border:1px solid var(--surface2);border-radius:99px;padding:4px 10px;color:var(--text-muted);font-size:.72rem;cursor:pointer;transition:border-color .15s,color .15s,background .15s;flex-shrink:0}.bookmark-btn:hover{border-color:#f59e0b;color:#f59e0b}.bookmark-btn--active{border-color:#f59e0b;color:#f59e0b;background:#1c1000}.bookmark-btn-label{font-weight:600}.bookmarks-screen{padding:16px;max-width:600px;margin:0 auto}.bookmarks-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.bookmarks-title{font-size:1.3rem;font-weight:800}.bookmarks-sub{font-size:.8rem;color:var(--text-muted);margin-top:2px}.bookmarks-empty{text-align:center;padding:60px 24px;display:flex;flex-direction:column;align-items:center;gap:10px}.bookmarks-empty-icon{font-size:3rem}.bookmarks-empty-title{font-size:1.1rem;font-weight:700}.bookmarks-empty-sub{font-size:.85rem;color:var(--text-muted);line-height:1.5;max-width:280px}.bookmarks-practice-btn{width:100%;padding:13px;background:var(--brand);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:700;cursor:pointer;margin-bottom:16px;transition:opacity .15s}.bookmarks-practice-btn:hover{opacity:.85}.bookmarks-list{display:flex;flex-direction:column;gap:10px}.bm-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:border-color .15s,box-shadow .15s}.bm-card:hover{border-color:#f59e0b88;box-shadow:0 4px 14px #f59e0b1f}.bm-card-top{padding:14px 16px;cursor:pointer}.bm-card-meta{margin-bottom:6px}.bm-topic-tag{font-size:.65rem;font-weight:700;letter-spacing:.06em;color:var(--brand-light);text-transform:uppercase}.bm-card-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.bm-question-text{font-size:.88rem;font-weight:600;line-height:1.45;flex:1}.bm-expand-icon{font-size:.65rem;color:var(--text-muted);flex-shrink:0;margin-top:4px}.bm-card-body{padding:12px 16px 16px;border-top:1px solid var(--surface2)}.bm-choices{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.bm-choice{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid transparent;border-radius:8px;padding:8px 12px}.bm-choice--correct{border-color:#22c55e;background:#0d2010}.bm-choice-label{width:20px;height:20px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;flex-shrink:0}.bm-choice-text{flex:1;font-size:.82rem}.bm-choice-check{color:#22c55e;font-size:.82rem}.bm-explanation{font-size:.78rem;color:var(--text-muted);line-height:1.5;border-top:1px solid var(--surface2);padding-top:10px;margin-bottom:12px}.bm-remove-btn{background:none;border:1px solid #ef444455;border-radius:99px;color:#ef4444;font-size:.75rem;padding:4px 12px;cursor:pointer;transition:background .15s}.bm-remove-btn:hover{background:#1a0000}.daily-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;width:100%;text-align:left;color:var(--text);transition:border-color .15s}.daily-card--collapsed{cursor:pointer}.daily-card--collapsed:hover{border-color:#f59e0b}.daily-card--correct{border-color:#22c55e55;background:#0d2010}.daily-card--wrong{border-color:#ef444455;background:#1a0000}.daily-card-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.daily-badge{font-size:.7rem;font-weight:700;background:#78350f;color:#fde68a;border-radius:99px;padding:3px 10px;letter-spacing:.04em}.daily-xp-teaser{font-size:.72rem;font-weight:700;color:#fbbf24}.daily-done-tag,.daily-result-tag{font-size:.72rem;font-weight:700;border-radius:99px;padding:3px 10px}.daily-done-tag--correct,.daily-result-tag--correct{background:#14532d;color:#86efac}.daily-done-tag--wrong,.daily-result-tag--wrong{background:#450a0a;color:#fca5a5}.daily-collapse-btn{margin-left:auto;background:none;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;padding:2px 6px}.daily-question-text,.daily-question-preview{font-size:.9rem;font-weight:600;line-height:1.5;margin-bottom:12px}.daily-question-preview{color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px}.daily-tap-hint{font-size:.72rem;color:var(--brand-light);font-weight:600}.daily-choices{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.daily-choice{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid transparent;border-radius:8px;padding:10px 14px;cursor:pointer;color:var(--text);text-align:left;transition:border-color .12s,background .12s;width:100%}.daily-choice:hover:not(:disabled){border-color:#f59e0b}.daily-choice--selected{border-color:#f59e0b;background:#1c1000}.daily-choices--readonly .daily-choice{cursor:default}.daily-choice--correct{border-color:#22c55e!important;background:#0d2010!important}.daily-choice--wrong{border-color:#ef4444!important;background:#1a0000!important}.daily-choice-letter{width:22px;height:22px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0}.daily-choice-text{flex:1;font-size:.85rem;line-height:1.4}.daily-choice-check{font-size:.85rem;color:#22c55e;flex-shrink:0}.daily-explanation{font-size:.8rem;color:var(--text-muted);line-height:1.5;border-top:1px solid var(--surface2);padding-top:10px;margin-bottom:10px}.daily-next-hint{font-size:.72rem;color:var(--text-muted);text-align:center}.exam-countdown{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px}.exam-countdown-left{display:flex;flex-direction:column;gap:3px}.exam-countdown-label{font-size:.6rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase}.exam-countdown-date{font-size:.85rem;font-weight:700}.exam-countdown-msg{font-size:.75rem;font-weight:500;margin-top:2px}.exam-countdown-right{display:flex;flex-direction:column;align-items:center;flex-shrink:0;margin-left:12px}.exam-countdown-days{font-size:2.4rem;font-weight:900;line-height:1}.exam-countdown-days-label{font-size:.65rem;color:var(--text-muted);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-top:2px}.exam-countdown-today,.exam-countdown-done{font-size:1.3rem;font-weight:900}.tab-bar{position:fixed;bottom:0;left:0;right:0;max-width:680px;margin:0 auto;display:flex;background:var(--tab-bar-bg);backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-top:1px solid rgba(255,255,255,.06);z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}[data-theme=light] .tab-bar{border-top:1px solid rgba(0,0,0,.07)}.tab-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 4px 12px;background:none;border:none;cursor:pointer;color:var(--text-muted);transition:color .2s;position:relative}.tab-bar-item--active{color:var(--brand-light)}.tab-bar-item--active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:3px;border-radius:0 0 3px 3px;background:var(--brand-light)}.tab-bar-icon{font-size:1.35rem;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.tab-bar-item--active .tab-bar-icon{transform:scale(1.15)}.tab-bar-label{font-size:.63rem;font-weight:600;letter-spacing:.02em}.progress-actions{display:flex;flex-direction:column;gap:10px}.progress-action-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;cursor:pointer;color:var(--text);text-align:left;transition:border-color .15s,transform .1s,box-shadow .15s}.progress-action-card:hover{border-color:var(--brand);transform:translateY(-1px);box-shadow:0 4px 16px #16a34a26}.progress-action-icon{font-size:1.8rem;flex-shrink:0}.progress-action-name{font-size:.95rem;font-weight:700}.progress-action-sub{font-size:.75rem;color:var(--text-muted);margin-top:2px}.rankings-no-school{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 24px;gap:12px}.rankings-no-school-icon{font-size:3rem}.rankings-no-school-title{font-size:1.2rem;font-weight:800}.rankings-no-school-sub{font-size:.85rem;color:var(--text-muted);line-height:1.5}.rankings-set-school-btn{margin-top:8px;padding:12px 24px;background:var(--brand);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .15s}.rankings-set-school-btn:hover{opacity:.85}.rankings-school-banner{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px}.rankings-school-banner-icon{font-size:1.6rem;flex-shrink:0}.rankings-school-banner-label{font-size:.6rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase}.rankings-school-banner-name{font-size:.95rem;font-weight:700;margin-top:2px}.rankings-change-btn{margin-left:auto;font-size:.75rem;color:var(--brand-light);background:none;border:1px solid var(--brand);border-radius:99px;padding:4px 12px;cursor:pointer;flex-shrink:0}.rankings-loading-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px 0;color:var(--text-muted);font-size:.85rem}.rankings-loading-spinner{width:24px;height:24px;border:2px solid var(--surface2);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.rankings-error{color:#ef4444;font-size:.8rem;padding:12px;background:#1a0000;border-radius:var(--radius)}.rankings-be-first{text-align:center;padding:40px 16px;display:flex;flex-direction:column;align-items:center;gap:8px}.rankings-be-first-icon{font-size:2.5rem}.rankings-be-first-msg{font-size:1rem;font-weight:700}.rankings-be-first-sub{font-size:.82rem;color:var(--text-muted)}.rankings-list{display:flex;flex-direction:column;gap:10px}.rankings-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:12px 16px;transition:border-color .15s,box-shadow .15s}.rankings-card:hover:not(.rankings-card--me){border-color:var(--text-muted);box-shadow:0 2px 10px #0003}.rankings-card--me{border-color:var(--brand);background:#0d2010}.rankings-card-rank{width:36px;text-align:center;flex-shrink:0}.rankings-medal{font-size:1.5rem}.rankings-num{font-size:.8rem;font-weight:700;color:var(--text-muted)}.rankings-card-avatar{flex-shrink:0}.rankings-card-info{flex:1;min-width:0}.rankings-card-name{font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rankings-card-you{font-size:.75rem;font-weight:500;color:var(--brand-light)}.rankings-card-xp{font-size:.8rem;color:#fbbf24;font-weight:600;margin-top:2px}.rankings-card-badges{display:flex;gap:3px;flex-wrap:wrap;margin-top:5px}.rankings-badge-emoji{font-size:.9rem;line-height:1}.rankings-search{width:100%;padding:10px 14px;background:var(--surface);border:1px solid var(--surface2);border-radius:var(--radius);color:var(--text);font-size:.9rem;margin-bottom:10px;outline:none;transition:border-color .15s}.rankings-search:focus{border-color:var(--brand)}.rankings-borough-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.rankings-borough-chip{padding:4px 12px;font-size:.7rem;font-weight:600;border-radius:99px;border:1px solid var(--surface2);background:var(--surface);color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s,background .15s}.rankings-borough-chip--active{border-color:var(--brand);background:#166534;color:#fff}.rankings-school-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--surface2);border-radius:var(--radius);padding:12px 14px;cursor:pointer;text-align:left;color:var(--text);transition:border-color .15s,background .15s}.rankings-school-row:hover{border-color:var(--brand);background:#0d2010}.rankings-school-name{font-size:.88rem;font-weight:600}.rankings-school-borough{font-size:.7rem;color:var(--text-muted);margin-top:2px}.rankings-school-arrow{font-size:1.3rem;color:var(--text-muted)}.rankings-empty{text-align:center;color:var(--text-muted);padding:24px 0;font-size:.85rem}.profile-tab{display:flex;flex-direction:column;gap:16px}.profile-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px 16px}.profile-avatar-lg{flex-shrink:0;border:3px solid var(--brand)}.profile-name{font-size:1.15rem;font-weight:800}.profile-email{font-size:.75rem;color:var(--text-muted);margin-top:3px;word-break:break-all}.profile-stats-row{display:flex;gap:8px;flex-wrap:wrap}.profile-stat{flex:1;min-width:70px;display:flex;flex-direction:column;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 8px;text-align:center}.profile-stat-value{font-size:.9rem;font-weight:700}.profile-stat-label{font-size:.65rem;color:var(--text-muted);margin-top:3px;text-transform:uppercase;letter-spacing:.06em}.profile-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}.profile-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.profile-section-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase}.profile-section-edit{font-size:.75rem;color:var(--brand-light);background:none;border:1px solid var(--brand);border-radius:99px;padding:3px 10px;cursor:pointer}.profile-school-display{display:flex;align-items:center;gap:10px}.profile-school-icon{font-size:1.4rem}.profile-school-name{font-size:.95rem;font-weight:700}.profile-school-picker{display:flex;flex-direction:column;gap:0}.profile-school-list{display:flex;flex-direction:column;gap:6px;max-height:280px;overflow-y:auto;margin-bottom:10px}.profile-cancel-btn{width:100%;padding:10px;background:none;border:1px solid var(--surface2);border-radius:var(--radius);color:var(--text-muted);font-size:.85rem;cursor:pointer;margin-top:4px}.profile-signout-btn{width:100%;padding:13px;background:none;border:1px solid #ef4444;border-radius:var(--radius);color:#ef4444;font-size:.9rem;font-weight:700;cursor:pointer;transition:background .15s}.profile-signout-btn:hover{background:#1a0000}.quick-flashcards{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#1a2e1a;border:1px solid #2d5a2d;border-radius:var(--radius);padding:14px 10px;cursor:pointer;color:var(--text);transition:border-color .15s,transform .1s;text-align:center}.quick-flashcards:hover{border-color:#4ade80;transform:translateY(-1px)}.flashcard-screen{padding:16px;max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:12px;min-height:100vh}.flashcard-header{display:flex;align-items:center;gap:12px}.flashcard-title{font-size:1.3rem;font-weight:800}.flashcard-topic-row{display:flex;gap:6px;flex-wrap:wrap}.fc-topic-chip{padding:5px 12px;font-size:.72rem;font-weight:600;border-radius:99px;border:1px solid var(--surface2);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s;white-space:nowrap}.fc-topic-chip--active{border-color:var(--brand);background:#166534;color:#fff}.flashcard-filter-row{display:flex;gap:8px;flex-wrap:wrap}.fc-filter-btn{font-size:.72rem;padding:4px 12px;border-radius:99px;border:1px solid var(--surface2);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s}.fc-filter-btn--active{border-color:#f59e0b;color:#f59e0b}.fc-filter-btn--reset{border-color:#ef4444;color:#ef4444}.flashcard-progress{display:flex;align-items:center;gap:8px}.flashcard-progress-text{font-size:.75rem;color:var(--text-muted);min-width:42px}.flashcard-progress-known-label{font-size:.75rem;color:#22c55e;min-width:32px;text-align:right}.flashcard-progress-bar{flex:1;height:6px;background:var(--surface2);border-radius:99px;position:relative;overflow:hidden}.flashcard-progress-cursor{position:absolute;top:0;left:0;height:100%;background:var(--brand);border-radius:99px;transition:width .3s ease;opacity:.5}.flashcard-progress-known{position:absolute;top:0;left:0;height:100%;background:#22c55e;border-radius:99px;transition:width .4s ease;z-index:1}.flashcard-card{perspective:1000px;height:260px;cursor:pointer;flex-shrink:0}.flashcard-card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .45s cubic-bezier(.4,0,.2,1)}.flashcard-card--flipped .flashcard-card-inner{transform:rotateY(180deg)}.flashcard-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--r-xl);border:1px solid var(--border);padding:24px 20px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:12px}.flashcard-face--front{background:var(--surface)}.flashcard-face--back{background:#1a2e1a;border-color:#2d5a2d;transform:rotateY(180deg)}.flashcard-face-label{font-size:.62rem;font-weight:700;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase}.flashcard-term{font-size:1.5rem;font-weight:800;line-height:1.25}.flashcard-definition{font-size:.88rem;line-height:1.55;color:var(--text)}.flashcard-tap-hint{font-size:.68rem;color:var(--text-muted);margin-top:8px}.flashcard-topic-tag{font-size:.65rem;color:#4ade80;border:1px solid #2d5a2d;border-radius:99px;padding:2px 10px;margin-top:4px}.flashcard-actions{display:flex;gap:12px}.fc-action{flex:1;padding:14px;border-radius:var(--radius);border:none;font-size:.9rem;font-weight:700;cursor:pointer;transition:transform .1s,opacity .1s}.fc-action:hover{transform:translateY(-2px);opacity:.9}.fc-action--learning{background:#7c2d12;color:#fed7aa}.fc-action--known{background:#14532d;color:#bbf7d0}.flashcard-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem;text-align:center}.flashcard-done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:32px 0}.flashcard-done-emoji{font-size:3.5rem}.flashcard-done-title{font-size:1.5rem;font-weight:800}.flashcard-done-stats{font-size:.85rem;color:var(--text-muted)}.flashcard-done-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:280px;margin-top:8px}.fc-btn{padding:13px;border-radius:var(--radius);border:none;font-size:.9rem;font-weight:700;cursor:pointer;transition:transform .1s}.fc-btn:hover{transform:translateY(-1px)}.fc-btn--review{background:#7c2d12;color:#fed7aa}.fc-btn--restart{background:var(--surface2);color:var(--text)}.fc-btn--home{background:transparent;color:var(--text-muted)}@media (max-width: 480px){.topic-grid-section{grid-template-columns:1fr}.topic-card--all{grid-column:1}.breakdown-topic{width:110px}.achievements-grid{grid-template-columns:repeat(2,1fr)}.flashcard-card{height:220px}}.flashcard-tab-panel{padding-bottom:24px}.sr-stats-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 0 4px}.sr-stat{font-size:.75rem;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--surface2)}.sr-stat--due{color:#f87171}.sr-stat--new{color:#60a5fa}.sr-stat--mastered{color:#4ade80}.sr-browse-toggle{margin-left:auto;font-size:.72rem;padding:3px 10px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s}.sr-browse-toggle:hover,.sr-browse-toggle--active{border-color:#818cf8;color:#818cf8;background:#818cf811}.sr-rate-row{display:flex;gap:10px;margin-top:14px}.sr-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;border-radius:14px;border:none;cursor:pointer;transition:transform .12s,opacity .12s;font-family:inherit}.sr-btn:hover{transform:translateY(-2px);opacity:.9}.sr-btn:active{transform:scale(.96)}.sr-btn-icon{font-size:1.3rem}.sr-btn-label{font-size:.85rem;font-weight:700}.sr-btn-hint{font-size:.68rem;opacity:.75}.sr-btn--again{background:#450a0a;color:#fca5a5}.sr-btn--good{background:#1e3a5f;color:#93c5fd}.sr-btn--easy{background:#14532d;color:#86efac}.theme-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}.theme-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 6px 10px;border-radius:14px;border:2px solid var(--surface2);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:all .15s;font-family:inherit;position:relative}.theme-btn:hover{border-color:var(--brand);color:var(--text)}.theme-btn--active{border-color:var(--brand);color:var(--text);background:var(--surface2)}.theme-btn--active:after{content:"✓";position:absolute;top:5px;right:7px;font-size:.65rem;font-weight:800;color:var(--brand-light)}.theme-swatch{width:34px;height:34px;border-radius:50%;border:2px solid rgba(255,255,255,.12);position:relative;overflow:hidden;flex-shrink:0}.theme-swatch:after{content:"";position:absolute;bottom:0;right:0;width:50%;height:50%;border-radius:50% 0 0}.theme-swatch--dark{background:#162032}.theme-swatch--dark:after{background:#22c55e}.theme-swatch--light{background:#fff;border-color:#0000001f}.theme-swatch--light:after{background:#16a34a}.theme-swatch--ocean{background:#0c2537}.theme-swatch--ocean:after{background:#22d3ee}.theme-swatch--purple{background:#1a1535}.theme-swatch--purple:after{background:#a78bfa}.theme-swatch--amber{background:#261600}.theme-swatch--amber:after{background:#fbbf24}.theme-swatch--system{background:linear-gradient(135deg,#162032 50%,#eef2f7 50%)}.theme-swatch--system:after{background:transparent}.theme-btn-label{font-size:.72rem;font-weight:600;letter-spacing:.01em}.friends-pill-row{display:flex;gap:8px;margin-bottom:4px}.friends-pill{flex:1;padding:8px 0;border-radius:20px;border:2px solid var(--surface2);background:var(--surface);color:var(--text-muted);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.friends-pill--active{border-color:var(--brand);color:var(--brand-light);background:#6366f11a}.friend-code-card{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:var(--r-xl);background:var(--surface);border:1px solid var(--border)}.friend-code-left{display:flex;flex-direction:column;gap:2px}.friend-code-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase}.friend-code-value{font-size:1.5rem;font-weight:800;letter-spacing:.12em;color:var(--brand-light);font-variant-numeric:tabular-nums}.friend-code-actions{display:flex;gap:8px}.friend-code-copy,.friend-add-toggle{padding:7px 14px;border-radius:10px;border:none;font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .15s}.friend-code-copy{background:var(--surface2);color:var(--text-muted)}.friend-add-toggle{background:var(--brand);color:#fff}.friend-add-toggle--active{background:#475569}.friend-code-copy:hover,.friend-add-toggle:hover{opacity:.85}.friend-add-form{display:flex;flex-wrap:wrap;gap:8px;padding:12px 14px;background:var(--surface);border-radius:14px;border:1px solid var(--surface2)}.friend-code-input{flex:1;min-width:140px;padding:10px 14px;border-radius:10px;border:2px solid var(--surface2);background:var(--bg);color:var(--text);font-size:1rem;font-weight:700;letter-spacing:.1em;font-family:inherit;outline:none;transition:border-color .15s}.friend-code-input:focus{border-color:var(--brand)}.friend-add-btn{padding:10px 20px;border-radius:10px;border:none;background:var(--brand);color:#fff;font-size:.88rem;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .15s}.friend-add-btn:disabled{opacity:.45;cursor:default}.friend-add-error{width:100%;font-size:.8rem;color:var(--wrong);margin:0;padding-left:2px}.fr-section{display:flex;flex-direction:column;gap:8px}.fr-section-title{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.friend-request-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-lg);background:var(--surface);border:1px solid rgba(99,102,241,.3);background:#6366f10d}.friend-request-info{flex:1;min-width:0}.friend-request-name{font-size:.9rem;font-weight:700;color:var(--text);margin:0}.friend-request-sub{font-size:.75rem;color:var(--text-muted);margin:0}.friend-request-actions{display:flex;gap:6px;flex-shrink:0}.friend-req-accept{padding:7px 14px;border-radius:var(--r-sm);border:none;background:var(--brand);color:#fff;font-size:.82rem;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .15s}.friend-req-accept:hover{opacity:.85}.friend-req-decline{width:32px;height:32px;border-radius:var(--r-sm);border:1px solid rgba(239,68,68,.3);background:#ef444414;color:#ef4444;font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.friend-req-decline:hover{opacity:.7}.lb-add-btn{padding:6px 12px;border-radius:99px;border:1px solid var(--brand);background:transparent;color:var(--brand-light);font-size:.75rem;font-weight:700;font-family:inherit;cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.lb-add-btn:hover:not(:disabled){background:var(--brand);color:#fff}.lb-add-btn--friend,.lb-add-btn--pending{border-color:var(--text-muted);color:var(--text-muted);cursor:default}.challenge-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:14px;background:#f59e0b0f;border:1px solid rgba(245,158,11,.2)}.challenge-card-info{display:flex;align-items:center;gap:10px}.challenge-from{font-size:.9rem;font-weight:600;color:var(--text);margin:0}.challenge-score-hint{font-size:.78rem;color:var(--text-muted);margin:0}.challenge-accept-btn{padding:8px 16px;border-radius:10px;border:none;background:var(--brand);color:#fff;font-size:.84rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:opacity .15s}.challenge-accept-btn:hover{opacity:.85}.friends-empty{padding:24px 0;text-align:center}.friends-empty-title{font-size:.95rem;font-weight:600;color:var(--text);margin:0 0 4px}.friends-empty-sub{font-size:.82rem;color:var(--text-muted);margin:0}.friends-list{display:flex;flex-direction:column;gap:8px}.friends-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--border);transition:border-color .15s}.friends-card:hover{border-color:var(--text-muted)}.friends-rank{font-size:.8rem;font-weight:700;color:var(--text-muted);min-width:24px;text-align:center}.friends-card-info{flex:1;min-width:0}.friends-card-name{font-size:.9rem;font-weight:600;color:var(--text);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friends-card-actions{display:flex;gap:6px;flex-shrink:0}.friends-challenge-btn{width:32px;height:32px;border-radius:8px;border:none;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;background:#6366f126;transition:opacity .15s}.friends-challenge-btn:hover{opacity:.7}.friends-card-meta{display:flex;align-items:center;gap:8px}.friends-card-xp{font-size:.78rem;color:var(--text-muted);margin:0}.battle-record{font-size:.72rem;font-weight:700;color:var(--text-muted);background:var(--surface2);border-radius:6px;padding:1px 6px}.battle-play-btn{padding:5px 12px;border-radius:8px;border:none;background:#22c55e;color:#fff;font-size:.8rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;transition:opacity .15s}.battle-play-btn:hover{opacity:.85}.battle-play-btn--card{padding:8px 16px;border-radius:10px;border:none;background:#22c55e;color:#fff;font-size:.84rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:opacity .15s}.battle-play-btn--card:hover{opacity:.85}.battle-chip{font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:6px;white-space:nowrap}.battle-chip--sent{background:#6366f11f;color:var(--text-muted)}.battle-chip--waiting{background:#f59e0b1f;color:#f59e0b}.battle-chip--incoming{background:#ef44441a;color:#ef4444}.battle-decline-btn{width:32px;height:32px;border-radius:8px;border:1px solid rgba(239,68,68,.3);background:transparent;color:#ef4444;font-size:.85rem;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.battle-decline-btn:hover{background:#ef44441a}.friends-remove-btn{padding:5px 10px;border-radius:8px;border:1px solid rgba(239,68,68,.35);background:transparent;color:#ef4444;font-size:.75rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.friends-remove-btn:hover{background:#ef44441a}.friends-remove-btn--confirm{background:#ef4444;color:#fff;border-color:#ef4444}.friends-remove-btn--confirm:hover{background:#dc2626}.friends-cancel-btn{padding:5px 10px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s;white-space:nowrap}.friends-cancel-btn:hover{background:var(--surface2)}.challenge-result-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface)}.challenge-result-row--win{border-color:#22c55e4d;background:#22c55e0d}.challenge-result-row--loss{border-color:#ef444433;background:#ef44440a}.challenge-result-icon{font-size:1.2rem}.challenge-result-name{font-size:.88rem;font-weight:600;color:var(--text);margin:0}.challenge-result-scores{font-size:.78rem;color:var(--text-muted);margin:0}.activity-feed{display:flex;flex-direction:column;gap:6px}.activity-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border)}.activity-emoji{font-size:1.2rem;flex-shrink:0}.activity-text{flex:1;min-width:0;font-size:.85rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-name{font-weight:700;color:var(--text)}.activity-time{font-size:.72rem;color:var(--text-muted);flex-shrink:0}.challenge-result-scores{display:flex;align-items:center;gap:20px;margin-top:12px}.crs-block{text-align:center}.crs-block--me .crs-pts{color:var(--brand-light)}.crs-pts{font-size:2rem;font-weight:800;margin:0;color:var(--text)}.crs-label{font-size:.8rem;color:var(--text-muted);margin:4px 0 0}.crs-vs{font-size:1rem;font-weight:700;color:var(--text-muted)}.xp-chart-card{padding:16px;border-radius:var(--r-xl);background:var(--surface);border:1px solid var(--border)}.xp-chart-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}.xp-chart-title{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.xp-chart-total{font-size:.88rem;font-weight:700;color:var(--brand-light)}.xp-chart-bars{display:flex;align-items:flex-end;gap:6px;height:90px;overflow-x:auto;padding-bottom:2px}.xp-bar-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:28px;max-width:48px;height:100%}.xp-bar-value{font-size:.65rem;font-weight:600;color:var(--text-muted);white-space:nowrap}.xp-bar-track{flex:1;width:100%;background:var(--surface2);border-radius:5px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;position:relative}.xp-bar-fill{width:100%;border-radius:5px 5px 0 0;transition:height .45s cubic-bezier(.4,0,.2,1);min-height:4px}.xp-bar-label{font-size:.8rem;line-height:1}.xp-chart-legend{display:flex;align-items:center;gap:4px;margin-top:10px;font-size:.72rem;color:var(--text-muted)}.xp-legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.quick-speed{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:16px;border-radius:var(--radius);border:none;background:linear-gradient(135deg,#5b21b6,#4338ca);color:#fff;cursor:pointer;font-family:inherit;transition:filter .15s,transform .1s,box-shadow .15s}.quick-speed:hover{filter:brightness(1.12);transform:translateY(-1px);box-shadow:0 6px 20px #4f46e573}.quick-speed:active{transform:translateY(0)}.quick-speed .quick-icon{font-size:1.7rem;line-height:1}.quick-speed .quick-name{font-size:.95rem;font-weight:700;margin:0}.quick-speed .quick-sub{font-size:.75rem;opacity:.75;margin:0}.quick-context{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;border-radius:var(--r-xl);border:none;cursor:pointer;font-family:inherit;text-align:center;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;transition:filter .15s,transform .1s,box-shadow .15s}.quick-context:hover{filter:brightness(1.12);transform:translateY(-1px);box-shadow:0 6px 20px #0ea5e973}.quick-context:active{transform:translateY(0)}.quick-context .quick-icon{font-size:1.7rem;line-height:1}.quick-context .quick-name{font-size:.95rem;font-weight:700;margin:0}.quick-context .quick-sub{font-size:.75rem;opacity:.75;margin:0}.question-context{background:#0ea5e914;border:1px solid rgba(14,165,233,.25);border-radius:var(--r-lg);padding:14px 16px;margin-bottom:12px}.question-context-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#0ea5e9;margin-bottom:8px}.question-context-text{font-size:.88rem;line-height:1.6;color:var(--text2);margin:0}.speed-round-screen{padding-top:20px;display:flex;flex-direction:column;gap:14px}.speed-timer-block{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 20px 12px;border-radius:var(--r-xl);background:var(--surface);border:2px solid var(--border);transition:border-color .3s,background .3s}.speed-timer-block--urgent{border-color:var(--wrong);background:#ef44440f}.speed-timer-num{font-size:3.5rem;font-weight:800;line-height:1;color:var(--brand-light);font-variant-numeric:tabular-nums;transition:color .3s}.speed-timer-num--urgent{color:var(--wrong);animation:pulse-urgent .5s ease-in-out infinite alternate}@keyframes pulse-urgent{0%{transform:scale(1)}to{transform:scale(1.06)}}.speed-timer-track{width:100%;height:6px;border-radius:3px;background:var(--surface2);overflow:hidden}.speed-timer-fill{height:100%;border-radius:3px;background:var(--brand);transition:width 1s linear,background .3s}.speed-timer-fill--urgent{background:var(--wrong)}.speed-round-meta{width:100%;display:flex;justify-content:space-between;align-items:center;margin-top:2px}.speed-answered-count{font-size:.8rem;color:var(--text-muted)}.speed-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;color:var(--brand-light);opacity:.7}.speed-score-cluster{display:flex;align-items:center;gap:8px}.speed-score{font-size:1.05rem;font-weight:700;color:var(--brand-light)}.speed-streak-badge{font-size:.8rem;font-weight:700;padding:2px 8px;border-radius:20px;background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.speed-question-card{padding:16px;border-radius:16px;background:var(--surface);border:2px solid var(--surface2);transition:border-color .2s,background .2s}.speed-card--correct{border-color:var(--correct);background:#22c55e0f}.speed-card--wrong{border-color:var(--wrong);background:#ef44440f}.speed-topic-tag{font-size:.72rem;font-weight:600;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}.speed-question-text{font-size:1rem;font-weight:600;color:var(--text);line-height:1.4;margin:0}.speed-choices{display:flex;flex-direction:column;gap:8px}.speed-choice{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;border:2px solid var(--surface2);background:var(--surface);color:var(--text);font-size:.9rem;font-family:inherit;cursor:pointer;text-align:left;transition:border-color .15s,background .15s,transform .1s}.speed-choice:hover:not(:disabled){border-color:var(--brand);background:#6366f114;transform:translateY(-1px)}.speed-choice:active:not(:disabled){transform:translateY(0)}.speed-choice:disabled{cursor:default}.speed-choice--correct{border-color:var(--correct);background:#22c55e1f}.speed-choice--wrong{border-color:var(--wrong);background:#ef44441a}.speed-choice-label{min-width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;background:var(--surface2);color:var(--text-muted);flex-shrink:0}.speed-choice--correct .speed-choice-label{background:var(--correct);color:#fff}.speed-choice--wrong .speed-choice-label{background:var(--wrong);color:#fff}.speed-choice-text{font-size:.88rem;line-height:1.35}.speed-round-answered{font-size:.9rem;color:var(--text-muted);margin-top:4px}.review-pts{margin-left:auto;font-size:.78rem;font-weight:600;color:var(--brand-light)}.fc-mode-row{display:flex;gap:8px}.fc-mode-btn{flex:1;padding:10px 12px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.fc-mode-btn--active{background:var(--brand);border-color:var(--brand);color:#fff}.mc-card{padding:20px;border-radius:var(--r-xl);background:var(--surface);border:1px solid var(--border);text-align:center;min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.mc-prompt-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-light)}.mc-prompt-text{font-size:1.1rem;font-weight:700;color:var(--text);line-height:1.4;margin:0}.mc-topic-tag{font-size:.72rem;color:var(--text-muted);margin-top:4px}.mc-options{display:flex;flex-direction:column;gap:8px}.mc-option{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-family:inherit;text-align:left;width:100%;transition:background .12s,border-color .12s,opacity .12s}.mc-option:hover:not(:disabled){border-color:var(--brand);background:#16a34a0f}.mc-option--correct{border-color:#22c55e!important;background:#22c55e1a!important}.mc-option--wrong{border-color:#ef4444!important;background:#ef44441a!important}.mc-option--dim{opacity:.45}.mc-option-letter{width:26px;height:26px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--text-muted);flex-shrink:0}.mc-option--correct .mc-option-letter{background:#22c55e;color:#fff}.mc-option--wrong .mc-option-letter{background:#ef4444;color:#fff}.mc-option-text{flex:1;font-size:.88rem;color:var(--text);line-height:1.4}.mc-option-icon{font-weight:700;font-size:1rem;flex-shrink:0}.mc-option--correct .mc-option-icon{color:#22c55e}.mc-option--wrong .mc-option-icon{color:#ef4444}.lab-section{display:flex;flex-direction:column;gap:8px}.lab-section-title{font-size:.8rem;font-weight:700;color:var(--text-muted);letter-spacing:.04em;margin:0}.lab-btn-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.lab-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 8px;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--border);cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}.lab-btn:hover{border-color:#06b6d4;background:#06b6d412}.lab-btn-icon{font-size:1.4rem}.lab-btn-label{font-size:.72rem;font-weight:600;color:var(--text);text-align:center;line-height:1.3}.lab-btn--all{grid-column:span 3;flex-direction:row;justify-content:center;gap:8px;background:linear-gradient(135deg,#06b6d41f,#0891b21f);border-color:#06b6d466}.lab-btn--all .lab-btn-label{font-size:.82rem}.fc-xp-row{display:flex;align-items:center;gap:10px;position:relative}.fc-xp-total{font-size:.82rem;font-weight:700;color:var(--brand-light);background:#16a34a1a;border:1px solid rgba(22,163,74,.25);padding:4px 10px;border-radius:999px}.fc-xp-flash{font-size:.85rem;font-weight:800;color:#22c55e;animation:xp-pop .9s ease-out forwards;position:absolute;left:120px;pointer-events:none}@keyframes xp-pop{0%{opacity:1;transform:translateY(0) scale(1)}60%{opacity:1;transform:translateY(-14px) scale(1.15)}to{opacity:0;transform:translateY(-28px) scale(.9)}}.profile-admin-btn{width:100%;padding:13px;border-radius:var(--r-lg);background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;margin-bottom:8px}.profile-admin-btn:hover{border-color:var(--brand);color:var(--brand-light)}.admin-screen{display:flex;flex-direction:column;height:100%;overflow-y:auto;background:var(--bg)}.admin-header{display:flex;align-items:center;gap:12px;padding:16px 16px 12px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}.admin-back-btn{background:none;border:none;color:var(--brand-light);font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;padding:6px 10px;border-radius:var(--r-md)}.admin-back-btn:hover{background:var(--surface2)}.admin-title{font-size:1.1rem;font-weight:800;color:var(--text);margin:0}.admin-loading{text-align:center;padding:48px;color:var(--text-muted)}.admin-body{display:flex;flex-direction:column;gap:20px;padding:16px}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:4px}.admin-stat-card--green{border-color:#22c55e66;background:#22c55e12}.admin-stat-card--amber{border-color:#f59e0b66;background:#f59e0b12}.admin-stat-card--blue{border-color:#60a5fa66;background:#60a5fa12}.admin-stat-val{font-size:1.6rem;font-weight:800;color:var(--text)}.admin-stat-lbl{font-size:.7rem;font-weight:600;color:var(--text-muted);text-align:center}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}.admin-section-title{font-size:.95rem;font-weight:700;color:var(--text);margin:0}.admin-section-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border)}.admin-school-list{padding:12px 16px;display:flex;flex-direction:column;gap:9px}.admin-school-row{display:flex;align-items:center;gap:10px}.admin-school-name{font-size:.8rem;color:var(--text);min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-school-bar-track{width:90px;height:6px;background:var(--surface2);border-radius:999px;flex-shrink:0}.admin-school-bar-fill{height:100%;background:var(--brand);border-radius:999px;transition:width .3s}.admin-school-count{font-size:.78rem;font-weight:700;color:var(--text-muted);min-width:20px;text-align:right}.admin-sort-row{display:flex;gap:6px}.admin-sort-btn{padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);color:var(--text-muted);font-family:inherit;font-size:.75rem;font-weight:600;cursor:pointer}.admin-sort-btn--active{background:var(--brand);border-color:var(--brand);color:#fff}.admin-user-list{display:flex;flex-direction:column}.admin-user-row{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border)}.admin-user-row:last-child{border-bottom:none}.admin-user-rank{font-size:.72rem;font-weight:700;color:var(--text-muted);min-width:26px}.admin-user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.admin-user-avatar--init{background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700}.admin-user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.admin-user-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-user-school{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-user-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.admin-user-xp{font-size:.8rem;font-weight:700;color:var(--brand-light)}.admin-user-time{font-size:.7rem;color:var(--text-muted)}
