*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--bg-primary:#07070b;--bg-secondary:#0f0f17;--bg-tertiary:#181824;--bg-hover:#20202e;--bg-input:#15151f;--border-color:#2a2a3a;--border-subtle:#1e1e2a;--accent:#1e40ff;--accent-hover:#3253ff;--accent-glow:#1e40ff59;--accent-soft:#1e40ff1a;--text-primary:#fff;--text-secondary:#c5c5d8;--text-muted:#7e7e95;--success:#4ade80;--warning:#facc15;--danger:#f87171;--info:#60a5fa;--sidebar-width:240px;--topbar-height:56px;--card-shadow:0 2px 16px #0009;--max-content-width:1100px}[data-theme=light]{--bg-primary:#f5f5f8;--bg-secondary:#fff;--bg-tertiary:#ececf2;--bg-hover:#e0e0ea;--bg-input:#f5f5f8;--border-color:#d8d8e2;--border-subtle:#e8e8ee;--accent:#1e40ff;--accent-hover:#3253ff;--accent-glow:#1e40ff33;--accent-soft:#1e40ff0f;--text-primary:#0a0a14;--text-secondary:#3a3a48;--text-muted:#696980;--success:#16a34a;--warning:#b45309;--danger:#dc2626;--info:#2563eb;--card-shadow:0 1px 3px #0a0a140f, 0 1px 2px #0a0a140a}html,body,#root{width:100%;height:100%}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;line-height:1.55}a{color:var(--accent);text-decoration:none;transition:color .15s}a:hover{color:var(--accent-hover)}button{cursor:pointer;font-family:inherit;font-size:.875rem}input,textarea,select{font-family:inherit;font-size:.875rem}h1,h2,h3,h4{color:var(--text-primary);letter-spacing:-.01em;font-weight:700}h1{margin-bottom:8px;font-size:1.75rem}h2{margin-bottom:8px;font-size:1.35rem}h3{margin-bottom:8px;font-size:1.05rem}p{color:var(--text-secondary)}.muted{color:var(--text-muted)}.tiny{font-size:.75rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-layout{background:var(--bg-primary);height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:100;flex-direction:column;flex-shrink:0;transition:transform .3s;display:flex}.sidebar-brand{border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:18px 20px;display:flex}.sidebar-brand .brand-wordmark{letter-spacing:.04em;color:var(--text-primary);font-size:1.05rem;font-weight:800}.sidebar-brand .brand-wordmark .accent{color:var(--accent)}.sidebar-nav{flex:1;padding:14px 8px;overflow-y:auto}.sidebar-nav a,.sidebar-nav button.nav-link{color:var(--text-secondary);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;width:100%;margin-bottom:2px;padding:10px 14px;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-nav a:hover,.sidebar-nav button.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav a.active{background:var(--accent-soft);color:var(--accent)}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:14px 16px 6px;font-size:.65rem;font-weight:700}.sidebar-footer{border-top:1px solid var(--border-color);align-items:center;gap:10px;padding:14px 16px;display:flex}.sidebar-footer .avatar-bubble{background:var(--accent-soft);width:32px;height:32px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.sidebar-footer .user-meta{flex:1;overflow:hidden}.sidebar-footer .user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.sidebar-footer .user-role{color:var(--text-muted);font-size:.65rem}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:var(--topbar-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-right{align-items:center;gap:10px;display:flex}.topbar-title{color:var(--text-primary);font-size:.95rem;font-weight:600}.mobile-menu-btn{color:var(--text-primary);background:0 0;border:none;border-radius:6px;padding:8px;display:none}.mobile-menu-btn:hover{background:var(--bg-hover)}.page-content{flex:1;padding:32px;overflow-y:auto}.container{max-width:var(--max-content-width);margin:0 auto}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:20px;padding:24px;transition:border-color .15s,box-shadow .15s}.card:hover{border-color:var(--border-color)}.card.accent-border{border-color:var(--accent)}.card.danger-border{border-color:var(--danger)}.card.success-border{border-color:var(--success)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-primary);font-size:1rem;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px}.stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px;font-size:.65rem;font-weight:700}.stat-value{color:var(--text-primary);font-size:1.75rem;font-weight:800;line-height:1}.stat-sub{color:var(--text-muted);margin-top:4px;font-size:.75rem}button,.btn{background:var(--accent);color:#fff;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:.875rem;font-weight:600;transition:all .15s;display:inline-flex}button:hover,.btn:hover{background:var(--accent-hover);box-shadow:0 4px 16px var(--accent-glow)}button.secondary,.btn.secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}button.secondary:hover,.btn.secondary:hover{background:var(--bg-hover);border-color:var(--text-muted);box-shadow:none}button.ghost,.btn.ghost{color:var(--text-secondary);border:1px solid var(--border-color);background:0 0}button.ghost:hover,.btn.ghost:hover{background:var(--bg-hover);color:var(--text-primary);box-shadow:none}button.danger,.btn.danger{background:var(--danger)}button.danger:hover,.btn.danger:hover{background:#ef4444}button.tiny,.btn.tiny{padding:5px 10px;font-size:.75rem}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:16px}.form-label,label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:.7rem;font-weight:700;display:block}input,textarea,select,.form-input{background:var(--bg-input);border:1px solid var(--border-color);width:100%;color:var(--text-primary);border-radius:8px;padding:10px 14px;font-size:.9rem;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus,.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}input::placeholder,textarea::placeholder{color:var(--text-muted)}textarea{resize:vertical;min-height:80px}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary);padding:12px 14px;font-size:.7rem;font-weight:700}td{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);padding:14px;font-size:.875rem}tr:hover td{background:var(--bg-hover)}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:12px;align-items:center;padding:3px 10px;font-size:.7rem;font-weight:700;display:inline-flex}.badge-blue{color:var(--accent);background:#1e40ff26}.badge-green{color:var(--success);background:#4ade8026}.badge-yellow{color:var(--warning);background:#facc1526}.badge-red{color:var(--danger);background:#f8717126}.badge-gray{background:var(--bg-tertiary);color:var(--text-muted)}.auth-page{background:radial-gradient(ellipse at top, #1e40ff1a, transparent 50%), var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;width:100%;max-width:420px;padding:40px;box-shadow:0 20px 60px #00000080}.auth-brand{text-align:center;margin-bottom:32px}.auth-brand .brand-wordmark{letter-spacing:.04em;font-size:1.4rem;font-weight:800}.auth-brand p{color:var(--text-muted);margin-top:6px;font-size:.85rem}.quiz-shell{max-width:720px;margin:0 auto;padding:40px 24px}.quiz-progress-bar{background:var(--bg-tertiary);border-radius:2px;height:4px;margin-bottom:32px;overflow:hidden}.quiz-progress-fill{background:var(--accent);height:100%;transition:width .3s}.quiz-question{color:var(--text-primary);margin-bottom:8px;font-size:1.5rem;font-weight:700}.quiz-q-label{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:12px;font-size:.7rem;font-weight:700}.quiz-options{flex-direction:column;gap:10px;margin-top:24px;display:flex}.quiz-option{white-space:normal;word-wrap:break-word;overflow-wrap:break-word;background:var(--bg-tertiary);border:2px solid var(--border-subtle);text-align:left;cursor:pointer;width:100%;color:var(--text-secondary);border-radius:10px;padding:16px 20px;font-size:.95rem;font-weight:500;line-height:1.5;transition:border-color .15s,background .15s,color .15s;display:block}.quiz-option:hover{border-color:var(--accent);color:var(--text-primary);background:var(--bg-hover);box-shadow:none}.quiz-option.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--text-primary);box-shadow:0 0 0 1px var(--accent)}.pillar-row{margin-bottom:16px}.pillar-row-head{justify-content:space-between;margin-bottom:6px;font-size:.875rem;font-weight:600;display:flex}.pillar-bar-track{background:var(--bg-tertiary);border-radius:5px;height:10px;overflow:hidden}.pillar-bar-fill{border-radius:5px;height:100%;transition:width .5s}.pillar-fill-good{background:var(--success)}.pillar-fill-mid{background:var(--warning)}.pillar-fill-bad{background:var(--danger)}.grade-hero{text-align:center;background:radial-gradient(ellipse at center, var(--accent-soft), transparent 70%), var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;margin-bottom:24px;padding:48px 24px}.grade-letter{color:var(--accent);letter-spacing:-.05em;margin:16px 0;font-size:96px;font-weight:900;line-height:1}.grade-score{color:var(--text-primary);font-size:1.25rem;font-weight:600}.grade-status{color:var(--text-muted);margin-top:12px;font-size:.9rem}.course-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.course-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;padding:24px;transition:all .15s;display:flex}.course-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.course-pillar-label{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:8px;font-size:.65rem;font-weight:700}.course-price{color:var(--text-primary);margin-top:auto;padding-top:16px;font-size:1.25rem;font-weight:700}.lesson-list-item{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:16px 20px;text-decoration:none;transition:all .15s;display:flex}.lesson-list-item:hover{border-color:var(--accent);background:var(--bg-tertiary)}.lesson-list-item.completed{opacity:.7}.lesson-list-item .lesson-meta{color:var(--text-muted);font-size:.75rem}.banner{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:10px;align-items:center;gap:12px;margin-bottom:16px;padding:14px 18px;font-size:.875rem;display:flex}.banner.success{border-color:var(--success);color:var(--success);background:#4ade800f}.banner.danger{border-color:var(--danger);color:var(--danger);background:#f871710f}.banner.info{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.page-loader{height:100vh;color:var(--text-muted);background:var(--bg-primary);justify-content:center;align-items:center;gap:12px;display:flex}.spinner{border:2px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.top-nav{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex}.top-nav .brand{letter-spacing:.04em;color:var(--text-primary);font-size:1rem;font-weight:800}.top-nav .brand .accent{color:var(--accent)}.top-nav .right{align-items:center;gap:16px;display:flex}.top-nav .right a{color:var(--text-secondary);font-size:.85rem}.top-nav .right a:hover{color:var(--text-primary)}.public-shell{background:var(--bg-primary);flex-direction:column;min-height:100vh;display:flex}.public-shell .public-content{flex:1;padding:32px 24px 64px}@media (width<=768px){.sidebar{z-index:200;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-menu-btn{justify-content:center;align-items:center;display:flex}.page-content{padding:16px}.top-nav{padding:0 16px}.top-nav .right{gap:10px}.grade-letter{font-size:72px}h1{font-size:1.4rem}h2{font-size:1.15rem}}.mobile-overlay{z-index:150;background:#00000080;display:none;position:fixed;inset:0}.mobile-overlay.visible{display:block}@media (width<=480px){input,select,textarea{font-size:16px}button,.btn{min-height:44px}.auth-card{padding:28px 20px}}
