:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Onest", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 20px;--transition: .2s cubic-bezier(.4, 0, .2, 1);--bg-primary: #f5f6f8;--bg-secondary: #eef1f6;--bg-card: #ffffff;--bg-card-hover: #f4f6f9;--bg-input: #f4f6f9;--bg-sidebar: #ffffff;--text-primary: #0b1020;--text-secondary: #566076;--text-muted: #8b94a8;--text-inverse: #ffffff;--accent: #0047ab;--accent-hover: #002f6c;--accent-light: rgba(0, 71, 171, .1);--accent-glow: rgba(0, 71, 171, .18);--success: #147f4b;--success-light: rgba(20, 127, 75, .12);--warning: #b5740a;--warning-light: rgba(181, 116, 10, .12);--danger: #df343b;--danger-light: rgba(223, 52, 59, .12);--info: #0047ab;--info-light: rgba(0, 71, 171, .1);--border: #e6e9ef;--border-light: #eef1f6;--shadow: 0 1px 2px rgba(16, 24, 40, .04), 0 6px 18px rgba(16, 24, 40, .05);--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06);--shadow-lg: 0 18px 50px rgba(16, 24, 40, .14);--shadow-glow: 0 0 0 3px var(--accent-light);--st-sched: #0047ab;--st-sched-bg: #e7eefb;--st-live: #df343b;--st-live-bg: #fde6e7;--st-proc: #b5740a;--st-proc-bg: #fbefd9;--st-done: #147f4b;--st-done-bg: #e1f4ea;--av1-bg: #e7eefb;--av1-fg: #0047ab;--av2-bg: #fdeede;--av2-fg: #b5740a;--av3-bg: #e3f4ea;--av3-fg: #147f4b;--av4-bg: #efe8fb;--av4-fg: #6b3fc0}[data-theme=dark]{--bg-primary: #070b14;--bg-secondary: #0b1220;--bg-card: #101829;--bg-card-hover: #18223a;--bg-input: #0b1220;--bg-sidebar: #0a1020;--text-primary: #eef1f8;--text-secondary: #9aa4bd;--text-muted: #69728c;--text-inverse: #070b14;--accent: #4584ec;--accent-hover: #7aa6f5;--accent-light: rgba(69, 132, 236, .16);--accent-glow: rgba(69, 132, 236, .32);--success: #47cb8b;--success-light: rgba(71, 203, 139, .15);--warning: #e3aa4d;--warning-light: rgba(227, 170, 77, .15);--danger: #ff6b70;--danger-light: rgba(255, 107, 112, .15);--info: #7aa6f5;--info-light: rgba(122, 166, 245, .15);--border: #222c44;--border-light: #1b2236;--shadow: 0 1px 2px rgba(0, 0, 0, .5), 0 10px 26px rgba(0, 0, 0, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 22px 60px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px var(--accent-glow);--st-sched: #7aa6f5;--st-sched-bg: #13213c;--st-live: #ff6b70;--st-live-bg: #341619;--st-proc: #e3aa4d;--st-proc-bg: #2e2410;--st-done: #47cb8b;--st-done-bg: #10271d;--av1-bg: #16223c;--av1-fg: #7aa6f5;--av2-bg: #2c2310;--av2-fg: #e3aa4d;--av3-bg: #10271d;--av3-fg: #47cb8b;--av4-bg: #221a3a;--av4-fg: #a98ae6}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-hover)}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:260px;padding:32px;min-height:100vh;transition:margin-left var(--transition)}@media (max-width: 768px){.main-content{margin-left:0;padding:16px}}.sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition)}.sidebar-brand{padding:24px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}.sidebar-brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;box-shadow:var(--shadow-glow)}.sidebar-brand h1{font-size:18px;font-weight:700;color:var(--text-primary)}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-section{margin-bottom:24px}.sidebar-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:0 12px 8px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;transition:all var(--transition);cursor:pointer}.sidebar-link:hover{color:var(--text-primary);background:var(--accent-light)}.sidebar-link.active{color:var(--accent-hover);background:var(--accent-light);box-shadow:inset 3px 0 0 var(--accent)}.sidebar-link svg{width:20px;height:20px;flex-shrink:0}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:12px;padding:10px;border-radius:var(--radius);transition:background var(--transition)}.sidebar-user:hover{background:var(--bg-card)}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-hover));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--text-muted)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition)}.card:hover{border-color:var(--accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:16px;font-weight:600}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:flex-start;gap:16px;transition:all var(--transition)}.stat-card:hover{border-color:var(--accent);box-shadow:var(--shadow-glow)}.stat-icon{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.purple{background:var(--accent-light);color:var(--accent-hover)}.stat-icon.green{background:var(--success-light);color:var(--success)}.stat-icon.blue{background:var(--info-light);color:var(--info)}.stat-icon.orange{background:var(--warning-light);color:var(--warning)}.stat-value{font-size:28px;font-weight:800;line-height:1.2;margin-bottom:2px}.stat-label{font-size:13px;color:var(--text-muted);font-weight:500}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-family:var(--font-family);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all var(--transition);line-height:1.4;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;box-shadow:0 4px 12px var(--accent-light)}.btn-primary:hover:not(:disabled){filter:brightness(1.06);box-shadow:0 6px 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--accent);background:var(--accent-light)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:6px 14px;font-size:13px}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-family);font-size:14px;transition:all var(--transition);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-input::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:100px}.form-error{color:var(--danger);font-size:12px;margin-top:4px}.table-container{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card)}table{width:100%;border-collapse:collapse}thead th{padding:14px 16px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border)}tbody td{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--border-light)}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--accent-light)}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.badge-accent{background:var(--accent-light);color:var(--accent-hover)}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.page-title{font-size:28px;font-weight:800;background:linear-gradient(135deg,var(--text-primary),var(--accent-hover));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{color:var(--text-muted);font-size:14px;margin-top:4px}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:20px}.auth-container{width:100%;max-width:440px}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-lg)}.auth-logo{display:flex;align-items:center;gap:12px;justify-content:center;margin-bottom:32px}.auth-logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:var(--shadow-glow)}.auth-logo h2{font-size:24px;font-weight:800;background:linear-gradient(135deg,var(--accent-hover),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-title{text-align:center;font-size:20px;font-weight:700;margin-bottom:8px}.auth-subtitle{text-align:center;color:var(--text-muted);font-size:14px;margin-bottom:28px}.auth-footer{text-align:center;margin-top:24px;font-size:14px;color:var(--text-muted)}.auth-footer a{font-weight:600}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}@media (max-width: 1024px){.detail-grid{grid-template-columns:1fr}}.hw-redesign-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;align-items:start}.hw-right-col{display:flex;flex-direction:column;gap:24px}.hw-pdf-pane{padding:0;overflow:hidden}.hw-pdf-object{width:100%;height:80vh;border:none;display:block;border-radius:var(--radius)}.hw-pdf-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:80vh;padding:24px}.hw-answer-key{max-height:48vh;overflow-y:auto}.hw-ak-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-light)}.hw-ak-item:last-child{border-bottom:none}@media (max-width: 900px){.hw-redesign-grid{grid-template-columns:1fr}.hw-pdf-object,.hw-pdf-placeholder{height:60vh}}.detail-section{margin-bottom:24px}.detail-section h3{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text-secondary)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.4}.empty-state h3{font-size:18px;margin-bottom:8px;color:var(--text-secondary)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:60px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.progress-bar{height:8px;background:var(--bg-input);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent),var(--accent-hover));transition:width .5s ease}.toast-custom{background:var(--bg-card)!important;color:var(--text-primary)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;box-shadow:var(--shadow-lg)!important}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.text-center{text-align:center}.text-sm{font-size:13px}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.font-semibold{font-weight:600}.w-full{width:100%}.theme-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;margin-bottom:8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-family:var(--font-family);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition)}.theme-toggle:hover{color:var(--text-primary);border-color:var(--accent)}.theme-toggle svg{width:18px;height:18px;flex-shrink:0}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.7)}}.lessons-hero{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 8px 64px;text-align:center}.lessons-hero-inner{width:100%;max-width:620px}.hero-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:999px;background:var(--bg-card);border:1px solid var(--border);font-size:12.5px;font-weight:600;color:var(--text-secondary);margin-bottom:20px}.hero-title{margin:0;font-family:var(--font-display);font-weight:800;font-size:36px;letter-spacing:-.7px;line-height:1.1;color:var(--text-primary)}.hero-sub{margin:12px auto 0;color:var(--text-secondary);font-size:16px;line-height:1.5;max-width:460px}.hero-row{display:flex;align-items:center;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:30px}.hero-or{color:var(--text-muted);font-weight:600;font-size:14px}.split-btn{position:relative;display:inline-flex;border-radius:14px;box-shadow:var(--shadow-lg)}.split-main{height:56px;padding:0 24px;border:none;border-radius:14px 0 0 14px;background:var(--accent);color:#fff;font-family:var(--font-display);font-weight:700;font-size:16px;cursor:pointer;display:flex;align-items:center;gap:10px;white-space:nowrap;transition:filter var(--transition)}.split-caret{width:50px;border:none;border-left:1px solid rgba(255,255,255,.22);border-radius:0 14px 14px 0;background:var(--accent);color:#fff;cursor:pointer;display:grid;place-items:center;transition:filter var(--transition)}.split-main:hover,.split-caret:hover{filter:brightness(1.06)}.split-main:disabled,.split-caret:disabled{opacity:.6;cursor:not-allowed}.hero-dropdown{position:absolute;top:62px;left:0;min-width:220px;z-index:30;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:6px;text-align:left}.hero-dropdown button{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:10px;background:none;color:var(--text-primary);font-family:var(--font-family);font-size:14px;font-weight:500;cursor:pointer}.hero-dropdown button:hover{background:var(--bg-secondary)}.join-group{display:flex;gap:9px;flex:1;max-width:360px;min-width:0}.join-box{flex:1;min-width:0;display:flex;align-items:center;gap:9px;height:56px;padding:0 15px;border-radius:14px;border:1px solid var(--border);background:var(--bg-card)}.join-box input{flex:1;min-width:0;border:none;background:none;outline:none;color:var(--text-primary);font-size:14px;font-family:var(--font-family)}.join-btn{height:56px;padding:0 18px;border-radius:14px;border:1px solid var(--border);background:var(--bg-card);color:var(--accent);font-weight:700;font-size:14px;cursor:pointer;flex:none;transition:opacity var(--transition)}.join-btn:hover{opacity:.8}.hero-links{display:flex;align-items:center;gap:18px;margin-top:18px;flex-wrap:wrap;justify-content:center}.linkbtn{display:flex;align-items:center;gap:7px;background:none;border:none;color:var(--text-secondary);font-family:var(--font-family);font-weight:600;font-size:13.5px;cursor:pointer;padding:2px 0;transition:color var(--transition)}.linkbtn:hover{color:var(--accent)}.linkbtn svg{width:16px;height:16px}.live-banner{display:flex;align-items:center;gap:11px;width:100%;margin-top:22px;padding:12px 14px;border-radius:14px;background:var(--st-live-bg);border:1px solid var(--st-live);color:var(--st-live);text-align:left}.lesson-list{width:100%;margin-top:26px;display:flex;flex-direction:column;gap:9px;text-align:left}.lesson-row{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:13px;background:var(--bg-card);border:1px solid var(--border)}.lesson-av{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-weight:700;font-size:13px;flex:none}.lesson-info{flex:1;min-width:0}.lesson-info .t{font-weight:600;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lesson-info .m{font-size:12px;color:var(--text-muted);margin-top:2px}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap;flex:none}.status-pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.status-pill .dot.live{animation:pulse-dot 1.1s infinite}.icon-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);display:grid;place-items:center;cursor:pointer;flex:none;transition:opacity var(--transition)}.icon-btn:hover{opacity:.7}.row-cta{height:36px;padding:0 13px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-weight:600;font-size:12.5px;cursor:pointer;white-space:nowrap;flex:none;transition:filter var(--transition)}.row-cta:hover{filter:brightness(1.06)}.row-cta.ghost{background:var(--bg-secondary);color:var(--accent);border:1px solid var(--border)}@media (max-width: 560px){.hero-title{font-size:28px}.lesson-row .status-pill{display:none}}
