*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;min-height:100vh}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.login-page{background-color:#efe9e3;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.login-card-split{background-color:#fff;width:100%;min-height:100vh;display:flex;overflow:hidden}.login-left{background-color:#f3ece4;flex-direction:column;flex:1;padding:32px;display:flex;position:relative;overflow:hidden}.login-rings{z-index:0;position:absolute;inset:0}.login-brand{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.login-logo-small{object-fit:contain;width:150px;height:150px}.login-brand-text{color:#6b1e2b;font-size:20px;font-weight:700;line-height:1.3}.login-illustration{z-index:1;object-fit:contain;pointer-events:none;width:140%;max-width:none;position:absolute;bottom:0;left:-10px}.login-right{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 44px;display:flex}.login-welcome,.login-subtext,.login-right form,.login-footer{width:100%;max-width:420px}.login-welcome{color:#2c2c2a;margin:0 0 8px;font-size:22px;font-weight:700}.login-subtext{color:#8a8584;margin:0 0 24px;font-size:14px}.login-label{color:#2c2c2a;align-items:center;gap:8px;margin-top:16px;margin-bottom:6px;font-size:13px;font-weight:600;display:flex}.login-icon{color:#6b1e2b;width:18px;height:18px}.login-input{box-sizing:border-box;color:#2c2c2a;background-color:#fff;border:1.5px solid #6b1e2b;border-radius:8px;width:100%;padding:10px 12px;font-size:14px}.login-input::placeholder{color:#aba5a5}.login-input:focus{background-color:#fff;border-color:#511620;outline:none}.login-input:-webkit-autofill{-webkit-text-fill-color:#2c2c2a;-webkit-box-shadow:inset 0 0 0 1000px #fff}.login-password-wrapper{position:relative}.login-eye-button{cursor:pointer;color:#6b1e2b;background:0 0;border:none;padding:0;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.login-eye-button svg{width:18px;height:18px}.login-error{color:#a32d2d;margin:12px 0 0;font-size:13px}.login-forgot{text-align:center;color:#8a8584;margin-top:18px;font-size:13px;text-decoration:none;display:block}.login-forgot:hover{text-decoration:underline}.login-button{color:#fff;cursor:pointer;background-color:#6b1e2b;border:none;border-radius:24px;width:100%;margin-top:20px;padding:12px;font-size:15px;font-weight:600}.login-button:hover{background-color:#511620}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{color:#aba5a5;text-align:right;margin-top:28px;font-size:12px}@media (width<=700px){.login-card-split{flex-direction:column}.login-left{justify-content:center;align-items:center;gap:12px;min-height:auto;padding:1px;display:flex}.login-rings,.login-illustration{display:none}.login-logo-small{width:100px;height:100px}.login-brand-text{font-size:15px}}.auditoria-container{padding:24px}.auditoria-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.auditoria-header h1{color:#1a1a1a;margin:0;font-size:28px}.auditoria-table-wrapper{background:#fff;border-radius:12px;overflow-x:auto;box-shadow:0 1px 3px #0000001a}.auditoria-table{border-collapse:collapse;width:100%}.auditoria-table thead{background:#f5f0ee}.auditoria-table th{text-align:left;color:#6b1b1b;text-transform:uppercase;letter-spacing:.5px;padding:14px 16px;font-size:13px;font-weight:600}.auditoria-table td{color:#333;border-top:1px solid #f0f0f0;padding:14px 16px;font-size:14px}.accion-badge{border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.accion-CREAR{color:#1e7e34;background:#e6f4ea}.accion-EDITAR{color:#856404;background:#fff3cd}.accion-ELIMINAR{color:#721c24;background:#f8d7da}.auditoria-cargando,.auditoria-vacio{text-align:center;color:#888;padding:40px}.recursos-container{width:100%}.recursos-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.recursos-header h1{margin:0}.recursos-lista{flex-direction:column;gap:14px;display:flex}.recurso-card{background-color:#fff;border-radius:12px;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px 20px;display:flex;box-shadow:0 1px 3px #00000014}.recurso-info h3{color:#6b1e2b;margin:0 0 4px;font-size:16px}.recurso-meta{color:#8a8584;margin:4px 0 8px;font-size:12px}.recurso-descripcion{color:#2c2c2a;margin:0;font-size:14px}.recurso-archivo-badge{color:#6b1e2b;background-color:#f3ece4;border-radius:10px;margin-top:8px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.recursos-vacio,.recursos-cargando{text-align:center;color:#8a8584;padding:40px}.form-group input[type=file]{width:100%;padding:9px 0;font-size:13px}.materias-container{width:100%}.materias-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.materias-header h1{margin:0}.materias-table-wrapper{background-color:#fff;border-radius:12px;overflow-x:auto;box-shadow:0 1px 3px #00000014}.materias-table{border-collapse:collapse;width:100%}.materias-table th{text-align:left;color:#6b1e2b;text-transform:uppercase;background-color:#f3ece4;padding:14px 16px;font-size:13px;font-weight:700}.materias-table td{color:#2c2c2a;border-bottom:1px solid #f0ebe6;padding:14px 16px;font-size:14px}.materias-table tr:last-child td{border-bottom:none}.materias-vacio,.materias-cargando{text-align:center;color:#8a8584;padding:40px}.inicio-container{width:100%}.inicio-container h1{color:#2c2c2a;margin:0 0 4px;font-size:24px}.inicio-container>p{color:#8a8584;margin:0 0 24px;font-size:14px}.inicio-stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px;display:grid}.inicio-stat-card{text-align:center;background-color:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #00000014}.inicio-stat-valor{color:#6b1e2b;font-size:32px;font-weight:700;display:block}.inicio-stat-label{color:#8a8584;margin-top:4px;font-size:13px}.inicio-section-title{color:#6b1e2b;margin:0 0 14px;font-size:16px;font-weight:700}.inicio-comunicados-lista{flex-direction:column;gap:12px;display:flex}.inicio-comunicado-item{background-color:#fff;border-radius:10px;padding:14px 16px;box-shadow:0 1px 3px #00000014}.inicio-comunicado-item h4{color:#2c2c2a;margin:0 0 4px;font-size:14px}.inicio-comunicado-item p{color:#8a8584;margin:0;font-size:13px}.inicio-vacio{color:#8a8584;padding:16px 0;font-size:14px}.usuarios-container{width:100%}.usuarios-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.usuarios-header h1{margin:0}.usuarios-table-wrapper{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014}.usuarios-table{border-collapse:collapse;width:100%}.usuarios-table th{text-align:left;color:#6b1e2b;text-transform:uppercase;background-color:#f3ece4;padding:14px 16px;font-size:13px;font-weight:700}.usuarios-table td{color:#2c2c2a;border-bottom:1px solid #f0ebe6;padding:14px 16px;font-size:14px}.usuarios-table tr:last-child td{border-bottom:none}.usuarios-vacio,.usuarios-cargando{text-align:center;color:#8a8584;padding:40px}.reportes-container{width:100%}.reportes-header{margin-bottom:20px}.reportes-header h1{margin:0 0 16px}.reportes-selector{max-width:360px}.reportes-grid{grid-template-columns:1fr 1fr;gap:20px;margin-top:24px;display:grid}@media (width<=900px){.reportes-grid{grid-template-columns:1fr}}.reporte-card{background-color:#fff;border-radius:12px;padding:22px;box-shadow:0 1px 3px #00000014}.reporte-card h2{color:#6b1e2b;margin:0 0 16px;font-size:18px}.boletin-table{border-collapse:collapse;width:100%}.boletin-table th{text-align:left;color:#8a8584;text-transform:uppercase;border-bottom:1px solid #f0ebe6;padding:10px 0;font-size:12px}.boletin-table td{border-bottom:1px solid #f7f4f1;padding:10px 0;font-size:14px}.boletin-promedio-general{border-top:2px solid #f3ece4;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;font-size:16px;font-weight:700;display:flex}.asistencia-resumen-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.resumen-stat{text-align:center;background-color:#f7f4f1;border-radius:8px;padding:14px}.resumen-stat-valor{font-size:24px;font-weight:700;display:block}.resumen-stat-label{color:#8a8584;margin-top:4px;font-size:12px}.resumen-porcentaje{text-align:center;background-color:#f3ece4;border-radius:8px;margin-top:16px;padding:16px}.resumen-porcentaje-valor{color:#6b1e2b;font-size:28px;font-weight:700}.reportes-vacio{text-align:center;color:#8a8584;padding:40px}.comunicados-container{width:100%}.comunicados-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.comunicados-header h1{margin:0}.comunicados-lista{flex-direction:column;gap:14px;display:flex}.comunicado-card{background-color:#fff;border-radius:12px;padding:18px 20px;box-shadow:0 1px 3px #00000014}.comunicado-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.comunicado-card-header h3{color:#6b1e2b;margin:0;font-size:16px}.comunicado-meta{color:#8a8584;margin:4px 0 10px;font-size:12px}.comunicado-rol-badge{color:#6b1e2b;background-color:#f3ece4;border-radius:10px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.comunicado-contenido{color:#2c2c2a;margin:0;font-size:14px;line-height:1.5}.comunicados-vacio,.comunicados-cargando{text-align:center;color:#8a8584;padding:40px}.form-group textarea{box-sizing:border-box;resize:vertical;border:1.5px solid #d8d2cc;border-radius:6px;width:100%;min-height:90px;padding:9px 12px;font-family:inherit;font-size:14px}.form-group textarea:focus{border-color:#6b1e2b;outline:none}.horarios-container{width:100%}.horarios-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.horarios-header h1{margin:0}.horarios-table-wrapper{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014}.horarios-table{border-collapse:collapse;width:100%}.horarios-table th{text-align:left;color:#6b1e2b;text-transform:uppercase;background-color:#f3ece4;padding:14px 16px;font-size:13px;font-weight:700}.horarios-table td{color:#2c2c2a;border-bottom:1px solid #f0ebe6;padding:14px 16px;font-size:14px}.horarios-table tr:last-child td{border-bottom:none}.horarios-vacio,.horarios-cargando{text-align:center;color:#8a8584;padding:40px}.asistencias-container{width:100%}.asistencias-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.asistencias-header h1{margin:0}.asistencias-table-wrapper{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014}.asistencias-table{border-collapse:collapse;width:100%}.asistencias-table th{text-align:left;color:#6b1e2b;text-transform:uppercase;background-color:#f3ece4;padding:14px 16px;font-size:13px;font-weight:700}.asistencias-table td{color:#2c2c2a;border-bottom:1px solid #f0ebe6;padding:14px 16px;font-size:14px}.asistencias-table tr:last-child td{border-bottom:none}.asistencias-vacio,.asistencias-cargando{text-align:center;color:#8a8584;padding:40px}.estado-badge{border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600}.estado-P{color:#2e7d3a;background-color:#e3f3e6}.estado-A{color:#a32d2d;background-color:#f3e3e3}.estado-J{color:#2d5fa3;background-color:#e3edf3}.estado-T{color:#b8780a;background-color:#fdf0d9}.btn-justificar:hover{color:#2d5fa3;border-color:#2d5fa3}.calificaciones-container{width:100%}.calificaciones-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.calificaciones-header h1{margin:0}.calificaciones-table-wrapper{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014}.calificaciones-table{border-collapse:collapse;width:100%}.calificaciones-table th{text-align:left;color:#6b1e2b;text-transform:uppercase;background-color:#f3ece4;padding:14px 16px;font-size:13px;font-weight:700}.calificaciones-table td{color:#2c2c2a;border-bottom:1px solid #f0ebe6;padding:14px 16px;font-size:14px}.calificaciones-table tr:last-child td{border-bottom:none}.calificaciones-vacio,.calificaciones-cargando{text-align:center;color:#8a8584;padding:40px}.valor-nota{font-weight:700}.valor-aprobado{color:#2e7d3a}.valor-reprobado{color:#a32d2d}.form-group select{box-sizing:border-box;background-color:#fff;border:1.5px solid #d8d2cc;border-radius:6px;width:100%;padding:9px 12px;font-size:14px}.form-group select:focus{border-color:#6b1e2b;outline:none}.docentes-container{width:100%}.docentes-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.docentes-header h1{margin:0}.docentes-table-wrapper{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014}.docentes-table{border-collapse:collapse;width:100%}.docentes-table th{text-align:left;color:#6b1e2b;text-transform:uppercase;background-color:#f3ece4;padding:14px 16px;font-size:13px;font-weight:700}.docentes-table td{color:#2c2c2a;border-bottom:1px solid #f0ebe6;padding:14px 16px;font-size:14px}.docentes-table tr:last-child td{border-bottom:none}.docentes-vacio,.docentes-cargando{text-align:center;color:#8a8584;padding:40px}.estudiantes-container{width:100%}.estudiantes-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.estudiantes-header h1{margin:0}.btn-nuevo{color:#fff;cursor:pointer;background-color:#6b1e2b;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600}.btn-nuevo:hover{background-color:#511620}.estudiantes-table-wrapper{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014}.estudiantes-table{border-collapse:collapse;width:100%}.estudiantes-table th{text-align:left;color:#6b1e2b;text-transform:uppercase;background-color:#f3ece4;padding:14px 16px;font-size:13px;font-weight:700}.estudiantes-table td{color:#2c2c2a;border-bottom:1px solid #f0ebe6;padding:14px 16px;font-size:14px}.estudiantes-table tr:last-child td{border-bottom:none}.badge{border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600}.badge-activo{color:#2e7d3a;background-color:#e3f3e6}.badge-inactivo{color:#a32d2d;background-color:#f3e3e3}.tabla-acciones{gap:8px;display:flex}.btn-accion{cursor:pointer;background-color:#fff;border:1px solid #d8d2cc;border-radius:6px;padding:6px 12px;font-size:13px}.btn-editar:hover{color:#6b1e2b;border-color:#6b1e2b}.btn-desactivar:hover{color:#a32d2d;border-color:#a32d2d}.estudiantes-vacio,.estudiantes-cargando{text-align:center;color:#8a8584;padding:40px}.modal-overlay{z-index:100;background-color:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:#fff;border-radius:12px;width:100%;max-width:420px;max-height:90vh;padding:28px;overflow-y:auto}.modal-content h2{color:#6b1e2b;margin:0 0 20px}.form-group{margin-bottom:14px}.form-group label{color:#2c2c2a;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input{box-sizing:border-box;border:1.5px solid #d8d2cc;border-radius:6px;width:100%;padding:9px 12px;font-size:14px}.form-group input:focus{border-color:#6b1e2b;outline:none}.form-hint{color:#8a8584;margin-top:4px;font-size:12px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.btn-cancelar{cursor:pointer;background-color:#fff;border:1px solid #d8d2cc;border-radius:6px;padding:9px 18px;font-size:14px}.btn-guardar{color:#fff;cursor:pointer;background-color:#6b1e2b;border:none;border-radius:6px;padding:9px 18px;font-size:14px;font-weight:600}.btn-guardar:hover{background-color:#511620}.modal-error{color:#a32d2d;margin-bottom:10px;font-size:13px}.dashboard-layout{min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.dashboard-sidebar{color:#fff;background-color:#6b1e2b;flex-direction:column;flex-shrink:0;width:260px;display:flex}.sidebar-brand{border-bottom:1px solid #ffffff26;align-items:center;gap:12px;padding:24px 20px;display:flex}.sidebar-logo{object-fit:contain;width:100px;height:100px}.sidebar-brand-text{font-size:13px;font-weight:700;line-height:1.3}.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}.sidebar-link{color:#ffffffd9;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 20px;font-size:14px;text-decoration:none;display:flex}.sidebar-link:hover{color:#fff;background-color:#ffffff1a}.sidebar-link.active{color:#fff;background-color:#ffffff26;font-weight:600}.sidebar-icon{flex-shrink:0;width:18px;height:18px}.sidebar-footer{border-top:1px solid #ffffff26;padding:16px 20px}.sidebar-user{margin-bottom:12px;font-size:13px}.sidebar-user-name{font-weight:700;display:block}.sidebar-user-role{color:#ffffffb3;font-size:12px}.sidebar-logout{color:#fff;cursor:pointer;background-color:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;width:100%;padding:10px;font-size:13px;font-weight:600}.sidebar-logout:hover{background-color:#fff3}.dashboard-main{background-color:#f7f5f3;flex:1;padding:32px 40px;overflow-y:auto}.dashboard-welcome h1{color:#2c2c2a;margin:0 0 4px;font-size:24px}.dashboard-welcome p{color:#8a8584;margin:0 0 24px;font-size:14px}.dashboard-placeholder{text-align:center;color:#8a8584;background-color:#fff;border:1px dashed #d8d2cc;border-radius:12px;padding:40px}.mobile-menu-btn,.sidebar-overlay{display:none}@media (width<=768px){.mobile-menu-btn{color:#fff;cursor:pointer;background-color:#6b1e2b;border:none;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:16px;font-size:20px;display:flex}.dashboard-sidebar{z-index:200;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.dashboard-sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:150;background-color:#0006;display:block;position:fixed;inset:0}.dashboard-main{padding:20px}}
