*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0f0f1e;color:#e5e7eb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background:#0f0f1e;min-height:100vh}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}*{scrollbar-color:#363759 #1a1b2e;scrollbar-width:thin}::-webkit-scrollbar{height:12px;width:12px}::-webkit-scrollbar-track{background:#1a1b2e;border-radius:10px}::-webkit-scrollbar-thumb{background:#363759;border:2px solid #1a1b2e;border-radius:10px;-webkit-transition:background .3s;transition:background .3s}::-webkit-scrollbar-thumb:hover{background:#454866}::-webkit-scrollbar-thumb:active{background:#3b82f6}::-webkit-scrollbar-corner{background:#1a1b2e}.loading{align-items:center;color:#8b92b8;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.spinner{animation:spin 1s linear infinite;border:4px solid #8b92b833;border-radius:50%;border-top-color:#3b82f6;height:50px;margin-bottom:20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-container{align-items:center;background:linear-gradient(135deg,#0f0f1e,#1a1b2e);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#1a1b2e;border:1px solid #252641;border-radius:12px;box-shadow:0 10px 40px #00000080;max-width:400px;padding:40px;width:100%}.login-box h1{align-items:center;color:#e5e7eb;display:flex;font-size:2rem;gap:12px;justify-content:center;margin-bottom:10px;text-align:center}.login-box p{color:#9ca3af;font-size:.95rem;margin-bottom:30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#9ca3af;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input{background:#252641;border:1px solid #363759;border-radius:8px;color:#e5e7eb;font-size:14px;padding:12px;transition:all .3s;width:100%}.form-group input:focus{background:#2a2c47;border-color:#3b82f6;outline:none}.form-group input::placeholder{color:#6b7280}.btn-login{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;font-weight:600;padding:12px;transition:all .3s;width:100%}.btn-login:hover{background:#2563eb;box-shadow:0 8px 20px #3b82f666;transform:translateY(-2px)}.btn-login:disabled{cursor:not-allowed;opacity:.6;transform:none}.error-message{background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#f87171;margin-bottom:20px;padding:10px;text-align:center}.dashboard{background:#0f0f1e;display:flex;min-height:100vh}.sidebar{background:#1a1b2e;border-right:1px solid #252641;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:280px;z-index:100}.sidebar-header{border-bottom:1px solid #252641;margin-bottom:20px;padding:20px}.sidebar-logo{align-items:center;display:flex;justify-content:center;margin-bottom:12px}.sidebar-logo svg{color:#3b82f6;height:60px;width:60px}.sidebar h2{align-items:center;color:#e5e7eb;display:flex;font-size:1.5rem;gap:10px;justify-content:center;margin:0;text-align:center}.nav-menu{list-style:none;padding:0 12px}.nav-menu li{margin-bottom:8px}.nav-menu a{align-items:center;border-radius:8px;color:#9ca3af;display:flex;font-weight:500;gap:12px;padding:12px 16px;text-decoration:none;transition:all .3s}.nav-menu a:hover{background:#252641;color:#e5e7eb}.nav-menu a.active{background:#3b82f6;color:#fff}.user-info{background:#1a1b2e;border-top:1px solid #252641;bottom:0;left:0;padding:20px;position:absolute;right:0}.user-profile{gap:12px;margin-bottom:12px}.user-avatar,.user-profile{align-items:center;display:flex}.user-avatar{background:#374151;border-radius:50%;color:#9ca3af;font-size:18px;font-weight:700;height:42px;justify-content:center;width:42px}.user-details h3{color:#e5e7eb;font-size:14px;margin:0}.user-details p{color:#6b7280;font-size:12px;margin:2px 0 0}.btn-logout{align-items:center;background:#252641;border:1px solid #363759;border-radius:8px;color:#9ca3af;cursor:pointer;display:flex;font-size:14px;gap:8px;justify-content:center;padding:10px;transition:all .3s;width:100%}.btn-logout:hover{background:#363759;color:#e5e7eb}.main-content{flex:1 1;margin-left:280px;min-height:100vh;padding:32px}.page-header{margin-bottom:32px}.page-header h1{color:#e5e7eb;font-size:2rem;margin-bottom:8px}.page-header p{color:#9ca3af;font-size:.95rem}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.stat-card{background:#1a1b2e;border:1px solid #252641;border-radius:12px;padding:24px;transition:all .3s}.stat-card:hover{box-shadow:0 8px 20px #0000004d;transform:translateY(-2px)}.stat-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.stat-card-title{color:#9ca3af;font-size:.875rem;font-weight:500}.stat-card-icon{align-items:center;background:#3b82f61a;border-radius:8px;color:#3b82f6;display:flex;height:40px;justify-content:center;width:40px}.stat-card-value{color:#e5e7eb;font-size:2rem;font-weight:700;margin-bottom:4px}.stat-card-label{color:#6b7280;font-size:.875rem}.data-table-container{background:#1a1b2e;border:1px solid #252641;border-radius:12px;overflow:hidden}.table-header{align-items:center;border-bottom:1px solid #252641;display:flex;justify-content:space-between;padding:20px 24px}.table-header h2{color:#e5e7eb;font-size:1.25rem;margin:0}.btn-primary{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s}.btn-primary:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.btn-secondary{background:#252641;border:1px solid #363759;border-radius:8px;color:#9ca3af;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s}.btn-secondary:hover{background:#363759;color:#e5e7eb}.btn-danger{background:#ef44441a;border:1px solid #ef44444d;border-radius:6px;color:#ef4444;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .3s}.btn-danger:hover{background:#ef444433}.data-table{border-collapse:collapse;width:100%}.data-table td,.data-table th{border-bottom:1px solid #252641;padding:16px 24px;text-align:left}.data-table th{background:#1a1b2e;color:#9ca3af;font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.data-table td{color:#e5e7eb;font-size:.95rem}.data-table tr:hover td{background:#252641}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#1a1b2e;border:1px solid #252641;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;padding:32px;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.modal-header h2{color:#e5e7eb;font-size:1.5rem;margin:0}.btn-close{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .3s;width:32px}.btn-close:hover{background:#252641;color:#e5e7eb}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:24px}.form-actions{display:flex;gap:12px;justify-content:flex-end}.badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:4px 12px;text-transform:uppercase}.badge-success{background:#22c55e1a;border:1px solid #22c55e4d;color:#22c55e}.badge-warning{background:#fbbf241a;border:1px solid #fbbf244d;color:#fbbf24}.badge-danger{background:#ef44441a;border:1px solid #ef44444d;color:#ef4444}.badge-info{background:#3b82f61a;border:1px solid #3b82f64d;color:#3b82f6}.checkbox-container{align-items:center;cursor:pointer;display:flex;gap:8px}.checkbox-container input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;height:20px;width:20px}.empty-state{color:#6b7280;padding:60px 20px;text-align:center}.empty-state svg{height:80px;margin-bottom:16px;opacity:.5;width:80px}.empty-state h3{color:#9ca3af;font-size:1.25rem;margin-bottom:8px}.empty-state p{font-size:.95rem}.attendance-btn{align-items:center;border-radius:8px;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.attendance-btn:hover:not(:disabled){box-shadow:0 4px 12px #0000004d;transform:scale(1.1)}.attendance-btn:disabled{cursor:not-allowed;opacity:.6}input[type=date],input[type=datetime-local],input[type=email],input[type=number],input[type=password],input[type=text],input[type=time],select,textarea{-webkit-appearance:none!important;appearance:none!important;background:#252641!important;border:1px solid #3b3d5c!important;border-radius:6px!important;box-shadow:none!important;color:#fff!important;font-family:inherit!important;font-size:14px!important;padding:10px 12px;transition:all .3s!important;width:100%}input[type=date]:focus,input[type=datetime-local]:focus,input[type=email]:focus,input[type=number]:focus,input[type=password]:focus,input[type=text]:focus,input[type=time]:focus,select:focus,textarea:focus{border-color:#3b82f6!important;box-shadow:0 0 0 3px #3b82f61a!important;outline:none!important}input::placeholder,textarea::placeholder{color:#6b7280!important}select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%239ca3af' d='M10.293 3.293 6 7.586 1.707 3.293A1 1 0 0 0 .293 4.707l5 5a1 1 0 0 0 1.414 0l5-5a1 1 0 1 0-1.414-1.414z'/%3E%3C/svg%3E")!important;background-position:right 12px center!important;background-repeat:no-repeat!important;background-size:12px!important;padding-right:36px!important}input[type=checkbox]{accent-color:#3b82f6!important;background:#252641!important;border:1px solid #3b3d5c!important;border-radius:4px!important;cursor:pointer!important;height:18px!important;width:18px!important}input[type=checkbox]:checked{background:#3b82f6!important;border-color:#3b82f6!important}input:disabled,select:disabled,textarea:disabled{background:#1a1b2e!important;cursor:not-allowed!important;opacity:.6!important}
/*# sourceMappingURL=main.94639fc3.css.map*/