*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0a;--surface: #141414;--card: #1a1a1a;--border: #2a2a2a;--primary: #2fa84e;--primary-light: #47D45A;--primary-dark: #1e8a3a;--accent: #d4a035;--accent-light: #e8b94a;--text: #e0e0e0;--text-muted: #808080;--text-bright: #ffffff;--success: #47D45A;--warning: #c79a2a;--error: #b83a3a;--info: #3a7ab8}body.light-mode{--bg: #f4f5f7;--surface: #ffffff;--card: #ffffff;--border: #e0e2e6;--primary: #228b3a;--primary-light: #2fa84e;--primary-dark: #1a6e2e;--accent: #b8892a;--accent-light: #c79a2a;--text: #2a2d32;--text-muted: #6b7280;--text-bright: #111318;--success: #228b3a;--warning: #b8892a;--error: #c0392b;--info: #2c6faa}html{overflow-x:hidden;-webkit-text-size-adjust:100%}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-tap-highlight-color:transparent;transition:background .3s,color .3s}#root{min-height:100vh}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.hd-display{font-family:Rajdhani,sans-serif;font-weight:300;letter-spacing:.12em;color:var(--text-bright);text-transform:uppercase}.hd-section{font-family:Rajdhani,sans-serif;font-weight:500;letter-spacing:.08em;color:var(--primary-light);text-transform:uppercase}.mono{font-family:JetBrains Mono,monospace}.text-center{text-align:center}.desktop-only{display:block}@media (max-width: 900px){.desktop-only{display:none!important}}.grad-bar{height:2px;background:linear-gradient(90deg,var(--primary-dark),var(--primary),var(--primary-light),var(--accent))}.topbar{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--surface);border-bottom:1px solid var(--border)}.topbar-inner{max-width:1400px;margin:0 auto;padding:10px 24px;display:flex;align-items:center;justify-content:space-between}.layout{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:50}.sidebar-header{padding:20px 16px 12px;border-bottom:1px solid var(--border)}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border)}.nav-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 16px;background:none;border:none;color:var(--text-muted);font-family:Inter,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-align:left}.nav-item:hover{color:var(--text);background:#2fa84e14}.nav-item.active{color:var(--primary-light);background:#2fa84e1f;border-right:2px solid var(--primary-light)}.nav-count{font-size:11px;font-family:JetBrains Mono,monospace;background:var(--card);padding:2px 6px;border-radius:10px;color:var(--text-muted)}.main-content{flex:1;margin-left:220px;margin-right:280px;min-height:100vh;padding:20px 28px}.right-panel{width:280px;background:var(--surface);border-left:1px solid var(--border);position:fixed;top:0;bottom:0;right:0;overflow-y:auto;padding:20px 16px}.rp-section{margin-bottom:24px}.rp-title{font-family:Rajdhani,sans-serif;font-weight:500;font-size:12px;letter-spacing:.08em;color:var(--primary-light);text-transform:uppercase;margin-bottom:10px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:10px;text-align:center}.stat-value{font-family:JetBrains Mono,monospace;font-size:22px;font-weight:700;color:var(--text-bright)}.stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}@media (max-width: 900px){.sidebar{display:none}.main-content{margin-left:0;margin-right:0;padding:16px}.right-panel{display:none}}.page-container{max-width:1200px;margin:0 auto;padding:24px}.card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:20px}.card-hover{cursor:pointer;transition:border-color .2s,background .2s}.card-hover:hover{border-color:var(--primary);background:#2fa84e0a}.card-dashed{border-style:dashed;display:flex;align-items:center;justify-content:center;min-height:90px}.btn{font-family:Inter,sans-serif;font-weight:500;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;border-radius:6px;transition:all .15s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light)}.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-outline:hover{border-color:var(--primary);color:var(--primary-light)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{opacity:.85}.btn-sm{font-size:12px;padding:6px 14px}.btn-xs{font-size:11px;padding:4px 10px;border-radius:4px}.btn-lg{font-size:15px;padding:14px 28px;border-radius:8px}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-link{background:none;border:none;color:var(--primary-light);font-family:Inter,sans-serif;font-size:13px;cursor:pointer;padding:0}.btn-link:hover{text-decoration:underline}.btn-link.muted{color:var(--text-muted);font-size:12px}.theme-toggle{background:var(--card);border:1px solid var(--border);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .15s;color:var(--text-muted)}.theme-toggle:hover{border-color:var(--primary);color:var(--primary-light)}.form-group{margin-bottom:14px}.form-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;display:block}.form-input{font-family:Inter,sans-serif;font-size:16px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);width:100%;outline:none;-webkit-appearance:none}.form-input:focus{border-color:var(--primary)}.form-input::placeholder{color:var(--text-muted)}.badge{font-family:Inter,sans-serif;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;display:inline-block}.badge-primary{background:#2fa84e2e;color:var(--primary-light)}.badge-success{background:#47d45a2e;color:#47d45a}.badge-warning{background:#c79a2a33;color:#fbbf24}.badge-error{background:#b83a3a33;color:#f87171}.badge-info{background:#3a7ab833;color:#60a5fa}.count-badge{font-size:12px;font-weight:400;color:var(--text-muted);margin-left:6px}.alert-error{padding:10px 14px;background:#b83a3a1f;border-radius:6px;font-size:13px;color:#f87171}.panel{position:relative;min-height:calc(100vh - 40px);padding-bottom:60px}.panel-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.panel-title{font-family:Rajdhani,sans-serif;font-weight:500;font-size:20px;letter-spacing:.06em;color:var(--text-bright);text-transform:uppercase}.panel-actions{display:flex;gap:6px;flex-wrap:wrap}.list-container{display:flex;flex-direction:column;gap:6px}.list-item{background:var(--card);border:1px solid var(--border);border-radius:6px;overflow:hidden}.list-item-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;transition:background .15s}.list-item-header:hover{background:#2fa84e0a}.list-item-detail{padding:12px 16px;border-top:1px solid var(--border);background:var(--surface)}.avatar{width:34px;height:34px;border-radius:6px;background:var(--primary-dark);color:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.detail-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:2px}.question-card{padding:10px 12px;margin-bottom:6px;background:var(--card);border-radius:6px;border:1px solid var(--border)}.fab{position:fixed;bottom:24px;right:300px;width:48px;height:48px;border-radius:50%;background:var(--primary);color:#fff;font-size:24px;font-weight:300;border:none;cursor:pointer;box-shadow:0 4px 16px #0006;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:30}.fab:hover{background:var(--primary-light);transform:scale(1.05)}@keyframes pulse{0%,to{box-shadow:0 4px 16px #0006}50%{box-shadow:0 4px 24px #2fa84e99,0 0 40px #2fa84e4d}}.fab-pulse{animation:pulse 2s ease-in-out infinite}@media (max-width: 900px){.fab{right:20px}}.empty-state{text-align:center;padding:40px 20px}.touch-btn{font-family:Inter,sans-serif;font-size:16px;padding:14px 20px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;width:100%;text-align:left;display:flex;align-items:center;min-height:52px;transition:all .15s}.touch-btn:hover,.touch-btn:active{border-color:var(--primary);background:#2fa84e0f}.touch-btn.selected{border-color:var(--primary);background:#2fa84e1f;color:var(--primary-light)}.touch-btn.correct{border-color:var(--success);background:#47d45a1f;color:#47d45a}.touch-btn.incorrect{border-color:var(--error);background:#b83a3a1a;color:#f87171}.spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--primary-light);border-radius:50%;animation:spin .7s linear infinite}.spinner-lg{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--primary-light);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ai-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0ae0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:200}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:8px;font-size:13px;font-weight:500;color:#fff;z-index:300;box-shadow:0 4px 20px #0006}.toast-success{background:var(--success)}.toast-error{background:var(--error)}.toast-warning{background:var(--warning)}.toast-info{background:var(--info)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:250;padding:20px}body.light-mode .modal-overlay{background:#0000004d}.modal-content{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:28px;max-width:440px;width:100%;box-shadow:0 8px 32px #0006}@supports (padding: env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top)}}button,a,input,select,textarea,.nav-item,.touch-btn,.card-hover,.list-item-header{touch-action:manipulation}.mobile-only{display:none}@media (max-width: 900px){.mobile-only{display:flex}}.toast{bottom:calc(20px + env(safe-area-inset-bottom,0px))}.fab{bottom:calc(24px + env(safe-area-inset-bottom,0px))}@media (max-width: 900px){input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],textarea,select{font-size:16px}}.ai-overlay-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0006;display:flex;justify-content:flex-end}.ai-panel{width:min(440px,100vw);height:100vh;height:100dvh;background:var(--card);border-left:1px solid var(--border);display:flex;flex-direction:column;box-shadow:-8px 0 32px #0000004d}@media (max-width: 600px){.ai-overlay-bg{align-items:flex-end;justify-content:stretch}.ai-panel{width:100%;height:88dvh;max-height:88vh;border-left:none;border-top:1px solid var(--border);border-radius:16px 16px 0 0;box-shadow:0 -8px 32px #0000004d;animation:slide-up-mobile .25s ease-out}}@keyframes slide-up-mobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ai-panel-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.ai-panel-body{flex:1;overflow-y:auto;padding:16px 18px;-webkit-overflow-scrolling:touch}.ai-panel-footer{padding:12px 18px calc(12px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);flex-shrink:0}.fab-ai{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));left:16px;width:56px;height:56px;border-radius:50%;background:var(--accent);color:#1a1a1a;font-family:Rajdhani,sans-serif;font-size:14px;font-weight:700;letter-spacing:.05em;border:none;cursor:pointer;box-shadow:0 6px 20px #d4a03566,0 2px 8px #0000004d;display:none;align-items:center;justify-content:center;z-index:30;transition:transform .15s,box-shadow .15s}.fab-ai:active{transform:scale(.95)}@media (max-width: 900px){.fab-ai{display:flex}}.fab-ai.fab-ai-student{display:flex;bottom:calc(24px + env(safe-area-inset-bottom,0px))}@media (max-width: 900px){.fab{bottom:calc(80px + env(safe-area-inset-bottom,0px))}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:6px 4px calc(6px + env(safe-area-inset-bottom,0px));z-index:40;justify-content:space-around;align-items:stretch;gap:2px}@media (max-width: 900px){.bottom-nav{display:flex}}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;color:var(--text-muted);font-family:Inter,sans-serif;font-size:11px;font-weight:500;padding:8px 4px;border-radius:8px;cursor:pointer;min-height:48px;transition:color .15s,background .15s}.bottom-nav-item:active{background:#2fa84e14}.bottom-nav-item.active{color:var(--primary-light)}.bottom-nav-item .nav-count{font-size:9px;padding:1px 5px;background:var(--card);border-radius:8px;min-width:16px;text-align:center}@media (max-width: 900px){.main-content{padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.panel{padding-bottom:100px}}.btn-ai-prominent{display:flex;align-items:center;justify-content:center;gap:8px;width:calc(100% - 24px);margin:12px 12px 8px;padding:12px 14px;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#1a1a1a;font-family:Rajdhani,sans-serif;font-size:14px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:none;border-radius:8px;cursor:pointer;box-shadow:0 2px 8px #d4a03540;transition:transform .12s,box-shadow .15s}.btn-ai-prominent:hover{transform:translateY(-1px);box-shadow:0 4px 14px #d4a03566}.btn-ai-prominent:active{transform:translateY(0)}.btn-ai-prominent .ai-glyph{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#1a1a1a2e;font-size:11px;font-weight:700;letter-spacing:0}@media (max-width: 600px){.topbar-inner{padding:8px 14px}.page-container{padding:16px}.panel-title{font-size:17px}.panel{padding-bottom:90px}}
