@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Syne:wght@400;500;600;700;800&family=JetBrains+Mono:ital,wght@0,400;0,500;1,400&display=swap);:root{--bg-primary:#0a0a0f;--bg-secondary:#111118;--bg-tertiary:#1a1a26;--bg-card:#16161f;--bg-hover:#1e1e2e;--border:#ffffff14;--border-strong:#ffffff26;--text-primary:#f0f0f8;--text-secondary:#8b8ba0;--text-muted:#4a4a60;--accent:#6c63ff;--accent-light:#8b83ff;--accent-dim:#6c63ff26;--accent-glow:#6c63ff4d;--success:#22d3a5;--success-dim:#22d3a526;--warning:#f59e0b;--warning-dim:#f59e0b26;--error:#ef4444;--error-dim:#ef444426;--info:#3b82f6;--gradient:linear-gradient(135deg,#6c63ff,#a855f7);--gradient-card:linear-gradient(135deg,#6c63ff1a,#a855f70d);--radius:12px;--radius-sm:8px;--radius-lg:16px;--radius-xl:24px;--shadow:0 4px 24px #0006;--shadow-lg:0 8px 48px #0009;--shadow-accent:0 0 24px #6c63ff33;--transition:all 0.2s cubic-bezier(0.4,0,0.2,1);--font-display:"Syne",sans-serif;--font-body:"Space Grotesk",sans-serif;--font-mono:"JetBrains Mono",monospace}[data-theme=light]{--bg-primary:#f8f8fc;--bg-secondary:#fff;--bg-tertiary:#f0f0f8;--bg-card:#fff;--bg-hover:#f4f4fc;--border:#00000014;--border-strong:#00000026;--text-primary:#0a0a1a;--text-secondary:#6b6b80;--text-muted:#a0a0b0;--accent-dim:#6c63ff1a;--shadow:0 4px 24px #00000014;--shadow-lg:0 8px 48px #0000001f}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;background:#0a0a0f;background:var(--bg-primary);color:#f0f0f8;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-family:var(--font-body);line-height:1.6;min-height:100vh}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#111118;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#ffffff26;background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4a4a60;background:var(--text-muted)}h1,h2,h3,h4,h5,h6{font-family:Syne,sans-serif;font-family:var(--font-display);font-weight:700;line-height:1.2}.btn{border:1px solid #0000;border-radius:12px;border-radius:var(--radius);font-family:Space Grotesk,sans-serif;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-primary{background:linear-gradient(135deg,#6c63ff,#a855f7);background:var(--gradient);border-color:#0000;box-shadow:0 0 20px #6c63ff4d;box-shadow:0 0 20px var(--accent-glow)}.btn-primary:hover{box-shadow:0 4px 24px #6c63ff4d;box-shadow:0 4px 24px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:#1a1a26;border-color:#ffffff14;border-color:var(--border);color:#f0f0f8}.btn-secondary:hover{background:#1e1e2e;background:var(--bg-hover);border-color:#ffffff26;border-color:var(--border-strong)}.btn-ghost{color:#8b8ba0}.btn-ghost:hover{background:#1e1e2e;background:var(--bg-hover);color:#f0f0f8;color:var(--text-primary)}.btn-danger{background:#ef444426;background:var(--error-dim);border-color:#ef44444d;color:#ef4444;color:var(--error)}.btn-danger:hover{background:#ef4444;background:var(--error);color:#fff}.btn-success{background:#22d3a526;background:var(--success-dim);border-color:#22d3a54d;color:#22d3a5;color:var(--success)}.btn-success:hover{background:#22d3a5;background:var(--success);color:#fff}.btn-sm{font-size:13px;padding:6px 14px}.btn-lg{font-size:16px;padding:14px 28px}.btn:disabled{transform:none!important}.card{background:#16161f;border:1px solid #ffffff14;border-radius:16px;padding:24px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.card:hover{border-color:#ffffff26;border-color:var(--border-strong)}.card-glow:hover{border-color:#6c63ff66;box-shadow:0 0 24px #6c63ff33;box-shadow:var(--shadow-accent)}input,select,textarea{background:#1a1a26;background:var(--bg-tertiary);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);color:#f0f0f8;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-family:var(--font-body);font-size:14px;outline:none;padding:12px 16px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:100%}input:focus,select:focus,textarea:focus{border-color:#6c63ff;border-color:var(--accent);box-shadow:0 0 0 3px #6c63ff26;box-shadow:0 0 0 3px var(--accent-dim)}input::placeholder,textarea::placeholder{color:#4a4a60;color:var(--text-muted)}label{color:#8b8ba0;color:var(--text-secondary);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.form-group{margin-bottom:20px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.badge{font-size:12px;font-weight:500;padding:3px 10px}.badge-accent{background:#6c63ff26;color:#8b83ff}.badge-success{background:#22d3a526;color:#22d3a5}.badge-warning{background:#f59e0b26;color:#f59e0b}.badge-error{background:#ef444426;color:#ef4444}.badge-muted{background:#1a1a26;color:#8b8ba0}th{color:#8b8ba0;color:var(--text-secondary);font-size:12px;font-weight:600;padding:12px 16px}td,th{border-bottom:1px solid #ffffff14}td{font-size:14px;padding:14px 16px}tr:hover td{background:#1e1e2e}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-4{gap:16px}.gap-6{gap:24px}.text-center{text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes glow{0%,to{box-shadow:0 0 20px #6c63ff4d;box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 40px #6c63ff4d,0 0 60px #6c63ff4d;box-shadow:0 0 40px var(--accent-glow),0 0 60px var(--accent-glow)}}.animate-fade-in{animation:fadeIn .3s ease forwards}.animate-slide-in{animation:slideIn .3s ease forwards}.animate-pulse{animation:pulse 2s ease infinite}.animate-spin{animation:spin 1s linear infinite}.animate-glow{animation:glow 2s ease infinite}.skeleton{background:linear-gradient(90deg,#1a1a26 25%,#1e1e2e 50%,#1a1a26 75%);background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;border-radius:12px;border-radius:var(--radius)}.toggle{cursor:pointer}.toggle input{display:none}.toggle-track{background:#1a1a26;background:var(--bg-tertiary);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:100px;inset:0;position:absolute;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.toggle input:checked+.toggle-track{background:#6c63ff;background:var(--accent);border-color:#6c63ff;border-color:var(--accent)}.toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 4px #0000004d;height:18px;left:2px;position:absolute;top:2px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:18px}.toggle input:checked~.toggle-thumb{left:22px}.progress-bar{background:#1a1a26;background:var(--bg-tertiary);border-radius:100px;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,#6c63ff,#a855f7);background:var(--gradient);border-radius:100px;height:100%;transition:width .5s ease}.question-card{background:#16161f;border:2px solid #ffffff14;border:2px solid var(--border);border-radius:16px;margin-bottom:16px;padding:28px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.question-card.answered{border-color:#6c63ff;border-color:var(--accent)}.question-card.flagged{border-color:#f59e0b;border-color:var(--warning)}.option-item{align-items:flex-start;background:#1a1a26;background:var(--bg-tertiary);border:1.5px solid #ffffff14;border-radius:12px;margin-bottom:10px;padding:14px 18px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.option-item:hover{background:#6c63ff26;border-color:#8b83ff;border-color:var(--accent-light)}.option-item.selected{background:#6c63ff26;border-color:#6c63ff}.option-item.correct{background:#22d3a526;border-color:#22d3a5}.option-item.incorrect{background:#ef444426;background:var(--error-dim);border-color:#ef4444;border-color:var(--error)}.exam-timer{font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:24px;font-weight:600;letter-spacing:2px}.exam-timer.warning{animation:pulse 1s ease infinite;color:#f59e0b}.exam-timer.critical{animation:pulse .5s ease infinite;color:#ef4444;color:var(--error)}.video-grid{grid-gap:12px;gap:12px}.video-grid.grid-1{grid-template-columns:1fr}.video-grid.grid-2{grid-template-columns:1fr 1fr}.video-grid.grid-3{grid-template-columns:repeat(3,1fr)}.video-grid.grid-4{grid-template-columns:repeat(2,1fr)}.video-grid.grid-9{grid-template-columns:repeat(3,1fr)}.video-tile{aspect-ratio:16/9;background:#1a1a26;background:var(--bg-tertiary);border-radius:12px;border-radius:var(--radius)}.video-tile video{height:100%;object-fit:cover;width:100%}.video-tile .name-tag{background:#000000b3;border-radius:100px;bottom:8px;font-size:13px;left:8px;padding:4px 10px;position:absolute}.whiteboard-canvas{background:#fff;border-radius:12px;border-radius:var(--radius);cursor:crosshair;touch-action:none}.tiptap-editor .ProseMirror{font-size:15px;line-height:1.7;min-height:120px;outline:none;padding:16px}.tiptap-editor .ProseMirror p.is-editor-empty:first-child:before{color:#4a4a60;color:var(--text-muted);content:attr(data-placeholder);float:left;height:0;pointer-events:none}.katex{font-size:1em}@media (max-width:768px){.form-row,.video-grid.grid-2,.video-grid.grid-3,.video-grid.grid-4{grid-template-columns:1fr}}.login-page{align-items:stretch;background:var(--bg-primary);display:flex;min-height:100vh;overflow:hidden;position:relative}.login-bg{inset:0;pointer-events:none;position:fixed;z-index:0}.bg-orb{border-radius:50%;filter:blur(80px);opacity:.15;position:absolute}.orb-1{animation:float 8s ease-in-out infinite;background:var(--accent);height:600px;left:-100px;top:-200px;width:600px}.orb-2{animation:float 10s ease-in-out infinite reverse;background:#a855f7;bottom:-100px;height:400px;right:200px;width:400px}.orb-3{animation:float 12s ease-in-out infinite;background:var(--success);height:300px;opacity:.08;right:-50px;top:50%;width:300px}.bg-grid{background-image:linear-gradient(#ffffff05 1px,#0000 0),linear-gradient(90deg,#ffffff05 1px,#0000 0);background-size:50px 50px;inset:0;position:absolute}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.login-container{display:flex;min-height:100vh;position:relative;width:100%;z-index:1}.login-left{display:flex;flex:1 1;flex-direction:column;justify-content:center;max-width:580px;padding:60px}.login-brand{gap:12px;margin-bottom:48px}.brand-icon,.login-brand{align-items:center;display:flex}.brand-icon{background:var(--gradient);border-radius:14px;color:#fff;height:48px;justify-content:center;width:48px}.brand-name{font-size:24px}.brand-name,.login-headline{color:var(--text-primary);font-family:var(--font-display);font-weight:800}.login-headline{font-size:52px;line-height:1.1;margin-bottom:20px}.gradient-text{-webkit-text-fill-color:#0000;background:var(--gradient);-webkit-background-clip:text;background-clip:text}.login-description{color:var(--text-secondary);font-size:17px;line-height:1.7;margin-bottom:40px;max-width:420px}.feature-list{display:flex;flex-direction:column;gap:16px;margin-bottom:48px}.feature-item{align-items:flex-start;display:flex;gap:14px}.feature-icon{align-items:center;background:var(--accent-dim);border:1px solid #6c63ff40;border-radius:10px;color:var(--accent-light);display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.feature-label{color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:2px}.feature-desc{color:var(--text-secondary);font-size:13px}.login-stats{align-items:center;display:flex;gap:24px}.stat{display:flex;flex-direction:column;gap:2px}.stat-num{-webkit-text-fill-color:#0000;background:var(--gradient);-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-size:24px;font-weight:800}.stat-divider{background:var(--border);height:40px;width:1px}.login-right{align-items:center;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-shrink:0;justify-content:center;padding:40px;width:480px}.auth-card{max-width:400px;width:100%}.auth-header{margin-bottom:28px}.auth-header h2{color:var(--text-primary);font-family:var(--font-display);font-size:28px;font-weight:800;margin-bottom:6px}.auth-header p{color:var(--text-secondary);font-size:14px}.google-btn-wrapper{margin-bottom:20px;min-height:44px;width:100%}.divider{align-items:center;display:flex;gap:12px;margin-bottom:20px}.divider:after,.divider:before{background:var(--border);content:"";flex:1 1;height:1px}.divider span{color:var(--text-muted);font-size:12px;white-space:nowrap}.auth-form{display:flex;flex-direction:column;gap:4px}.password-field{position:relative}.password-field input{padding-right:44px}.password-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:var(--transition)}.password-toggle:hover{color:var(--text-primary)}.loading-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:18px;width:18px}.auth-switch{color:var(--text-secondary);font-size:13px;margin-top:20px;text-align:center}.auth-switch button{background:none;border:none;color:var(--accent-light);cursor:pointer;font-size:13px;font-weight:600;margin-left:6px;transition:var(--transition)}.auth-switch button:hover{color:var(--accent)}@media (max-width:1100px){.login-left{padding:40px}.login-headline{font-size:40px}}@media (max-width:900px){.login-container{flex-direction:column}.login-left{max-width:100%;padding:40px 30px}.login-right{border-left:none;border-top:1px solid var(--border);width:100%}}.rich-editor{background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}.rich-editor:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.editor-toolbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-wrap:wrap;gap:2px;padding:8px 10px}.editor-btn,.editor-toolbar{align-items:center;display:flex}.editor-btn{background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;height:30px;justify-content:center;transition:var(--transition);width:30px}.editor-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.editor-btn.active{background:var(--accent-dim);color:var(--accent-light)}.editor-btn.disabled{cursor:not-allowed;opacity:.3}.editor-separator{background:var(--border);height:20px;margin:0 4px;width:1px}.editor-content-wrapper{background:var(--bg-tertiary)}.tiptap-content{color:var(--text-primary);font-size:15px;line-height:1.7;outline:none;padding:16px}.tiptap-content p.is-editor-empty:first-child:before{color:var(--text-muted);content:attr(data-placeholder);float:left;height:0;pointer-events:none}.tiptap-content h1,.tiptap-content h2,.tiptap-content h3{font-family:var(--font-display);margin:16px 0 8px}.tiptap-content img{border-radius:var(--radius-sm);height:auto;margin:8px 0;max-width:100%}.tiptap-content ol,.tiptap-content ul{padding-left:24px}.tiptap-content blockquote{border-left:3px solid var(--accent);color:var(--text-secondary);font-style:italic;margin:12px 0;padding-left:16px}.tiptap-content code{background:var(--bg-secondary);border-radius:4px;font-family:var(--font-mono);font-size:13px;padding:2px 6px}.tiptap-content pre{background:var(--bg-secondary);border-radius:var(--radius);overflow-x:auto;padding:12px 16px}.color-picker-wrapper{position:relative}.color-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;flex-wrap:wrap;gap:6px;left:0;padding:8px;position:absolute;top:calc(100% + 6px);width:140px;z-index:100}.color-swatch{border:2px solid #0000;border-radius:50%;cursor:pointer;height:24px;transition:var(--transition);width:24px}.color-swatch:hover{border-color:#fff;transform:scale(1.2)}.color-swatch.clear{background:var(--bg-tertiary);border-color:var(--border);color:var(--text-secondary);font-size:12px}.color-swatch.clear,.equation-dialog-overlay{align-items:center;display:flex;justify-content:center}.equation-dialog-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;inset:0;position:fixed;z-index:1000}.equation-dialog{animation:fadeIn .2s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:90vw;width:520px}.dialog-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}.dialog-header h3{font-size:18px;font-weight:700}.dialog-close{background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:16px;padding:4px 8px;transition:var(--transition)}.dialog-close:hover{background:var(--bg-hover)}.dialog-body{display:flex;flex-direction:column;gap:16px;padding:24px}.equation-input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-mono);font-size:14px;padding:12px;resize:vertical;width:100%}.equation-input:focus{border-color:var(--accent);outline:none}.common-label,.preview-label{color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.equation-chips{display:flex;flex-wrap:wrap;gap:6px}.eq-chip{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:100px;color:var(--text-secondary);cursor:pointer;font-family:var(--font-body);font-size:12px;padding:4px 10px;transition:var(--transition)}.eq-chip:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-light)}.preview-box{align-items:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);display:flex;font-size:18px;justify-content:center;min-height:60px;padding:16px}.preview-placeholder{color:var(--text-muted);font-size:13px}.dialog-footer{align-items:center;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.question-bank-page{animation:fadeIn .3s ease}.filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;padding:16px 20px}.search-wrapper{flex:1 1;min-width:220px;position:relative}.search-icon{color:var(--text-muted);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:var(--bg-tertiary)!important;padding-left:38px!important}.suggestions-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);left:0;overflow:hidden;position:absolute;right:0;top:calc(100% + 6px);z-index:100}.suggestion-item{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-size:13px;gap:10px;padding:10px 14px;transition:var(--transition)}.suggestion-item:hover{background:var(--bg-hover)}.suggestion-item svg{color:var(--text-muted);flex-shrink:0}.filters-bar select{min-width:140px;padding:10px 14px;width:auto}.mb-6{margin-bottom:24px}.questions-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.question-skeleton{border-radius:var(--radius-lg);height:220px}.q-card{animation:fadeIn .3s ease;display:flex;flex-direction:column;gap:14px;transition:var(--transition)}.q-card-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.q-actions{display:flex;gap:4px;opacity:0;transition:var(--transition)}.q-card:hover .q-actions{opacity:1}.icon-btn.danger:hover{background:var(--error-dim);color:var(--error)}.q-text{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:var(--text-primary);display:-webkit-box;font-size:14px;line-height:1.6;overflow:hidden}.q-text img{border-radius:6px;height:auto;max-width:100%}.q-text p{margin:0}.q-options-preview{display:flex;flex-direction:column;gap:6px}.q-opt-preview{align-items:center;background:var(--bg-tertiary);border-radius:6px;color:var(--text-secondary);display:flex;font-size:12px;gap:8px;padding:4px 8px}.q-opt-preview.correct{background:var(--success-dim);color:var(--success);font-weight:500}.q-opt-preview span:first-child{flex-shrink:0;font-weight:600}.q-opt-preview svg{flex-shrink:0;margin-left:auto}.q-card-footer{align-items:center;border-top:1px solid var(--border);display:flex;justify-content:space-between;margin-top:auto;padding-top:12px}.q-marks{color:var(--accent-light);font-size:12px;font-weight:600}.q-subject{color:var(--text-muted);font-size:12px}.empty-state{padding:80px 40px}.empty-icon{color:var(--text-muted);margin-bottom:8px}.empty-state h3{color:var(--text-primary);font-size:20px}.empty-state p{color:var(--text-secondary);max-width:400px}.modal-overlay{background:#000000bf}.modal-panel{animation:fadeIn .2s ease;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:90vh;max-width:700px;width:100%}.modal-panel.large{max-width:780px}.modal-header{padding:24px 28px}.modal-header h2{font-size:20px}.modal-close{border-radius:8px;color:var(--text-secondary);display:flex;padding:6px;transition:var(--transition)}.modal-body{flex:1 1;overflow-y:auto;padding:24px 28px}.modal-footer{padding:16px 28px}.options-section{margin-bottom:20px}.options-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.option-row{align-items:flex-start;background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--radius);display:flex;gap:10px;padding:10px;transition:var(--transition)}.option-row.correct{background:var(--success-dim);border-color:var(--success)}.option-correct-btn{align-items:center;background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;margin-top:6px;transition:var(--transition);width:28px}.option-correct-btn.active{background:var(--success);border-color:var(--success);color:#fff}.option-letter{align-items:center;color:var(--text-secondary);display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:28px;justify-content:center;margin-top:6px;width:24px}.option-editor{flex:1 1}.option-remove{background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;display:flex;margin-top:6px;padding:4px;transition:var(--transition)}.option-remove:hover{color:var(--error)}.ai-panel-header{justify-content:space-between;margin-bottom:20px}.ai-badge,.ai-panel-header{align-items:center;display:flex}.ai-badge{background:var(--gradient);border-radius:100px;color:#fff;font-size:12px;font-weight:700;gap:6px;padding:6px 14px}.ai-form{margin-bottom:24px}.three-col{grid-template-columns:1fr 1fr 1fr}.ai-results-header{align-items:center;color:var(--text-primary);display:flex;font-size:14px;font-weight:600;justify-content:space-between;margin-bottom:16px}.ai-questions-list{display:flex;flex-direction:column;gap:12px;max-height:500px;overflow-y:auto;padding-right:4px}.ai-question-card{background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:16px;transition:var(--transition)}.ai-question-card:hover{border-color:var(--border-strong)}.ai-question-card.selected{background:var(--accent-dim);border-color:var(--accent)}.ai-q-header{align-items:center;display:flex;gap:8px;margin-bottom:10px}.ai-q-text{color:var(--text-primary);font-size:14px;line-height:1.6;margin-bottom:12px}.ai-q-options{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.ai-option{align-items:center;background:var(--bg-secondary);border-radius:6px;color:var(--text-secondary);display:flex;font-size:13px;gap:8px;padding:6px 10px}.ai-option.correct{background:var(--success-dim);color:var(--success);font-weight:500}.ai-option-letter{flex-shrink:0;font-weight:700;width:16px}.ai-correct-icon{flex-shrink:0;margin-left:auto}.ai-q-explanation{background:var(--bg-secondary);border-left:3px solid var(--accent);border-radius:6px;color:var(--text-secondary);font-size:12px;padding:8px 12px}.exam-builder{display:flex;flex-direction:column;gap:0}.builder-header{flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.builder-header,.builder-steps{align-items:center;display:flex}.builder-steps{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);gap:0;margin-bottom:24px;padding:4px}.step-item{align-items:center;border-radius:var(--radius);color:var(--text-muted);cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:10px 16px;transition:all .2s}.step-item.active{background:var(--accent);color:#fff;font-weight:600}.step-item.completed{color:var(--success)}.step-number{align-items:center;border:2px solid;border-radius:50%;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:22px;justify-content:center;width:22px}.builder-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);min-height:400px;padding:24px}.question-list{display:flex;flex-direction:column;gap:10px}.question-card{background:var(--bg-tertiary);border-radius:var(--radius);cursor:pointer;padding:16px;transition:all .2s}.question-card.selected,.question-card:hover{border-color:var(--accent)}.question-card.selected{background:var(--accent-dim)}.question-card-header{align-items:flex-start;display:flex;gap:10px;justify-content:space-between}.question-text{flex:1 1;font-size:14px;font-weight:500}.builder-nav{border-top:1px solid var(--border);justify-content:space-between;margin-top:20px;padding-top:20px}.builder-nav,.step-indicator{align-items:center;display:flex}.step-indicator{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);gap:0;margin-bottom:28px;padding:20px}.step-dot{align-items:center;background:var(--bg-tertiary);border:2px solid var(--border-strong);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:32px;justify-content:center;transition:all .2s;width:32px}.step-dot.active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-dim);color:#fff}.step-dot.done{background:var(--success);border-color:var(--success);color:#fff}.step-label{color:var(--text-secondary);font-size:12px;font-weight:600;padding:0 8px;white-space:nowrap}.step-line{background:var(--border);border-radius:1px;flex:1 1;height:2px;margin:0 4px}.step-line.done{background:var(--success)}.exam-builder-page{margin:0 auto;max-width:900px}.builder-top{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.builder-title h1{font-family:var(--font-display);font-size:22px;font-weight:800}.builder-body{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);min-height:420px;padding:28px}.builder-footer{align-items:center;border-top:1px solid var(--border);display:flex;justify-content:space-between;margin-top:20px;padding-top:20px}.form-section{margin-bottom:24px}.form-section-title{align-items:center;border-bottom:1px solid var(--border);color:var(--text-secondary);display:flex;font-size:14px;font-size:11px;font-weight:700;gap:8px;letter-spacing:.5px;margin-bottom:14px;padding-bottom:8px;text-transform:uppercase}.q-bank-grid{display:flex;flex-direction:column;gap:8px;max-height:480px;overflow-y:auto;padding-right:4px}.q-bank-card{align-items:flex-start;background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;gap:12px;padding:14px;transition:all .15s}.q-bank-card.selected,.q-bank-card:hover{background:var(--accent-dim);border-color:var(--accent)}.q-bank-card .q-checkbox{align-items:center;background:var(--bg-secondary);border:2px solid var(--border-strong);border-radius:4px;display:flex;flex-shrink:0;height:18px;justify-content:center;margin-top:2px;width:18px}.q-bank-card.selected .q-checkbox{background:var(--accent);border-color:var(--accent)}.q-bank-text{flex:1 1;font-size:13px;line-height:1.5}.q-bank-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.setting-row{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 0}.setting-row:last-child{border-bottom:none}.setting-info .setting-label{color:var(--text-primary);font-size:14px;font-weight:600}.setting-info .setting-desc{color:var(--text-muted);font-size:12px;margin-top:3px}.toggle{flex-shrink:0;height:24px;position:relative;width:44px}.toggle input{height:0;opacity:0;width:0}.toggle-slider{background:var(--bg-tertiary);border:1.5px solid var(--border-strong);border-radius:12px;cursor:pointer;inset:0;position:absolute;transition:all .2s}.toggle-slider:before{background:var(--text-muted);border-radius:50%;content:"";height:16px;left:3px;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s;width:16px}.toggle input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle input:checked+.toggle-slider:before{background:#fff;left:21px}.review-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.review-item{background:var(--bg-tertiary);border-radius:var(--radius);padding:14px}.review-item span{color:var(--text-muted);display:block;font-size:11px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.review-item strong{font-size:14px;font-weight:600}.selected-q-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.selected-q-item{align-items:center;background:var(--bg-tertiary);border-radius:var(--radius);display:flex;font-size:13px;gap:10px;padding:12px 14px}.selected-q-num{align-items:center;background:var(--accent-dim);border-radius:50%;color:var(--accent-light);display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:24px;justify-content:center;width:24px}.exam-taking{background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;min-height:100vh}.exam-taking-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:12px 24px;position:sticky;top:0;z-index:100}.exam-timer{align-items:center;display:flex;font-size:18px;font-weight:700;gap:8px}.exam-timer.warning{color:var(--warning)}.exam-timer.danger{animation:pulse 1s infinite;color:var(--error)}.exam-body{display:flex;flex:1 1;overflow:hidden}.question-nav-panel{background:var(--bg-secondary);border-right:1px solid var(--border);flex-shrink:0;overflow-y:auto;padding:16px;width:220px}.question-nav-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(5,1fr)}.q-nav-btn{background:none;border:1.5px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:600;height:36px;transition:all .2s;width:36px}.q-nav-btn.answered{background:var(--success-dim);border-color:var(--success);color:var(--success)}.q-nav-btn.current{background:var(--accent);border-color:var(--accent);color:#fff}.q-nav-btn.flagged{background:var(--warning-dim);border-color:var(--warning);color:var(--warning)}.question-area{flex:1 1;margin:0 auto;max-width:800px;overflow-y:auto;padding:28px;width:100%}.question-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;padding:24px}.question-number{color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.question-text{font-size:16px;line-height:1.7;margin-bottom:20px}.options-list{display:flex;flex-direction:column;gap:10px}.option-item{align-items:center;border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;gap:12px;padding:14px 16px;transition:all .2s}.option-item.selected,.option-item:hover{background:var(--accent-dim);border-color:var(--accent)}.option-item.correct{background:var(--success-dim);border-color:var(--success)}.option-item.wrong{background:var(--error-dim);border-color:var(--error)}.option-label{border:2px solid;border-radius:50%;flex-shrink:0;font-size:12px;font-weight:700;height:28px;justify-content:center;width:28px}.exam-controls,.option-label{align-items:center;display:flex}.exam-controls{background:var(--bg-secondary);border-top:1px solid var(--border);justify-content:space-between;padding:16px 28px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:768px){.question-nav-panel{display:none}.question-area{padding:16px}}.classroom{font-family:Inter,sans-serif;font-family:var(--font-body,"Inter",sans-serif);overflow:hidden}.classroom,.classroom-loading{background:#0a0a12;color:#f0f0f8;display:flex;flex-direction:column;height:100vh}.classroom-loading{align-items:center;gap:14px;justify-content:center}.classroom-loading p{color:#8a8aa8;font-size:15px}.classroom-header{align-items:center;background:#12121e;border-bottom:1px solid #ffffff14;display:flex;flex-shrink:0;gap:16px;justify-content:space-between;padding:12px 20px}.header-left{display:flex;flex-direction:column;gap:4px;min-width:0}.class-title-wrap{align-items:center;display:flex;gap:10px}.class-title{font-size:16px;font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.socket-badge{align-items:center;border-radius:100px;display:flex;flex-shrink:0;font-size:11px;font-weight:700;gap:5px;padding:3px 10px}.socket-badge.connected{background:#10b98126;color:#10b981}.socket-badge.connecting{background:#f59e0b26;color:#f59e0b}.socket-badge.disconnected{background:#ef444426;color:#ef4444}.header-meta{align-items:center;color:#8a8aa8;display:flex;font-size:12px;gap:6px}.dot{color:#55556a}.header-right{flex-shrink:0;gap:10px}.btn-header,.header-right{align-items:center;display:flex}.btn-header{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;color:#f0f0f8;cursor:pointer;font-size:13px;font-weight:600;gap:6px;padding:7px 14px;transition:all .15s}.btn-header:hover{background:#ffffff1a}.btn-end{align-items:center;background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:700;gap:6px;padding:7px 16px;transition:all .15s}.btn-end:hover{background:#dc2626}.btn-leave{align-items:center;background:#ef444426;border:1px solid #ef44444d;border-radius:8px;color:#ef4444;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:7px 16px;transition:all .15s}.btn-leave:hover{background:#ef444440}.classroom-body,.video-section{display:flex;flex:1 1;overflow:hidden}.video-section{align-items:center;justify-content:center;padding:16px;transition:all .3s}.video-grid{grid-gap:10px;align-items:center;display:grid;gap:10px;height:100%;justify-items:center;width:100%}.video-grid.count-1{grid-template-columns:1fr;max-width:900px}.video-grid.count-2,.video-grid.count-3{grid-template-columns:1fr 1fr}.video-grid.count-3{grid-template-rows:1fr 1fr}.video-grid.count-3 .video-tile:first-child{grid-column:span 2}.video-grid.count-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.video-grid.count-5,.video-grid.count-6{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr}.video-tile{background:#12121e;border:2px solid #ffffff0f;border-radius:14px;height:100%;min-height:160px;overflow:hidden;position:relative;transition:border-color .2s;width:100%}.video-tile:hover{border-color:#6366f166}.video-tile.local{border-color:#6366f180}.video-feed{display:block;height:100%;object-fit:cover;width:100%}.video-avatar{background:linear-gradient(135deg,#1a1a2e,#12121e);height:100%;width:100%}.avatar-circle,.video-avatar{align-items:center;display:flex;justify-content:center}.avatar-circle{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;font-size:26px;font-weight:800;height:72px;width:72px}.tile-info{background:linear-gradient(#0000,#000000bf);bottom:0;justify-content:space-between;left:0;padding:20px 12px 8px;position:absolute;right:0}.tile-info,.tile-name{align-items:center;display:flex}.tile-name{color:#fff;font-size:12px;font-weight:600;gap:4px}.tile-muted{color:#ef4444}.side-panel{background:#12121e;border-left:1px solid #ffffff14;flex-direction:column;width:300px}.panel-header,.side-panel{display:flex;flex-shrink:0}.panel-header{align-items:center;border-bottom:1px solid #ffffff14;justify-content:space-between;padding:16px 18px}.panel-header h3{font-size:15px;font-weight:700;margin:0}.panel-close{background:none;border:none;border-radius:6px;color:#8a8aa8;cursor:pointer;display:flex;padding:4px}.panel-close:hover{background:#ffffff0f;color:#f0f0f8}.chat-panel{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:16px}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.chat-empty{align-items:center;color:#55556a;display:flex;flex-direction:column;gap:10px;padding:40px 20px;text-align:center}.chat-empty p{font-size:13px}.chat-msg{display:flex;flex-direction:column;gap:3px}.chat-msg.mine{align-items:flex-end}.msg-sender{color:#8a8aa8;font-size:11px;font-weight:600;padding:0 10px}.msg-bubble{background:#ffffff14;border-radius:14px;font-size:13px;line-height:1.5;max-width:85%;padding:9px 13px;word-break:break-word}.chat-msg.mine .msg-bubble{background:#6366f1;border-radius:14px 14px 4px 14px;color:#fff}.chat-msg:not(.mine) .msg-bubble{border-radius:4px 14px 14px 14px}.msg-time{color:#55556a;font-size:10px;padding:0 10px}.chat-input{border-top:1px solid #ffffff14;display:flex;flex-shrink:0;gap:8px;padding:12px 14px}.chat-input input{background:#ffffff0f;border:1.5px solid #ffffff1a;border-radius:10px;color:#f0f0f8;flex:1 1;font-size:13px;outline:none;padding:9px 13px}.chat-input input:focus{border-color:#6366f1}.chat-input input::placeholder{color:#55556a}.send-btn{align-items:center;background:#6366f1;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:all .15s;width:38px}.send-btn:hover:not(:disabled){background:#5558e8}.send-btn:disabled{cursor:default;opacity:.4}.people-panel{flex:1 1;overflow-y:auto;padding:12px}.person-row{align-items:center;border-radius:10px;display:flex;gap:12px;padding:10px 12px;transition:background .15s}.person-row:hover{background:#ffffff0a}.person-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:36px;justify-content:center;width:36px}.person-info{flex:1 1;min-width:0}.person-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.person-role{color:#8a8aa8;font-size:11px;margin-top:2px}.person-icons{color:#ef4444;display:flex;flex-shrink:0;gap:6px}.controls-bar{align-items:center;background:#12121e;border-top:1px solid #ffffff14;display:flex;flex-shrink:0;gap:12px;justify-content:space-between;padding:12px 20px}.controls-left,.controls-right{flex:1 1}.controls-right{display:flex;justify-content:flex-end}.controls-center{align-items:center;display:flex;gap:6px}.room-id-badge{background:#ffffff0a;border-radius:6px;color:#8a8aa8;font-family:monospace;font-size:11px;max-width:160px;overflow:hidden;padding:5px 10px;text-overflow:ellipsis;white-space:nowrap}.ctrl-btn{background:#ffffff0f;border:none;border-radius:10px;color:#f0f0f8;cursor:pointer;flex-direction:column;gap:4px;min-width:64px;padding:8px 14px;transition:all .15s}.ctrl-btn,.ctrl-btn span{align-items:center;display:flex}.ctrl-btn span{font-size:10px;font-weight:600;gap:3px}.ctrl-btn:hover{background:#ffffff1a}.ctrl-btn.active{background:#6366f133;color:#a5b4fc}.ctrl-btn.danger{background:#ef444426;color:#ef4444}.ctrl-btn.danger:hover{background:#ef444440}.ctrl-btn.end{background:#ef444426;border:1px solid #ef44444d;color:#ef4444}.ctrl-btn.end:hover,.msg-count{background:#ef4444;color:#fff}.msg-count{border-radius:100px;font-size:9px;font-weight:700;padding:1px 5px}.wb-container{border:1px solid #ffffff14;border-radius:14px;display:flex;flex-direction:column;height:100%;overflow:hidden;width:100%}.wb-toolbar{align-items:center;background:#12121e;border-bottom:1px solid #ffffff14;display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;padding:10px 14px}.wb-tools{display:flex;gap:4px}.wb-colors{display:flex;flex-wrap:wrap;gap:5px}.wb-size{align-items:center;display:flex;gap:6px}.wb-size-label{color:#8a8aa8;font-size:12px;min-width:30px;text-align:center}.wb-btn{align-items:center;background:#ffffff0f;border:none;border-radius:8px;color:#f0f0f8;cursor:pointer;display:flex;font-size:13px;height:32px;justify-content:center;transition:all .15s;width:32px}.wb-btn:hover{background:#ffffff1a}.wb-btn.active{background:#6366f140;color:#a5b4fc}.wb-btn.danger{color:#ef4444}.wb-btn.danger:hover{background:#ef444426}.wb-color{border:2px solid #0000;border-radius:50%;cursor:pointer;height:22px;transition:all .15s;width:22px}.wb-color:hover{transform:scale(1.2)}.wb-color.selected{border-color:#fff;transform:scale(1.15)}.wb-divider{background:#ffffff1a;height:24px;margin:0 2px;width:1px}.wb-canvas{display:block;flex:1 1;touch-action:none}@media (max-width:768px){.side-panel{bottom:0;box-shadow:-4px 0 30px #00000080;max-width:320px;position:fixed;right:0;top:0;width:100%;z-index:100}.controls-center{gap:4px}.ctrl-btn{min-width:48px;padding:7px 8px}.ctrl-btn span{font-size:9px}.header-right .btn-header span{display:none}.room-id-badge{max-width:100px}.video-grid.count-3,.video-grid.count-4,.video-grid.count-5,.video-grid.count-6{grid-template-columns:1fr 1fr}}.layout{background:var(--bg-primary);display:flex;font-family:var(--font-body);height:100vh;overflow:hidden}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-x:hidden;overflow-y:auto;position:relative;transition:width .3s cubic-bezier(.4,0,.2,1);width:260px;z-index:100}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.layout.sidebar-closed .sidebar{width:72px}.layout.sidebar-closed .logo-text,.layout.sidebar-closed .nav-item span,.layout.sidebar-closed .upgrade-card,.layout.sidebar-closed .user-details,.layout.sidebar-closed .user-menu{display:none}.layout.sidebar-closed .nav-item{justify-content:center;padding:12px}.layout.sidebar-closed .user-info{justify-content:center;padding:10px}.sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;padding:18px 16px 14px}.logo,.sidebar-header{align-items:center;display:flex}.logo{gap:10px}.logo-icon{align-items:center;border-radius:10px;box-shadow:0 4px 12px #6c63ff59;color:#fff;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.logo-icon,.logo-text{background:var(--gradient)}.logo-text{-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-size:18px;font-weight:800;white-space:nowrap}.sidebar-toggle{background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;padding:6px;transition:var(--transition)}.sidebar-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:12px 10px}.nav-item{align-items:center;border-radius:var(--radius);color:var(--text-secondary);display:flex;font-size:14px;font-weight:500;gap:10px;padding:10px 12px;position:relative;text-decoration:none;transition:var(--transition);white-space:nowrap}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-dim);color:var(--accent-light);font-weight:600}.nav-item.active:before{background:var(--accent);border-radius:0 3px 3px 0;bottom:20%;content:"";left:0;position:absolute;top:20%;width:3px}.upgrade-card{align-items:flex-start;background:linear-gradient(135deg,#6c63ff1f,#a855f714);border:1px solid #6c63ff33;border-radius:var(--radius);cursor:pointer;display:flex;gap:10px;margin:4px 10px 8px;padding:13px;transition:var(--transition)}.upgrade-card:hover{border-color:var(--accent);box-shadow:var(--shadow-accent);transform:translateY(-1px)}.upgrade-icon{color:var(--accent-light);flex-shrink:0;margin-top:1px}.upgrade-title{color:var(--text-primary);font-size:13px;font-weight:700}.upgrade-subtitle{color:var(--text-secondary);font-size:11px;line-height:1.4;margin-top:2px}.sidebar-footer{border-top:1px solid var(--border);padding:8px 10px 12px;position:relative}.user-info{align-items:center;border-radius:var(--radius);cursor:pointer;display:flex;gap:10px;padding:10px;transition:var(--transition)}.user-info:hover{background:var(--bg-hover)}.user-avatar{align-items:center;background:var(--gradient);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:34px;justify-content:center;overflow:hidden;width:34px}.user-avatar img{height:100%;object-fit:cover;width:100%}.user-details{flex:1 1;min-width:0}.user-name{color:var(--text-primary);font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:var(--text-secondary);font-size:11px;margin-top:1px;text-transform:capitalize}.user-menu{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);bottom:calc(100% + 4px);box-shadow:var(--shadow-lg);left:10px;padding:6px;position:absolute;right:10px;z-index:200}.user-menu button{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;font-family:var(--font-body);font-size:13px;gap:8px;padding:9px 12px;transition:var(--transition);width:100%}.user-menu button:hover{background:var(--bg-hover);color:var(--text-primary)}.user-menu button.danger:hover{background:var(--error-dim);color:var(--error)}.main-content{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.topbar{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;flex-shrink:0;height:60px;justify-content:space-between;padding:0 24px}.menu-btn{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;padding:8px;transition:var(--transition)}.menu-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.topbar-right{align-items:center;display:flex;gap:8px}.icon-btn{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;padding:8px;position:relative;transition:var(--transition)}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.topbar-avatar{align-items:center;background:var(--gradient);border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:700;height:34px;justify-content:center;overflow:hidden;width:34px}.topbar-avatar img{height:100%;object-fit:cover;width:100%}.page-content{flex:1 1;overflow-y:auto;padding:28px}.page-content::-webkit-scrollbar{width:6px}.page-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.page-title{color:var(--text-primary);font-family:var(--font-display);font-size:26px;font-weight:800}.page-subtitle{color:var(--text-secondary);font-size:14px;margin-top:4px}.sidebar-overlay{background:#00000080;display:none;inset:0;position:fixed;z-index:99}@media (max-width:768px){.sidebar{bottom:0;left:0;position:fixed;top:0;transform:translateX(-100%);width:260px!important;z-index:200}.layout.sidebar-open .sidebar{transform:translateX(0)}.layout.sidebar-closed .sidebar{transform:translateX(-100%);width:260px!important}.layout.sidebar-closed .logo-text,.layout.sidebar-closed .nav-item span,.layout.sidebar-closed .upgrade-card,.layout.sidebar-closed .user-details{display:block}.layout.sidebar-closed .nav-item{justify-content:flex-start;padding:10px 12px}.sidebar-overlay{display:block}.page-content{padding:16px}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.btn{align-items:center;border:1.5px solid #0000;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:14px;font-weight:600;gap:7px;padding:9px 18px;text-decoration:none;transition:var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#5a52d5;border-color:#5a52d5;box-shadow:var(--shadow-accent)}.btn-secondary{background:var(--bg-tertiary);border-color:var(--border-strong);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-ghost{background:#0000;border-color:#0000;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--error);border-color:var(--error);color:#fff}.btn-sm{font-size:12px;padding:6px 12px}.btn-lg{font-size:15px;padding:12px 24px}.w-full{justify-content:center;width:100%}.badge{align-items:center;border-radius:100px;display:inline-flex;font-size:11px;font-weight:700;gap:4px;padding:3px 9px}.badge-muted{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary)}.badge-success{background:var(--success-dim);color:var(--success)}.badge-error{background:var(--error-dim);color:var(--error)}.badge-warning{background:var(--warning-dim);color:var(--warning)}.badge-accent{background:var(--accent-dim);color:var(--accent-light)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{color:var(--text-secondary);font-size:13px;font-weight:600}.form-input{background:var(--bg-tertiary);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:14px;outline:none;padding:10px 13px;transition:var(--transition);width:100%}.form-input:focus{background:var(--bg-card);border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}.form-input:disabled{cursor:not-allowed;opacity:.6}select.form-input{cursor:pointer}textarea.form-input{min-height:80px;resize:vertical}.empty-state{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:12px;justify-content:center;padding:60px 20px;text-align:center}.empty-state svg{opacity:.4}.empty-state h3{color:var(--text-secondary);font-size:18px;font-weight:700}.empty-state p{font-size:14px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{font-family:var(--font-display);font-size:18px;font-weight:700}.modal-close{background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:18px;padding:4px 8px}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-hover) 50%,var(--bg-secondary) 75%);background-size:200%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.table-wrap{overflow-x:auto}table{border-collapse:collapse;font-size:14px;width:100%}th{color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase}td,th{border-bottom:1px solid var(--border)}td{color:var(--text-primary);padding:12px 14px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-hover)}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-card{gap:14px}.stat-card,.stat-icon{align-items:center;display:flex}.stat-icon{border-radius:12px;flex-shrink:0;height:44px;justify-content:center;width:44px}.stat-icon.indigo{background:#6366f126;color:#6366f1}.stat-icon.green{background:#10b98126;color:#10b981}.stat-icon.blue{background:#3b82f626;color:#3b82f6}.stat-icon.violet{background:#8b5cf626;color:#8b5cf6}.stat-value{font-size:24px;font-weight:800;line-height:1}.stat-label{color:var(--text-secondary);font-size:12px;font-weight:500;margin-top:4px}
/*# sourceMappingURL=main.2c67809d.css.map*/