:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;-webkit-overflow-scrolling:touch}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:20px}.loading-spinner{display:flex;align-items:center;justify-content:center}.spinner{border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner.small .spinner{width:20px;height:20px;border-width:2px}.loading-spinner.medium .spinner{width:40px;height:40px;border-width:3px}.loading-spinner.large .spinner{width:60px;height:60px;border-width:4px}.loading-message{margin-top:15px;color:#666;font-size:14px;text-align:center}.loading-overlay{position:fixed;inset:0;background-color:#ffffffe6;z-index:9999;display:flex;align-items:center;justify-content:center}.loading-overlay .loading-spinner-container{min-height:auto}.mobile-warning{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#ff6b6b,orange);color:#fff;z-index:9999;padding:12px 16px;box-shadow:0 2px 10px #0003;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.warning-content{display:flex;align-items:center;gap:12px;max-width:1200px;margin:0 auto}.warning-icon{font-size:24px;flex-shrink:0}.warning-text{flex:1;min-width:0}.warning-text h4{margin:0 0 4px;font-size:14px;font-weight:600}.warning-text p{margin:0;font-size:12px;opacity:.9;line-height:1.3}.warning-actions{display:flex;gap:8px;flex-shrink:0}.warning-action-btn,.warning-dismiss-btn{padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.warning-action-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.warning-action-btn:hover{background:#ffffff4d}.warning-dismiss-btn{background:#0003;color:#fff;border:1px solid rgba(255,255,255,.2)}.warning-dismiss-btn:hover{background:#0000004d}@media (max-width: 480px){.mobile-warning{padding:10px 12px}.warning-content{gap:8px}.warning-icon{font-size:20px}.warning-text h4{font-size:13px}.warning-text p{font-size:11px}.warning-actions{flex-direction:column;gap:4px}.warning-action-btn,.warning-dismiss-btn{padding:4px 8px;font-size:11px}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;padding:40px;width:100%;max-width:500px;animation:slideUp .5s ease-out}.register-card{max-width:700px}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:30px}.auth-header h1{color:#333;font-size:28px;font-weight:700;margin-bottom:8px}.auth-header h2{color:#555;font-size:24px;font-weight:600;margin-bottom:8px}.auth-header p{color:#666;font-size:16px;margin:0}.auth-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.form-group{display:flex;flex-direction:column}.form-group label{color:#333;font-weight:600;margin-bottom:8px;font-size:14px}.form-group input,.form-group select{padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;color:#000;transition:all .3s ease;background-color:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled{background-color:#f8f9fa;cursor:not-allowed}.password-input-container{position:relative}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:18px;padding:4px;border-radius:4px;transition:background-color .2s ease}.password-toggle:hover{background-color:#f8f9fa}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.role-specific-fields{padding:20px;background-color:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-height:50px}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.auth-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;border-left:4px solid #c33;display:flex;align-items:center;gap:8px;font-size:14px}.error-icon{font-size:16px}.auth-footer{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #e1e5e9}.auth-footer p{color:#666;margin:0}.auth-link{color:#667eea;text-decoration:none;font-weight:600;transition:color .3s ease}.auth-link:hover{color:#764ba2;text-decoration:underline}.demo-accounts{margin-top:30px;padding-top:20px;border-top:1px solid #e1e5e9}.demo-accounts h3{text-align:center;color:#333;font-size:18px;margin-bottom:15px}.demo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:15px}.demo-account{background-color:#f8f9fa;padding:12px;border-radius:8px;text-align:center;font-size:12px}.demo-account strong{display:block;color:#333;font-size:14px;margin-bottom:5px}.demo-account p{margin:2px 0;color:#666;font-family:monospace}@media (max-width: 768px){.auth-container{padding:10px}.auth-card{padding:30px 20px}.form-row{grid-template-columns:1fr;gap:20px}.demo-grid{grid-template-columns:repeat(2,1fr)}.auth-header h1{font-size:24px}.auth-header h2{font-size:20px}}@media (max-width: 480px){.demo-grid{grid-template-columns:1fr}}.qr-scanner-container{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:500px;margin:0 auto}.scanner-header{text-align:center}.scanner-header h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#333}.scanner-header p{margin:0;color:#666;font-size:14px}.scanner-video-container{position:relative;width:100%;max-width:400px;aspect-ratio:1;border-radius:12px;overflow:hidden;background-color:#000}.scanner-video{width:100%;height:100%;object-fit:cover}.scanner-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.scanner-frame{position:relative;width:250px;height:250px;border:2px solid rgba(255,255,255,.5);border-radius:12px}.corner{position:absolute;width:30px;height:30px;border:3px solid #fff}.corner.top-left{top:-3px;left:-3px;border-right:none;border-bottom:none;border-top-left-radius:12px}.corner.top-right{top:-3px;right:-3px;border-left:none;border-bottom:none;border-top-right-radius:12px}.corner.bottom-left{bottom:-3px;left:-3px;border-right:none;border-top:none;border-bottom-left-radius:12px}.corner.bottom-right{bottom:-3px;right:-3px;border-left:none;border-top:none;border-bottom-right-radius:12px}.scanning-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:250px;height:250px;pointer-events:none}.scanning-line{width:100%;height:2px;background:linear-gradient(90deg,transparent,#00ff00,transparent);animation:scan 2s linear infinite}@keyframes scan{0%{transform:translateY(-125px);opacity:0}50%{opacity:1}to{transform:translateY(125px);opacity:0}}.scanner-status{display:flex;align-items:center;gap:10px;padding:12px 20px;background-color:#f8f9fa;border-radius:8px;font-size:14px;font-weight:500}.status-scanning{display:flex;align-items:center;gap:10px;color:#28a745}.status-loading{display:flex;align-items:center;gap:10px;color:#6c757d}.status-dot{width:8px;height:8px;background-color:#28a745;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.loading-spinner{width:16px;height:16px;border:2px solid #e9ecef;border-top:2px solid #6c757d;border-radius:50%;animation:spin 1s linear infinite}.scanner-tips{background-color:#f8f9fa;padding:20px;border-radius:8px;width:100%;max-width:400px}.scanner-tips h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.scanner-tips ul{margin:0;padding-left:20px;color:#666}.scanner-tips li{margin-bottom:5px;font-size:14px}.qr-scanner-error{text-align:center;padding:40px 20px;max-width:500px;margin:0 auto}.error-icon{font-size:64px;margin-bottom:20px}.qr-scanner-error h3{margin:0 0 12px;font-size:24px;font-weight:600;color:#dc3545}.qr-scanner-error p{margin:0 0 20px;color:#666;font-size:16px}.retry-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:30px}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.error-help{background-color:#f8f9fa;padding:20px;border-radius:8px;text-align:left}.error-help h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.error-help ul{margin:0;padding-left:20px;color:#666}.error-help li{margin-bottom:8px;font-size:14px}.manual-input{background-color:#e9ecef;padding:20px;border-radius:8px;margin-top:20px;text-align:left}.manual-input h4{margin:0 0 8px;font-size:16px;font-weight:600;color:#333}.manual-input p{margin:0 0 12px;color:#666;font-size:14px}.manual-input textarea{width:100%;padding:12px;border:1px solid #ced4da;border-radius:6px;font-family:monospace;font-size:12px;resize:vertical;box-sizing:border-box}.manual-input textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.scanner-video{width:100%;height:100%;object-fit:cover;-webkit-transform:scaleX(-1);transform:scaleX(-1)}@supports (-webkit-touch-callout: none){.scanner-video{-webkit-playsinline:true;playsinline:true}}@media (max-width: 768px){.qr-scanner-container{padding:0 15px;gap:15px}.scanner-video-container{max-width:350px}.scanner-frame,.scanning-indicator{width:220px;height:220px}.scanner-header h3{font-size:16px}.scanner-header p{font-size:13px}}@media (max-width: 480px){.qr-scanner-container{padding:0 10px;gap:12px}.scanner-video-container{max-width:280px}.scanner-frame{width:180px;height:180px}.corner{width:20px;height:20px}.scanning-indicator{width:180px;height:180px}.scanner-tips{padding:12px}.scanner-tips h4{font-size:14px}.scanner-tips li{font-size:12px}.error-help,.manual-input{padding:15px}}@media (max-width: 768px) and (orientation: landscape){.qr-scanner-container{flex-direction:row;align-items:flex-start;gap:20px;max-width:none}.scanner-video-container{flex-shrink:0;max-width:300px}.scanner-tips{flex:1;max-width:none}}.student-dashboard{min-height:100vh;background-color:#f8f9fa}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 0;box-shadow:0 2px 10px #0000001a}.header-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.user-info h1{margin:0 0 5px;font-size:28px;font-weight:700}.user-role{margin:0;opacity:.9;font-size:16px}.header-actions{display:flex;gap:15px;align-items:center}.qr-scan-btn,.logout-btn{padding:10px 20px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.qr-scan-btn{background-color:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3)}.qr-scan-btn:hover{background-color:#ffffff4d;transform:translateY(-2px)}.logout-btn{background-color:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.2)}.logout-btn:hover{background-color:#fff3}.error-banner{background-color:#fee;color:#c33;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;border-left:4px solid #c33}.error-banner button{background:none;border:none;color:#c33;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.dashboard-main{max-width:1200px;margin:0 auto;padding:30px 20px}.stats-section{margin-bottom:30px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stat-card{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;align-items:center;gap:20px;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-icon{font-size:40px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.stat-content h3{margin:0 0 5px;font-size:32px;font-weight:700;color:#333}.stat-content p{margin:0;color:#666;font-size:14px;font-weight:500}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:25px}.dashboard-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden;transition:transform .3s ease}.dashboard-card:hover{transform:translateY(-3px)}.card-header{padding:20px 25px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.card-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.view-all-link{color:#667eea;text-decoration:none;font-weight:600;font-size:14px;transition:color .3s ease}.view-all-link:hover{color:#764ba2}.card-content{padding:25px}.courses-list,.attendance-list,.grades-list{display:flex;flex-direction:column;gap:15px}.course-item,.attendance-item,.grade-item{padding:15px;background-color:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;align-items:center;transition:background-color .3s ease}.course-item:hover,.attendance-item:hover,.grade-item:hover{background-color:#e9ecef}.course-info h4,.attendance-info h4,.grade-info h4{margin:0 0 5px;font-size:16px;font-weight:600;color:#333}.course-info p,.attendance-info p,.grade-info p{margin:0 0 5px;color:#666;font-size:14px}.course-department{background-color:#667eea;color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500}.attendance-status{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize;display:flex;align-items:center;gap:5px}.attendance-status.present{background-color:#d4edda;color:#155724}.attendance-status.absent{background-color:#f8d7da;color:#721c24}.grade-value{padding:8px 16px;border-radius:20px;font-weight:700;font-size:16px}.grade-a,.grade-a+{background-color:#d4edda;color:#155724}.grade-b,.grade-b+{background-color:#d1ecf1;color:#0c5460}.grade-c,.grade-c+{background-color:#fff3cd;color:#856404}.grade-d,.grade-f{background-color:#f8d7da;color:#721c24}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.action-btn{padding:15px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border:none;border-radius:8px;font-weight:600;text-align:center;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.action-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.empty-state{text-align:center;padding:40px 20px;color:#666}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow:hidden;box-shadow:0 20px 40px #0000004d}.modal-header{padding:20px 25px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:20px;font-weight:600;color:#333}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .3s ease}.close-btn:hover{background-color:#f8f9fa}@media (max-width: 768px){.header-content{flex-direction:column;gap:15px;text-align:center}.header-actions{flex-direction:column;width:100%}.qr-scan-btn,.logout-btn{width:100%}.dashboard-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{padding:20px}.quick-actions{grid-template-columns:1fr}}@media (max-width: 480px){.dashboard-main{padding:20px 15px}.card-content{padding:20px}.stats-grid{grid-template-columns:1fr}.stat-card{flex-direction:column;text-align:center;gap:15px}}.admin-dashboard{min-height:100vh;background-color:#f8f9fa;display:flex;flex-direction:column}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:#f8f9fa}.loading-spinner{width:40px;height:40px;border:4px solid #e9ecef;border-top:4px solid #dc3545;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-header{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;padding:20px 30px;box-shadow:0 2px 10px #0000001a}.admin-header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.admin-title h1{margin:0 0 5px;font-size:28px;font-weight:700}.admin-title p{margin:0;opacity:.9;font-size:16px}.admin-header-actions{display:flex;align-items:center;gap:30px}.admin-stats-summary{display:flex;gap:25px}.stat-number{font-size:24px;font-weight:700;line-height:1}.stat-label{font-size:12px;opacity:.8;margin-top:2px}.logout-btn{background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.2);padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.logout-btn:hover{background:#fff3;border-color:#fff6}.admin-content{display:flex;flex:1;max-width:1400px;margin:0 auto;width:100%}.admin-sidebar{width:280px;background:#fff;border-right:1px solid #e9ecef;padding:30px 0;box-shadow:2px 0 10px #0000000d}.admin-nav{display:flex;flex-direction:column;gap:5px;padding:0 20px}.nav-item{display:flex;align-items:center;gap:15px;padding:15px 20px;background:none;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;text-align:left;font-size:16px;color:#495057;width:100%}.nav-item:hover{background-color:#f8f9fa;color:#dc3545}.nav-item.active{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;box-shadow:0 4px 15px #dc35454d}.nav-icon{font-size:20px;width:24px;text-align:center}.nav-label{font-weight:500}.admin-main{flex:1;padding:30px;overflow-y:auto}.admin-card{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 10px #00000014;margin-bottom:25px}.admin-card h2{margin:0 0 20px;color:#333;font-size:24px;font-weight:600}.admin-card h3{margin:0 0 15px;color:#495057;font-size:18px;font-weight:600}.btn{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px;text-decoration:none}.btn-primary{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #007bff4d}.btn-success{background:linear-gradient(135deg,#28a745,#1e7e34);color:#fff}.btn-success:hover{transform:translateY(-2px);box-shadow:0 4px 15px #28a7454d}.btn-warning{background:linear-gradient(135deg,#ffc107,#e0a800);color:#212529}.btn-warning:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ffc1074d}.btn-danger{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 15px #dc35454d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-outline{background:transparent;border:2px solid #dee2e6;color:#495057}.btn-outline:hover{background:#f8f9fa;border-color:#adb5bd}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:15px 30px;font-size:16px}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:#333}.form-control{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:all .3s ease;background-color:#fff}.form-control:focus{outline:none;border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.form-control:disabled{background-color:#f8f9fa;cursor:not-allowed}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #00000014}.admin-table th,.admin-table td{padding:15px;text-align:left;border-bottom:1px solid #e9ecef}.admin-table th{background-color:#f8f9fa;font-weight:600;color:#495057;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.admin-table tr:hover{background-color:#f8f9fa}.admin-table tr:last-child td{border-bottom:none}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-active{background-color:#d4edda;color:#155724}.status-inactive{background-color:#f8d7da;color:#721c24}.status-pending{background-color:#fff3cd;color:#856404}.pagination{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:25px}.pagination button{padding:8px 12px;border:1px solid #dee2e6;background:#fff;color:#495057;border-radius:6px;cursor:pointer;transition:all .3s ease}.pagination button:hover:not(:disabled){background-color:#f8f9fa;border-color:#adb5bd}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination button.active{background-color:#dc3545;color:#fff;border-color:#dc3545}.search-filters{display:flex;gap:15px;margin-bottom:25px;flex-wrap:wrap;align-items:center}.search-input{flex:1;min-width:250px}.filter-select{min-width:150px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 10px #00000014;text-align:center;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#dc3545,#c82333)}.stat-card h3{margin:0 0 10px;font-size:32px;font-weight:700;color:#dc3545}.stat-card p{margin:0;color:#6c757d;font-weight:500}@media (max-width: 1024px){.admin-content{flex-direction:column}.admin-sidebar{width:100%;padding:20px 0}.admin-nav{flex-direction:row;overflow-x:auto;padding:0 20px}.nav-item{min-width:150px;justify-content:center}.admin-header-content{flex-direction:column;gap:20px;text-align:center}.admin-stats-summary{justify-content:center}}@media (max-width: 768px){.admin-header{padding:15px 20px}.admin-main{padding:20px}.search-filters{flex-direction:column;align-items:stretch}.search-input,.filter-select{min-width:auto}.stats-grid{grid-template-columns:1fr}.admin-table{font-size:14px}.admin-table th,.admin-table td{padding:10px}}@media (max-width: 480px){.admin-title h1{font-size:24px}.nav-item{min-width:120px;padding:12px 15px}.nav-label{font-size:14px}.admin-card{padding:20px}.btn{padding:8px 16px;font-size:13px}}.overview-header{margin-bottom:30px}.overview-header h2{margin-bottom:8px}.overview-header p{color:#6c757d;margin:0}.overview-content{display:grid;grid-template-columns:2fr 1fr;gap:25px}.department-stats{display:flex;flex-direction:column;gap:15px}.department-item{display:flex;flex-direction:column;gap:8px}.department-info{display:flex;justify-content:space-between;align-items:center}.department-name{font-weight:600;color:#333}.department-count{color:#6c757d;font-size:14px}.department-bar{height:8px;background-color:#e9ecef;border-radius:4px;overflow:hidden}.department-fill{height:100%;background:linear-gradient(135deg,#dc3545,#c82333);transition:width .3s ease}.activities-list{display:flex;flex-direction:column;gap:15px}.activity-item{display:flex;gap:12px;padding:15px;background-color:#f8f9fa;border-radius:8px;border-left:4px solid #dc3545}.activity-icon{font-size:20px;flex-shrink:0}.activity-content{flex:1}.activity-message{margin:0 0 5px;font-weight:500;color:#333}.activity-time{font-size:12px;color:#6c757d}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.system-status{display:flex;flex-direction:column;gap:12px}.status-item{display:flex;align-items:center;gap:12px;padding:10px;background-color:#f8f9fa;border-radius:6px}.status-indicator{width:12px;height:12px;border-radius:50%}.status-online{background-color:#28a745}.status-warning{background-color:#ffc107}.status-offline{background-color:#dc3545}.status-text{margin-left:auto;font-weight:600;font-size:14px}.trend-up{color:#28a745;font-size:12px}.trend-down{color:#dc3545;font-size:12px}.trend-neutral{color:#6c757d;font-size:12px}.trend-info{color:#007bff;font-size:12px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h2{margin:0 0 5px}.page-header p{margin:0;color:#6c757d}.bulk-actions{display:flex;justify-content:space-between;align-items:center;padding:15px;background-color:#e3f2fd;border-radius:8px;margin-top:15px}.selected-count{font-weight:600;color:#1976d2}.bulk-buttons{display:flex;gap:10px}.user-info{display:flex;flex-direction:column}.user-id{color:#6c757d;font-size:12px}.action-buttons{display:flex;gap:5px}.user-stats{display:flex;gap:30px}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-label{font-size:14px;color:#6c757d;margin-bottom:5px}.stat-value{font-size:24px;font-weight:700;color:#333}.course-info{display:flex;flex-direction:column}.course-description{color:#6c757d;font-size:12px;margin-top:2px}.enrollment-count{color:#007bff;font-weight:600;font-size:14px}.course-stats{display:flex;gap:30px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.large-modal{max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #e9ecef}.modal-header h3{margin:0;color:#333}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.modal-close:hover{background-color:#f8f9fa;color:#333}.modal-body{padding:25px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px 25px;border-top:1px solid #e9ecef;background-color:#f8f9fa}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-help{color:#6c757d;font-size:12px;margin-top:5px}.report-tabs{display:flex;gap:5px;margin-bottom:0}.tab-button{display:flex;align-items:center;gap:8px;padding:12px 20px;background:none;border:none;border-radius:8px 8px 0 0;cursor:pointer;transition:all .3s ease;color:#6c757d;font-weight:500}.tab-button:hover{background-color:#f8f9fa;color:#333}.tab-button.active{background-color:#dc3545;color:#fff}.tab-icon{font-size:16px}.tab-label{font-size:14px}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.report-summary{margin-bottom:30px}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.report-table{margin-top:25px}.report-table h4{margin-bottom:15px;color:#333}.percentage{padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.percentage.good{background-color:#d4edda;color:#155724}.percentage.average{background-color:#fff3cd;color:#856404}.percentage.poor{background-color:#f8d7da;color:#721c24}.progress-bar{position:relative;height:20px;background-color:#e9ecef;border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,#dc3545,#c82333);transition:width .3s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.grade-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;text-align:center;min-width:30px;display:inline-block}.grade-Aplus,.grade-A,.grade-Aminus{background-color:#d4edda;color:#155724}.grade-Bplus,.grade-B,.grade-Bminus{background-color:#cce5ff;color:#004085}.grade-Cplus,.grade-C,.grade-Cminus{background-color:#fff3cd;color:#856404}.grade-Dplus,.grade-D{background-color:#ffeaa7;color:#6c5ce7}.grade-F{background-color:#f8d7da;color:#721c24}.report-info{background-color:#f8f9fa;padding:20px;border-radius:8px}.report-info p{margin:0 0 10px}.report-info p:last-child{margin-bottom:0}.operation-tabs{display:flex;gap:5px;margin-bottom:0}.bulk-form{padding:25px}.enrollment-methods{display:flex;flex-direction:column;gap:30px;margin-top:25px}.method-section{padding:20px;border:2px solid #e9ecef;border-radius:12px}.method-section h4{margin:0 0 20px;color:#333}.method-divider{text-align:center;font-weight:600;color:#6c757d;padding:20px 0;position:relative}.method-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:#e9ecef;z-index:1}.method-divider span{background-color:#fff;padding:0 20px;position:relative;z-index:2}.student-selection{display:flex;flex-direction:column;gap:15px}.selection-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:15px;border-bottom:1px solid #e9ecef}.selection-count{color:#6c757d;font-size:14px}.student-list{max-height:300px;overflow-y:auto;border:1px solid #e9ecef;border-radius:8px;padding:15px}.student-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #f8f9fa}.student-item:last-child{border-bottom:none}.student-name{font-weight:500;color:#333}.student-id{color:#6c757d;font-size:12px;margin-left:auto}.more-students{text-align:center;color:#6c757d;font-style:italic;margin:10px 0 0}.csv-section{display:flex;flex-direction:column;gap:20px}.csv-format{background-color:#f8f9fa;padding:15px;border-radius:8px;border-left:4px solid #007bff}.csv-format h5{margin:0 0 10px;color:#333}.csv-format code{display:block;font-family:Courier New,monospace;font-size:12px;line-height:1.4;color:#495057}.form-actions{display:flex;justify-content:center;margin-top:30px;padding-top:25px;border-top:1px solid #e9ecef}.results-summary{margin-bottom:25px}.results-table{max-height:400px;overflow-y:auto}.help-content{display:grid;grid-template-columns:1fr 1fr;gap:30px}.help-section h4{margin:0 0 15px;color:#333}.help-section ul{margin:0;padding-left:20px}.help-section li{margin-bottom:8px;color:#6c757d;line-height:1.4}.settings-layout{display:flex;gap:30px}.settings-nav{width:280px;background:#fff;border-radius:12px;padding:20px 0;box-shadow:0 2px 10px #00000014;height:fit-content}.settings-content{flex:1}.settings-form{display:flex;flex-direction:column;gap:25px}.checkbox-group{display:flex;align-items:center;gap:10px}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:500;color:#333}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.notification-types{display:grid;grid-template-columns:1fr 1fr;gap:30px}.backup-status{margin-top:30px;padding:20px;background-color:#f8f9fa;border-radius:8px}.backup-status h4{margin:0 0 15px;color:#333}.status-info{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.status-item{display:flex;justify-content:space-between;align-items:center}.status-label{font-weight:500;color:#333}.status-value{color:#6c757d}.status-success{color:#28a745!important;font-weight:600}.settings-actions{display:flex;justify-content:center;gap:20px;margin-top:40px;padding-top:30px;border-top:2px solid #e9ecef}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6c757d}.loading-activities{display:flex;flex-direction:column;align-items:center;padding:40px 20px;color:#6c757d}.empty-state{text-align:center;padding:40px 20px;color:#6c757d}.empty-state p{margin:0;font-size:16px}.app{width:100%;min-height:100vh;min-height:calc(var(--vh, 1vh) * 100);background-color:#f8f9fa}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}input,textarea,[contenteditable]{-webkit-user-select:text;-khtml-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}button,.btn,.auth-button{min-height:44px;min-width:44px;touch-action:manipulation;-webkit-appearance:none;-moz-appearance:none;appearance:none}input,select,textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:8px;font-size:16px;min-height:44px}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;text-align:center;background-color:#f8f9fa}.error-page h1{color:#dc3545;font-size:2rem;margin-bottom:1rem}.error-page p{color:#6c757d;font-size:1.1rem;max-width:500px;line-height:1.5}.mobile-only{display:none}.desktop-only{display:block}@media (max-width: 768px){.mobile-only{display:block}.desktop-only{display:none}.app{width:100vw;overflow-x:hidden}.container{padding:10px}h1{font-size:1.8rem}h2{font-size:1.5rem}h3{font-size:1.3rem}}@media (max-width: 480px){.container{padding:5px}h1{font-size:1.6rem}h2{font-size:1.4rem}h3{font-size:1.2rem}}@supports (-webkit-touch-callout: none){.app{min-height:-webkit-fill-available}input[type=email],input[type=password],input[type=text]{font-size:16px}}@media screen and (-webkit-min-device-pixel-ratio: 0){input[type=email],input[type=password],input[type=text]{font-size:16px}}
