.login-page{min-height:100vh;min-width:100%;background-color:#f0f4f8;display:flex;align-items:center;justify-content:center;padding:1rem;box-sizing:border-box}.login-container{max-width:400px;width:100%;margin:0;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000014;text-align:center}.school-logo{width:150px;height:120px;display:block;margin:10px auto}.disclaimer{font-size:12px;color:#666;margin-top:10px}.login-container h2{margin-bottom:1rem}.login-container input{width:100%;padding:.7rem;margin:.5rem 0;border:1px solid #ccc;border-radius:4px}.login-container button{width:50%;padding:.7rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;margin-top:.5rem;cursor:pointer}.login-container button:hover{background-color:#0056b3}.preloader{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#fffc;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.login-container form input:disabled,.login-container form button:disabled{opacity:.7;cursor:not-allowed}.spinner:before{transform:rotateX(60deg) rotateY(45deg) rotate(45deg);animation:.75s rotateBefore infinite linear reverse}.spinner:after{transform:rotateX(240deg) rotateY(45deg) rotate(45deg);animation:.75s rotateAfter infinite linear}.spinner:before,.spinner:after{box-sizing:border-box;content:"";display:block;position:absolute;margin-top:-5em;margin-left:-5em;width:10em;height:10em;transform-style:preserve-3d;transform-origin:50%;transform:rotateY(50%);perspective-origin:50% 50%;perspective:340px;background-size:10em 10em;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+Cjxzdmcgd2lkdGg9IjI2NnB4IiBoZWlnaHQ9IjI5N3B4IiB2aWV3Qm94PSIwIDAgMjY2IDI5NyIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWxuczpza2V0Y2g9Imh0dHA6Ly93d3cuYm9oZW1pYW5jb2RpbmcuY29tL3NrZXRjaC9ucyI+CiAgICA8dGl0bGU+c3Bpbm5lcjwvdGl0bGU+CiAgICA8ZGVzY3JpcHRpb24+Q3JlYXRlZCB3aXRoIFNrZXRjaCAoaHR0cDovL3d3dy5ib2hlbWlhbmNvZGluZy5jb20vc2tldGNoKTwvZGVzY3JpcHRpb24+CiAgICA8ZGVmcz48L2RlZnM+CiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBza2V0Y2g6dHlwZT0iTVNQYWdlIj4KICAgICAgICA8cGF0aCBkPSJNMTcxLjUwNzgxMywzLjI1MDAwMDM4IEMyMjYuMjA4MTgzLDEyLjg1NzcxMTEgMjk3LjExMjcyMiw3MS40OTEyODIzIDI1MC44OTU1OTksMTA4LjQxMDE1NSBDMjE2LjU4MjAyNCwxMzUuODIwMzEgMTg2LjUyODQwNSw5Ny4wNjI0OTY0IDE1Ni44MDA3NzQsODUuNzczNDM0NiBDMTI3LjA3MzE0Myw3NC40ODQzNzIxIDc2Ljg4ODQ2MzIsODQuMjE2MTQ2MiA2MC4xMjg5MDY1LDEwOC40MTAxNTMgQy0xNS45ODA0Njg1LDIxOC4yODEyNDcgMTQ1LjI3NzM0NCwyOTYuNjY3OTY4IDE0NS4yNzczNDQsMjk2LjY2Nzk2OCBDMTQ1LjI3NzM0NCwyOTYuNjY3OTY4IC0yNS40NDkyMTg3LDI1Ny4yNDIxOTggMy4zOTg0Mzc1LDEwOC40MTAxNTUgQzE2LjMwNzA2NjEsNDEuODExNDE3NCA4NC43Mjc1ODI5LC0xMS45OTIyOTg1IDE3MS41MDc4MTMsMy4yNTAwMDAzOCBaIiBpZD0iUGF0aC0xIiBmaWxsPSIjMDAwMDAwIiBza2V0Y2g6dHlwZT0iTVNTaGFwZUdyb3VwIj48L3BhdGg+CiAgICA8L2c+Cjwvc3ZnPg==)}@keyframes rotateBefore{0%{transform:rotateX(60deg) rotateY(45deg) rotate(0)}to{transform:rotateX(60deg) rotateY(45deg) rotate(-360deg)}}@keyframes rotateAfter{0%{transform:rotateX(240deg) rotateY(45deg) rotate(0)}to{transform:rotateX(240deg) rotateY(45deg) rotate(360deg)}}.register-container{max-width:400px;margin:100px auto;padding:2rem;background-color:#f8f8f8;border-radius:8px;box-shadow:0 0 10px #ccc;text-align:center}.register-container h2{text-align:center;margin-bottom:20px;color:#333}.register-container form{display:flex;flex-direction:column}.register-container input,.register-container select{margin-bottom:15px;padding:12px;border-radius:6px;border:1px solid #ccc;font-size:14px}.register-container button{background-color:#007bff;color:#fff;border:none;padding:12px;font-size:16px;border-radius:6px;cursor:pointer;transition:background .3s ease;width:50%}.register-container button:hover{background-color:#0056b3}.register-container p{margin-top:15px;font-size:14px;text-align:center}.register-container a{color:#007bff;text-decoration:none}.register-container a:hover{text-decoration:underline}.estudiantes-lista{padding:20px;max-width:100%;margin:0 auto}.btn-refresh{display:inline-flex;align-items:center;gap:6px;background-color:#007bff;color:#fff;border:none;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:14px;transition:background-color .3s}.estudiantes-tabla{width:100%;border-collapse:collapse;background-color:#fff;font-size:14px}.estudiantes-tabla th{background-color:#343a40;color:#fff;padding:12px 8px;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6;position:sticky;top:0;z-index:10}.estudiantes-tabla td{padding:10px 8px;border-bottom:1px solid #dee2e6;vertical-align:top}.estudiantes-tabla tbody tr:hover{background-color:#f8f9fa}.estudiantes-tabla tbody tr:nth-child(2n){background-color:#f9f9f9}.estudiantes-tabla tbody tr:nth-child(2n):hover{background-color:#f1f1f1}.fila-incompleta{background-color:#fff3cd!important;border-left:4px solid #ffc107}.fecha{font-size:12px;color:#6c757d;white-space:nowrap}.acciones{display:flex;gap:5px;justify-content:center;flex-wrap:wrap}.acciones button{border:none;background:none;cursor:pointer;padding:5px;border-radius:3px;font-size:16px;transition:background-color .2s}.btn-editar:hover{background-color:#e7f3ff}.btn-eliminar:hover{background-color:#ffebee}.btn-editar,.btn-eliminar,.btn-qr{display:inline-flex;align-items:center;justify-content:center}.btn-qr:hover{background-color:#f3e5f5}.no-data{text-align:center;color:#6c757d;font-style:italic;padding:40px}.paginacion{display:flex;flex-direction:column;align-items:center;gap:15px;margin-top:30px;margin-bottom:30px;padding:10px}.paginacion-info{font-size:14px;color:#6c757d;font-weight:500}.paginacion-controles{display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap}.paginas{display:flex;gap:5px;align-items:center}.puntos{color:#6c757d;padding:0 5px;font-weight:700}.btn-paginacion{padding:8px 12px;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:5px;cursor:pointer;font-size:14px;color:#333;transition:all .2s;display:flex;align-items:center;justify-content:center;min-width:40px}.btn-paginacion:hover:not(:disabled){background-color:#e9ecef;border-color:#ced4da;color:#007bff}.btn-paginacion:disabled{opacity:.5;cursor:not-allowed;background-color:#f1f1f1}.btn-pagina{min-width:35px;height:35px;padding:0 8px;display:flex;align-items:center;justify-content:center;background-color:#fff;border:1px solid #dee2e6;border-radius:5px;cursor:pointer;font-size:14px;transition:all .2s}.btn-pagina:hover{background-color:#f8f9fa;border-color:#007bff;color:#007bff}.btn-pagina.active{background-color:#007bff;border-color:#007bff;color:#fff;font-weight:700;box-shadow:0 2px 4px #007bff4d}@media (max-width: 768px){.estudiantes-lista{padding:10px}.header{flex-direction:column;align-items:stretch}.header h2{text-align:center;margin-bottom:10px}.filtros{flex-direction:column}.filtro-texto,.filtro-select{min-width:100%}.estudiantes-tabla{font-size:12px}.estudiantes-tabla th,.estudiantes-tabla td{padding:6px 4px}.acciones{flex-direction:column}.estadisticas{grid-template-columns:1fr}}@media (max-width: 600px){.paginacion{flex-wrap:wrap;gap:15px}.paginas{order:3;width:100%;justify-content:center;overflow-x:auto;padding-bottom:5px}}@media (max-width: 480px){.tabla-container{font-size:11px}.info-relacionada .id{font-size:10px}.info-relacionada .nombre{font-size:11px}}.editar-estudiante{max-width:900px;margin:0 auto;padding:20px;background-color:#f8f9fa;min-height:100vh}.header{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.header h2{color:#333;margin:0;font-size:1.8rem;font-weight:600}.info-estudiante{display:flex;flex-direction:column;gap:5px;font-size:14px;color:#6c757d}.info-estudiante span{background-color:#e9ecef;padding:4px 8px;border-radius:4px;font-weight:500}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;color:#6c757d}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.formulario{display:flex;flex-direction:column;gap:25px}.seccion{background-color:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 10px #0000001a}.seccion h3{color:#333;margin:0 0 20px;font-size:1.3rem;font-weight:600;border-bottom:2px solid #007bff;padding-bottom:10px}.campos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.campo{display:flex;flex-direction:column;gap:8px}.campo label{font-weight:600;color:#495057;font-size:14px}.campo input,.campo select{padding:12px;border:2px solid #dee2e6;border-radius:6px;font-size:14px;transition:border-color .3s,box-shadow .3s;background-color:#fff}.campo input:focus,.campo select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.campo input:invalid{border-color:#dc3545}.campo input:invalid:focus{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.info-registro{background-color:#f8f9fa;padding:15px;border-radius:6px;border-left:4px solid #28a745}.info-registro p{margin:5px 0;color:#495057;font-size:14px}.info-registro strong{color:#333}.botones{display:flex;gap:15px;justify-content:flex-end;padding-top:20px;border-top:2px solid #dee2e6}.btn-cancelar,.btn-guardar{padding:12px 24px;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;min-width:120px}.btn-cancelar{background-color:#6c757d;color:#fff}.btn-cancelar:hover{background-color:#5a6268;transform:translateY(-1px)}.btn-guardar{background-color:#007bff;color:#fff}.btn-guardar:hover{background-color:#0056b3;transform:translateY(-1px)}.btn-guardar:active,.btn-cancelar:active{transform:translateY(0)}.campo input:required:valid{border-left:4px solid #28a745}.campo select:required:valid{border-left:4px solid #28a745}@media (max-width: 768px){.editar-estudiante{padding:10px}.header{flex-direction:column;align-items:stretch;gap:15px}.header h2{text-align:center}.info-estudiante{align-items:center}.seccion{padding:20px 15px}.campos-grid{grid-template-columns:1fr;gap:15px}.botones{flex-direction:column-reverse}.btn-cancelar,.btn-guardar{width:100%}}@media (max-width: 480px){.editar-estudiante{padding:5px}.header,.seccion{padding:15px 10px}.seccion h3{font-size:1.1rem}.campo input,.campo select{padding:10px;font-size:13px}}.qr-estudiantes-container{max-width:1200px;margin:0 auto;padding:24px;background-color:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a}.header-section{margin-bottom:24px}.main-title{font-size:32px;font-weight:700;color:#1f2937;text-align:center;margin-bottom:16px}.btn-retry{background-color:#f59e0b;color:#fff;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s ease-in-out;display:flex;align-items:center;gap:8px;margin-left:12px}.btn-retry:hover:not(:disabled){background-color:#d97706}.btn-retry:disabled{opacity:.6;cursor:not-allowed}.retry-icon{width:16px;height:16px}.spinning{animation:spin 1s linear infinite}.search-box{position:relative;flex:1;min-width:300px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8}.search-input{width:100%;padding:12px 12px 12px 40px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .2s ease;background-color:#f8fafc}.search-input:focus{outline:none;border-color:#3b82f6;background-color:#fff;box-shadow:0 0 0 4px #3b82f61a}.tabs-container{display:flex;gap:12px;margin-bottom:24px;background:#f1f5f9;padding:6px;border-radius:12px;width:fit-content}.tab-btn{padding:10px 24px;border:none;border-radius:8px;background:transparent;color:#64748b;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px;display:flex;align-items:center;gap:8px}.tab-btn:hover{color:#1e293b;background:#e2e8f0}.tab-btn.active{background:#fff;color:#2563eb;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.filters-grid{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.filter-group{display:flex;align-items:center;gap:8px;background-color:#f8fafc;padding:4px 12px;border:1px solid #e2e8f0;border-radius:8px;transition:border-color .2s}.filter-group:focus-within{border-color:#3b82f6}.filter-icon{color:#64748b}.filter-select{border:none;background:transparent;font-size:14px;color:#334155;padding:6px 0;outline:none;cursor:pointer;font-weight:500}.estudiante-dni{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:4px}.badge-tipo,.badge-nivel,.badge-turno{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase}.badge-tipo{background-color:#e2e8f0;color:#475569}.badge-tipo[data-tipo=colegio]{background-color:#dcfce7;color:#166534}.badge-tipo[data-tipo=academia]{background-color:#dbeafe;color:#1e40af}.badge-tipo[data-tipo=reforzamiento]{background-color:#fef9c3;color:#854d0e}.badge-nivel{background-color:#f3e8ff;color:#6b21a8}.badge-turno{background-color:#ffedd5;color:#9a3412}.items-per-page{display:flex;align-items:center;gap:8px;margin-left:auto;font-size:13px;color:#64748b}.estudiantes-list{display:flex;flex-direction:column;gap:24px}.estudiante-card{background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px;border:1px solid #f3f4f6;transition:box-shadow .2s ease-in-out}.estudiante-card:hover{box-shadow:0 4px 12px #00000026}.estudiante-header{margin-bottom:20px}.estudiante-nombre{font-size:20px;font-weight:700;color:#1f2937;margin-bottom:8px}.estudiante-dni{font-size:14px;color:#6b7280;font-weight:500}.btn-cargar-codigos{background-color:#3b82f6;color:#fff;padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s ease-in-out;display:flex;align-items:center;gap:8px;margin:0 auto}.btn-cargar-codigos:hover{background-color:#2563eb}.loading-message{display:flex;align-items:center;gap:12px;color:#3b82f6;font-weight:600;justify-content:center;padding:16px}.main-loading{font-size:18px;padding:32px}.loading-spinner{width:20px;height:20px;animation:spin 1s linear infinite}.error-message{color:#dc2626;background-color:#fef2f2;padding:16px;border-radius:8px;text-align:center;font-weight:600;border:1px solid #fecaca;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:16px}.no-results{text-align:center;color:#6b7280;font-size:18px;padding:32px;background-color:#f9fafb;border-radius:8px}.codes-container{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:24px}.code-section{text-align:center;padding:20px;background-color:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.code-header{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px}.code-title{font-weight:700;font-size:16px;color:#374151}.icon{width:20px;height:20px}.qr-icon{color:#059669}.barcode-icon{color:#7c3aed}.code-content{display:flex;flex-direction:column;align-items:center;gap:16px}.qr-image{width:128px;height:128px;border:2px solid #e5e7eb;border-radius:8px;background-color:#fff}.barcode-image{width:192px;height:64px;border:2px solid #e5e7eb;border-radius:8px;background-color:#fff}.btn-download{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:6px;color:#fff;font-weight:600;cursor:pointer;transition:background-color .2s ease-in-out;font-size:14px}.qr-download{background-color:#059669}.qr-download:hover{background-color:#047857}.barcode-download{background-color:#7c3aed}.barcode-download:hover{background-color:#6d28d9}.download-icon{width:16px;height:16px}.code-unavailable{color:#9ca3af;font-style:italic;padding:32px 16px}.controls-section{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:20px;flex-wrap:wrap}.items-per-page{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b7280}.items-select{padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;font-size:14px;cursor:pointer;outline:none;transition:border-color .2s ease}.items-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.results-info{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;margin-bottom:20px;font-size:14px;color:#64748b;text-align:center}.pagination-container{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.pagination{display:flex;align-items:center;gap:4px;background-color:#fff;border-radius:12px;padding:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:8px 12px;border:1px solid transparent;border-radius:8px;background-color:#fff;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;outline:none;position:relative;overflow:hidden}.pagination-btn:hover:not(.disabled){background-color:#f8fafc;color:#374151;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.pagination-btn:active:not(.disabled){transform:translateY(0);box-shadow:0 1px 2px #0000001a}.pagination-btn.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f64d;font-weight:600}.pagination-btn.active:hover{background:linear-gradient(135deg,#2563eb,#1e40af);transform:translateY(-1px);box-shadow:0 6px 16px #3b82f666}.pagination-btn.disabled{background-color:#f9fafb;color:#d1d5db;cursor:not-allowed;border-color:#f3f4f6}.pagination-btn.disabled:hover{background-color:#f9fafb;color:#d1d5db;transform:none;box-shadow:none}.pagination-btn:first-child,.pagination-btn:last-child,.pagination-btn:nth-child(2),.pagination-btn:nth-last-child(2){background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-color:#e2e8f0}.pagination-btn:first-child:hover:not(.disabled),.pagination-btn:last-child:hover:not(.disabled),.pagination-btn:nth-child(2):hover:not(.disabled),.pagination-btn:nth-last-child(2):hover:not(.disabled){background:linear-gradient(135deg,#e2e8f0,#cbd5e1);color:#475569}.pagination-info{font-size:14px;color:#6b7280;background-color:#f8fafc;padding:8px 16px;border-radius:20px;border:1px solid #e5e7eb;font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.pagination-container{animation:fadeIn .3s ease-out}.pagination-btn{position:relative;overflow:hidden}.pagination-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s}.pagination-btn:hover:before:not(.disabled){left:100%}.pagination-btn.loading{pointer-events:none;opacity:.7}.pagination-btn.loading:after{content:"";position:absolute;width:16px;height:16px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.search-input{flex:1;min-width:250px}@media (max-width: 768px){.codes-container{grid-template-columns:1fr;gap:24px}.controls-section{flex-direction:column;align-items:stretch;gap:16px}.items-per-page{justify-content:center;order:-1}.pagination-container{margin-top:24px;padding-top:20px}.pagination{flex-wrap:wrap;justify-content:center;gap:2px;padding:6px}.pagination-btn{min-width:36px;height:36px;padding:6px 10px;font-size:13px}.results-info{font-size:13px;padding:10px 12px}.pagination-info{font-size:13px;padding:6px 12px}}@media (max-width: 640px){.qr-estudiantes-container{padding:16px}.main-title{font-size:24px}.estudiante-card{padding:16px}.estudiante-nombre{font-size:18px}.barcode-image{width:160px;height:56px}}@media (max-width: 480px){.pagination{gap:1px;padding:4px;max-width:100%;overflow-x:auto}.pagination-btn{min-width:32px;height:32px;padding:4px 8px;font-size:12px;flex-shrink:0}.pagination-btn:first-child,.pagination-btn:last-child{display:none}}:root{--primary-color: #3b82f6;--primary-dark: #2563eb;--secondary-color: #64748b;--success-color: #10b981;--warning-color: #f59e0b;--danger-color: #ef4444;--background-color: #f8fafc;--card-background: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--border-radius: .75rem;--sidebar-width: 16rem;--header-height: 4rem}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--background-color);color:var(--text-primary);line-height:1.6}.dashboard{display:flex;min-height:100vh;height:100%;width:100%;background-color:var(--background-color)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background-color:var(--card-background);border-right:1px solid var(--border-color);box-shadow:var(--shadow-md);transform:translate(-100%);transition:transform .3s ease-in-out;z-index:1000;display:flex;flex-direction:column}.sidebar.open{transform:translate(0)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);height:var(--header-height)}.logo{display:flex;align-items:center;gap:.75rem;color:var(--primary-color);font-weight:700;font-size:1.25rem}.logo svg{width:2rem;height:2rem}.close-sidebar{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:.5rem;transition:all .2s}.close-sidebar:hover{background-color:var(--background-color);color:var(--text-primary)}.sidebar-nav{flex:1;padding:1.5rem 1rem;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;margin-bottom:.5rem;border:none;background:none;color:var(--text-secondary);text-align:left;border-radius:var(--border-radius);cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500}.nav-item:hover{background-color:var(--background-color);color:var(--text-primary)}.nav-item.active{background-color:var(--primary-color);color:#fff;box-shadow:var(--shadow-sm)}.nav-item.parent-active{background-color:#3b82f61a;color:var(--primary-color);border-left:4px solid var(--primary-color);border-radius:0 var(--border-radius) var(--border-radius) 0}.sidebar .nav-item:focus,.sidebar .nav-item:focus-visible,.sidebar button:focus,.sidebar button:focus-visible{outline:none;box-shadow:none}.nav-icon{width:1.25rem;height:1.25rem;flex-shrink:0}.nav-expandable-wrap{margin-bottom:.5rem}.nav-item-expandable{justify-content:space-between}.nav-item-expandable .nav-chevron{width:1rem;height:1rem;flex-shrink:0;opacity:.8}.nav-submenu{padding-left:1rem;margin-top:.25rem;margin-bottom:.5rem;border-left:2px solid var(--border-color)}.nav-submenu-label{display:block;padding:.5rem 1rem .25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-secondary)}.nav-subitem{padding:.5rem 1rem!important;margin-bottom:.25rem!important;font-size:.8125rem!important}.nav-subitem .nav-icon{width:1rem;height:1rem}.sidebar-footer{padding:1rem;border-top:1px solid var(--border-color)}.logout-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;background:none;color:var(--danger-color);text-align:left;border-radius:var(--border-radius);cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500}.logout-btn:hover{background-color:#fef2f2}.overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999}.main-content{flex:1;min-height:0;min-width:0;margin-left:0;display:flex;flex-direction:column}.top-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 1.5rem;background-color:var(--card-background);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.menu-toggle{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border:none;background-color:#1e293b;color:#fff;cursor:pointer;border-radius:.75rem;transition:all .2s;box-shadow:0 4px 6px -1px #0000001a}.menu-toggle:hover{background-color:#0f172a;transform:translateY(-1px)}.menu-toggle span{font-weight:600;font-size:.9rem}.search-icon{position:absolute;left:.75rem;width:1rem;height:1rem;color:var(--text-secondary)}.page-content{flex:1;min-height:0;padding:2rem;overflow-y:auto}.dashboard-home{display:flex;flex-direction:column;gap:2rem}.welcome-banner{display:flex;align-items:center;justify-content:space-between;padding:2rem;background:linear-gradient(135deg,var(--primary-color),#8b5cf6);color:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow-md)}.welcome-content h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.welcome-content p{font-size:1.125rem;opacity:.9}.welcome-icon{width:8rem;height:4rem;opacity:.8}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stat-card{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:all .2s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-content{display:flex;flex-direction:column;gap:.25rem}.stat-number{font-size:2rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.stat-change{font-size:.75rem;font-weight:600}.stat-change.positive{color:var(--success-color)}.stat-change.neutral{color:var(--warning-color)}.stat-icon{width:2.5rem;height:2.5rem;color:var(--primary-color)}.quick-actions{background-color:var(--card-background);border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.quick-actions h2{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;color:var(--text-primary)}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.action-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;border:1px solid var(--border-color);border-radius:var(--border-radius);background-color:var(--card-background);cursor:pointer;transition:all .2s;text-align:left}.action-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.action-icon{width:2.5rem;height:2.5rem;color:var(--primary-color);flex-shrink:0}.action-content h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.action-content p{font-size:.875rem;color:var(--text-secondary)}.section-content{display:flex;flex-direction:column;gap:2rem}.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.section-icon{width:2.5rem;height:2.5rem;color:var(--primary-color)}.section-header h1{font-size:2rem;font-weight:700;color:var(--text-primary)}.section-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.section-card{display:flex;align-items:flex-start;gap:1rem;padding:2rem;background-color:var(--card-background);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s;text-align:left}.section-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-icon{width:3rem;height:3rem;color:var(--primary-color);flex-shrink:0}.card-content h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.card-content p{font-size:.875rem;color:var(--text-secondary);line-height:1.5}@media (min-width: 1024px){.sidebar{position:fixed;transform:translate(0)}.main-content{margin-left:var(--sidebar-width)}.menu-toggle,.close-sidebar{display:none}}@media (max-width: 1023px) and (min-width: 768px){.stats-grid,.actions-grid,.section-grid{grid-template-columns:repeat(2,1fr)}.welcome-banner{flex-direction:column;text-align:center;gap:1rem}.welcome-icon{width:3rem;height:3rem}}@media (max-width: 767px){.page-content{padding:1rem}.stats-grid,.actions-grid,.section-grid{grid-template-columns:1fr}.welcome-banner{flex-direction:column;text-align:center;gap:1rem;padding:1.5rem}.welcome-content h1{font-size:1.5rem}.welcome-content p{font-size:1rem}.welcome-icon{width:2.5rem;height:2.5rem}.top-header{padding:0 1rem}.action-card,.section-card,.stat-card{flex-direction:column;text-align:center;gap:1rem}}@media (max-width: 480px){.welcome-content h1{font-size:1.25rem}.stat-number,.section-header h1{font-size:1.5rem}.card-content h3{font-size:1rem}.action-content h3{font-size:.875rem}}.crear-planes-form{max-width:500px;margin:30px auto;background:linear-gradient(135deg,#fff,#fafbfc);padding:40px;border-radius:20px;box-shadow:0 25px 50px #00000014,0 12px 24px #0000000d,0 0 0 1px #ffffffe6;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.crear-planes-form:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#667eea,#764ba2,#f093fb);border-radius:20px 20px 0 0}.crear-planes-form:after{content:"";position:absolute;top:-50%;right:-50%;width:200px;height:200px;background:radial-gradient(circle,rgba(102,126,234,.1) 0%,transparent 70%);border-radius:50%;pointer-events:none}.crear-planes-form h2{text-align:center;margin-bottom:35px;color:#2d3748;font-size:32px;font-weight:800;position:relative;letter-spacing:-.025em}.crear-planes-form h2:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:80px;height:4px;background:linear-gradient(90deg,#667eea,#39e909);border-radius:2px;box-shadow:0 2px 8px #667eea4d}.crear-planes-group{display:flex;flex-direction:column;margin-bottom:28px;position:relative}.crear-planes-group label{font-weight:700;margin-bottom:10px;color:#4a5568;font-size:15px;letter-spacing:.025em;transition:all .3s ease;position:relative}.crear-planes-group label:before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:6px;height:6px;background:linear-gradient(45deg,#667eea,#39e909);border-radius:50%;opacity:0;transition:opacity .3s ease}.crear-planes-group:focus-within label:before{opacity:1}.crear-planes-group input,.crear-planes-group textarea{padding:16px 20px;border:2px solid #e2e8f0;border-radius:16px;font-size:16px;background:#fff;color:#2d3748;transition:all .4s cubic-bezier(.4,0,.2,1);font-family:inherit;outline:none;box-shadow:0 2px 4px #00000005,inset 0 1px 3px #00000005;position:relative;z-index:1}.crear-planes-group textarea{resize:vertical;min-height:120px;line-height:1.6}.crear-planes-group input:focus,.crear-planes-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a,0 8px 20px #667eea26,inset 0 1px 3px #00000005;transform:translateY(-2px)}.crear-planes-group input:hover:not(:focus),.crear-planes-group textarea:hover:not(:focus){border-color:#cbd5e0;box-shadow:0 4px 12px #00000014,inset 0 1px 3px #00000005;transform:translateY(-1px)}.crear-planes-group input:valid,.crear-planes-group textarea:valid{border-color:#48bb78;background:linear-gradient(135deg,#fff,#f0fff4)}.crear-planes-group input:invalid:not(:placeholder-shown),.crear-planes-group textarea:invalid:not(:placeholder-shown){border-color:#f56565;background:linear-gradient(135deg,#fff,snow)}.crear-planes-group input[type=number]{position:relative}.crear-planes-group input[type=number]:before{content:"S/.";position:absolute;left:20px;top:50%;transform:translateY(-50%);color:#718096;font-weight:600;pointer-events:none}.btn-crear-plan{background:linear-gradient(135deg,#667eea,#39e909);color:#fff;padding:18px 32px;width:100%;border:none;border-radius:16px;cursor:pointer;font-size:18px;font-weight:700;letter-spacing:.5px;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 20px #667eea4d,0 4px 8px #0000001a;position:relative;overflow:hidden;text-transform:uppercase;margin-top:10px}.btn-crear-plan:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s}.btn-crear-plan:hover{background:linear-gradient(135deg,#040404,#39e909);transform:translateY(-3px);box-shadow:0 12px 28px #667eea66,0 8px 16px #00000026}.btn-crear-plan:hover:before{left:100%}.btn-crear-plan:active{transform:translateY(-1px);box-shadow:0 6px 16px #667eea59,0 2px 8px #0000001a}.btn-crear-plan:disabled{background:linear-gradient(135deg,#a0aec0,#9ca3af);cursor:not-allowed;transform:none;box-shadow:0 2px 8px #0000001a}.crear-planes-success{color:#22543d;background:linear-gradient(135deg,#c6f6d5,#e6fffa);border:2px solid #9ae6b4;padding:16px 20px;border-radius:16px;margin-bottom:20px;text-align:center;font-weight:600;font-size:15px;box-shadow:0 4px 12px #48bb7833;position:relative;overflow:hidden}.crear-planes-success:before{content:"✓";position:absolute;left:20px;top:50%;transform:translateY(-50%);font-size:20px;color:#22543d;font-weight:700}.crear-planes-error{color:#39e909;background:linear-gradient(135deg,#fed7d7,snow);border:2px solid #fc8181;padding:16px 20px;border-radius:16px;margin-bottom:20px;text-align:center;font-weight:600;font-size:15px;box-shadow:0 4px 12px #f5656533;position:relative;overflow:hidden}.crear-planes-error:before{content:"⚠";position:absolute;left:20px;top:50%;transform:translateY(-50%);font-size:20px;color:#39e909;font-weight:700}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.crear-planes-form{animation:fadeInScale .7s ease-out}.crear-planes-group{animation:slideInUp .6s ease-out;animation-fill-mode:both}.crear-planes-group:nth-child(2){animation-delay:.1s}.crear-planes-group:nth-child(3){animation-delay:.2s}.crear-planes-group:nth-child(4){animation-delay:.3s}.btn-crear-plan{animation:slideInUp .6s ease-out .4s both}.loading .btn-crear-plan{position:relative;color:transparent;pointer-events:none}.loading .btn-crear-plan:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top:3px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}@media (max-width: 640px){.crear-planes-form{margin:20px;padding:28px;max-width:none;border-radius:16px}.crear-planes-form h2{font-size:28px;margin-bottom:28px}.crear-planes-group{margin-bottom:24px}.crear-planes-group input,.crear-planes-group textarea{padding:14px 18px;font-size:15px;border-radius:12px}.btn-crear-plan{padding:16px 28px;font-size:16px;border-radius:12px}.crear-planes-success,.crear-planes-error{padding:14px 18px;border-radius:12px;font-size:14px}}@media (prefers-reduced-motion: reduce){.crear-planes-form,.crear-planes-group,.btn-crear-plan{animation:none}.crear-planes-group input,.crear-planes-group textarea,.btn-crear-plan{transition-duration:.1s}}.crear-planes-group input:focus-visible,.crear-planes-group textarea:focus-visible,.btn-crear-plan:focus-visible{outline:3px solid #667eea;outline-offset:2px}.crear-planes-form:after{content:"";position:absolute;bottom:-30%;left:-30%;width:150px;height:150px;background:radial-gradient(circle,rgba(118,75,162,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}.planes-lista-container{padding:20px;max-width:100%;margin:0 auto}.planes-lista-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.planes-lista-header h2{color:#333;margin:0;font-size:1.8rem}.planes-lista-btn-refresh{background-color:#007bff;color:#fff;border:none;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:14px;transition:background-color .3s}.planes-lista-btn-refresh:hover{background-color:#0056b3}.planes-lista-tabla-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px}.planes-lista-tabla{width:100%;border-collapse:collapse;background-color:#fff;font-size:14px}.planes-lista-tabla th{background-color:#343a40;color:#fff;padding:12px 8px;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6;position:sticky;top:0;z-index:10}.planes-lista-tabla td{padding:10px 8px;border-bottom:1px solid #dee2e6;vertical-align:top}.planes-lista-tabla tbody tr:hover{background-color:#f8f9fa}.planes-lista-tabla tbody tr:nth-child(2n){background-color:#f9f9f9}.planes-lista-tabla tbody tr:nth-child(2n):hover{background-color:#f1f1f1}.planes-lista-info-relacionada{display:flex;flex-direction:column;gap:2px}.planes-lista-info-relacionada .id{font-size:11px;color:#6c757d;font-weight:500}.planes-lista-info-relacionada .nombre{font-size:13px;color:#495057;font-weight:600}.planes-lista-sin-datos{color:#6c757d;font-style:italic;font-size:12px}.planes-lista-fecha{font-size:12px;color:#6c757d;white-space:nowrap}.planes-lista-no-data{text-align:center;color:#6c757d;font-style:italic;padding:40px;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a}.planes-lista-acciones{display:flex;gap:5px;justify-content:center;flex-wrap:wrap}.planes-lista-acciones button{border:none;background:none;cursor:pointer;padding:5px;border-radius:3px;font-size:16px;transition:background-color .2s}.planes-lista-btn-editar:hover{background-color:#e7f3ff}.planes-lista-btn-eliminar:hover{background-color:#ffebee}.planes-lista-loading{text-align:center;padding:40px;font-size:18px;color:#6c757d}.planes-lista-estadisticas{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-top:20px}.planes-lista-stat-card{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a;text-align:center;border-left:4px solid #007bff}.planes-lista-stat-card h4{margin:0 0 10px;color:#495057;font-size:14px;font-weight:600}.planes-lista-stat-number{font-size:24px;font-weight:700;color:#007bff}.planes-lista-search-container{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap;padding:15px;background-color:#f8f9fa;border-radius:8px}.planes-lista-filtro-texto{flex:1;min-width:200px;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px}@media (max-width: 768px){.planes-lista-container{padding:10px}.planes-lista-header{flex-direction:column;align-items:stretch}.planes-lista-header h2{text-align:center;margin-bottom:10px}.planes-lista-tabla{font-size:12px}.planes-lista-search-container{flex-direction:column}.planes-lista-tabla th,.planes-lista-tabla td{padding:6px 4px}.planes-lista-estadisticas{grid-template-columns:1fr}}@media (max-width: 480px){.planes-lista-tabla-container{font-size:11px}.planes-lista-info-relacionada .id{font-size:10px}.planes-lista-info-relacionada .nombre{font-size:11px}.planes-lista-stat-card{padding:15px}.planes-lista-stat-number{font-size:20px}}.editar-plan-container{max-width:480px;margin:40px auto;background:#fff;padding:32px 24px;border-radius:12px;box-shadow:0 4px 16px #00000017}.editar-plan-title{text-align:center;font-size:2rem;font-weight:700;color:#1e3a8a;margin-bottom:28px}.editar-plan-form-group{margin-bottom:18px}.editar-plan-label{display:block;font-size:1rem;font-weight:500;color:#374151;margin-bottom:6px}.editar-plan-input,.editar-plan-textarea{width:80%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s;background:#f9fafb}.editar-plan-input:focus,.editar-plan-textarea:focus{border-color:#2563eb;outline:none;background:#fff}.editar-plan-btn{width:80%;background:#2563eb;color:#fff;padding:12px 0;border:none;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .2s}.editar-plan-btn:hover{background:#1d4ed8}.editar-plan-msg-success{color:#256029;background:#e9fbe8;border:1px solid #b6e2b7;padding:10px;border-radius:6px;margin-bottom:15px;text-align:center;font-weight:500}.editar-plan-msg-error{color:#a94442;background:#fbeaea;border:1px solid #e2b6b6;padding:10px;border-radius:6px;margin-bottom:15px;text-align:center;font-weight:500}.asistencias-lista{padding:20px;max-width:100%;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.header h2{color:#333;margin:0;font-size:1.8rem}.btn-refresh{background-color:#007bff;color:#fff;border:none;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:14px;transition:background-color .3s}.btn-refresh:hover{background-color:#0056b3}.header-buttons .btn-icon,.btn-editar svg{vertical-align:middle;margin-right:6px;flex-shrink:0}.header-buttons button{display:inline-flex;align-items:center}.btn-editar{display:inline-flex;align-items:center;justify-content:center}.btn-editar .btn-icon{margin-right:0}.btn-icon.spin{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.filtros{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap;padding:15px;background-color:#f8f9fa;border-radius:8px}.filtro-texto{flex:1;min-width:200px;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px}.filtro-select{padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px;background-color:#fff;min-width:150px}.tabla-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px}.asistencias-tabla{width:100%;border-collapse:collapse;background-color:#fff;font-size:14px}.asistencias-tabla th{background-color:#343a40;color:#fff;padding:12px 8px;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6;position:sticky;top:0;z-index:10}.asistencias-tabla td{padding:10px 8px;border-bottom:1px solid #dee2e6;vertical-align:top}.asistencias-tabla tbody tr:hover{background-color:#f8f9fa}.asistencias-tabla tbody tr:nth-child(2n){background-color:#f9f9f9}.asistencias-tabla tbody tr:nth-child(2n):hover{background-color:#f1f1f1}.campo-vacio{background-color:#f8d7da;color:#721c24;font-style:italic}.contexto-badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500;background-color:#e7f1ff;color:#0d6efd}.estado-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.estado-presente{background-color:#d4edda;color:#155724}.estado-ausente{background-color:#f8d7da;color:#721c24}.estado-justificado{background-color:#fff3cd;color:#856404}.estado-tarde{background-color:#d1ecf1;color:#0c5460}.info-relacionada{display:flex;flex-direction:column;gap:2px}.info-relacionada .id{font-size:11px;color:#6c757d;font-weight:500}.info-relacionada .nombre{font-size:13px;color:#495057;font-weight:600}.sin-datos{color:#6c757d;font-style:italic;font-size:12px}.fecha,.observaciones{font-size:12px;color:#6c757d;white-space:nowrap}.no-data{text-align:center;color:#6c757d;font-style:italic;padding:40px;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a}.loading{text-align:center;padding:40px;font-size:18px;color:#6c757d}.tabla-container{position:relative}.loading-overlay{position:absolute;inset:0;background-color:#ffffffb3;display:flex;justify-content:center;align-items:center;z-index:20;font-size:18px;font-weight:700;color:#007bff;border-radius:8px}.estadisticas{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-top:20px}.stat-card{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a;text-align:center;border-left:4px solid #007bff}.stat-card h4{margin:0 0 10px;color:#495057;font-size:14px;font-weight:600}.stat-number{font-size:24px;font-weight:700;color:#007bff}.header-buttons{display:flex;gap:10px;flex-wrap:wrap}.btn-export{background-color:#28a745;color:#fff;border:none;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:14px;transition:background-color .3s;display:flex;align-items:center;gap:5px}.btn-export:hover:not(:disabled){background-color:#218838}.btn-export:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.btn-excel{background-color:#198754}.btn-excel:hover:not(:disabled){background-color:#157347}.btn-pdf{background-color:#dc3545}.btn-pdf:hover:not(:disabled){background-color:#bb2d3b}.btn-planilla{background-color:#6f42c1}.btn-planilla:hover:not(:disabled){background-color:#5a32a3}.pagination-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding:10px 15px;background-color:#f8f9fa;border-radius:5px;font-size:14px;color:#6c757d}.pagination{display:flex;justify-content:center;align-items:center;gap:5px;margin:20px 0;flex-wrap:wrap}.pagination-btn{background-color:#fff;color:#007bff;border:1px solid #dee2e6;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .3s;min-width:40px}.pagination-btn:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd}.pagination-btn:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed;border-color:#dee2e6}.pagination-btn.active{background-color:#007bff;color:#fff;border-color:#007bff}.pagination-btn.active:hover{background-color:#0056b3;border-color:#0056b3}.acciones{text-align:center;padding:8px}.btn-editar{background:none;border:none;font-size:16px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .3s}.btn-editar:hover{background-color:#f8f9fa}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #dee2e6}.modal-header h3{margin:0;color:#333}.btn-cerrar-modal{background:none;border:none;font-size:20px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%}.btn-cerrar-modal:hover{background-color:#f8f9fa;color:#333}.modal-body{padding:20px}.info-estudiante{background-color:#f8f9fa;padding:15px;border-radius:6px;margin-bottom:20px}.info-estudiante h4{margin:0 0 10px;color:#007bff}.info-estudiante p{margin:5px 0;color:#6c757d;font-size:14px}.campo-edicion{margin-bottom:15px}.campo-edicion label{display:block;margin-bottom:5px;font-weight:500;color:#333}.select-edicion{width:100%;padding:8px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;background-color:#fff}.select-edicion:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.textarea-edicion{width:100%;padding:8px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;resize:vertical;font-family:inherit}.textarea-edicion:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px;border-top:1px solid #dee2e6}.btn-cancelar{background-color:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px}.btn-cancelar:hover:not(:disabled){background-color:#5a6268}.btn-guardar{background-color:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px}.btn-guardar:hover:not(:disabled){background-color:#0056b3}.btn-cancelar:disabled,.btn-guardar:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.asistencias-lista{padding:10px}.header{flex-direction:column;align-items:stretch}.modal-content{width:95%;margin:10px}.modal-header,.modal-body,.modal-footer{padding:15px}.modal-footer{flex-direction:column}.btn-cancelar,.btn-guardar{width:100%}.header h2{text-align:center;margin-bottom:10px}.filtros{flex-direction:column}.filtro-texto,.filtro-select{min-width:100%}.asistencias-tabla{font-size:12px}.asistencias-tabla th,.asistencias-tabla td{padding:6px 4px}.estadisticas{grid-template-columns:1fr}.header-buttons{width:100%;justify-content:center}.btn-export,.btn-refresh{flex:1;min-width:80px}.pagination{gap:3px}.pagination-btn{padding:6px 8px;font-size:12px;min-width:35px}.pagination-info{flex-direction:column;gap:5px;text-align:center}}@media (max-width: 480px){.tabla-container{font-size:11px}.info-relacionada .id{font-size:10px}.info-relacionada .nombre{font-size:11px}.stat-card{padding:15px}.stat-number{font-size:20px}.estado-badge{font-size:10px;padding:3px 6px}.header-buttons{flex-direction:column}.pagination{flex-wrap:wrap;gap:2px}.pagination-btn{padding:5px 6px;font-size:11px;min-width:30px}}/*! tailwindcss v4.2.0 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-blue-50:oklch(97% .014 254.604);--color-blue-100:oklch(93.2% .032 255.585);--color-blue-400:oklch(70.7% .165 254.624);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-blue-700:oklch(48.8% .243 264.376);--color-blue-900:oklch(37.9% .146 265.522);--color-indigo-700:oklch(45.7% .24 277.023);--color-slate-50:oklch(98.4% .003 247.858);--color-slate-100:oklch(96.8% .007 247.896);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-wider:.05em;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.\@container{container-type:inline-size}.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.start\!{inset-inline-start:var(--spacing)!important}.end{inset-inline-end:var(--spacing)}.top-1\/2{top:50%}.left-3{left:calc(var(--spacing) * 3)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.m-1{margin:calc(var(--spacing) * 1)}.\!mt-0\.5{margin-top:calc(var(--spacing) * .5)!important}.\!mt-1{margin-top:calc(var(--spacing) * 1)!important}.\!mt-3{margin-top:calc(var(--spacing) * 3)!important}.\!mt-4{margin-top:calc(var(--spacing) * 4)!important}.\!mt-6{margin-top:calc(var(--spacing) * 6)!important}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-4{margin-top:calc(var(--spacing) * 4)}.\!mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)!important}.\!mb-3{margin-bottom:calc(var(--spacing) * 3)!important}.\!mb-4{margin-bottom:calc(var(--spacing) * 4)!important}.\!mb-6{margin-bottom:calc(var(--spacing) * 6)!important}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.block{display:block}.contents{display:contents}.flex{display:flex}.flow-root{display:flow-root}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.inline-grid{display:inline-grid}.inline-table{display:inline-table}.list-item{display:list-item}.table{display:table}.table\!{display:table!important}.table-caption{display:table-caption}.table-cell{display:table-cell}.table-column{display:table-column}.table-column-group{display:table-column-group}.table-footer-group{display:table-footer-group}.table-header-group{display:table-header-group}.table-row{display:table-row}.table-row-group{display:table-row-group}.h-4{height:calc(var(--spacing) * 4)}.h-8{height:calc(var(--spacing) * 8)}.min-h-\[calc\(100vh-8rem\)\]{min-height:calc(100vh - 8rem)}.w-4{width:calc(var(--spacing) * 4)}.w-8{width:calc(var(--spacing) * 8)}.w-full{width:100%}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-full{min-width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.transform\!{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)!important}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-gray-200>:not(:last-child)){border-color:var(--color-gray-200)}.overflow-hidden{overflow:hidden}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-blue-400\/50{border-color:#54a2ff80}@supports (color:color-mix(in lab,red,red)){.border-blue-400\/50{border-color:color-mix(in oklab,var(--color-blue-400) 50%,transparent)}}.border-blue-600{border-color:var(--color-blue-600)}.border-gray-100{border-color:var(--color-gray-100)}.border-gray-200{border-color:var(--color-gray-200)}.border-gray-300{border-color:var(--color-gray-300)}.border-white\/80{border-color:#fffc}@supports (color:color-mix(in lab,red,red)){.border-white\/80{border-color:color-mix(in oklab,var(--color-white) 80%,transparent)}}.bg-blue-600{background-color:var(--color-blue-600)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-50\/50{background-color:#f9fafb80}@supports (color:color-mix(in lab,red,red)){.bg-gray-50\/50{background-color:color-mix(in oklab,var(--color-gray-50) 50%,transparent)}}.bg-gray-50\/80{background-color:#f9fafbcc}@supports (color:color-mix(in lab,red,red)){.bg-gray-50\/80{background-color:color-mix(in oklab,var(--color-gray-50) 80%,transparent)}}.bg-white{background-color:var(--color-white)}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.bg-gradient-to-b{--tw-gradient-position:to bottom in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-blue-600{--tw-gradient-from:var(--color-blue-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-slate-50{--tw-gradient-from:var(--color-slate-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.via-blue-600{--tw-gradient-via:var(--color-blue-600);--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-indigo-700{--tw-gradient-to:var(--color-indigo-700);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-slate-100\/80{--tw-gradient-to:#f1f5f9cc}@supports (color:color-mix(in lab,red,red)){.to-slate-100\/80{--tw-gradient-to:color-mix(in oklab, var(--color-slate-100) 80%, transparent)}}.to-slate-100\/80{--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-12{padding-block:calc(var(--spacing) * 12)}.pr-4{padding-right:calc(var(--spacing) * 4)}.pl-10{padding-left:calc(var(--spacing) * 10)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.break-all{word-break:break-all}.text-blue-100\/90{color:#dbeafee6}@supports (color:color-mix(in lab,red,red)){.text-blue-100\/90{color:color-mix(in oklab,var(--color-blue-100) 90%,transparent)}}.text-blue-500{color:var(--color-blue-500)}.text-blue-600{color:var(--color-blue-600)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-800{color:var(--color-gray-800)}.text-gray-900{color:var(--color-gray-900)}.text-red-600{color:var(--color-red-600)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.line-through{text-decoration-line:line-through}.overline{text-decoration-line:overline}.underline{text-decoration-line:underline}.shadow,.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-1{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-blue-900\/5{--tw-shadow-color:#1c398e0d}@supports (color:color-mix(in lab,red,red)){.shadow-blue-900\/5{--tw-shadow-color:color-mix(in oklab, color-mix(in oklab, var(--color-blue-900) 5%, transparent) var(--tw-shadow-alpha), transparent)}}.ring-black\/5{--tw-ring-color:#0000000d}@supports (color:color-mix(in lab,red,red)){.ring-black\/5{--tw-ring-color:color-mix(in oklab, var(--color-black) 5%, transparent)}}.\!outline{outline-style:var(--tw-outline-style)!important;outline-width:1px!important}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter\!{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)!important}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.placeholder\:text-gray-400::placeholder{color:var(--color-gray-400)}@media (hover:hover){.hover\:bg-blue-50:hover{background-color:var(--color-blue-50)}.hover\:bg-blue-700:hover{background-color:var(--color-blue-700)}.hover\:bg-gray-50:hover{background-color:var(--color-gray-50)}.hover\:bg-gray-50\/80:hover{background-color:#f9fafbcc}@supports (color:color-mix(in lab,red,red)){.hover\:bg-gray-50\/80:hover{background-color:color-mix(in oklab,var(--color-gray-50) 80%,transparent)}}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:bg-red-50:hover{background-color:var(--color-red-50)}.hover\:bg-white\/20:hover{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/20:hover{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.hover\:text-gray-900:hover{color:var(--color-gray-900)}.hover\:text-red-700:hover{color:var(--color-red-700)}}.focus\:border-blue-500:focus{border-color:var(--color-blue-500)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-blue-500:focus{--tw-ring-color:var(--color-blue-500)}.focus\:ring-blue-500\/20:focus{--tw-ring-color:#3080ff33}@supports (color:color-mix(in lab,red,red)){.focus\:ring-blue-500\/20:focus{--tw-ring-color:color-mix(in oklab, var(--color-blue-500) 20%, transparent)}}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-100:disabled{background-color:var(--color-gray-100)}.disabled\:text-gray-500:disabled{color:var(--color-gray-500)}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}@media (min-width:40rem){.sm\:col-span-2{grid-column:span 2/span 2}.sm\:col-start-1{grid-column-start:1}.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}.sm\:justify-end{justify-content:flex-end}.sm\:gap-4{gap:calc(var(--spacing) * 4)}.sm\:p-8{padding:calc(var(--spacing) * 8)}.sm\:px-8{padding-inline:calc(var(--spacing) * 8)}}@media (min-width:64rem){.lg\:col-span-1{grid-column:span 1/span 1}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}}:root{color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}#root{width:100%;min-height:100vh}body{width:100%;min-width:320px;min-height:100vh;margin:0}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s,background-color .2s}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}input:-webkit-autofill{-webkit-text-fill-color:#111827;color:#111827;box-shadow:inset 0 0 0 1000px #fff}input:-webkit-autofill:hover{-webkit-text-fill-color:#111827;color:#111827;box-shadow:inset 0 0 0 1000px #fff}input:-webkit-autofill:focus{-webkit-text-fill-color:#111827;color:#111827;box-shadow:inset 0 0 0 1000px #fff}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}
