@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700&display=swap";*{box-sizing:border-box;font-family:Poppins,system-ui,sans-serif}body{margin:0;background:#f6f7fb}.admindash{display:flex;height:100vh}.sidebar{width:260px;background:#fff;padding:24px;display:flex;flex-direction:column;border-right:1px solid #eee}.logo h3{margin:0}.logo span{font-size:12px;color:#777}.nav{margin-top:32px;display:flex;flex-direction:column;gap:14px}.nav a{color:#444;text-decoration:none;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s}.nav a.active{background:#e9f0ff;color:#2563eb;font-weight:600}.content{flex:1;padding:32px;overflow-y:auto;display:flex;flex-direction:column}.content-area{flex:1;margin-top:24px}.dashboard-content{background:#fff;border-radius:14px;padding:40px;text-align:center;box-shadow:0 1px 3px #0000000d}.dashboard-content h2{color:#1f2937;margin:0 0 12px;font-size:24px}.dashboard-content p{color:#6b7280;margin:0;font-size:14px}.topbar{display:flex;justify-content:space-between;align-items:center}.actions{display:flex;gap:12px;align-items:center}.admin-btn{background:#fff;border:1px solid #e5e7eb;color:#374151;padding:10px 16px;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;transition:all .2s}.admin-btn:hover{background:#f9fafb;border-color:#d1d5db}.logout-btn{background:#e11d48;color:#fff;border:none;padding:10px 16px;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;transition:all .2s}.menu-toggle{display:none;position:fixed;top:18px;left:18px;z-index:1001;background:#fff;border:none;padding:10px;border-radius:10px;box-shadow:0 4px 10px #0000001a;font-size:20px}@media(max-width:768px){.menu-toggle{display:block}.sidebar{position:fixed;top:0;left:-100%;height:100%;z-index:1000;transition:left .3s ease;box-shadow:8px 0 20px #0000001a}.sidebar.open{left:0}.content{padding:80px 20px 20px}.topbar{flex-direction:column;gap:16px;align-items:flex-start}.actions{width:100%;flex-direction:column}.admin-btn,.logout-btn{width:100%;justify-content:center}}.admin-class{padding:0}.class-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.class-header h2{margin:0;color:#1f2937;font-size:24px;font-weight:700}.class-header p{margin:4px 0 0;color:#6b7280;font-size:14px}.classes-table{width:100%;border-collapse:collapse;min-width:600px}.classes-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.classes-table th{padding:16px 24px;text-align:left;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.classes-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.classes-table tbody tr:hover{background:#f9fafb}.classes-table tbody tr:last-child{border-bottom:none}.classes-table td{padding:16px 24px;color:#374151;font-size:14px}.badge-level{background:#f0fdf4;color:#16a34a}.class-form{padding:24px}.form-group input,.form-group select{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;transition:all .2s}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.submit-btn:disabled:hover{background:#9ca3af}@media(max-width:768px){.class-header{flex-direction:column;align-items:flex-start;gap:16px}.create-btn{width:100%;justify-content:center}.table-container{overflow-x:auto}.classes-table{min-width:600px}.modal-content{max-width:100%;margin:20px}.form-actions{flex-direction:column}.cancel-btn,.submit-btn,.delete-confirm-btn{width:100%}.success-message,.error-message-toast{right:20px;left:20px;top:20px}.classes-table th,.classes-table td{padding:12px 16px;font-size:13px}.action-btn{width:32px;height:32px;font-size:14px}}@media(max-width:480px){.class-header h2{font-size:20px}}.admin-subject{padding:0}.subject-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.subject-header h2{margin:0;color:#1f2937;font-size:24px;font-weight:700}.subject-header p{margin:4px 0 0;color:#6b7280;font-size:14px}.subjects-table{width:100%;border-collapse:collapse;min-width:600px}.subjects-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.subjects-table th{padding:16px 24px;text-align:left;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.subjects-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.subjects-table tbody tr:hover{background:#f9fafb}.subjects-table tbody tr:last-child{border-bottom:none}.subjects-table td{padding:16px 24px;color:#374151;font-size:14px}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-muted{color:#9ca3af;font-style:italic}.badge-code{background:#fef3c7;color:#92400e}.subject-form{padding:24px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;transition:all .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{resize:vertical;min-height:80px}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}@media(max-width:768px){.subject-header{flex-direction:column;align-items:flex-start;gap:16px}.create-btn{width:100%;justify-content:center}.table-container{overflow-x:auto}.subjects-table{min-width:600px}.description-cell{max-width:200px}.modal-content{max-width:100%;margin:20px}.form-actions{flex-direction:column}.cancel-btn,.submit-btn,.delete-confirm-btn{width:100%}.success-message,.error-message-toast{right:20px;left:20px;top:20px}}@media(max-width:480px){.subject-header h2{font-size:20px}.subjects-table th,.subjects-table td{padding:12px 16px;font-size:13px}.action-btn{width:32px;height:32px;font-size:14px}}.admin-teacher{padding:0}.teacher-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.teacher-header h2{margin:0;color:#1f2937;font-size:24px;font-weight:700}.teacher-header p{margin:4px 0 0;color:#6b7280;font-size:14px}.teachers-table{width:100%;border-collapse:collapse;min-width:800px}.teachers-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.teachers-table th{padding:16px 24px;text-align:left;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.teachers-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.teachers-table tbody tr:hover{background:#f9fafb}.teachers-table tbody tr:last-child{border-bottom:none}.teachers-table td{padding:16px 24px;color:#374151;font-size:14px}.badge{display:inline-block;padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600}.badge-sex{background:#fce7f3;color:#9f1239}.badge-section{background:#e9f0ff;color:#2563eb}.tags-container{display:flex;flex-wrap:wrap;gap:6px}.tag{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500}.tag-subject{background:#fef3c7;color:#92400e}.tag-class{background:#dbeafe;color:#1e40af}.tag-more{background:#f3f4f6;color:#6b7280}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s;overflow-y:auto}.teacher-modal{background:#fff;border-radius:14px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a;animation:slideUp .3s;margin:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:10}.teacher-form{padding:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group input,.form-group select{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;transition:all .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.multi-select-container{position:relative}.selected-items{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;min-height:40px;padding:8px;border:1px solid #e5e7eb;border-radius:10px;background:#f9fafb}.selected-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#2563eb;color:#fff;border-radius:6px;font-size:13px;font-weight:500}.remove-tag{background:none;border:none;color:#fff;cursor:pointer;padding:0;display:flex;align-items:center;font-size:14px;transition:transform .2s}.remove-tag:hover{transform:scale(1.2)}.search-dropdown{position:relative}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:#9ca3af;font-size:16px;pointer-events:none}.search-input{width:100%;padding:12px 16px 12px 40px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;transition:all .2s;box-sizing:border-box}.search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.dropdown-list{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;max-height:200px;overflow-y:auto;box-shadow:0 10px 15px -3px #0000001a;z-index:100}.checkbox-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .2s;border-bottom:1px solid #f3f4f6}.checkbox-item:last-child{border-bottom:none}.checkbox-item:hover{background:#f9fafb}.checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#2563eb}.checkbox-item span{flex:1;color:#374151;font-size:14px}.checkbox-item strong{color:#1f2937}.dropdown-empty{padding:16px;text-align:center;color:#9ca3af;font-size:14px}@media(max-width:768px){.teacher-header{flex-direction:column;align-items:flex-start;gap:16px}.create-btn{width:100%;justify-content:center}.table-container{overflow-x:auto}.teachers-table{min-width:800px}.form-row{grid-template-columns:1fr}.teacher-modal{max-width:100%;margin:20px}.form-actions{flex-direction:column}.cancel-btn,.submit-btn,.delete-confirm-btn{width:100%}.success-message,.error-message-toast{right:20px;left:20px;top:20px}.dropdown-list{max-height:150px}}@media(max-width:480px){.teacher-header h2{font-size:20px}.teachers-table th,.teachers-table td{padding:12px 16px;font-size:13px}.action-btn{width:32px;height:32px;font-size:14px}.selected-tag{font-size:12px;padding:4px 8px}}.admin-users{padding:0}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.users-header h2{margin:0;color:#1f2937;font-size:24px;font-weight:700}.users-header p{margin:4px 0 0;color:#6b7280;font-size:14px}.create-btn{background:#2563eb;color:#fff;border:none;padding:12px 24px;border-radius:10px;font-size:14px;font-weight:600;font-family:Poppins,system-ui,sans-serif;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;box-shadow:0 2px 4px #2563eb33}.create-btn:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.create-btn:active{transform:translateY(0)}.empty-state p{color:#6b7280;font-size:16px;margin-bottom:24px}.create-btn-secondary{background:#2563eb;color:#fff;border:none;padding:12px 24px;border-radius:10px;font-size:14px;font-weight:600;font-family:Poppins,system-ui,sans-serif;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .2s}.create-btn-secondary:hover{background:#1d4ed8}.table-container{background:#fff;border-radius:14px;box-shadow:0 1px 3px #0000000d;overflow:hidden;overflow-x:auto}.users-table{width:100%;border-collapse:collapse;min-width:600px}.users-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.users-table th{padding:16px 24px;text-align:left;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.users-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.users-table tbody tr:hover{background:#f9fafb}.users-table tbody tr:last-child{border-bottom:none}.users-table td{padding:16px 24px;color:#374151;font-size:14px}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:#e9f0ff;color:#2563eb;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.date-text{color:#6b7280;font-size:13px}.action-buttons{display:flex;gap:8px}.action-btn{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:16px}.edit-btn{background:#e9f0ff;color:#2563eb}.edit-btn:hover{background:#dbeafe;transform:scale(1.1)}.delete-btn{background:#fee2e2;color:#e11d48}.delete-btn:hover{background:#fecaca;transform:scale(1.1)}.modal-content{background:#fff;border-radius:14px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a;animation:slideUp .3s}.user-form{padding:24px}.form-group label{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#374151;font-size:14px;font-weight:500}.form-group input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;transition:all .2s;box-sizing:border-box}.form-hint{display:block;margin-top:6px;color:#9ca3af;font-size:12px;font-style:italic}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.cancel-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn:hover:not(:disabled){background:#1d4ed8}.submit-btn:disabled{background:#9ca3af;cursor:not-allowed}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn:disabled:hover{transform:none}.delete-modal{max-width:400px}.delete-modal-body{padding:24px}.delete-modal-body p{margin:0 0 12px;color:#374151;font-size:14px}.delete-modal-body p:last-child{margin-bottom:0}.delete-warning{color:#e11d48!important;font-size:13px!important}.delete-confirm-btn{padding:12px 24px;border:none;background:#e11d48;color:#fff;border-radius:10px;font-size:14px;font-weight:600;font-family:Poppins,system-ui,sans-serif;cursor:pointer;transition:all .2s}.delete-confirm-btn:hover:not(:disabled){background:#be185d}.delete-confirm-btn:disabled{background:#9ca3af;cursor:not-allowed}.success-message svg{font-size:20px}@media(max-width:768px){.users-header{flex-direction:column;align-items:flex-start;gap:16px}.create-btn{width:100%;justify-content:center}.table-container{overflow-x:auto}.users-table{min-width:600px}.modal-content{max-width:100%;margin:20px}.form-actions{flex-direction:column}.cancel-btn,.submit-btn,.delete-confirm-btn{width:100%}.success-message,.error-message-toast{right:20px;left:20px;top:20px}}@media(max-width:480px){.users-header h2{font-size:20px}.users-table th,.users-table td{padding:12px 16px;font-size:13px}.action-btn,.user-avatar{width:32px;height:32px;font-size:14px}}.admin-settings{padding:0}.settings-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;gap:16px}.settings-header h2{margin:0;color:#1f2937;font-size:24px;font-weight:700}.settings-header p{margin:4px 0 0;color:#6b7280;font-size:14px}.header-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.class-selector{padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;min-width:250px;cursor:pointer;transition:all .2s}.class-selector:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.class-selector:disabled{background:#f9fafb;cursor:not-allowed}.save-btn{background:#2563eb;color:#fff;border:none;padding:12px 24px;border-radius:10px;font-size:14px;font-weight:600;font-family:Poppins,system-ui,sans-serif;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;box-shadow:0 2px 4px #2563eb33}.save-btn:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.save-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.empty-state{text-align:center;padding:80px 20px;background:#fff;border-radius:14px;box-shadow:0 1px 3px #0000000d}.empty-state p{color:#6b7280;font-size:16px}.periods-section{background:#fff;border-radius:14px;padding:24px;margin-bottom:32px;box-shadow:0 1px 3px #0000000d}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{margin:0;color:#1f2937;font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}.add-period-btn{background:#10b981;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;font-family:Poppins,system-ui,sans-serif;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.add-period-btn:hover{background:#059669}.periods-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.period-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.period-number{font-weight:600;color:#374151;font-size:14px;min-width:70px}.period-time{flex:1;color:#6b7280;font-size:14px;font-family:Courier New,monospace}.period-actions{display:flex;gap:6px}.edit-period-btn,.delete-period-btn{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:14px}.edit-period-btn{background:#e9f0ff;color:#2563eb}.edit-period-btn:hover{background:#dbeafe}.delete-period-btn{background:#fee2e2;color:#e11d48}.delete-period-btn:hover{background:#fecaca}.teacher-periods-section{background:#fff;border-radius:14px;padding:24px;margin-bottom:32px;box-shadow:0 1px 3px #0000000d}.teacher-periods-table{width:100%;border-collapse:collapse}.teacher-periods-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.teacher-periods-table th{padding:16px 12px;text-align:left;font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.teacher-periods-table tbody tr{border-bottom:1px solid #e5e7eb}.teacher-periods-table tbody tr:hover{background:#f9fafb}.teacher-periods-table td{padding:16px 12px;color:#374151;font-size:14px}.empty-state-cell{text-align:center;color:#6b7280;padding:40px!important}.period-count-badge{display:inline-block;background:#2563eb;color:#fff;padding:6px 14px;border-radius:20px;font-weight:600;font-size:14px;min-width:40px;text-align:center}.timetable-section{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 3px #0000000d}.timetable-section h3{margin:0 0 20px;color:#1f2937;font-size:18px;font-weight:700}.table-container{overflow-x:auto;border:1px solid #e5e7eb;border-radius:10px}.timetable-table{width:100%;border-collapse:collapse;min-width:800px}.timetable-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.timetable-table th{padding:16px 12px;text-align:left;font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.period-col{width:120px;min-width:120px}.timetable-table tbody tr{border-bottom:1px solid #e5e7eb}.timetable-table tbody tr:hover{background:#f9fafb}.period-cell{background:#f9fafb;padding:12px;vertical-align:top}.period-info{display:flex;flex-direction:column;gap:4px}.period-num{font-weight:700;color:#2563eb;font-size:14px}.period-time-small{font-size:11px;color:#6b7280;font-family:Courier New,monospace}.schedule-cell{padding:8px;vertical-align:top;min-width:200px}.cell-content{display:flex;flex-direction:column;gap:6px}.teacher-select,.subject-select{width:100%;padding:8px 10px;border:1px solid #e5e7eb;border-radius:6px;font-size:12px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;cursor:pointer;transition:all .2s}.teacher-select:focus,.subject-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.cell-preview{margin-top:4px;padding:6px 8px;background:#eff6ff;border-radius:6px;font-size:11px}.teacher-preview{display:block;color:#2563eb;font-weight:600;margin-bottom:2px}.subject-preview{display:block;color:#6b7280;font-size:10px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:14px;width:100%;max-width:500px;box-shadow:0 20px 25px -5px #0000001a;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;color:#1f2937;font-size:20px;font-weight:700}.modal-close{width:32px;height:32px;border:none;background:#f3f4f6;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s}.modal-close:hover{background:#e5e7eb;color:#374151}.modal-body{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#374151;font-size:14px;font-weight:500}.form-group input[type=time]{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;transition:all .2s;box-sizing:border-box}.form-group input[type=time]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.time-preview{display:block;margin-top:6px;color:#2563eb;font-size:13px;font-weight:500;font-family:Courier New,monospace}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding:24px;border-top:1px solid #e5e7eb}.cancel-btn{padding:12px 24px;border:1px solid #e5e7eb;background:#fff;color:#374151;border-radius:10px;font-size:14px;font-weight:500;font-family:Poppins,system-ui,sans-serif;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#f9fafb;border-color:#d1d5db}.submit-btn{padding:12px 24px;border:none;background:#2563eb;color:#fff;border-radius:10px;font-size:14px;font-weight:600;font-family:Poppins,system-ui,sans-serif;cursor:pointer;transition:all .2s}.submit-btn:hover{background:#1d4ed8}@media(max-width:1024px){.timetable-table{min-width:700px}}@media(max-width:768px){.settings-header{flex-direction:column}.header-actions{width:100%}.class-selector{width:100%;min-width:auto}.save-btn{width:100%;justify-content:center}.periods-list{grid-template-columns:1fr}.table-container{overflow-x:scroll}.timetable-table{min-width:600px}.schedule-cell{min-width:180px}.success-message,.error-message-toast{right:20px;left:20px;top:20px}}@media(max-width:480px){.settings-header h2{font-size:20px}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.add-period-btn{width:100%;justify-content:center}.period-item{flex-direction:column;align-items:flex-start}.period-actions{width:100%;justify-content:flex-end}.timetable-table th,.timetable-table td{padding:8px;font-size:12px}.teacher-select,.subject-select{font-size:11px;padding:6px 8px}}.admin-report{padding:0}.report-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.report-header h2{margin:0;color:#1f2937;font-size:24px;font-weight:700}.report-header p{margin:4px 0 0;color:#6b7280;font-size:14px}.report-filters{background:#fff;border-radius:14px;padding:24px;margin-bottom:32px;box-shadow:0 1px 3px #0000000d;display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end}.filter-group{flex:1;min-width:180px}.filter-group label{display:block;margin-bottom:8px;color:#374151;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px}.filter-select,.filter-input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;transition:all .2s;box-sizing:border-box}.filter-select:focus,.filter-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.filter-select:disabled,.filter-input:disabled{background:#f9fafb;cursor:not-allowed}.filter-actions{display:flex;gap:12px;align-items:center}.generate-btn,.print-btn{padding:12px 24px;border:none;border-radius:10px;font-size:14px;font-weight:600;font-family:Poppins,system-ui,sans-serif;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;white-space:nowrap}.generate-btn{background:#2563eb;color:#fff}.generate-btn:hover:not(:disabled){background:#1d4ed8}.generate-btn:disabled{background:#9ca3af;cursor:not-allowed}.print-btn{background:#10b981;color:#fff}.print-btn:hover{background:#059669}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state,.empty-state{background:#fff;border-radius:14px;padding:80px 20px;text-align:center;box-shadow:0 1px 3px #0000000d}.loading-state p,.empty-state p{color:#6b7280;font-size:16px;margin:0}.report-container{background:#fff;border-radius:14px;padding:32px;box-shadow:0 1px 3px #0000000d;overflow-x:auto}.report-content{width:100%;min-width:1200px}.report-title-section{margin-bottom:32px;text-align:center;border-bottom:2px solid #e5e7eb;padding-bottom:24px}.report-title-section h1{margin:0 0 16px;color:#1f2937;font-size:28px;font-weight:700}.report-meta{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;font-size:13px;color:#6b7280}.report-meta p{margin:0}.report-meta strong{color:#374151;font-weight:600}.report-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:24px}.report-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.report-table th{padding:12px 8px;text-align:left;font-weight:600;color:#374151;border:1px solid #e5e7eb;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.report-table tbody tr{border-bottom:1px solid #e5e7eb}.report-table tbody tr:nth-child(2n){background:#f9fafb}.report-table tbody tr:hover{background:#f3f4f6}.report-table td{padding:10px 8px;color:#374151;border:1px solid #e5e7eb;font-size:12px}.report-table td:first-child{text-align:center;font-weight:600;color:#6b7280}.percentage-cell{font-weight:600;color:#2563eb;text-align:center}.remark-cell{font-weight:500;text-align:center}@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}html,body{margin:0!important;padding:0!important;background:#fff!important;width:100%!important;height:auto!important;overflow:visible!important}body>*{display:none!important}#report-container,#report-content{display:block!important;position:relative!important}.admin-report{padding:0!important;margin:0!important;background:#fff!important}.report-header,.report-filters,.filter-actions,.error-message-toast,.loading-state,.empty-state{display:none!important}.report-container{box-shadow:none!important;padding:0!important;border-radius:0!important;margin:0!important;background:#fff!important;overflow:visible!important}.report-content{min-width:100%!important;width:100%!important;overflow:visible!important}.report-title-section{page-break-after:avoid;margin-bottom:20px;padding-bottom:15px}.report-title-section h1{font-size:24px!important;margin-bottom:10px!important}.report-meta{font-size:11px!important;gap:16px!important}.report-table{page-break-inside:auto;font-size:9px!important;width:100%!important;table-layout:fixed!important;border-collapse:collapse!important;margin:0!important}.report-table thead{display:table-header-group!important;background:#f9fafb!important}.report-table thead th{background:#f9fafb!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.report-table tbody tr{page-break-inside:avoid;page-break-after:auto}.report-table tbody tr:nth-child(2n){background:#f9fafb!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.report-table th,.report-table td{padding:6px 4px!important;font-size:8px!important;border:1px solid #e5e7eb!important;word-wrap:break-word;overflow-wrap:break-word}@page{size:A4 landscape;margin:.8cm}.report-table th:nth-child(1),.report-table td:nth-child(1){width:3%!important;min-width:3%!important;max-width:3%!important}.report-table th:nth-child(2),.report-table td:nth-child(2){width:15%!important;min-width:15%!important;max-width:15%!important}.report-table th:nth-child(3),.report-table td:nth-child(3){width:10%!important;min-width:10%!important;max-width:10%!important}.report-table th:nth-child(4),.report-table td:nth-child(4){width:12%!important;min-width:12%!important;max-width:12%!important}.report-table th:nth-child(5),.report-table td:nth-child(5){width:8%!important;min-width:8%!important;max-width:8%!important;text-align:center!important}.report-table th:nth-child(6),.report-table td:nth-child(6){width:10%!important;min-width:10%!important;max-width:10%!important;text-align:center!important}.report-table th:nth-child(7),.report-table td:nth-child(7){width:10%!important;min-width:10%!important;max-width:10%!important;text-align:center!important}.report-table th:nth-child(8),.report-table td:nth-child(8){width:12%!important;min-width:12%!important;max-width:12%!important}.report-table th:nth-child(9),.report-table td:nth-child(9){width:10%!important;min-width:10%!important;max-width:10%!important;text-align:center!important}.report-table th:nth-child(10),.report-table td:nth-child(10){width:10%!important;min-width:10%!important;max-width:10%!important;text-align:center!important}*{overflow:visible!important;scrollbar-width:none!important;-ms-overflow-style:none!important}*::-webkit-scrollbar{display:none!important;width:0!important;height:0!important}}.error-message-toast svg{font-size:20px}@media(max-width:1024px){.report-content{min-width:1000px}}@media(max-width:768px){.report-filters{flex-direction:column}.filter-group{width:100%;min-width:auto}.filter-actions{width:100%;flex-direction:column}.generate-btn,.print-btn{width:100%;justify-content:center}.report-container{padding:16px;overflow-x:scroll}.report-content{min-width:900px}.report-meta{flex-direction:column;gap:8px}.error-message-toast{right:12px;left:12px;top:12px}}@media(max-width:480px){.report-header h2{font-size:20px}.report-title-section h1{font-size:22px}.report-table{font-size:10px}.report-table th,.report-table td{padding:8px 4px;font-size:10px}}.dashboard{padding:0}.dashboard-header{margin-bottom:32px}.dashboard-header h2{margin:0 0 8px;color:#1f2937;font-size:24px;font-weight:700}.dashboard-header p{margin:0;color:#6b7280;font-size:14px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.stat-card{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 3px #0000000d;display:flex;align-items:center;gap:20px;transition:all .3s;border:1px solid transparent}.stat-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px -5px #0000001a}.stat-card-classes{border-left:4px solid #2563eb}.stat-card-classes:hover{border-color:#2563eb;background:linear-gradient(135deg,#fff,#eff6ff)}.stat-card-subjects{border-left:4px solid #10b981}.stat-card-subjects:hover{border-color:#10b981;background:linear-gradient(135deg,#fff,#ecfdf5)}.stat-card-teachers{border-left:4px solid #f59e0b}.stat-card-teachers:hover{border-color:#f59e0b;background:linear-gradient(135deg,#fff,#fffbeb)}.stat-icon{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.stat-card-classes .stat-icon{background:#e9f0ff;color:#2563eb}.stat-card-subjects .stat-icon{background:#d1fae5;color:#10b981}.stat-card-teachers .stat-icon{background:#fef3c7;color:#f59e0b}.stat-content{flex:1}.stat-content h3{margin:0 0 4px;color:#1f2937;font-size:32px;font-weight:700;line-height:1}.stat-content p{margin:0;color:#6b7280;font-size:14px;font-weight:500}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.stat-card{padding:20px}.stat-icon{width:56px;height:56px;font-size:24px}.stat-content h3{font-size:28px}}@media(max-width:480px){.dashboard-header h2{font-size:20px}.stat-card{flex-direction:column;text-align:center;gap:16px}}.user-attendance{min-height:100vh;background:#f6f7fb;padding:20px;font-family:Poppins,system-ui,sans-serif}.attendance-header{background:#fff;border-radius:14px;padding:20px 24px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000000d;flex-wrap:wrap;gap:16px}.header-info h2{margin:0;color:#1f2937;font-size:24px;font-weight:700}.header-info p{margin:4px 0 0;color:#6b7280;font-size:14px}.logout-btn{background:#e11d48;color:#fff;border:none;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.logout-btn:hover{background:#be185d}.welcome-section{display:flex;justify-content:center;align-items:center;min-height:60vh}.welcome-card{background:#fff;border-radius:14px;padding:48px 32px;text-align:center;box-shadow:0 1px 3px #0000000d;max-width:500px;width:100%}.welcome-icon{font-size:64px;color:#2563eb;margin-bottom:24px}.welcome-card h3{margin:0 0 12px;color:#1f2937;font-size:24px;font-weight:700}.welcome-card p{margin:0 0 32px;color:#6b7280;font-size:14px}.mark-attendance-btn{background:#2563eb;color:#fff;border:none;padding:14px 32px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #2563eb33}.mark-attendance-btn:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.controls-section{background:#fff;border-radius:14px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000000d;display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end}.control-group{flex:1;min-width:200px}.control-group label{display:block;margin-bottom:8px;color:#374151;font-size:14px;font-weight:500}.class-selector,.date-input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;color:#374151;background:#fff;transition:all .2s;box-sizing:border-box}.class-selector:focus,.date-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.class-selector:disabled,.date-input:disabled{background:#f9fafb;cursor:not-allowed}.back-btn{padding:12px 24px;border:1px solid #e5e7eb;background:#fff;color:#374151;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.back-btn:hover{background:#f9fafb;border-color:#d1d5db}.empty-state{background:#fff;border-radius:14px;padding:80px 20px;text-align:center;box-shadow:0 1px 3px #0000000d}.empty-state p{color:#6b7280;font-size:16px;margin:0}.table-wrapper{background:#fff;border-radius:14px;padding:20px;margin-bottom:24px;box-shadow:0 1px 3px #0000000d;overflow-x:auto}.attendance-table{width:100%;border-collapse:collapse;min-width:800px;font-size:13px}.attendance-table th,.attendance-table td{border:1px solid #e5e7eb;padding:12px 8px;text-align:left;vertical-align:middle}.attendance-table thead th{background:#f9fafb;font-weight:600;color:#374151;text-transform:uppercase;font-size:11px;letter-spacing:.5px;text-align:center}.attendance-table tbody td{color:#374151;font-size:12px}.attendance-table tbody tr:nth-child(2n){background:#f9fafb}.attendance-table tbody tr:hover{background:#f3f4f6}.ap-cell{text-align:center;padding:8px!important}.ap-buttons{display:flex;gap:6px;justify-content:center}.ap-btn{width:36px;height:36px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;font-family:Poppins,system-ui,sans-serif}.absent-btn{background:#fff;color:#e11d48;border-color:#e11d48}.absent-btn:hover:not(:disabled){background:#fee2e2;border-color:#e11d48}.absent-btn.active{background:#e11d48;color:#fff;border-color:#e11d48}.present-btn{background:#fff;color:#10b981;border-color:#10b981}.present-btn:hover:not(:disabled){background:#d1fae5;border-color:#10b981}.present-btn.active{background:#10b981;color:#fff;border-color:#10b981}.ap-btn:disabled{opacity:.5;cursor:not-allowed}.minutes-cell{text-align:center;font-weight:600;color:#e11d48}.date-cell{text-align:center;color:#6b7280}.time-cell{text-align:center;font-family:Courier New,monospace;color:#6b7280;font-size:11px}.save-section{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 3px #0000000d;text-align:center}.save-attendance-btn{background:#10b981;color:#fff;border:none;padding:14px 48px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #10b98133}.save-attendance-btn:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.save-attendance-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.success-message{position:fixed;top:24px;right:24px;background:#10b981;color:#fff;padding:16px 24px;border-radius:10px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;box-shadow:0 10px 15px -3px #0000001a;z-index:2000;animation:slideInRight .3s}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.error-message-toast{position:fixed;top:24px;right:24px;background:#e11d48;color:#fff;padding:16px 24px;border-radius:10px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;box-shadow:0 10px 15px -3px #0000001a;z-index:2000;animation:slideInRight .3s}.success-message svg,.error-message-toast svg{font-size:20px}@media(max-width:768px){.user-attendance{padding:12px}.attendance-header{flex-direction:column;align-items:flex-start}.logout-btn{width:100%;justify-content:center}.controls-section{flex-direction:column}.control-group{width:100%;min-width:auto}.back-btn{width:100%}.table-wrapper{padding:12px;overflow-x:scroll;-webkit-overflow-scrolling:touch}.attendance-table{min-width:700px;font-size:11px}.attendance-table th,.attendance-table td{padding:8px 6px;font-size:11px}.ap-btn{width:32px;height:32px;font-size:12px}.save-attendance-btn{width:100%;padding:14px 24px}.success-message,.error-message-toast{right:12px;left:12px;top:12px;font-size:13px;padding:12px 16px}}@media(max-width:480px){.attendance-header h2{font-size:20px}.welcome-card{padding:32px 20px}.welcome-icon{font-size:48px}.attendance-table{min-width:600px;font-size:10px}.attendance-table th,.attendance-table td{padding:6px 4px;font-size:10px}.ap-btn{width:28px;height:28px;font-size:11px}.time-cell{font-size:9px}}.login-container{min-height:100vh;background:#f6f7fb;display:flex;align-items:center;justify-content:center;padding:20px;font-family:Poppins,system-ui,sans-serif}.login-card{background:#fff;border-radius:14px;padding:40px;width:100%;max-width:420px;box-shadow:0 1px 3px #0000000d}.login-header{text-align:center;margin-bottom:32px}.login-header h2{margin:0;color:#2563eb;font-size:28px;font-weight:700}.login-header p{margin:8px 0 0;color:#777;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#374151;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px}.form-group input{padding:12px 16px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Poppins,system-ui,sans-serif;transition:all .2s;background:#fff;color:#374151}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input:disabled{background:#f9fafb;cursor:not-allowed}.form-group input::placeholder{color:#9ca3af}.error-message{background:#fee2e2;color:#b91c1c;padding:12px 16px;border-radius:10px;font-size:14px;border:1px solid #fca5a5}.login-btn{width:100%;padding:12px 16px;background:#2563eb;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;font-family:Poppins,system-ui,sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;margin-top:8px}.login-btn:hover:not(:disabled){background:#1d4ed8}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{background:#9ca3af;cursor:not-allowed}@media(max-width:480px){.login-card{padding:32px 24px}.login-header h2{font-size:24px}}body{font-family:Poppins,sans-serif;margin:0;padding:1rem;background:#f6f8fa}.app{max-width:640px;margin:2rem auto;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 6px #00000014}
