.auth-page{background:#f8fafc;justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.auth-card{background:#fff;border:1px solid #e8ecf0;border-radius:12px;width:100%;max-width:440px;padding:36px 32px;box-shadow:0 1px 3px #0000000d}.auth-logo{justify-content:center;margin-bottom:24px;display:flex}.auth-header{text-align:center;margin-bottom:24px}.auth-header h1{color:#1a202c;margin-bottom:6px;font-size:26px;font-weight:700}.auth-header p{color:#888;font-size:14px}.auth-banner{border-radius:12px;margin-bottom:16px;padding:12px 16px;font-size:14px}.auth-banner.success{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e4d}.auth-banner.error{color:#ef4444;background:#ef44441a;border:1px solid #ef44444d}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:#374151;font-size:13.5px;font-weight:500}.auth-field input{color:#1a202c;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;height:44px;padding:0 16px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.auth-field input::placeholder{color:#94a3b8}.auth-field input:focus{border-color:#3aafe8;box-shadow:0 0 0 3px #3aafe826}.auth-field input.input-error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441f}.auth-select{color:#1a202c;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;height:44px;padding:0 16px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.auth-date{color:#1a202c;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;height:44px;padding:0 16px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.auth-grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.auth-row{justify-content:space-between;align-items:center;font-size:13.5px;display:flex}.auth-remember{color:#94a3b8;cursor:pointer;align-items:center;gap:8px;display:flex}.auth-link-btn{cursor:pointer;color:#3aafe8;background:0 0;border:none;padding:0;font-family:inherit;font-size:13.5px}.auth-link-btn:hover{color:#7dd3f8}.auth-submit{color:#071426;cursor:pointer;background:#3aafe8;border:none;border-radius:12px;height:46px;margin-top:4px;font-family:inherit;font-size:15px;font-weight:700;transition:background .15s}.auth-submit:hover:not(:disabled){background:#7dd3f8}.auth-submit:disabled{opacity:.65;cursor:not-allowed}.field-error{color:#f87171;align-items:center;gap:4px;font-size:12px;display:flex}.required{color:#f87171}.auth-terms{color:#64748b;margin:0;font-size:12px}.auth-footer-text{text-align:center;color:#64748b;margin-top:20px;font-size:13.5px}.auth-link{color:#3aafe8;font-weight:500}.auth-link:hover{color:#7dd3f8}.pwd-strength{flex-direction:column;gap:6px;margin-top:8px;display:flex}.pwd-strength-header{color:#64748b;justify-content:space-between;font-size:12px;display:flex}.pwd-strength-bar-bg{background:#e2e8f0;border-radius:99px;height:6px;overflow:hidden}.pwd-strength-bar{border-radius:99px;height:100%;transition:width .3s,background .3s}.pwd-checks{grid-template-columns:1fr 1fr;gap:2px 12px;display:grid}.pwd-check{color:#94a3b8;font-size:11.5px}.pwd-check.passed{color:#64748b}body.admin-page .navbar-inner{max-width:100%;padding:0 20px}body.admin-page .navbar-links{display:none}.coming-soon-page{text-align:center;max-width:1280px;margin:0 auto;padding:80px 32px}.profile-layout{flex-wrap:wrap;align-items:flex-start;gap:24px;display:flex}.profile-avatar-card{background:#fff;border:1px solid #e8ecf0;border-radius:16px;flex-direction:column;flex-shrink:0;align-items:center;width:260px;padding:32px 28px;display:flex;box-shadow:0 1px 3px #0000000d}.profile-avatar-wrap{flex-direction:column;align-items:center;gap:16px;display:flex}.profile-avatar-img{object-fit:cover;border:3px solid #e0f4fc;border-radius:50%;width:100px;height:100px;box-shadow:0 0 0 3px #3aafe826}.profile-avatar-placeholder{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;font-size:36px;font-weight:800;display:flex;box-shadow:0 0 0 3px #3aafe826}.profile-avatar-upload-btn{color:#3aafe8;cursor:pointer;background:#fff;border:1.5px solid #3aafe8;border-radius:8px;align-items:center;gap:7px;padding:8px 18px;font-family:inherit;font-size:13.5px;font-weight:600;transition:background .15s,color .15s;display:flex}.profile-avatar-upload-btn:hover{color:#fff;background:#3aafe8}.profile-upload-actions{gap:8px;margin-top:14px;display:flex}.profile-save-btn{color:#fff;cursor:pointer;background:#3aafe8;border:none;border-radius:8px;padding:8px 18px;font-family:inherit;font-size:13.5px;font-weight:600;transition:background .15s}.profile-save-btn:hover:not(:disabled){background:#0ea5e9}.profile-save-btn:disabled{opacity:.6;cursor:not-allowed}.profile-cancel-btn{color:#555;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px 18px;font-family:inherit;font-size:13.5px;font-weight:500;transition:background .15s}.profile-cancel-btn:hover:not(:disabled){background:#f1f5f9}.profile-upload-hint{color:#94a3b8;text-align:center;margin-top:14px;font-size:12px}.profile-info-card{background:#fff;border:1px solid #e8ecf0;border-radius:16px;flex:1;min-width:280px;padding:32px 28px;box-shadow:0 1px 3px #0000000d}.profile-info-title{color:#1a202c;margin-bottom:24px;font-size:17px;font-weight:700}.profile-info-grid{flex-direction:column;gap:20px;display:flex}.profile-info-item{border-bottom:1px solid #f1f5f9;flex-direction:column;gap:4px;padding-bottom:20px;display:flex}.profile-info-item:last-child{border-bottom:none;padding-bottom:0}.profile-info-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;font-size:11.5px;font-weight:600}.profile-info-value{color:#1a202c;font-size:15px;font-weight:500}.profile-role-badge{color:#3aafe8;text-transform:capitalize;background:#e0f4fc;border-radius:20px;width:fit-content;padding:3px 12px;font-size:13px;font-weight:600;display:inline-block}.home-page{background:#f5f7fa;flex-direction:column;align-items:center;min-height:calc(100vh - 76px);padding:60px 24px 80px;display:flex}.home-hero{text-align:center;margin-bottom:52px}.home-title{color:#1a202c;margin-bottom:12px;font-size:36px;font-weight:800}.home-title span{color:#3aafe8}.home-subtitle{color:#888;max-width:480px;margin:0 auto;font-size:16px;line-height:1.6}.home-tiles{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;width:100%;max-width:1100px;display:grid}.home-tile{text-align:left;cursor:pointer;background:#fff;border:1px solid #e8ecf0;border-radius:16px;padding:32px 28px;font-family:inherit;transition:transform .15s,box-shadow .15s,border-color .15s;box-shadow:0 1px 3px #0000000d}.home-tile:hover{border-color:#bae3f7;transform:translateY(-4px);box-shadow:0 12px 32px #00000017}.home-tile-icon{border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:18px;font-size:26px;display:flex}.home-tile-title{margin-bottom:8px;font-size:18px;font-weight:700}.home-tile-desc{color:#888;font-size:13.5px;line-height:1.6}.navbar{z-index:100;background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;box-shadow:0 1px 3px #0000000f}.navbar-inner{justify-content:space-between;align-items:center;max-width:1280px;height:76px;margin:0 auto;padding:0 32px;display:flex}.navbar-brand{letter-spacing:.3px;align-items:center;gap:10px;font-size:18px;font-weight:900;display:flex}.brand-study{color:#555}.brand-squadrons{color:#3aafe8}.navbar-links{gap:2px;display:flex}.nav-link{color:#666;border-radius:8px;padding:8px 18px;font-size:14.5px;font-weight:500;transition:color .15s,background .15s;display:block}.nav-link:hover{color:#3aafe8;background:#f0f9ff}.nav-link.active{color:#3aafe8;background:#e0f4fc;font-weight:600}.navbar-user{align-items:center;gap:12px;margin-left:16px;display:flex}.navbar-username{color:#555;font-size:14px;font-weight:500}.nav-link-admin{color:#8b5cf6!important}.nav-link-admin:hover{color:#7c3aed!important;background:#f5f3ff!important}.nav-link-admin.active{color:#7c3aed!important;background:#ede9fe!important}.navbar-profile-wrap{position:relative}.navbar-chevron{color:#888;flex-shrink:0;transition:transform .15s}.navbar-welcome{cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:5px 8px;font-family:inherit;transition:background .15s;display:flex}.navbar-welcome:hover{background:#f1f5f9}.navbar-dropdown{z-index:300;background:#fff;border:1px solid #e8ecf0;border-radius:12px;width:220px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 24px #0000001a}.navbar-dropdown-header{align-items:center;gap:12px;padding:14px 16px;display:flex}.navbar-dropdown-avatar{color:#fff;background:linear-gradient(135deg,#3aafe8 0%,#0ea5e9 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:15px;font-weight:700;display:flex;overflow:hidden}.navbar-dropdown-name{color:#1a202c;font-size:14px;font-weight:600}.navbar-dropdown-email{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;max-width:130px;margin-top:1px;font-size:12px;overflow:hidden}.navbar-dropdown-role{color:#3aafe8;text-transform:capitalize;background:#e0f4fc;border-radius:20px;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.navbar-dropdown-divider{background:#f1f5f9;height:1px;margin:0}.navbar-dropdown-item{cursor:pointer;color:#374151;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s;display:flex}.navbar-dropdown-item:hover{background:#f8fafc}.navbar-dropdown-logout{cursor:pointer;color:#dc2626;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s;display:flex}.navbar-dropdown-logout:hover{background:#fef2f2}.navbar-login-btn{color:#3aafe8;cursor:pointer;background:#fff;border:1.5px solid #3aafe8;border-radius:8px;padding:8px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s,color .15s}.navbar-login-btn:hover{color:#fff;background:#3aafe8}.navbar-welcome-text{color:#555;font-size:14px}.navbar-welcome-text strong{color:#1a202c;font-weight:600}.navbar-avatar{color:#fff;background:linear-gradient(135deg,#3aafe8 0%,#0ea5e9 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex;overflow:hidden}.navbar-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.navbar-logout{color:#555;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:7px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s,color .15s,border-color .15s}.navbar-logout:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.page{max-width:1280px;margin:0 auto;padding:40px 32px 60px}.page-header{margin-bottom:28px}.page-title{color:#1a202c;margin-bottom:6px;font-size:26px;font-weight:700}.page-subtitle{color:#888;font-size:14px}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:18px;display:grid}.card{cursor:pointer;background:#fff;border:1px solid #e8ecf0;border-radius:12px;padding:24px;transition:transform .15s,box-shadow .15s,border-color .15s;box-shadow:0 1px 3px #0000000d}.card:hover{border-color:#bae3f7;transform:translateY(-2px);box-shadow:0 6px 20px #3aafe821}.card-icon{background:#e8f6fd;border-radius:10px;justify-content:center;align-items:center;width:46px;height:46px;margin-bottom:14px;font-size:22px;display:flex}.card-title{color:#1a202c;margin-bottom:6px;font-size:15.5px;font-weight:600}.card-desc{color:#888;font-size:13.5px;line-height:1.55}.card-badge{color:#3aafe8;background:#e8f6fd;border-radius:20px;margin-top:14px;padding:3px 12px;font-size:12px;font-weight:600;display:inline-block}.discussion-list{flex-direction:column;gap:8px;display:flex}.discussion-login-prompt{color:#0369a1;background:#f0f9ff;border:1px solid #bae3f7;border-radius:10px;align-items:center;gap:10px;padding:14px 18px;font-size:14px;font-weight:500;display:flex}.discussion-board{gap:14px;display:grid}.discussion-compose,.teacher-discussion-card{background:#fff;border:1px solid #e8ecf0;border-radius:10px;padding:14px;box-shadow:0 1px 3px #0000000d}.discussion-compose label{color:#1a202c;margin-bottom:7px;font-size:13px;font-weight:700;display:block}.discussion-compose textarea,.teacher-discussion-reply textarea{resize:vertical;width:100%;font:inherit;border:1px solid #e2e8f0;border-radius:8px;outline:none;padding:10px 12px;font-size:13.5px}.discussion-compose textarea:focus,.teacher-discussion-reply textarea:focus{border-color:#3aafe8}.discussion-compose .admin-add-btn{margin-top:10px}.discussion-item{cursor:pointer;background:#fff;border:1px solid #e8ecf0;border-radius:12px;align-items:center;gap:16px;padding:12px 16px;transition:box-shadow .15s,border-color .15s;display:flex;box-shadow:0 1px 3px #0000000d}.discussion-chat-item{cursor:default;align-items:flex-start}.discussion-item:hover{border-color:#bae3f7;box-shadow:0 4px 14px #3aafe81a}.disc-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;min-width:42px;height:42px;font-size:15px;font-weight:700;display:flex;overflow:hidden}.disc-thread-author{align-items:center;gap:10px;display:flex}.disc-compose-row{flex-direction:column;display:flex}.disc-compose-input{flex-direction:column;flex:1;gap:10px;display:flex}.disc-body{flex:1;min-width:0}.disc-title{color:#1a202c;white-space:normal;text-overflow:clip;margin-bottom:2px;font-size:15px;font-weight:600;overflow:visible}.disc-meta{color:#999;font-size:13px}.disc-meta span{margin-right:12px}.disc-replies{color:#3aafe8;white-space:nowrap;background:#e8f6fd;border-radius:20px;flex-shrink:0;padding:4px 12px;font-size:13px;font-weight:600}.discussion-answer{background:#f0f9ff;border-left:3px solid #3aafe8;border-radius:8px;margin-top:8px;padding:8px 12px}.discussion-answer strong{color:#0284c7;margin-bottom:2px;font-size:12.5px;display:block}.discussion-answer p{color:#334155;margin:0;font-size:13.5px;line-height:1.55}.discussion-pending{color:#f59e0b;margin-top:9px;font-size:12.5px;font-weight:600}.teacher-discussion-list{gap:12px;display:grid}.teacher-discussion-header{justify-content:space-between;gap:12px;margin-bottom:10px;display:flex}.teacher-discussion-header strong{color:#1a202c;font-size:14px;display:block}.teacher-discussion-header span{color:#94a3b8;font-size:12px}.teacher-discussion-question{color:#334155;margin:0 0 10px;font-size:14px;line-height:1.55}.teacher-discussion-reply{gap:10px;margin-top:12px;display:grid}.video-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.video-card{cursor:pointer;background:#fff;border:1px solid #e8ecf0;border-radius:12px;transition:transform .15s,box-shadow .15s;overflow:hidden;box-shadow:0 1px 3px #0000000d}.video-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3aafe821}.video-thumb{justify-content:center;align-items:center;height:170px;font-size:42px;display:flex;position:relative}.video-duration{color:#fff;background:#000000ad;border-radius:4px;padding:2px 7px;font-size:12px;font-weight:600;position:absolute;bottom:8px;right:10px}.video-info{padding:14px 16px 18px}.video-title{color:#1a202c;margin-bottom:6px;font-size:14.5px;font-weight:600;line-height:1.4}.video-instructor{color:#888;font-size:13px}.student-video-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.student-video-thumb{cursor:pointer;background:#e0f2fe;border:none;width:100%;font-family:inherit}.student-video-thumb:hover{background:#bae6fd}.student-video-play{color:#0284c7;font-size:18px;font-weight:800}.admin-layout{background:#f5f7fa;width:100%;min-height:calc(100vh - 76px);display:flex}.admin-sidebar{background:#fff;border-right:1px solid #e8ecf0;flex-direction:column;flex-shrink:0;width:230px;height:calc(100vh - 76px);transition:width .2s;display:flex;position:sticky;top:76px;overflow:hidden auto}.admin-sidebar.collapsed{width:56px}.admin-sidebar-group-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;justify-content:space-between;align-items:center;padding:10px 12px 4px;font-size:10.5px;font-weight:700;display:flex}.admin-sidebar-collapse{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:2px 4px;transition:color .15s,background .15s;display:flex}.admin-sidebar-collapse:hover{color:#3aafe8;background:#e0f4fc}.admin-sidebar-collapse-icon{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:100%;padding:8px 0;transition:color .15s,background .15s;display:flex}.admin-sidebar-collapse-icon:hover{color:#3aafe8;background:#e0f4fc}.admin-sidebar.collapsed .admin-sidebar-nav{padding:12px 6px}.admin-sidebar.collapsed .admin-sidebar-item{justify-content:center;padding:10px 0}.admin-sidebar.collapsed .admin-sidebar-group{margin-bottom:8px}.admin-sidebar-nav{flex-direction:column;gap:2px;padding:16px 10px;display:flex}.admin-sidebar-item{color:#64748b;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-family:inherit;font-size:13.5px;font-weight:500;transition:background .15s,color .15s;display:flex}.admin-sidebar-item:hover{color:#1a202c;background:#f1f5f9}.admin-sidebar-item.active{color:#3aafe8;background:#e0f4fc;font-weight:600}.admin-sidebar-item.active svg{color:#3aafe8}.admin-sidebar-group{margin-bottom:6px}.admin-main{flex:1;min-width:0;overflow-y:auto}.admin-section{padding:24px 28px 40px}.admin-coming-soon{text-align:center;color:#94a3b8;background:#fff;border:1px dashed #e2e8f0;border-radius:12px;margin-top:32px;padding:48px;font-size:14px}.cm-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cm-breadcrumb{align-items:center;gap:6px;font-size:15px;display:flex}.cm-breadcrumb-btn{color:#3aafe8;cursor:pointer;background:0 0;border:none;padding:0;font-size:15px;font-weight:500}.cm-breadcrumb-btn:hover{text-decoration:underline}.cm-breadcrumb-sep{color:#cbd5e1;font-size:17px}.cm-breadcrumb-current{color:#1a202c;font-size:15px;font-weight:600}.cm-context{color:#64748b;margin:0 0 20px;font-size:13px}.cm-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:16px;display:grid}.cm-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:10px;padding:16px;transition:box-shadow .15s,border-color .15s;display:flex;position:relative}.cm-card-clickable{cursor:pointer}.cm-card-clickable:hover{border-color:#3aafe8;box-shadow:0 4px 14px #3aafe824}.cm-card-icon{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:19px;font-weight:700;display:flex}.cm-card-body{flex-direction:column;flex:1;gap:3px;display:flex}.cm-card-name{color:#1a202c;font-size:14px;font-weight:600}.cm-card-desc{color:#64748b;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;display:-webkit-box;overflow:hidden}.cm-card-date{color:#94a3b8;margin-top:2px;font-size:11px}.cm-card-actions{gap:6px;display:flex}.cm-edit-btn,.cm-delete-btn{cursor:pointer;border:1px solid;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500;transition:background .15s}.cm-edit-btn{color:#0284c7;background:#f0f9ff;border-color:#bae6fd}.cm-edit-btn:hover{background:#e0f2fe}.cm-delete-btn{color:#dc2626;background:#fff5f5;border-color:#fecaca}.cm-delete-btn:hover{background:#fee2e2}.cm-card-arrow{color:#cbd5e1;pointer-events:none;font-size:18px;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.cm-empty{text-align:center;color:#94a3b8;background:#fff;border:1px dashed #e2e8f0;border-radius:12px;margin-top:32px;padding:48px 24px}.cm-empty-icon{margin-bottom:10px;font-size:44px}.cm-empty p{font-size:14px;line-height:1.6}.auth-textarea{color:#1a202c;box-sizing:border-box;resize:vertical;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.auth-textarea:focus{border-color:#3aafe8;outline:none}.sm-wrap{flex-direction:column;gap:20px;display:flex}.sm-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:22px 24px}.sm-section-title{color:#1a202c;align-items:center;gap:8px;margin-bottom:16px;font-size:14px;font-weight:600;display:flex}.sm-count{color:#fff;background:#3aafe8;border-radius:20px;padding:1px 7px;font-size:11px;font-weight:700}.sm-hierarchy{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.sm-hierarchy-step{flex-direction:column;flex:1;gap:6px;min-width:160px;display:flex}.sm-hierarchy-step label{color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.sm-hierarchy-arrow{color:#cbd5e1;flex-shrink:0;padding-bottom:6px;font-size:22px}.sm-upload-zone{text-align:center;cursor:pointer;border:2px dashed #e2e8f0;border-radius:10px;padding:28px 20px;transition:border-color .2s,background .2s}.sm-upload-zone:hover,.sm-upload-zone.drag-over{background:#f0f9ff;border-color:#3aafe8}.sm-upload-icon{margin-bottom:8px;font-size:32px}.sm-upload-text{color:#475569;margin-bottom:4px;font-size:14px}.sm-upload-text span{color:#3aafe8;cursor:pointer;font-weight:600;text-decoration:underline}.sm-upload-hint{color:#94a3b8;font-size:12px}.sm-file-selected{text-align:left;align-items:center;gap:12px;display:flex}.sm-file-icon-lg{flex-shrink:0;font-size:28px}.sm-file-meta{flex:1;min-width:0}.sm-file-name{color:#1a202c;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.sm-file-size{color:#94a3b8;margin-top:2px;font-size:12px}.sm-file-clear{color:#dc2626;cursor:pointer;background:#fff5f5;border:1px solid #fecaca;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:16px;line-height:1;display:flex}.sm-upload-form{flex-direction:column;gap:12px;margin-top:14px;display:flex}.sm-materials-list{flex-direction:column;gap:10px;display:flex}.sm-material-item{background:#fafafa;border:1px solid #f1f5f9;border-radius:8px;align-items:center;gap:12px;padding:12px 14px;transition:border-color .15s;display:flex}.sm-material-item:hover{background:#fff;border-color:#e2e8f0}.sm-material-icon{flex-shrink:0;font-size:24px}.sm-material-info{flex:1;min-width:0}.sm-material-title{color:#1a202c;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.sm-material-meta{color:#94a3b8;margin-top:2px;font-size:12px}.sm-empty-list{text-align:center;color:#94a3b8;padding:24px 0;font-size:14px}.sm-select-hint{text-align:center;color:#94a3b8;background:#fff;border:1px dashed #e2e8f0;border-radius:12px;padding:32px;font-size:14px}.sm-upload-zone.has-file{cursor:default}.preview-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172aa6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.preview-modal{background:#fff;border-radius:14px;flex-direction:column;width:92vw;max-width:1100px;height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 64px #00000059}.preview-modal-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:12px 18px;display:flex}.preview-modal-title{color:#1a202c;flex:1;align-items:center;gap:8px;min-width:0;font-size:14px;font-weight:600;display:flex}.preview-modal-name{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}.sm-preview-type{color:#0284c7;letter-spacing:.06em;background:#e0f2fe;border-radius:20px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:700}.preview-modal-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.preview-modal-close{cursor:pointer;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;line-height:1;transition:background .15s;display:flex}.preview-modal-close:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.preview-modal-body{background:#f1f5f9;flex-direction:column;flex:1;display:flex;overflow:hidden}.preview-embed{border:none;width:100%;height:100%;display:block}.preview-unsupported{text-align:center;color:#64748b;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;padding:40px;display:flex}.preview-unsupported-icon{font-size:56px}.preview-unsupported-title{color:#1a202c;font-size:17px;font-weight:600}.preview-unsupported-sub{color:#64748b;font-size:13px}.preview-unsupported-note{color:#94a3b8;max-width:360px;font-size:13px;line-height:1.7}.video-preview-modal{max-width:min(920px,94vw)}.video-preview-body{background:#0f172a}.video-preview-player{object-fit:contain;background:#0f172a;width:100%;height:100%;max-height:68vh}.sm-preview-btn{cursor:pointer;color:#0284c7;white-space:nowrap;background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500;transition:background .15s}.sm-preview-btn:hover{background:#e0f2fe}.admin-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.admin-add-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#3aafe8;border:none;border-radius:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s}.admin-add-btn:hover{background:#0ea5e9}.admin-stats{grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:10px;margin-bottom:14px;display:grid}.admin-stat-card{background:#fff;border:1px solid #e8ecf0;border-radius:10px;padding:12px 14px;box-shadow:0 1px 3px #0000000d}.admin-stat-value{margin-bottom:3px;font-size:22px;font-weight:800;line-height:1}.admin-stat-label{color:#888;font-size:12px}.admin-analytics-grid{grid-template-columns:minmax(0,1.35fr) minmax(220px,.8fr) minmax(220px,.8fr);align-items:stretch;gap:12px;display:grid}.admin-chart-panel{background:#fff;border:1px solid #e8ecf0;border-radius:10px;padding:14px;box-shadow:0 1px 3px #0000000d}.admin-chart-panel-line{min-width:0}.admin-chart-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.admin-chart-header h2{color:#1a202c;margin:0 0 2px;font-size:14px}.admin-chart-header p{color:#94a3b8;margin:0;font-size:12px}.admin-line-chart-wrap{width:100%;overflow:hidden}.admin-line-chart{width:100%;min-height:150px;display:block}.admin-line-grid{stroke:#edf2f7;stroke-width:1px}.admin-line-area{fill:#3aafe81f}.admin-line-path{fill:none;stroke:#3aafe8;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.admin-line-dot{fill:#fff;stroke:#3aafe8;stroke-width:2.5px}.admin-line-value{fill:#1a202c;font-size:11px;font-weight:700}.admin-line-label{fill:#64748b;font-size:11px;font-weight:600}.admin-vertical-bars{grid-template-columns:repeat(2,minmax(70px,1fr));align-items:end;gap:18px;height:168px;padding:0 4px;display:grid}.admin-vertical-bar-item{text-align:center;grid-template-rows:18px 1fr 18px;align-items:end;gap:7px;height:100%;display:grid}.admin-vertical-bar-value{color:#1a202c;font-size:12px;font-weight:800}.admin-vertical-bar-track{background:#f1f5f9;border-radius:8px;align-items:flex-end;height:100%;display:flex;overflow:hidden}.admin-vertical-bar-fill{border-radius:8px 8px 0 0;width:100%}.admin-vertical-bar-label{color:#64748b;font-size:11px;font-weight:600}.admin-donut-layout{grid-template-columns:118px 1fr;align-items:center;gap:12px;min-height:168px;display:grid}.admin-donut{width:112px;height:112px;position:relative}.admin-donut svg{width:112px;height:112px;transform:rotate(-90deg)}.admin-donut-bg{fill:none;stroke:#fee2e2;stroke-width:16px}.admin-donut-active{fill:none;stroke:#10b981;stroke-width:16px;stroke-linecap:round}.admin-donut-center{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.admin-donut-center strong{color:#1a202c;font-size:21px;line-height:1}.admin-donut-center span{color:#64748b;margin-top:3px;font-size:11px;font-weight:600}.admin-donut-legend{flex-direction:column;gap:10px;display:flex}.admin-donut-legend-item{align-items:center;gap:8px;display:flex}.admin-donut-legend-item>span{border-radius:50%;flex-shrink:0;width:11px;height:11px}.admin-donut-legend-item div{flex-direction:column;gap:2px;display:flex}.admin-donut-legend-item strong{color:#1a202c;font-size:13px}.admin-donut-legend-item small{color:#64748b;font-size:11px;font-weight:600}@media (width<=900px){.admin-analytics-grid{grid-template-columns:1fr}.admin-donut-layout{grid-template-columns:1fr;justify-items:center}.admin-donut-legend{flex-direction:row;justify-content:center;width:100%}}.admin-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.admin-filter-tabs{background:#f1f5f9;border-radius:8px;gap:4px;padding:3px;display:flex}.admin-filter-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 16px;font-family:inherit;font-size:13.5px;font-weight:500;transition:background .15s,color .15s}.admin-filter-tab.active{color:#1a202c;background:#fff;box-shadow:0 1px 3px #00000014}.admin-search{color:#1a202c;background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:240px;height:38px;padding:0 14px;font-family:inherit;font-size:14px;transition:border-color .15s}.admin-search:focus{border-color:#3aafe8}.admin-search::placeholder{color:#94a3b8}.admin-table{background:#fff;border:1px solid #e8ecf0;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.admin-table-head,.admin-table-row{grid-template-columns:2.5fr 1fr 1.2fr 1.1fr .9fr 1.1fr;align-items:center;gap:12px;padding:12px 20px;display:grid}.admin-table-head{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;background:#fafbfc;border-bottom:1px solid #f1f5f9;font-size:12px;font-weight:600}.admin-table-row{border-bottom:1px solid #f8fafc;transition:background .1s}.admin-table-row:last-child{border-bottom:none}.admin-table-row:hover{background:#fafbfc}.admin-user-cell{align-items:center;gap:12px;min-width:0;display:flex}.admin-user-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.admin-user-name{color:#1a202c;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.admin-user-email{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.admin-cell-muted{color:#94a3b8;font-size:13px}.admin-role-badge{text-transform:capitalize;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.admin-role-badge.student{color:#7c3aed;background:#ede9fe}.admin-role-badge.teacher{color:#d97706;background:#fef3c7}.admin-status-badge{text-transform:capitalize;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.admin-status-badge.active{color:#16a34a;background:#dcfce7}.admin-status-badge.inactive{color:#dc2626;background:#fee2e2}.disc-badge{white-space:nowrap;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.disc-badge-answered{color:#16a34a;background:#dcfce7}.disc-badge-pending{color:#a16207;background:#fef9c3}.admin-toggle-btn{cursor:pointer;border:none;border-radius:6px;padding:5px 12px;font-family:inherit;font-size:12.5px;font-weight:600;transition:background .15s,color .15s}.admin-toggle-btn.deactivate{color:#dc2626;background:#fee2e2}.admin-toggle-btn.deactivate:hover{background:#fecaca}.admin-toggle-btn.activate{color:#16a34a;background:#dcfce7}.admin-toggle-btn.activate:hover{background:#bbf7d0}.teacher-dashboard-grid{grid-template-columns:220px minmax(0,1fr);gap:12px;display:grid}.teacher-panel,.teacher-form-panel{background:#fff;border:1px solid #e8ecf0;border-radius:10px;padding:14px;box-shadow:0 1px 3px #0000000d}.teacher-panel-wide{min-width:0}.teacher-progress-ring{border-radius:50%;place-items:center;width:138px;height:138px;margin:8px auto 2px;display:grid}.teacher-progress-ring>div{background:#fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:96px;height:96px;display:flex}.teacher-progress-ring strong{color:#1a202c;font-size:24px;line-height:1}.teacher-progress-ring span{color:#64748b;margin-top:4px;font-size:12px;font-weight:600}.teacher-mini-list{gap:8px;display:grid}.teacher-mini-item{background:#fafbfc;border:1px solid #eef2f7;border-radius:8px;justify-content:space-between;gap:12px;padding:10px 12px;display:flex}.teacher-mini-item strong{color:#1a202c;font-size:13px;display:block}.teacher-mini-item span,.teacher-mini-item small{color:#64748b;font-size:12px}.teacher-form-panel{margin-bottom:16px}.teacher-form-panel .admin-add-btn{margin-top:12px}.teacher-table{margin-top:14px}.teacher-exam-row{grid-template-columns:2fr 1.2fr 1fr 1fr 1fr}.teacher-result-row{grid-template-columns:1.25fr 1.4fr .8fr 1.5fr .9fr .8fr}.teacher-table strong{color:#1a202c;font-size:13px;display:block}.teacher-table small{color:#94a3b8;margin-top:2px;font-size:11.5px;display:block}.teacher-table-input{width:100%;height:32px;font:inherit;border:1px solid #e2e8f0;border-radius:6px;outline:none;padding:0 9px;font-size:12.5px}.teacher-table-input:focus{border-color:#3aafe8}@media (width<=900px){.teacher-dashboard-grid,.teacher-exam-row,.teacher-result-row{grid-template-columns:1fr}}.admin-empty{text-align:center;color:#94a3b8;padding:40px;font-size:14px}.navbar-profile{color:#555;cursor:pointer;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;transition:border-color .15s,background .15s,color .15s;display:flex}.navbar-profile:hover{color:#3aafe8;background:#e0f4fc;border-color:#3aafe8}.modal-overlay{z-index:200;background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border:1px solid #e8ecf0;border-radius:16px;width:100%;max-width:420px;max-height:calc(100vh - 48px);padding:32px 28px 28px;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0000002e}.signup-modal{max-width:460px}.modal-avatar{color:#3aafe8;background:linear-gradient(135deg,#e0f4fc 0%,#bae3f7 100%);border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;display:flex;box-shadow:0 0 0 3px #3aafe833}.modal-close{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:22px;line-height:1;transition:color .15s,background .15s;position:absolute;top:12px;right:14px}.modal-close:hover{color:#374151;background:#f1f5f9}.auth-footer{text-align:center;color:#64748b;margin-top:16px;font-size:13.5px}button.auth-link{cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:13.5px}.auth-select:focus,.auth-date:focus{border-color:#3aafe8;box-shadow:0 0 0 3px #3aafe826}.auth-select.input-error,.auth-date.input-error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441f}*,:before,:after{box-sizing:border-box}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}*{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}body{color:#333;-webkit-font-smoothing:antialiased;background:#f5f7fa;margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif}h1,h2,h3,h4,p{margin:0}ul{margin:0;padding:0;list-style:none}a{text-decoration:none}
