*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f172a;--bg2:#1e293b;--bg3:#334155;--border:#475569;--text:#f1f5f9;--text2:#94a3b8;--primary:#6366f1;--primary-h:#818cf8;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b;--radius:10px;--shadow:0 4px 24px #0006}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,system-ui,sans-serif;font-size:15px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;background:0 0;border:none}input,select,textarea{font:inherit;background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;padding:.5rem .75rem;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--primary)}.btn{border-radius:7px;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-size:.9rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-h)}.btn-ghost{background:var(--bg3);color:var(--text2)}.btn-ghost:hover{background:var(--border);color:var(--text)}.btn-danger{color:var(--danger);border:1px solid var(--danger);background:0 0}.btn-danger:hover{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-sm{padding:.3rem .7rem;font-size:.8rem}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.badge{border-radius:20px;padding:.15rem .55rem;font-size:.75rem;font-weight:600;display:inline-block}.tag{background:var(--bg3);color:var(--text2);border-radius:20px;padding:.15rem .5rem;font-size:.75rem}select option{background:var(--bg2)}@media (width<=768px){.kpi-grid{grid-template-columns:repeat(2,1fr)!important}.row{flex-direction:column!important}.side-card,.mastery-card{width:100%!important}.option-row,.type-grid{grid-template-columns:1fr!important}.word-table-wrap,table{max-width:100%;display:block;overflow-x:auto}.form-row{grid-template-columns:1fr!important}}@media (width<=480px){.kpi-grid{grid-template-columns:repeat(2,1fr)!important}h1{font-size:1.4rem!important}}.layout.svelte-12qhfyh{max-width:1440px;min-height:100vh;margin:0 auto;display:flex}.sidebar.svelte-12qhfyh{background:var(--bg2);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:2rem;width:220px;height:100vh;padding:1.5rem 1rem;display:flex;position:sticky;top:0;overflow-y:auto}.logo.svelte-12qhfyh{align-items:center;gap:.6rem;padding:0 .5rem;display:flex}.logo-icon.svelte-12qhfyh{font-size:1.6rem}.logo-text.svelte-12qhfyh{color:var(--primary-h);font-size:1.1rem;font-weight:700}nav.svelte-12qhfyh{flex-direction:column;flex:1;gap:.25rem;display:flex}.nav-link.svelte-12qhfyh{color:var(--text2);border-radius:8px;align-items:center;gap:.65rem;padding:.6rem .75rem;font-weight:500;transition:all .15s;display:flex}.nav-link.svelte-12qhfyh:hover{background:var(--bg3);color:var(--text)}.nav-link.active.svelte-12qhfyh{background:var(--primary);color:#fff}.content.svelte-12qhfyh{flex:1;min-width:0;max-width:1100px;padding:2rem 2.5rem}.sidebar-footer.svelte-12qhfyh{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;padding-top:1rem;display:flex}.username.svelte-12qhfyh{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;padding:0 .25rem;font-size:.8rem;overflow:hidden}.logout-btn.svelte-12qhfyh{width:100%;font:inherit;color:var(--text2);border:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-radius:8px;padding:.5rem .75rem;font-size:.825rem;font-weight:500;transition:all .15s}.logout-btn.svelte-12qhfyh:hover{color:#f87171;background:#ef444415;border-color:#ef444450}.mobile-bar.svelte-12qhfyh{background:var(--bg2);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;height:52px;padding:0 1rem;display:none;position:fixed;top:0;left:0;right:0}.mobile-logo.svelte-12qhfyh{color:var(--primary-h);font-size:1rem;font-weight:700}.hamburger.svelte-12qhfyh{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .6rem;font-size:1.25rem;line-height:1;transition:background .15s}.hamburger.svelte-12qhfyh:hover{background:var(--bg3)}.backdrop.svelte-12qhfyh{z-index:150;background:#0000008c;display:none;position:fixed;inset:0}@media (width<=768px){.mobile-bar.svelte-12qhfyh{display:flex}.backdrop.open.svelte-12qhfyh{display:block}.layout.svelte-12qhfyh{max-width:100%;padding-top:52px}.sidebar.svelte-12qhfyh{z-index:200;border-right:1px solid var(--border);width:260px;height:100vh;padding-top:68px;transition:left .25s;position:fixed;top:0;left:-260px;box-shadow:4px 0 20px #0006}.sidebar.open.svelte-12qhfyh{left:0}.content.svelte-12qhfyh{width:100%;max-width:100%;padding:1rem}}
