:root{--bg: #0b1220;--bg-elev: #131c30;--bg-card: #1a2540;--bg-card-hi: #1f2c4d;--border: #243150;--border-hi: #344770;--text: #e6ecff;--text-dim: #8a96b3;--text-faint: #5d6a8a;--primary: #4f9cff;--primary-glow: rgba(79, 156, 255, .4);--accent: #7c3aed;--success: #22c55e;--success-bg: rgba(34, 197, 94, .12);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .12);--warning: #fbbf24;--xp: #a78bfa;--gold: #fbbf24;--radius: 12px;--radius-lg: 16px;--nav-h: 64px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;width:100%;min-height:100vh;min-height:100dvh}body{background:radial-gradient(ellipse at top,#1a2540,#0b1220 60%) fixed;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior-y:none}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;font-family:inherit}input,select,textarea{font:inherit;color:inherit;font-family:inherit}a{color:inherit;text-decoration:none}.loading-screen,.page-loading{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--text-dim);padding:2rem}.auth-shell{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.auth-card{width:100%;max-width:380px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 1.5rem;box-shadow:0 25px 50px #0006}.brand{text-align:center;margin-bottom:1.5rem}.brand-logo-img{display:block;width:180px;height:180px;margin:0 auto .5rem;border-radius:18px;object-fit:cover;box-shadow:0 12px 32px #00000073}.brand-tagline{font-size:.875rem;color:var(--text-dim);margin-top:.25rem}.auth-tabs{display:flex;background:var(--bg-elev);padding:4px;border-radius:10px;margin-bottom:1.25rem}.auth-tabs button{flex:1;padding:.5rem;border-radius:7px;font-weight:600;color:var(--text-dim);transition:all .15s}.auth-tabs button.active{background:var(--bg-card);color:var(--text);box-shadow:0 2px 6px #0000004d}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form label{display:flex;flex-direction:column;gap:.35rem}.auth-form label span{font-size:.8rem;color:var(--text-dim);font-weight:500}.auth-form input{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:.75rem .875rem;font-size:1rem;outline:none;transition:border-color .15s,box-shadow .15s}.auth-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.auth-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:.625rem .875rem;border-radius:8px;font-size:.875rem}.auth-submit{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;padding:.875rem;border-radius:10px;font-weight:700;font-size:1rem;letter-spacing:.01em;transition:transform .1s,box-shadow .15s;box-shadow:0 4px 12px var(--primary-glow)}.auth-submit:hover{box-shadow:0 6px 20px var(--primary-glow)}.auth-submit:active{transform:scale(.98)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:#0b1220eb;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10;padding-top:max(.875rem,env(safe-area-inset-top))}.brand-mini{display:flex;align-items:center;gap:.5rem}.brand-mini-logo-img{display:block;height:64px;width:64px;border-radius:12px;object-fit:cover}.header-stats{display:flex;align-items:center;gap:.5rem}.hs-pill{display:inline-flex;align-items:center;gap:.35rem;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;padding:.3rem .7rem;font-size:.85rem}.hs-label{color:var(--text-dim);font-weight:600;font-size:.7rem;letter-spacing:.04em}.hs-value{font-weight:700}.app-main{flex:1;padding:1.25rem;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 1.25rem);max-width:720px;width:100%;margin:0 auto}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:stretch;background:#131c30f2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);z-index:20;padding-bottom:env(safe-area-inset-bottom)}.bn-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-faint);padding:.6rem .25rem;font-size:.7rem;font-weight:600;min-height:var(--nav-h);transition:color .1s}.bn-tab.active{color:var(--primary)}.bn-tab:active{background:#ffffff0a}.bn-icon{font-size:1.25rem;line-height:1}.bn-label{font-size:.65rem;letter-spacing:.02em}.home-page{display:flex;flex-direction:column;gap:1.25rem}.welcome-block{padding:.5rem .25rem}.welcome-sub{color:var(--xp);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.25rem}.welcome-title{font-size:1.85rem;margin:0;letter-spacing:-.02em;font-weight:700}.welcome-title-btn{display:inline-flex;align-items:center;gap:.55rem;padding:0;border:0;background:none;cursor:pointer;color:inherit;border-radius:8px;margin-left:-2px;transition:opacity .1s}.welcome-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--accent));font-size:1.5rem;box-shadow:0 6px 18px var(--primary-glow);line-height:1}.welcome-title-btn:hover{opacity:.85}.welcome-title-btn:active{transform:scale(.98)}.welcome-edit-icon{font-size:.9rem;color:var(--text-faint);padding:.15rem .35rem;border-radius:6px;background:var(--bg-card)}.name-edit{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;margin-top:.1rem}.name-input{flex:1;min-width:140px;background:var(--bg-elev);border:1.5px solid var(--primary);border-radius:10px;padding:.55rem .75rem;font-size:1.15rem;font-weight:700;letter-spacing:-.01em;outline:none}.name-save{background:var(--primary);color:#fff;padding:.55rem .95rem;border-radius:10px;font-weight:700;font-size:.9rem}.name-save:disabled{opacity:.6}.name-cancel{background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);padding:.55rem .85rem;border-radius:10px;font-weight:600;font-size:.9rem}.name-error{flex-basis:100%;font-size:.8rem;color:#fca5a5}.xp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.25rem}.xp-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.6rem;font-size:.85rem}.xp-level{font-weight:700;font-size:1rem}.xp-text{color:var(--text-dim)}.xp-bar{width:100%;height:8px;background:var(--bg-elev);border-radius:4px;overflow:hidden}.xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--xp));border-radius:4px;transition:width .4s;box-shadow:0 0 12px var(--primary-glow)}.xp-meta{display:flex;justify-content:space-between;margin-top:1rem;gap:.75rem}.xp-meta-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.xp-meta-num{font-size:1.25rem;font-weight:700}.xp-meta-label{font-size:.7rem;color:var(--text-dim)}.hangar-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.875rem}.tile{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1rem;min-height:130px;display:flex;flex-direction:column;justify-content:space-between;transition:transform .1s,border-color .15s,background .15s;cursor:pointer}.tile:active{transform:scale(.97)}.tile:hover{border-color:var(--border-hi);background:var(--bg-card-hi)}.tile-primary{background:linear-gradient(135deg,var(--primary),var(--accent));border:none;color:#fff;box-shadow:0 8px 24px var(--primary-glow)}.tile-primary:hover{background:linear-gradient(135deg,var(--primary),var(--accent));filter:brightness(1.1)}.tile-primary .tile-sub{color:#ffffffd9}.tile-icon{font-size:1.75rem}.tile-title{font-weight:700;font-size:1rem;margin-top:.5rem}.tile-sub{font-size:.75rem;color:var(--text-dim);margin-top:.25rem}.due-banner{display:flex;align-items:center;gap:.5rem;background:#a78bfa14;border:1px solid rgba(167,139,250,.3);color:#c4b5fd;padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem}.due-dot{width:8px;height:8px;border-radius:50%;background:var(--xp);box-shadow:0 0 8px var(--xp);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-dim)}.empty-state h2{color:var(--text);margin:.5rem 0}.empty-state p{margin:.5rem 0 1.5rem}.empty-icon{font-size:3rem}.primary-btn{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;padding:.875rem 1.5rem;border-radius:12px;font-weight:700;font-size:1rem;box-shadow:0 4px 12px var(--primary-glow);transition:transform .1s,box-shadow .15s}.primary-btn:active{transform:scale(.98)}.primary-btn:hover{box-shadow:0 6px 20px var(--primary-glow)}.primary-btn.full{width:100%}.quiz-shell{min-height:100dvh;display:flex;flex-direction:column;background:var(--bg);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.quiz-topbar{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;border-bottom:1px solid var(--border)}.quiz-exit{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--bg-card);font-size:1.1rem;color:var(--text-dim)}.quiz-progress{flex:1;height:8px;background:var(--bg-elev);border-radius:4px;overflow:hidden}.quiz-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--xp));border-radius:4px;transition:width .3s}.quiz-counter{font-size:.85rem;color:var(--text-dim);font-weight:700;min-width:42px;text-align:right}.quiz-session-stats{display:flex;gap:1rem;padding:.75rem 1rem;font-size:.8rem;color:var(--text-dim)}.qss-item{display:flex;align-items:baseline;gap:.35rem}.qss-num{font-weight:700;color:var(--text);font-size:1rem}.qss-num.xp{color:var(--xp)}.qss-label{font-size:.75rem}.quiz-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin:.5rem 1rem}.quiz-category{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--xp);margin-bottom:.625rem}.quiz-question{font-size:1.05rem;line-height:1.45;font-weight:600;margin-bottom:1.25rem}.quiz-choices{display:flex;flex-direction:column;gap:.625rem}.quiz-choice{display:flex;align-items:flex-start;gap:.75rem;text-align:left;background:var(--bg-elev);border:1.5px solid var(--border);border-radius:12px;padding:.875rem 1rem;font-size:.95rem;line-height:1.35;transition:all .15s;min-height:56px;width:100%}.quiz-choice:active:not(:disabled){transform:scale(.98)}.quiz-choice:hover:not(:disabled){border-color:var(--primary);background:var(--bg-card-hi)}.quiz-choice.is-selected{border-color:var(--primary);background:#4f9cff1a}.quiz-choice.is-correct{border-color:var(--success);background:var(--success-bg);color:#86efac}.quiz-choice.is-wrong{border-color:var(--danger);background:var(--danger-bg);color:#fca5a5}.quiz-choice.is-faded{opacity:.45}.quiz-choice-letter{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;border-radius:7px;background:#ffffff14;font-weight:700;font-size:.85rem}.quiz-choice.is-correct .quiz-choice-letter{background:var(--success);color:#fff}.quiz-choice.is-wrong .quiz-choice-letter{background:var(--danger);color:#fff}.quiz-choice-text{flex:1;padding-top:3px}.quiz-reveal{margin:.5rem 1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem 1.25rem}.quiz-reveal.good{border-color:var(--success)}.quiz-reveal.bad{border-color:var(--danger)}.reveal-head{display:flex;align-items:baseline;flex-wrap:wrap;gap:.5rem;margin-bottom:.625rem}.reveal-title{font-size:1.1rem;font-weight:800}.quiz-reveal.good .reveal-title{color:#86efac}.quiz-reveal.bad .reveal-title{color:#fca5a5}.reveal-xp{font-size:.85rem;font-weight:700;color:var(--xp);margin-left:auto}.reveal-mastered{font-size:.75rem;font-weight:700;color:var(--gold);background:#fbbf241f;padding:.15rem .5rem;border-radius:999px}.reveal-explain{font-size:.92rem;line-height:1.5;color:var(--text);margin-bottom:.625rem}.reveal-ref{font-size:.78rem;color:var(--text-dim);margin-bottom:1rem}.quiz-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:var(--text-dim);gap:.75rem}.quiz-empty h2{color:var(--text);margin:0}.summary-card{margin:auto;max-width:480px;width:calc(100% - 2rem);text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:2rem 1.5rem;margin-top:2rem;display:flex;flex-direction:column;gap:.875rem}.summary-headline{font-size:1.5rem;font-weight:800;letter-spacing:-.01em}.summary-score{display:flex;align-items:baseline;justify-content:center;gap:.25rem;margin:.5rem 0}.summary-correct{font-size:4rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--xp));-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}.summary-of{font-size:1.5rem;color:var(--text-dim);font-weight:600}.summary-accuracy{font-size:1rem;color:var(--text-dim)}.summary-xp{font-size:1.5rem;font-weight:800;color:var(--xp);margin-top:.5rem}.summary-levelup{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;padding:.75rem 1rem;border-radius:12px;font-weight:700;font-size:1rem;box-shadow:0 4px 16px var(--primary-glow)}.summary-streak{font-size:1rem;color:var(--text-dim);font-weight:600}.summary-achievements{text-align:left;margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}.summary-section-title{font-size:.85rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.achievement-row{display:flex;align-items:center;gap:.75rem;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:.625rem .875rem}.achievement-row.earned{border-color:var(--gold);background:#fbbf2414}.ach-icon{font-size:1.5rem}.ach-text{flex:1}.ach-name{font-weight:700;font-size:.9rem}.ach-desc{font-size:.75rem;color:var(--text-dim)}.stats-page{display:flex;flex-direction:column;gap:1.25rem}.stats-header{display:flex;align-items:baseline;justify-content:space-between;padding:0 .25rem}.stats-rank-label{color:var(--xp);font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.stats-level{font-size:1.5rem;font-weight:700}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-cell{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.25rem}.stat-num{font-size:1.75rem;font-weight:800;letter-spacing:-.02em}.stat-label{font-size:.85rem;color:var(--text);font-weight:600}.stat-sub{font-size:.7rem;color:var(--text-dim)}.section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-top:.75rem;padding:0 .25rem}.achievement-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.625rem}.achievement-tile{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem;text-align:center;display:flex;flex-direction:column;gap:.25rem;min-height:110px}.achievement-tile.earned{border-color:var(--gold);background:#fbbf240f}.achievement-tile.locked{opacity:.5}.at-icon{font-size:1.5rem}.at-name{font-size:.85rem;font-weight:700}.at-desc{font-size:.7rem;color:var(--text-dim)}.trouble-page{display:flex;flex-direction:column;gap:1rem}.page-title{font-size:1.5rem;margin:0;letter-spacing:-.01em;font-weight:700}.page-sub{color:var(--text-dim);font-size:.9rem;margin:0 0 .5rem}.cat-bars{display:flex;flex-direction:column;gap:.625rem}.cat-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s}.cat-bar.is-open{border-color:var(--primary)}.cat-bar.is-mastered{border-color:var(--gold);background:#fbbf240a}.cat-bar-btn{width:100%;text-align:left;background:none;border:none;padding:.75rem .875rem;display:block;cursor:pointer}.cat-bar-btn:active{background:#ffffff08}.cat-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;gap:.5rem}.cat-name{font-weight:600;font-size:.95rem;display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.cat-mastered-badge{font-size:.65rem;font-weight:700;color:var(--gold);background:#fbbf2426;padding:.1rem .4rem;border-radius:999px;letter-spacing:.04em}.cat-accuracy{font-weight:700;font-size:.95rem}.cat-track{height:6px;background:var(--bg-elev);border-radius:3px;overflow:hidden}.cat-fill{height:100%;transition:width .4s}.cat-fill.good{background:var(--success)}.cat-fill.meh{background:var(--warning)}.cat-fill.bad{background:var(--danger)}.cat-fill.untouched{background:var(--bg-elev)}.cat-meta{font-size:.72rem;color:var(--text-dim);margin-top:.4rem}.cat-length-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding:.75rem .875rem .875rem;border-top:1px solid var(--border);margin-top:0}.cat-length-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.65rem .25rem;border-radius:10px;background:var(--bg-elev);border:1px solid var(--border);font-weight:700;font-size:1rem;color:var(--text);text-align:center;transition:all .1s;min-height:52px}.cat-length-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.cat-length-btn:active{transform:scale(.96)}.cat-length-btn.disabled{opacity:.35;cursor:not-allowed;background:var(--bg-elev);color:var(--text-faint);pointer-events:none}.cat-length-sub{font-size:.65rem;font-weight:500;color:var(--text-dim);margin-top:1px;text-transform:uppercase;letter-spacing:.04em}.cat-length-btn:hover .cat-length-sub{color:#ffffffd9}.mastered-cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.625rem}.mastered-cat-tile{background:#fbbf2414;border:1px solid var(--gold);border-radius:var(--radius);padding:.75rem;text-align:center;display:flex;flex-direction:column;gap:.25rem;min-height:92px}.mastered-cat-tile.in-progress{background:var(--bg-card);border-color:var(--border);opacity:.85}.mct-icon{font-size:1.4rem}.mct-name{font-weight:700;font-size:.85rem;line-height:1.2}.mct-sub{font-size:.7rem;color:var(--text-dim)}.worst-list{display:flex;flex-direction:column;gap:.5rem}.worst-item{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:.75rem .875rem}.worst-q{font-size:.9rem;line-height:1.4;margin-bottom:.4rem}.worst-meta{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.72rem;color:var(--text-dim)}.worst-cat{color:var(--xp);font-weight:600}.worst-acc{color:var(--danger);font-weight:700}.admin-page{display:flex;flex-direction:column;gap:.875rem}.admin-toolbar{display:flex;flex-direction:column;gap:.625rem}.filter-row{display:flex;gap:.4rem}.filter-chip{padding:.4rem .875rem;border-radius:999px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-dim);font-size:.85rem;font-weight:600}.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.admin-search{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:.625rem .875rem;font-size:.95rem;width:100%;outline:none}.admin-search:focus{border-color:var(--primary)}.admin-import{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.upload-btn{display:inline-flex;align-items:center;background:var(--bg-card);border:1px dashed var(--border-hi);border-radius:10px;padding:.5rem .875rem;font-size:.85rem;color:var(--xp);cursor:pointer;font-weight:600}.upload-btn:hover{background:var(--bg-card-hi)}.import-msg{font-size:.8rem;color:var(--text-dim)}.admin-count{font-size:.85rem;color:var(--text-dim);padding:.25rem .25rem 0}.admin-list{display:flex;flex-direction:column;gap:.625rem}.admin-q{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem 1rem}.admin-q.inactive{opacity:.55}.admin-q-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.75rem}.admin-q-cat{color:var(--xp);font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-size:.7rem}.admin-q-id{color:var(--text-faint)}.toggle-btn{margin-left:auto;padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:700;border:1px solid}.toggle-btn.on{color:var(--success);border-color:var(--success);background:var(--success-bg)}.toggle-btn.off{color:var(--text-dim);border-color:var(--border);background:var(--bg-elev)}.admin-q-text{font-size:.92rem;line-height:1.4;margin-bottom:.625rem}.admin-q-choices{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.admin-choice{font-size:.85rem;padding:.35rem .625rem;border-radius:6px;background:var(--bg-elev);color:var(--text-dim)}.admin-choice.correct{color:#86efac;background:var(--success-bg);font-weight:600}.ac-letter{font-weight:700;margin-right:.25rem}.ac-mark{font-weight:800}.admin-q-ex{font-size:.82rem;color:var(--text-dim);margin-top:.4rem;line-height:1.4}.admin-q-ex strong{color:var(--text)}.admin-q-ref{font-size:.72rem;color:var(--text-faint);margin-top:.25rem}.upload-btn input[type=file]{display:none}.leaderboard-page{display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem}.lb-header{padding:.25rem .25rem 0}.lb-title{font-size:1.6rem;font-weight:800;margin:0;letter-spacing:-.01em}.lb-sub{font-size:.85rem;color:var(--text-dim);margin-top:.2rem}.lb-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:.35rem}.lb-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:.55rem .25rem;border-radius:10px;background:transparent;color:var(--text-faint);font-weight:600;font-size:.72rem;transition:background .15s,color .15s,transform .05s;min-height:56px}.lb-tab:active{transform:scale(.96)}.lb-tab.active{background:linear-gradient(135deg,var(--primary),var(--accent, #8b5cf6));color:#fff;box-shadow:0 4px 12px var(--primary-glow)}.lb-tab-icon{font-size:1.1rem}.lb-tab-label{font-size:.7rem;letter-spacing:.02em}.lb-myrank{display:flex;align-items:center;gap:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:.7rem .9rem}.lb-myrank-label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.lb-myrank-value{font-size:1.4rem;font-weight:800;color:var(--primary)}.lb-myrank-of{font-size:.8rem;color:var(--text-faint)}.lb-jump-btn{margin-left:auto;background:#4f9cff26;color:var(--primary);border:1px solid rgba(79,156,255,.35);border-radius:999px;padding:.4rem .75rem;font-size:.78rem;font-weight:700}.lb-jump-btn:active{transform:scale(.97)}.lb-podium{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:.5rem;align-items:end;padding:.25rem 0}.lb-podium[data-count="1"]{grid-template-columns:1fr}.lb-podium[data-count="2"]{grid-template-columns:1fr 1.15fr}.lb-podium-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:.9rem .5rem .8rem;display:flex;flex-direction:column;align-items:center;text-align:center;min-height:150px}.lb-podium-card.place-1{background:linear-gradient(180deg,rgba(251,191,36,.18),var(--bg-card) 70%);border-color:#fbbf248c;min-height:180px;box-shadow:0 8px 24px #fbbf242e}.lb-podium-card.place-2{background:linear-gradient(180deg,rgba(203,213,225,.14),var(--bg-card) 70%);border-color:#cbd5e166}.lb-podium-card.place-3{background:linear-gradient(180deg,rgba(217,119,6,.14),var(--bg-card) 70%);border-color:#d9770666}.lb-podium-card.me{outline:2px solid var(--primary);outline-offset:-2px}.lb-podium-medal{font-size:2rem;line-height:1;margin-bottom:.4rem}.lb-podium-medal.gold{filter:drop-shadow(0 0 8px rgba(251,191,36,.6))}.lb-podium-name{font-weight:800;font-size:1rem;color:var(--text);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-podium-rank{font-size:.7rem;color:var(--text-dim);margin-top:.15rem;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.lb-podium-value{margin-top:.5rem;display:flex;flex-direction:column;align-items:center;gap:1px}.lb-podium-num{font-size:1.25rem;font-weight:800;color:var(--primary);line-height:1}.lb-podium-card.place-1 .lb-podium-num{font-size:1.5rem;color:var(--gold)}.lb-podium-unit{font-size:.65rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em}.lb-you-tag{position:absolute;top:-8px;right:10px;background:var(--primary);color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.08em;padding:2px 8px;border-radius:999px;box-shadow:0 2px 8px var(--primary-glow)}.lb-you-tag.inline{position:static;margin-left:.4rem;font-size:.55rem;padding:1px 6px;vertical-align:middle}.lb-list{display:flex;flex-direction:column;gap:.4rem}.lb-row{display:grid;grid-template-columns:44px 1fr auto;gap:.6rem;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:.65rem .85rem;min-height:60px}.lb-row.me{background:linear-gradient(90deg,rgba(79,156,255,.14),var(--bg-card) 60%);border-color:var(--primary);box-shadow:0 2px 12px #4f9cff26}.lb-rank{font-size:1rem;font-weight:800;color:var(--text-dim);text-align:center}.lb-row.me .lb-rank{color:var(--primary)}.lb-pilot{min-width:0}.lb-pilot-name{font-weight:700;color:var(--text);font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-pilot-meta{font-size:.7rem;color:var(--text-dim);margin-top:1px}.lb-value{text-align:right}.lb-value-num{display:block;font-weight:800;color:var(--primary);font-size:1.05rem;line-height:1.1}.lb-value-unit{font-size:.62rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em}
