*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.collapse{visibility:collapse}.relative{position:relative}.sticky{position:sticky}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.resize{resize:both}.border{border-width:1px}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#080c15;--surface:#0f1422;--surface2:#161d30;--surface3:#1d2640;--primary:#3d7eff;--primary-dim:rgba(61,126,255,.12);--primary-glow:rgba(61,126,255,.28);--secondary:#6e44ff;--accent:#3d7eff;--accent2:#6e44ff;--accent-dim:rgba(61,126,255,.12);--green:#00d4a8;--orange:#ff8c00;--red:#ff2d55;--yellow:#ffd000;--gold:#ffd000;--silver:#b8c4d4;--bronze:#cd7f32;--text:#f0f4ff;--text2:#89b;--muted:#4a5578;--text-inverse:#080c15;--border:hsla(0,0%,100%,.08);--border-hover:rgba(61,126,255,.22);--border-focus:rgba(61,126,255,.5);--grad-primary:linear-gradient(135deg,#3d7eff,#6e44ff);--grad-hero:radial-gradient(ellipse at 20% 30%,rgba(61,126,255,.09) 0%,transparent 60%),radial-gradient(ellipse at 80% 70%,rgba(110,68,255,.07) 0%,transparent 50%);--font-display:"Syne",sans-serif;--font-body:"DM Sans",sans-serif;--shadow-card:0 2px 12px rgba(0,0,0,.4),0 0 0 1px hsla(0,0%,100%,.05);--shadow-glow:0 0 40px rgba(61,126,255,.15);--shadow-elevated:0 8px 32px rgba(0,0,0,.5),0 0 0 1px hsla(0,0%,100%,.06);--radius:12px;--radius-sm:8px;--radius-lg:18px;--sp-xs:4px;--sp-sm:8px;--sp-md:16px;--sp-lg:24px;--sp-xl:32px;--sp-2xl:48px;--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--duration-fast:150ms;--duration-base:220ms;--duration-slow:350ms}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:14px;line-height:1.6;letter-spacing:-.01em;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.text-xs{font-size:11px;line-height:1.5;letter-spacing:.01em}.text-sm{font-size:13px;line-height:1.55;letter-spacing:-.005em}.text-muted{color:var(--text2)}.font-display{font-family:var(--font-display);letter-spacing:-.02em}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:100px;transition:background var(--duration-base)}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}::-webkit-scrollbar-corner{background:transparent}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes popIn{0%{transform:scale(.88);opacity:0}60%{transform:scale(1.03)}to{transform:scale(1);opacity:1}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px rgba(61,126,255,0)}50%{box-shadow:0 0 28px rgba(61,126,255,.12)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .35s var(--ease-out) both}.fade-up,.pop-in{will-change:transform,opacity}.pop-in{animation:popIn .3s var(--ease-spring) both}@media (prefers-reduced-motion:reduce){.fade-up,.pop-in{animation:none!important;opacity:1;transform:none}*{transition-duration:.01ms!important;animation-duration:.01ms!important}}.page-container{padding:var(--sp-xl) var(--sp-lg);max-width:1280px;margin:0 auto;width:100%}@media (max-width:768px){.page-container{padding:var(--sp-lg) var(--sp-md)}}.app{display:flex;min-height:100vh}.sidebar{width:240px;min-width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:28px 16px;position:fixed;top:0;left:0;height:100vh;z-index:100;transition:transform var(--duration-slow) var(--ease-out)}.sidebar.hidden{transform:translateX(-100%)}.main{margin-left:240px;flex:1;padding:var(--sp-xl) 28px;max-width:calc(100vw - 240px)}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main{margin-left:0;max-width:100vw;padding:20px var(--sp-md)}}.logo{display:flex;align-items:center;gap:10px;margin-bottom:36px}.logo-mark{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:grid;place-items:center;font-size:18px;color:#fff;letter-spacing:-1px;box-shadow:0 4px 16px rgba(61,126,255,.25)}.logo-mark,.logo-text{font-family:var(--font-display);font-weight:800}.logo-text{font-size:22px;letter-spacing:-.5px;background:linear-gradient(135deg,var(--text) 60%,var(--text2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-sub{line-height:1;font-weight:500}.logo-sub,.nav-section{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase}.nav-section{padding:0 12px;margin:20px 0 8px;font-weight:600}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:500;color:var(--text2);letter-spacing:-.01em;transition:all var(--duration-base) var(--ease-out);margin-bottom:2px;border:none;background:none;width:100%;text-align:left;text-decoration:none;position:relative}.nav-item:hover{background:var(--surface2);color:var(--text);transform:translateX(2px)}.nav-item.active{background:linear-gradient(135deg,rgba(61,126,255,.14),rgba(110,68,255,.14));color:var(--accent);box-shadow:inset 3px 0 0 var(--accent)}.nav-item .icon{width:18px;height:18px;opacity:.6;transition:opacity var(--duration-fast)}.nav-item:hover .icon{opacity:.85}.nav-item.active .icon{opacity:1}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-lg);gap:12px;position:sticky;top:0;z-index:20;background:var(--bg);padding:12px 0;border-bottom:1px solid var(--border)}.topbar-title{font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:-.03em;line-height:1.2}.topbar-right{display:flex;align-items:center;gap:10px}.quiz-sticky-header{position:sticky;top:60px;z-index:19;background:var(--bg);padding:10px 0;border-bottom:1px solid var(--border);margin-bottom:16px}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:grid;place-items:center;font-weight:700;font-size:13px;cursor:pointer;transition:transform var(--duration-base) var(--ease-spring),box-shadow var(--duration-base);box-shadow:0 0 0 2px transparent}.avatar:hover{transform:scale(1.08);box-shadow:0 0 0 2px var(--surface),0 0 0 4px rgba(61,126,255,.3)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all var(--duration-fast);white-space:nowrap}.badge-blue{background:rgba(61,126,255,.1);color:var(--accent);border:1px solid rgba(61,126,255,.2)}.badge-green{background:rgba(0,212,168,.1);color:var(--green);border:1px solid rgba(0,212,168,.2)}.badge-orange{background:rgba(255,140,0,.1);color:var(--orange);border:1px solid rgba(255,140,0,.2)}.badge-purple{background:rgba(110,68,255,.1);color:var(--accent2);border:1px solid rgba(110,68,255,.2)}.badge-red{background:rgba(255,45,85,.1);color:var(--red);border:1px solid rgba(255,45,85,.2)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--sp-lg);transition:border-color var(--duration-base) var(--ease-out),box-shadow var(--duration-slow) var(--ease-out),transform var(--duration-base) var(--ease-out);box-shadow:var(--shadow-card)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-card),var(--shadow-glow)}.card-title{font-family:var(--font-display);font-weight:700;font-size:16px;margin-bottom:6px;letter-spacing:-.02em;line-height:1.3}.card-sub{color:var(--text2);font-size:13px;line-height:1.5}.grid-2{grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:var(--sp-md)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-md)}@media (max-width:900px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;position:relative;overflow:hidden;transition:border-color var(--duration-base) var(--ease-out),box-shadow var(--duration-slow) var(--ease-out),transform var(--duration-base) var(--ease-out);box-shadow:var(--shadow-card)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-accent,var(--accent));opacity:.85;transition:opacity var(--duration-base)}.stat-card:after{content:"";position:absolute;inset:0;border-radius:var(--radius);background:radial-gradient(circle at 50% 0,var(--primary-glow) 0,transparent 70%);opacity:0;transition:opacity var(--duration-slow) var(--ease-out);pointer-events:none}.stat-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-card),var(--shadow-glow)}.stat-card:hover:before{opacity:1}.stat-card:hover:after{opacity:.5}.stat-value{font-family:var(--font-body);font-size:26px;font-weight:600;line-height:1;margin-bottom:6px;letter-spacing:-.02em;position:relative;z-index:1}.stat-label{color:var(--text2);font-weight:500;text-transform:uppercase;letter-spacing:.04em;line-height:1.4}.stat-delta,.stat-label{font-size:12px;position:relative;z-index:1}.stat-delta{font-weight:600;margin-top:10px;letter-spacing:.01em}.stat-delta.up{color:var(--green)}.stat-delta.down{color:var(--red)}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;letter-spacing:-.01em;cursor:pointer;border:none;font-family:var(--font-body);transition:all var(--duration-base) var(--ease-out);position:relative;overflow:hidden;-webkit-user-select:none;user-select:none}.btn:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,hsla(0,0%,100%,.08),transparent 60%);opacity:0;transition:opacity var(--duration-fast);pointer-events:none}.btn:hover:after{opacity:1}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 2px 8px rgba(61,126,255,.2)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(61,126,255,.35),0 2px 8px rgba(61,126,255,.2)}.btn-primary:active{transform:translateY(0);box-shadow:0 2px 8px rgba(61,126,255,.2)}.btn-ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--border-hover);background:var(--surface3);transform:translateY(-1px)}.btn-ghost:active{transform:translateY(0)}.btn-danger{background:rgba(255,45,85,.1);color:var(--red);border:1px solid rgba(255,45,85,.18)}.btn-danger:hover{background:rgba(255,45,85,.16);border-color:rgba(255,45,85,.3);transform:translateY(-1px)}.btn-danger:active{transform:translateY(0)}.btn-sm{padding:7px 14px;font-size:13px}.btn-full{width:100%;justify-content:center}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn:disabled:after{display:none}.input-wrap{margin-bottom:var(--sp-md)}.input-label{font-size:13px;font-weight:600;color:var(--text2);margin-bottom:8px;display:block;letter-spacing:.01em}.input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-size:14px;line-height:1.5;font-family:var(--font-body);transition:border-color var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out),background var(--duration-base);outline:none}.input:hover{border-color:var(--border-hover)}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-dim),0 0 20px var(--primary-dim);background:var(--surface2)}.input::placeholder{color:var(--muted)}select.input{cursor:pointer}textarea.input{resize:vertical;min-height:80px}.quiz-option{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 20px;cursor:pointer;transition:all var(--duration-base) var(--ease-out);display:flex;align-items:center;gap:14px;margin-bottom:10px;position:relative}.quiz-option:hover{border-color:var(--border-hover);background:rgba(61,126,255,.06);transform:translateX(4px);box-shadow:0 2px 12px rgba(0,0,0,.15)}.quiz-option.selected{border-color:var(--accent);background:rgba(61,126,255,.1);box-shadow:0 0 0 1px rgba(61,126,255,.15),0 4px 16px rgba(61,126,255,.08)}.quiz-option.correct{border-color:var(--green);background:rgba(0,212,168,.08);box-shadow:0 0 0 1px rgba(0,212,168,.15)}.quiz-option.wrong{border-color:var(--red);background:rgba(255,45,85,.08);box-shadow:0 0 0 1px rgba(255,45,85,.12)}.option-dot{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);display:grid;place-items:center;font-size:11px;font-weight:700;flex-shrink:0;transition:all var(--duration-base) var(--ease-spring)}.quiz-option:hover .option-dot{border-color:var(--border-hover)}.selected .option-dot{border-color:var(--accent);background:var(--accent);color:#fff;transform:scale(1.1);box-shadow:0 0 12px rgba(61,126,255,.3)}.correct .option-dot{border-color:var(--green);background:var(--green);color:#fff;transform:scale(1.1);box-shadow:0 0 12px rgba(0,212,168,.3)}.wrong .option-dot{border-color:var(--red);background:var(--red);color:#fff;transform:scale(1.1);box-shadow:0 0 12px rgba(255,45,85,.3)}.progress-bar{height:6px;background:var(--surface3);border-radius:100px;overflow:hidden}.progress-fill{height:100%;border-radius:100px;transition:width .6s var(--ease-out);background:var(--grad-primary)}.loader{display:inline-block;width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.loader-lg{width:40px;height:40px;border-width:3px}.tag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500;background:var(--surface2);border:1px solid var(--border);color:var(--text2);transition:all var(--duration-fast)}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:14px;line-height:1.5}th{text-align:left;font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);background:hsla(0,0%,100%,.015);white-space:nowrap}td,th{padding:14px 18px;border-bottom:1px solid var(--border)}td{vertical-align:middle;color:var(--text)}tr:last-child td{border-bottom:none}tr{transition:background var(--duration-fast)}tr:hover td{background:hsla(0,0%,100%,.025)}tbody tr:hover td:first-child{box-shadow:inset 3px 0 0 var(--accent)}.donut-wrap{position:relative;width:100px;height:100px;margin:0 auto 12px}.donut-label{position:absolute;inset:0;align-items:center;justify-content:center}.donut-label,.toast-container{display:flex;flex-direction:column}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;gap:10px}.toast{background:var(--surface);backdrop-filter:blur(16px) saturate(1.6);-webkit-backdrop-filter:blur(16px) saturate(1.6);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;font-size:13px;line-height:1.5;min-width:260px;animation:slideDown .35s var(--ease-out);gap:10px;box-shadow:var(--shadow-elevated);color:var(--text)}.auth-page,.toast{display:flex;align-items:center}.auth-page{min-height:100vh;justify-content:center;padding:20px;background:var(--bg);position:relative;overflow:hidden}.auth-bg{position:absolute;inset:0;background:var(--grad-hero);animation:fadeIn 1s ease}.auth-card{background:var(--surface);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border:1px solid var(--border);border-radius:var(--radius-lg);padding:44px 40px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:var(--shadow-card),var(--shadow-glow)}@media (max-width:480px){.auth-card{padding:32px 24px;border-radius:var(--radius)}}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:var(--sp-sm)}.chip{padding:7px 16px;border-radius:20px;font-size:13px;font-weight:500;letter-spacing:-.01em;cursor:pointer;border:1.5px solid var(--border);background:var(--surface2);color:var(--text2);transition:all var(--duration-base) var(--ease-out);-webkit-user-select:none;user-select:none}.chip:hover{border-color:var(--border-hover);background:var(--surface3);color:var(--text);transform:translateY(-1px)}.chip:active{transform:translateY(0) scale(.97)}.chip.active{border-color:var(--accent);color:var(--accent);background:var(--primary-dim);box-shadow:0 0 16px rgba(61,126,255,.1)}.hamburger{display:none;background:none;border:none;color:var(--text);cursor:pointer;padding:12px;margin:-12px;border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;-webkit-user-select:none;min-width:44px;min-height:44px;align-items:center;justify-content:center}.hamburger:active{background:var(--surface2);transition:none}@media (max-width:768px){.hamburger{display:flex}}.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:99}.overlay.show{display:block}.section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:var(--sp-md)}.section-title{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.02em;line-height:1.3}.subj-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.streak-tile{background:var(--surface2);border-radius:var(--radius-sm);width:34px;height:34px;display:grid;place-items:center;font-size:11px;font-weight:600;transition:all var(--duration-base) var(--ease-spring);border:1px solid transparent}.streak-tile:hover{border-color:var(--border);transform:scale(1.08)}.streak-tile.done{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 2px 8px rgba(61,126,255,.25)}.lb-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border);transition:background var(--duration-fast)}.lb-row:hover{background:hsla(0,0%,100%,.02)}.lb-rank{width:28px;font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:-.02em;color:var(--muted);text-align:center;flex-shrink:0}.lb-rank.gold{color:var(--yellow);text-shadow:0 0 16px rgba(255,208,0,.3)}.lb-rank.silver{color:var(--silver);text-shadow:0 0 12px rgba(184,196,212,.2)}.lb-rank.bronze{color:var(--bronze);text-shadow:0 0 12px rgba(205,127,50,.2)}.explanation{background:rgba(0,212,168,.05);border:1px solid rgba(0,212,168,.15);border-radius:var(--radius);padding:16px 18px;margin-top:16px;font-size:13px;line-height:1.75;color:var(--text)}.weak-bar{margin-bottom:16px}.weak-bar-header{display:flex;justify-content:space-between;font-size:13px;margin-bottom:8px;color:var(--text2)}.welcome-banner{background:linear-gradient(135deg,rgba(61,126,255,.1),rgba(110,68,255,.1) 50%,rgba(61,126,255,.06));border:1px solid rgba(61,126,255,.15);border-radius:var(--radius);padding:28px var(--sp-lg);margin-bottom:var(--sp-lg);position:relative;overflow:hidden}.welcome-banner:before{content:"";position:absolute;top:0;right:0;width:300px;height:100%;background:radial-gradient(ellipse at 100% 50%,rgba(110,68,255,.08) 0,transparent 70%);pointer-events:none}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(8px) saturate(1.2);-webkit-backdrop-filter:blur(8px) saturate(1.2);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:480px;animation:popIn .3s var(--ease-spring);box-shadow:var(--shadow-elevated)}.modal-title{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-.02em;margin-bottom:24px;line-height:1.3}.empty-state{text-align:center;padding:var(--sp-2xl) 20px;color:var(--text2)}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.4}.empty-state-text{font-size:15px;line-height:1.6;max-width:320px;margin:0 auto}::selection{background:rgba(61,126,255,.25);color:var(--text)}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.fade-up:first-child{animation-delay:0ms}.fade-up:nth-child(2){animation-delay:30ms}.fade-up:nth-child(3){animation-delay:60ms}.fade-up:nth-child(4){animation-delay:90ms}.fade-up:nth-child(5){animation-delay:.12s}.fade-up:nth-child(6){animation-delay:.15s}.fade-up:nth-child(7){animation-delay:.18s}.fade-up:nth-child(8){animation-delay:.21s}.app-footer{text-align:center;padding:24px 16px 16px;font-size:11px;color:var(--muted);opacity:.6;margin-top:auto}@media (max-width:768px){.topbar{margin-bottom:var(--sp-md)}.grid-4{display:flex;overflow-x:auto;gap:12px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding-bottom:4px}.grid-4>*{min-width:160px;flex-shrink:0;scroll-snap-align:start}.grid-4::-webkit-scrollbar{height:0;display:none}.grid-4{scrollbar-width:none}}