body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-page{display:flex;flex-direction:row;min-height:100vh;width:100%}.left-panel{align-items:center;background-color:#f0f2f5;display:flex;flex:1 1;justify-content:center;padding:20px}.logo-image{height:auto;max-height:70vh;max-width:70%;object-fit:contain}.right-panel{align-items:center;background-color:#f9fafb;display:flex;flex:1 1;justify-content:center;padding:20px}.form-container{animation:fadeIn .8s ease-in-out;background:#fff;border-radius:12px;box-shadow:0 8px 20px #0000001a;max-width:400px;padding:30px;width:100%}.form-container h2{color:#333;font-size:24px;margin-bottom:25px;text-align:center}.form-group label{color:#555;font-size:14px}.form-group input{border:1px solid #ccc;box-sizing:border-box;padding:12px 15px}.form-group input:focus{box-shadow:0 0 0 2px #4a6ef533}button{background-color:#4a6ef5;color:#fff;font-size:16px;font-weight:600;margin-top:5px;padding:12px;width:100%}button:hover{background-color:#3b5dd9;transform:translateY(-1px)}button:active{transform:translateY(0)}.mensaje{color:#d9534f;font-size:14px;font-weight:700;margin-top:15px}.boton-registro{background-color:#6c757d;margin-top:10px}.boton-registro:hover{background-color:#5a6268}@media (max-width:992px){.login-page{flex-direction:column;min-height:100vh}.left-panel{flex:none;height:auto;padding:40px 20px}.right-panel{align-items:flex-start;flex:none;padding:20px;width:100%}.logo-image{max-height:150px;max-width:250px}.form-container{border-radius:0;border-top:1px solid #eee;box-shadow:none;margin-top:0;max-width:100%;padding:25px}}@media (max-width:576px){.left-panel{padding:30px 20px}.right-panel{padding:15px}.form-container{padding:20px 15px}.form-container h2{font-size:20px;margin-bottom:20px}.form-group input{font-size:15px;padding:10px 12px}button{font-size:15px;padding:10px}}:root{--primary-color:#4a6ef5;--primary-hover:#3b5dd9;--secondary-color:#6c757d;--error-color:#dc3545;--success-color:#28a745;--light-gray:#f8f9fa;--border-color:#dee2e6;--text-color:#495057;--text-light:#6c757d}body{color:#495057;color:var(--text-color);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6}.registro-page{display:flex;min-height:100vh;width:100%}.left-panel-registro{background-color:#f5f7ff;background-image:linear-gradient(135deg,#f5f7ff,#e8ecfe)}.left-panel-registro,.right-panel-registro{align-items:center;display:flex;flex:1 1;justify-content:center;padding:2rem}.right-panel-registro{background-color:#fff;overflow-y:auto}.logo-image-small{height:auto;max-width:300px;transition:transform .3s ease}.logo-image-small:hover{transform:scale(1.05)}.form-container-registro{animation:fadeIn .8s ease-in-out;background:#fff;border-radius:16px;box-shadow:0 10px 30px #00000014;max-width:500px;padding:2.5rem;width:100%}.form-container-registro h2{color:#2c3e50;font-size:1.8rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1.5rem;position:relative}.form-group label{color:#495057;color:var(--text-color);font-weight:500;margin-bottom:.5rem}.form-group input{background-color:#f8f9fa;background-color:var(--light-gray);border:1px solid #dee2e6;border:1px solid var(--border-color);border-radius:8px;padding:.8rem 1rem;transition:all .3s ease}.form-group input:focus{background-color:#fff;border-color:#4a6ef5;border-color:var(--primary-color);box-shadow:0 0 0 3px #4a6ef533}.form-group input::placeholder{color:#6c757d;color:var(--text-light);opacity:.7}.button-group{display:flex;gap:1rem;margin-top:1.5rem}button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;padding:.8rem;transition:all .3s ease}button[type=submit]{background-color:#4a6ef5;background-color:var(--primary-color);color:#fff}button[type=submit]:hover{background-color:#3b5dd9;background-color:var(--primary-hover);box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}button[type=button]{background-color:#fff;border:1px solid #dee2e6;border:1px solid var(--border-color);color:#6c757d;color:var(--secondary-color)}button[type=button]:hover{background-color:#f8f9fa;background-color:var(--light-gray);transform:translateY(-2px)}.mensaje{animation:fadeIn .3s ease-in-out;border-radius:8px;font-weight:500;margin-top:1.5rem;padding:.8rem;text-align:center}.mensaje.error{background-color:#dc35451a;border:1px solid #dc354533;color:#dc3545;color:var(--error-color)}.mensaje.success{background-color:#28a7451a;border:1px solid #28a74533;color:#28a745;color:var(--success-color)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:992px){.form-container-registro{padding:2rem}}@media (max-width:768px){.registro-page{flex-direction:column}.left-panel-registro{height:auto;padding:1.5rem}.right-panel-registro{padding:1.5rem}.logo-image-small{max-width:200px}.form-container-registro{box-shadow:none;margin-top:0}}@media (max-width:480px){.form-container-registro{padding:1.5rem}.form-container-registro h2{font-size:1.5rem}.button-group{flex-direction:column;gap:.75rem}button{width:100%}.form-group input{padding:.7rem .9rem}}.dashboard-administrador{display:flex;flex-direction:row;min-height:100vh;overflow:hidden;width:100%}.sidebar-administrador{background-color:#d60812;color:#fff;display:flex;flex-direction:column;padding:20px 15px;transition:all .3s ease;width:280px;z-index:100}.sidebar-administrador h2{border-bottom:1px solid #fff3;font-size:1.5rem;margin-bottom:30px;padding-bottom:15px;text-align:center}.sidebar-administrador ul{flex-grow:1;list-style:none;padding:0}.sidebar-administrador li{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:10px;margin-bottom:12px;padding:12px 15px;transition:all .3s ease}.sidebar-administrador li:hover{background-color:#ffffff1a;transform:translateX(5px)}.sidebar-administrador li:active{transform:translateX(5px) scale(.98)}.sidebar-administrador .logout{color:#fca5a5;margin-top:auto}.contenido-administrador{background-color:#f9fafb;flex:1 1;min-height:100vh;overflow-y:auto;padding:30px}.contenido-administrador h1{color:#1f2937;font-size:2rem;font-weight:600;margin-bottom:15px}.contenido-administrador p{color:#4b5563;font-size:1.1rem;line-height:1.6}@media (max-width:992px){.sidebar-administrador{width:240px}.contenido-administrador{padding:25px}}@media (max-width:768px){.dashboard-administrador{flex-direction:column}.sidebar-administrador{align-items:center;flex-direction:row;justify-content:space-between;padding:15px 10px;position:-webkit-sticky;position:sticky;top:0;width:100%}.sidebar-administrador h2{border-bottom:none;display:block;font-size:1.3rem;margin-bottom:0;padding-bottom:0;white-space:nowrap}.sidebar-administrador ul{display:none}.menu-toggle{cursor:pointer;display:flex;flex-direction:column;height:21px;justify-content:space-between;width:30px}.menu-toggle span{background-color:#fff;border-radius:3px;display:block;height:3px;width:100%}.sidebar-administrador.mobile-open ul{background-color:#d60812;box-shadow:0 5px 10px #0003;display:flex;flex-direction:column;left:0;padding:15px;position:absolute;top:100%;width:100%}.contenido-administrador{padding:20px 15px}}@media (max-width:576px){.sidebar-administrador h2{font-size:1.2rem}.contenido-administrador h1{font-size:1.7rem}.contenido-administrador p{font-size:1rem}}.usuarios-container{padding:30px}.usuarios-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:30px}.usuarios-header h1{color:#1f2937;font-size:2rem;margin:0}.filtros{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.input-busqueda,.select-filtro{border:1px solid #d1d5db;border-radius:6px;font-size:1rem;padding:12px;transition:all .3s ease;width:100%}.input-busqueda:focus,.select-filtro:focus{border-color:#d60812;box-shadow:0 0 0 3px #d608121a;outline:none}.usuarios-table{border-collapse:collapse;min-width:600px;width:100%}.usuarios-table thead{background-color:#d60812;color:#fff}.usuarios-table th{font-weight:600;padding:16px;text-align:left}.usuarios-table td{border-bottom:1px solid #e5e7eb;padding:14px 16px;vertical-align:middle}.usuarios-table tr:last-child td{border-bottom:none}.usuarios-table tr:hover{background-color:#f9fafb}.badge.alumno{background-color:#e0f2fe;color:#0369a1}.badge.maestro{background-color:#f0fdf4;color:#15803d}.badge.administrador{background-color:#fef2f2;color:#b91c1c}.no-results{padding:30px}@media (max-width:992px){.usuarios-container{padding:25px}}@media (max-width:768px){.usuarios-header{align-items:flex-start;flex-direction:column}.usuarios-container{padding:20px 15px}.filtros{grid-template-columns:1fr}.usuarios-table td,.usuarios-table th{padding:12px}}@media (max-width:480px){.usuarios-table{display:block}.usuarios-table thead{display:none}.usuarios-table tr{border-bottom:1px solid #e5e7eb;display:block;margin-bottom:15px}.usuarios-table td{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:10px}.usuarios-table td:before{color:#4b5563;content:attr(data-label);font-weight:600;margin-right:15px}.badge,.btn-estatus,.estatus{margin-left:auto}}.form-registro{background-color:#fff;border-radius:12px;box-shadow:0 0 10px #0000000d;display:flex;flex-direction:column}.form-registro input,.form-registro select{border:1px solid #ccc;border-radius:6px;margin-bottom:12px;padding:10px}.form-registro button{background-color:#2c3e50;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:10px}.form-registro button:hover{background-color:#1a242f}.perfil-header{flex-wrap:wrap;gap:15px;margin-bottom:30px}.perfil-header h1{color:#1f2937;font-size:2rem;margin:0}.edit-button{background-color:#d60812;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 20px;transition:all .3s ease}.edit-button:hover{background-color:#b3070f;transform:translateY(-2px)}.perfil-container{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;margin-bottom:30px;padding:30px}.perfil-info{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{border-bottom:1px solid #e5e7eb;flex-direction:column;padding:15px 0}.info-label{color:#4b5563;font-size:.9rem;margin-bottom:5px}.info-value{color:#1f2937;font-size:1.1rem}.status-active{background-color:#ecfdf5;color:#10b981}.status-active,.status-inactive{border-radius:12px;font-weight:600;padding:4px 8px}.status-inactive{background-color:#fef2f2;color:#ef4444}.perfil-form{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-group{margin-bottom:20px}.form-group label{display:block}.form-group input{border:1px solid #d1d5db;border-radius:6px;font-size:1rem;padding:12px;transition:border .3s ease;width:100%}.form-group input:focus{border-color:#d60812;box-shadow:0 0 0 3px #d608121a;outline:none}.form-actions{grid-column:1/-1;margin-top:20px}.save-button{background-color:#d60812;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 24px;transition:all .3s ease}.save-button:hover{background-color:#b3070f}.cancel-button{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;color:#4b5563;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 24px;transition:all .3s ease}.cancel-button:hover{background-color:#f3f4f6}@media (max-width:768px){.perfil-header{align-items:flex-start;flex-direction:column}.perfil-container{padding:20px}.form-actions{flex-direction:column;gap:10px}.cancel-button,.save-button{width:100%}}@media (max-width:480px){.perfil-form,.perfil-info{grid-template-columns:1fr}.contenido-administrador{padding:20px 15px}}.loading{align-items:center;color:#4b5563;display:flex;font-size:1.2rem;height:100vh;justify-content:center}.notificaciones-container{margin:0 auto;max-width:800px;padding:40px}.notificaciones-header{border-bottom:2px solid #4a90e233;margin-bottom:40px;padding-bottom:20px;text-align:center}.notificaciones-header h1{color:#1a365d;font-size:2rem;font-weight:600;margin-bottom:10px}.notificaciones-header p{color:#4a5568;font-size:1.1rem}.form-notificacion{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;display:flex;flex-direction:column;gap:25px;padding:30px}.form-group{gap:8px}.form-group label{color:#2d3748}.form-notificacion textarea{border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;line-height:1.5;min-height:150px;padding:15px;resize:vertical;transition:all .3s ease}.form-notificacion textarea:focus{border-color:#4a6ef5;box-shadow:0 0 0 3px #4a6ef51a;outline:none}.form-notificacion select{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:1rem;padding:12px 15px;transition:all .3s ease}.form-notificacion select:focus{border-color:#4a6ef5;box-shadow:0 0 0 3px #4a6ef51a;outline:none}.form-actions{justify-content:flex-end}.btn-enviar{align-items:center;background-color:#4a6ef5;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;gap:8px;padding:12px 30px;transition:all .3s ease}.btn-enviar:hover{background-color:#3b5dd9;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.btn-enviar:active{transform:translateY(0)}.notification-success{background-color:#f0fff4;border:1px solid #c6f6d5;border-radius:8px;color:#2f855a;font-weight:500;margin-top:20px;padding:15px;text-align:center}@media (max-width:768px){.notificaciones-container{padding:30px 20px}.form-notificacion{padding:25px}.notificaciones-header h1{font-size:1.8rem}}@media (max-width:480px){.notificaciones-container{padding:25px 15px}.form-notificacion{gap:20px;padding:20px}.notificaciones-header h1{font-size:1.6rem}.btn-enviar,.form-actions{justify-content:center}.btn-enviar{padding:14px;width:100%}}.reportes-container{margin:0 auto;max-width:1200px;padding:40px}.reportes-header{border-bottom:2px solid #4a90e233;margin-bottom:40px;padding-bottom:20px;text-align:center}.reportes-header h1{color:#1a365d;font-size:2rem;font-weight:600;margin-bottom:10px}.reportes-header p{color:#4a5568;font-size:1.1rem}.filtros-container{border-radius:12px;box-shadow:0 4px 12px #00000014;padding:25px}.filtros{grid-gap:15px;align-items:flex-end;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filtro-group label{color:#2d3748}.filtro-group input,.filtro-group select{border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:12px 15px;transition:all .3s ease;width:100%}.filtro-group input:focus,.filtro-group select:focus{border-color:#4a6ef5;box-shadow:0 0 0 3px #4a6ef51a;outline:none}.filtro-actions{grid-column:1/-1;justify-content:flex-end}.btn-descargar,.btn-imprimir{align-items:center;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s ease}.btn-descargar{background-color:#4a6ef5;border:none;color:#fff}.btn-descargar:hover{background-color:#3b5dd9;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.btn-imprimir{background-color:#fff;border:1px solid #d1d5db;color:#4b5563}.btn-imprimir:hover{background-color:#f3f4f6;transform:translateY(-2px)}.graficas-container{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-top:30px}.grafica-card{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;padding:25px}.grafica-title{color:#2d3748;font-size:1.2rem;font-weight:600;margin-bottom:20px;text-align:center}.grafica-wrapper{height:300px;width:100%}.resumen-container{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;margin-top:30px;padding:25px}.resumen-title{color:#2d3748;font-size:1.2rem;font-weight:600;margin-bottom:20px;text-align:center}.resumen-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.resumen-item{background-color:#f8fafc;border-radius:8px;padding:15px;text-align:center}.resumen-value{color:#1e3a8a;font-size:2rem;font-weight:700;margin:10px 0}.resumen-label{color:#4b5563;font-size:.9rem}@media (max-width:992px){.reportes-container{padding:30px 20px}.graficas-container{grid-template-columns:1fr}}@media (max-width:768px){.filtros{grid-template-columns:1fr}.filtro-actions{justify-content:center}.btn-descargar,.btn-imprimir{justify-content:center;width:100%}}@media (max-width:480px){.reportes-container{padding:25px 15px}.grafica-card{padding:20px}.grafica-wrapper{height:250px}.resumen-grid{grid-template-columns:1fr}}.dispositivos-container{padding:30px}.dispositivos-header{margin-bottom:30px}.dispositivos-header h1{color:#1f2937;font-size:2rem;margin:0}.form-dispositivo{margin-bottom:30px}.input-group{display:flex;flex-wrap:wrap;gap:15px}.input-nuevo-dispositivo{border:1px solid #d1d5db;border-radius:6px;flex:1 1;font-size:1rem;min-width:250px;padding:12px 15px;transition:all .3s ease}.input-nuevo-dispositivo:focus{border-color:#d60812;box-shadow:0 0 0 3px #d608121a;outline:none}.btn-agregar{align-items:center;background-color:#2ed573;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.btn-agregar:hover{background-color:#1dd1a1;transform:translateY(-2px)}.btn-agregar:active{transform:translateY(0)}.dispositivos-table{border-collapse:collapse;min-width:600px;width:100%}.dispositivos-table thead{background-color:#d60812;color:#fff}.dispositivos-table th{font-weight:600;padding:16px;text-align:left}.dispositivos-table td{border-bottom:1px solid #e5e7eb;padding:14px 16px;vertical-align:middle}.dispositivos-table tr:last-child td{border-bottom:none}.dispositivos-table tr:hover{background-color:#f9fafb}.estatus{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:500;padding:4px 10px}.estatus.activo{background-color:#ecfdf5;color:#059669}.estatus.inactivo{background-color:#fef2f2;color:#dc2626}.btn-estatus{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .3s ease}.btn-estatus.activar{background-color:#2ed573;color:#fff}.btn-estatus.desactivar{background-color:#ff4757;color:#fff}.btn-estatus:hover{opacity:.9;transform:translateY(-1px)}.btn-estatus:active{transform:translateY(0)}@media (max-width:992px){.dispositivos-container{padding:25px}}@media (max-width:768px){.dispositivos-container{padding:20px 15px}.input-group{flex-direction:column;gap:10px}.btn-agregar,.input-nuevo-dispositivo{width:100%}}@media (max-width:480px){.dispositivos-table{display:block}.dispositivos-table thead{display:none}.dispositivos-table tr{border-bottom:1px solid #e5e7eb;display:block;margin-bottom:15px}.dispositivos-table td{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:10px}.dispositivos-table td:before{color:#4b5563;content:attr(data-label);font-weight:600;margin-right:15px}.btn-estatus,.estatus{margin-left:auto}}.aulas-container{padding:30px}.aulas-header{margin-bottom:30px}.aulas-header h1{color:#1f2937;font-size:2rem;margin:0}.form-aula{background-color:#fff;border-radius:8px;box-shadow:0 2px 6px #0000000d;margin-bottom:30px;padding:25px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.form-group label{color:#4b5563;font-size:.95rem;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:6px;font-size:1rem;padding:12px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#d60812;box-shadow:0 0 0 3px #d608121a;outline:none}.form-actions{display:flex;gap:15px}.btn-cancelar,.btn-guardar{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s ease}.btn-guardar{background-color:#2ed573}.btn-guardar:hover{background-color:#1dd1a1;transform:translateY(-2px)}.btn-cancelar{background-color:#fff;border:1px solid #d1d5db;color:#4b5563}.btn-cancelar:hover{background-color:#f3f4f6;transform:translateY(-2px)}.aulas-table{border-collapse:collapse;min-width:800px;width:100%}.aulas-table thead{background-color:#d60812;color:#fff}.aulas-table th{font-weight:600;padding:16px;text-align:left}.aulas-table td{border-bottom:1px solid #e5e7eb;padding:14px 16px;vertical-align:middle}.aulas-table tr:last-child td{border-bottom:none}.aulas-table tr:hover{background-color:#f9fafb}.dispositivo-asignado{background-color:#e0f2fe;border-radius:12px;color:#0369a1;display:inline-block;font-size:.85rem;font-weight:500;padding:4px 10px}.sin-dispositivo{color:#64748b;font-style:italic}.btn-editar{background-color:#4a6ef5;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .3s ease}.btn-editar:hover{background-color:#3b5dd9;transform:translateY(-1px)}.btn-editar:active{transform:translateY(0)}.no-results{color:#64748b;font-size:1.1rem}@media (max-width:992px){.aulas-container{padding:25px}}@media (max-width:768px){.aulas-container{padding:20px 15px}.form-actions{flex-direction:column;gap:10px}.btn-cancelar,.btn-guardar{justify-content:center;width:100%}}@media (max-width:480px){.aulas-table{display:block}.aulas-table thead{display:none}.aulas-table tr{border-bottom:1px solid #e5e7eb;display:block;margin-bottom:15px}.aulas-table td{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:10px}.aulas-table td:before{color:#4b5563;content:attr(data-label);font-weight:600;margin-right:15px}.btn-editar,.dispositivo-asignado{margin-left:auto}.form-grid{grid-template-columns:1fr}}.asistencia-container{padding:30px}.asistencia-header{margin-bottom:30px}.asistencia-header h1{color:#1f2937;font-size:2rem;margin:0}.filtros-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 6px #0000000d;margin-bottom:30px;padding:20px}.filtros-form{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.filtro-group{display:flex;flex-direction:column}.filtro-group label{color:#4b5563;font-size:.95rem;font-weight:600;margin-bottom:8px}.input-filtro{border:1px solid #d1d5db;border-radius:6px;font-size:1rem;padding:12px;transition:all .3s ease;width:100%}.input-filtro:focus{border-color:#d60812;box-shadow:0 0 0 3px #d608121a;outline:none}.filtro-actions{align-items:flex-end;display:flex;gap:15px}.btn-filtrar,.btn-limpiar{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:8px;padding:12px 20px;transition:all .3s ease}.btn-filtrar{background-color:#d60812;color:#fff}.btn-filtrar:hover{background-color:#b3070f;transform:translateY(-2px)}.btn-limpiar{background-color:#fff;border:1px solid #d1d5db;color:#4b5563}.btn-limpiar:hover{background-color:#f3f4f6;transform:translateY(-2px)}.table-responsive{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000014;overflow-x:auto}.asistencias-table{border-collapse:collapse;min-width:800px;width:100%}.asistencias-table thead{background-color:#d60812;color:#fff}.asistencias-table th{font-weight:600;padding:16px;text-align:left}.asistencias-table td{border-bottom:1px solid #e5e7eb;padding:14px 16px;vertical-align:middle}.asistencias-table tr:last-child td{border-bottom:none}.asistencias-table tr:hover{background-color:#f9fafb}.badge{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:500;padding:4px 10px}.badge.grupo{background-color:#e0f2fe;color:#0369a1}.hora{font-family:monospace;font-size:.95rem}.hora.entrada{color:#059669}.hora.salida{color:#dc2626}.sin-salida{color:#64748b;font-style:italic}.no-results{padding:40px;text-align:center}.no-results p{color:#64748b;font-size:1.1rem;margin-bottom:20px}@media (max-width:992px){.asistencia-container{padding:25px}}@media (max-width:768px){.filtros-form{grid-template-columns:1fr}.filtro-actions{justify-content:flex-end}.asistencia-container{padding:20px 15px}}@media (max-width:480px){.asistencias-table{display:block}.asistencias-table thead{display:none}.asistencias-table tr{border-bottom:1px solid #e5e7eb;display:block;margin-bottom:15px}.asistencias-table td{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:10px}.asistencias-table td:before{color:#4b5563;content:attr(data-label);font-weight:600;margin-right:15px}.badge,.hora{margin-left:auto}.filtro-actions{flex-direction:column;gap:10px}.btn-filtrar,.btn-limpiar{justify-content:center;width:100%}}.error,.loading{align-items:center;display:flex;font-size:1.2rem;height:100vh;justify-content:center}.error{color:#dc2626}.dashboard-maestro{display:flex;flex-direction:row;min-height:100vh;overflow:hidden;width:100%}.sidebar-maestro{background-color:#0ca73f;color:#fff;display:flex;flex-direction:column;padding:20px 15px;transition:all .3s ease;width:280px;z-index:100}.sidebar-maestro h2{border-bottom:1px solid #fff3;font-size:1.5rem;margin-bottom:30px;padding-bottom:15px;text-align:center}.sidebar-maestro ul{flex-grow:1;list-style:none;padding:0}.sidebar-maestro li{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:10px;margin-bottom:12px;padding:12px 15px;transition:all .3s ease}.sidebar-maestro li:hover{background-color:#ffffff1a;transform:translateX(5px)}.sidebar-maestro li:active{transform:translateX(5px) scale(.98)}.sidebar-maestro .logout{color:#fca5a5;margin-top:auto}.contenido-maestro{background-color:#f9fafb;flex:1 1;min-height:100vh;overflow-y:auto;padding:30px}.contenido-maestro h1{color:#1f2937;font-size:2rem;font-weight:600;margin-bottom:15px}.contenido-maestro p{color:#4b5563;font-size:1.1rem;line-height:1.6}.tabla-historial-maestro{background-color:#fff;border-collapse:collapse;border-radius:10px;box-shadow:0 4px 12px #0eec0614;margin:20px 0;max-width:100%;overflow:hidden;width:100%}.tabla-historial-maestro th{background-color:#21f705;color:#fff;font-weight:700;padding:12px}.tabla-historial-maestro td{border-bottom:1px solid #e0e0e0;color:#000;padding:12px}.tabla-historial-maestro tr:nth-child(2n){background-color:#f0f4ff}.tabla-historial-maestro tr:last-child td{border-bottom:none}@media (max-width:992px){.sidebar-maestro{width:240px}.contenido-maestro{padding:25px}}@media (max-width:768px){.dashboard-maestro{flex-direction:column}.sidebar-maestro{align-items:center;flex-direction:row;justify-content:space-between;padding:15px 10px;position:-webkit-sticky;position:sticky;top:0;width:100%}.sidebar-maestro h2{border-bottom:none;display:block;font-size:1.3rem;margin-bottom:0;padding-bottom:0;white-space:nowrap}.sidebar-maestro ul{display:none}.menu-toggle{cursor:pointer;display:flex;flex-direction:column;height:21px;justify-content:space-between;width:30px}.menu-toggle span{background-color:#fff;border-radius:3px;display:block;height:3px;width:100%}.sidebar-maestro.mobile-open ul{background-color:#0ca73f;box-shadow:0 5px 10px #0003;display:flex;flex-direction:column;left:0;padding:15px;position:absolute;top:100%;width:100%}.contenido-maestro{padding:20px 15px}}@media (max-width:576px){.sidebar-maestro h2{font-size:1.2rem}.contenido-maestro h1{font-size:1.7rem}.contenido-maestro p{font-size:1rem}.tabla-historial-maestro{display:block;overflow-x:auto;white-space:nowrap}}.titulo-maestro{color:#1f2937;font-size:2rem;font-weight:600;margin:20px 0;text-align:center}@media (min-width:768px){.titulo-maestro{font-size:2.5rem;margin:30px 0}}.contenido-maestro{padding:2rem}@media (max-width:768px){.contenido-maestro{padding:1.5rem}}@media (max-width:576px){.contenido-maestro{padding:1rem}}.titulo-seccion{margin-bottom:2rem}.contenedor-perfil{display:flex;justify-content:center;margin:0 auto;max-width:800px;width:100%}.tarjeta-perfil{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:2rem;width:100%}.campo-perfil{border-bottom:1px solid #e5e7eb;display:flex;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:1rem}.campo-perfil:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.etiqueta-perfil{color:#374151;font-weight:600;margin-right:1rem;width:150px}.valor-perfil{color:#4b5563;flex:1 1}.valor-perfil.activo{color:#10b981;font-weight:600}.valor-perfil.inactivo{color:#ef4444;font-weight:600}.cargando-perfil{color:#6b7280;padding:2rem;text-align:center}@media (max-width:768px){.titulo-seccion{font-size:1.7rem;margin-bottom:1.5rem}.tarjeta-perfil{padding:1.5rem}.campo-perfil{flex-direction:column;gap:.5rem}.etiqueta-perfil{margin-right:0;width:100%}}@media (max-width:576px){.titulo-seccion{font-size:1.5rem;margin-bottom:1.2rem}.tarjeta-perfil{padding:1.2rem}.campo-perfil{margin-bottom:1.2rem;padding-bottom:.8rem}}.titulo-calendario{color:#1f2937;font-size:2rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.contenedor-calendario{display:flex;flex-direction:column;gap:2rem;margin:0 auto;max-width:1200px;padding:0 1rem;width:100%}.tarjeta-calendario{align-items:center;background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;justify-content:center;padding:1.5rem;width:100%}.imagen-calendario{border-radius:8px;box-shadow:0 2px 8px #0000001a;height:auto;max-width:100%}@media (max-width:768px){.titulo-calendario{font-size:1.7rem;margin-bottom:1.2rem}.contenedor-calendario{gap:1.5rem;padding:0 .5rem}.tarjeta-calendario{padding:1rem}}@media (max-width:576px){.titulo-calendario{font-size:1.5rem}.contenedor-calendario{gap:1rem}}.contenedor-qr{max-width:800px}.tarjeta-qr{box-shadow:0 4px 12px #0000001a}.nombre-profesor{color:#0ca73f;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.numero-empleado{color:#4b5563;font-size:1.1rem;margin-bottom:1.5rem}@media (max-width:768px){.titulo-qr{font-size:1.7rem;margin-bottom:1.2rem}.tarjeta-qr{padding:1.5rem}.nombre-profesor{font-size:1.3rem}.codigo-qr-container{margin:1rem auto}}@media (max-width:576px){.titulo-qr{font-size:1.5rem}.tarjeta-qr{padding:1.2rem}.nombre-profesor{font-size:1.2rem}.codigo-qr{max-width:220px}.instrucciones{font-size:.9rem}}.contenedor-tabla{border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-top:1.5rem;overflow-x:auto;width:100%}.tabla-historial{background-color:#fff;border-collapse:collapse;width:100%}.tabla-historial th{background-color:#676b69;color:#fff;font-weight:600;padding:12px 15px;text-align:left}.tabla-historial td{border-bottom:1px solid #e5e7eb;color:#4b5563;padding:12px 15px}.tabla-historial tr:nth-child(2n){background-color:#f8fafc}.tabla-historial tr:hover{background-color:#f0fdf4}.cargando-historial,.sin-registros{color:#6b7280;font-size:1.1rem;padding:2rem;text-align:center}@media (max-width:768px){.tabla-historial{display:block;width:100%}.tabla-historial thead{display:none}.tabla-historial tbody,.tabla-historial td,.tabla-historial tr{display:block;width:100%}.tabla-historial tr{border-bottom:2px solid #e5e7eb;margin-bottom:15px}.tabla-historial td{padding-left:50%;position:relative;text-align:right}.tabla-historial td:before{color:#1f2937;content:attr(data-label);font-weight:600;left:15px;padding-right:10px;position:absolute;text-align:left;width:45%}}@media (max-width:576px){.titulo-seccion{font-size:1.7rem;margin-bottom:1.2rem}.tabla-historial td{padding:10px 15px 10px 50%}.tabla-historial td:before{left:10px}}.titulo-seccion{color:#1f2937;font-size:2rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.contenedor-busqueda{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:2rem;padding:1.5rem}.instrucciones{color:#4b5563;font-size:1.1rem;margin-bottom:1rem;text-align:center}.controles-busqueda{align-items:center;display:flex;flex-direction:column;gap:1rem}.input-fecha{border:1px solid #d1d5db;border-radius:8px;font-size:1rem;max-width:300px;padding:.75rem 1rem;text-align:center;width:100%}.boton-buscar{background-color:#0ca73f;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .3s}.boton-buscar:hover:not(:disabled){background-color:#0d9e3a}.boton-buscar:disabled{background-color:#9ca3af;cursor:not-allowed}.contenedor-clases{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));width:100%}.tarjeta-clase{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.info-clase{flex:1 1}.titulo-clase{color:#1f2937;font-size:1.25rem;margin-bottom:.5rem}.edificio{color:#0ca73f}.aula,.edificio{font-weight:600}.horario,.total-alumnos{color:#4b5563;font-size:.95rem;margin-bottom:.3rem}.boton-descargar{align-self:flex-end;background-color:#fff;border:2px solid #0ca73f;border-radius:8px;color:#0ca73f;cursor:pointer;font-size:.95rem;font-weight:600;padding:.5rem 1rem;transition:all .3s}.boton-descargar:hover{background-color:#f0fdf4}.mensaje-error{color:#ef4444;font-weight:500;margin:1rem 0;text-align:center}.cargando-listas{color:#6b7280;padding:1.5rem;text-align:center}@media (max-width:768px){.titulo-seccion{font-size:1.7rem}.contenedor-busqueda{padding:1.2rem}.controles-busqueda{flex-direction:column}.contenedor-clases{grid-template-columns:1fr}}@media (max-width:576px){.titulo-seccion{font-size:1.5rem}.instrucciones{font-size:1rem}.input-fecha{width:100%}}.alumno-notificaciones-container{background-color:#f5f7fa;display:flex;flex-direction:row;min-height:100vh}.alumno-noti-contenedor{flex:1 1;margin-left:280px;padding:2rem;transition:all .3s ease;width:calc(100% - 280px)}.alumno-noti-titulo{color:#2d3748;font-size:1.8rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:10px;position:relative;text-align:center}.alumno-noti-titulo:after{background-color:#4299e1;bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:80px}.alumno-noti-cargando,.alumno-noti-sin-datos{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;color:#4a5568;font-size:1.1rem;margin-left:auto;margin-right:auto;margin-top:2rem;max-width:800px;padding:1rem;text-align:center}.alumno-noti-tabla-contenedor{background-color:#fff;border-radius:10px;box-shadow:0 4px 6px #0000000d;margin-left:auto;margin-right:auto;margin-top:2rem;max-width:1000px;overflow:hidden;overflow-x:auto}.alumno-noti-tabla{border-collapse:collapse;min-width:600px;width:100%}.alumno-noti-cabecera{background-color:#2b6cb0;color:#fff;font-size:.95rem;font-weight:600;padding:1rem 1.5rem;text-align:left}.alumno-noti-fila{border-bottom:1px solid #edf2f7;transition:background-color .2s ease}.alumno-noti-fila:hover{background-color:#ebf8ff}.alumno-noti-fecha,.alumno-noti-mensaje{color:#4a5568;font-size:.95rem;padding:1rem 1.5rem}.alumno-noti-mensaje{cursor:pointer;max-width:600px;overflow:hidden;position:relative;text-overflow:ellipsis;white-space:nowrap}.alumno-noti-fecha{color:#718096;white-space:nowrap}.alumno-noti-tabla tbody tr:nth-child(2n){background-color:#f8fafc}@media (max-width:1200px){.alumno-noti-contenedor{margin-left:240px;padding:1.8rem;width:calc(100% - 240px)}}@media (max-width:992px){.alumno-notificaciones-container{flex-direction:column}.alumno-noti-contenedor{margin-left:0;padding:1.5rem;width:100%}.alumno-noti-titulo{font-size:1.7rem}}@media (max-width:768px){.alumno-noti-contenedor{padding:1.2rem}.alumno-noti-titulo{font-size:1.5rem}.alumno-noti-cabecera,.alumno-noti-fecha,.alumno-noti-mensaje{font-size:.9rem;padding:.8rem 1rem}}@media (max-width:576px){.alumno-noti-contenedor{padding:1rem}.alumno-noti-titulo{font-size:1.4rem}.alumno-noti-titulo:after{width:60px}.alumno-noti-cargando,.alumno-noti-sin-datos{font-size:1rem}}*{box-sizing:border-box;margin:0;padding:0}body,html{background-color:#f3f4f6;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:16px;height:100%;width:100%}.alumno-container{display:flex;flex-direction:row;min-height:100vh;overflow:hidden;width:100%}.sidebar-alumno{background-color:#2563eb;color:#fff;display:flex;flex-direction:column;padding:20px 15px;transition:all .3s ease;width:280px;z-index:100}.sidebar-alumno h2{border-bottom:1px solid #fff3;font-size:1.5rem;margin-bottom:30px;padding-bottom:15px;text-align:center}.sidebar-alumno ul{flex-grow:1;list-style:none;padding:0}.sidebar-alumno li{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:10px;margin-bottom:12px;padding:12px 15px;transition:all .3s ease}.sidebar-alumno li:hover{background-color:#ffffff1a;transform:translateX(5px)}.sidebar-alumno li:active{transform:translateX(5px) scale(.98)}.sidebar-alumno .logout{color:#fca5a5;margin-top:auto}.contenido-alumno{background-color:#f9fafb;flex:1 1;min-height:100vh;overflow-y:auto;padding:30px}.contenido-alumno h1{color:#1f2937;font-size:2rem;font-weight:600;margin-bottom:15px}.contenido-alumno p{color:#4b5563;font-size:1.1rem;line-height:1.6}@media (max-width:992px){.sidebar-alumno{width:240px}.contenido-alumno{padding:25px}}@media (max-width:768px){.alumno-container{flex-direction:column}.sidebar-alumno{align-items:center;flex-direction:row;justify-content:space-between;padding:15px 10px;position:-webkit-sticky;position:sticky;top:0;width:100%}.sidebar-alumno h2{border-bottom:none;display:block;font-size:1.3rem;margin-bottom:0;padding-bottom:0;white-space:nowrap}.sidebar-alumno ul{display:none}.menu-toggle{cursor:pointer;display:flex;flex-direction:column;height:21px;justify-content:space-between;width:30px}.menu-toggle span{background-color:#fff;border-radius:3px;display:block;height:3px;width:100%}.sidebar-alumno.mobile-open ul{background-color:#2563eb;box-shadow:0 5px 10px #0003;display:flex;flex-direction:column;left:0;padding:15px;position:absolute;top:100%;width:100%}.contenido-alumno{padding:20px 15px}}@media (max-width:576px){.sidebar-alumno h2{font-size:1.2rem}.contenido-alumno h1{font-size:1.7rem}.contenido-alumno p{font-size:1rem}}.titulo-perfil{color:#1f2937;font-size:2rem;margin-bottom:1.5rem;text-align:center}.card-perfil{background-color:#fff;border-radius:10px;box-shadow:0 4px 12px #2563eb1a;margin:0 auto;max-width:800px;padding:2rem}.perfil-header{border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1rem}.perfil-header h2{color:#2563eb;font-size:1.5rem}.perfil-info{grid-gap:1.2rem;display:grid;gap:1.2rem;grid-template-columns:1fr}.info-item{align-items:center;display:flex;flex-wrap:wrap}.info-label{color:#374151;font-weight:600;margin-right:1rem;width:120px}.info-value{color:#4b5563;flex:1 1}.cargando{align-items:center;color:#4b5563;display:flex;font-size:1.2rem;height:100vh;justify-content:center}@media (max-width:768px){.card-perfil{padding:1.5rem}.titulo-perfil{font-size:1.7rem}.perfil-header h2{font-size:1.3rem}.info-item{align-items:flex-start;flex-direction:column;gap:.3rem}.info-label{margin-right:0;width:100%}}@media (max-width:576px){.card-perfil{border-radius:8px;padding:1rem}.titulo-perfil{font-size:1.5rem;margin-bottom:1rem}.perfil-info{gap:1rem}}.form-editar{gap:15px;padding:20px}.form-editar,.form-group{display:flex;flex-direction:column}.form-group{gap:5px}.form-group label{color:#333;font-weight:700}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:16px;padding:8px 12px}.btn-cancelar,.btn-editar,.btn-guardar{border:none;border-radius:4px;cursor:pointer;font-weight:700;padding:8px 16px;transition:background-color .3s}.btn-editar{background-color:#4caf50;color:#fff}.btn-editar:hover{background-color:#45a049}.btn-guardar{align-self:flex-end;background-color:#2196f3;color:#fff;margin-top:10px}.btn-guardar:hover{background-color:#0b7dda}.btn-guardar:disabled{background-color:#ccc;cursor:not-allowed}.btn-cancelar{background-color:#f44336;color:#fff;margin-left:10px}.btn-cancelar:hover{background-color:#da190b}.message{border-radius:4px;font-weight:700;margin-bottom:20px;padding:10px 15px}.message.success{background-color:#dff0d8;color:#3c763d}.message.error{background-color:#f2dede;color:#a94442}.perfil-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.titulo-qr{color:#1f2937;font-size:2rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.contenedor-qr{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:500px;padding:0 1rem;width:100%}.tarjeta-qr{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #2563eb1a;padding:2rem;text-align:center;width:100%}.nombre-alumno{color:#2563eb;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.matricula{color:#4b5563;font-size:1.1rem;font-weight:500;margin-bottom:1.5rem}.codigo-qr-container{background-color:#fff;background-color:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;display:inline-block;margin:1.5rem auto;padding:1rem}.codigo-qr{height:auto;max-width:256px;width:100%}.instrucciones{color:#6b7280;font-size:1rem;font-style:italic;margin-left:auto;margin-right:auto;margin-top:1.5rem;max-width:80%}.cargando-qr{color:#6b7280}.cargando-qr,.error-qr{font-size:1.2rem;padding:2rem;text-align:center}.error-qr{background-color:#fee2e2;border-radius:8px;color:#ef4444;margin:0 auto;max-width:500px}@media (max-width:768px){.titulo-qr{font-size:1.7rem;margin-bottom:1.2rem}.tarjeta-qr{padding:1.5rem}.nombre-alumno{font-size:1.3rem}.codigo-qr-container{margin:1rem auto}}@media (max-width:576px){.titulo-qr{font-size:1.5rem}.tarjeta-qr{border-radius:8px;padding:1.2rem}.nombre-alumno{font-size:1.2rem}.matricula{font-size:1rem}.codigo-qr{max-width:200px}.instrucciones{font-size:.9rem;max-width:90%}}
/*# sourceMappingURL=main.61017b4f.css.map*/