:root{font-family:Segoe UI,system-ui,sans-serif;line-height:1.5;color:#1a1a2e;background:#f4f6fb}*{box-sizing:border-box}body{margin:0;overflow-x:hidden;-webkit-text-size-adjust:100%}.app{max-width:900px;margin:0 auto;padding:2rem 1rem 4rem}.app-header{margin-bottom:2rem}.app-header h1{margin:0 0 .25rem;font-size:1.75rem}.app-header p{margin:0;color:#5a6278}.app-nav{display:flex;gap:.5rem;margin-top:1rem}.nav-btn{padding:.5rem 1rem;border:1px solid #cbd5e1;border-radius:8px;background:#fff;font:inherit;font-weight:600;cursor:pointer;color:#475569}.nav-btn.activo{background:#4f46e5;border-color:#4f46e5;color:#fff}.nav-link{text-decoration:none;display:inline-flex;align-items:center}.btn-danger{background:#dc2626;color:#fff;border:none}.btn-danger:hover{background:#b91c1c}.admin-layout{max-width:1100px;margin:0 auto;padding:2rem 1rem 4rem}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e2e8f0}.admin-header h1{margin:0 0 .25rem}.admin-header p{margin:0;color:#64748b}.admin-header-actions{display:flex;gap:.5rem;flex-shrink:0}.admin-login{display:flex;justify-content:center;padding:3rem 0}.admin-login-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:2.25rem;width:100%;max-width:420px;display:flex;flex-direction:column;gap:1rem;box-shadow:0 12px 32px #0f172a14}.admin-login-card h2{margin:0;font-size:1.6rem}.admin-login-card label{margin-bottom:0;color:#334155}.admin-login-card input[type=password]{padding:.75rem .9rem}.admin-login-card .btn-primary{margin-top:.25rem;padding:.75rem 1.2rem}.admin-login-hint{margin:0;font-size:.8rem;color:#94a3b8}.admin-login-hint code{background:#f1f5f9;padding:.1rem .35rem;border-radius:4px}.admin-dashboard h2{margin:0}.admin-acciones{display:flex;gap:.4rem;white-space:nowrap}.admin-edit-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.admin-edit-header h2{margin:.25rem 0 0}.admin-back-link{color:#6366f1;text-decoration:none;font-size:.875rem;font-weight:600}.admin-back-link:hover{text-decoration:underline}.reportes-lista-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.reportes-lista-header h2{margin:0}.reportes-filtros{display:flex;gap:.75rem;margin-bottom:1rem}.reportes-filtros select{flex:1}.reportes-vacio{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:2rem;text-align:center}.reportes-tabla-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;background:#fff;border:1px solid #e2e8f0;border-radius:10px}.reportes-tabla{width:100%;border-collapse:collapse;font-size:.9rem}.reportes-tabla th,.reportes-tabla td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e2e8f0}.reportes-tabla th{background:#f8fafc;font-weight:700;color:#475569}.reportes-tabla tbody tr:hover{background:#f8fafc}.btn-sm{padding:.35rem .75rem;font-size:.875rem}.estado-badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.75rem;font-weight:700}.estado-badge.cerrado{background:#ecfdf5;color:#065f46}.estado-badge.borrador{background:#fef3c7;color:#92400e}.reporte-detalle-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:100}.reporte-detalle{background:#fff;border-radius:12px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;padding:1.5rem;box-shadow:0 20px 40px #00000026}.reporte-detalle-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.reporte-detalle-header h3{margin:0 0 .25rem}.reporte-detalle-periodo{margin:0;color:#64748b}.reporte-detalle-grid section{margin-bottom:1.25rem}.reporte-detalle-grid h4{margin:0 0 .5rem;font-size:.95rem;color:#334155}.detalle-lista{margin:0;padding-left:1.25rem}.detalle-vacio{margin:0;color:#94a3b8;font-style:italic}.detalle-texto{margin:0;white-space:pre-wrap}.detalle-meta{display:flex;justify-content:space-between;font-size:.8rem;color:#94a3b8;padding-top:.75rem;border-top:1px solid #e2e8f0}.reporte-mensual-form section{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:1.25rem;margin-bottom:1rem}.reporte-mensual-form h2,.reporte-mensual-form h3{margin-top:0}.reporte-periodo{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.periodo-selector{display:flex;align-items:center;gap:.5rem}.periodo-controles{display:flex;gap:.5rem;flex:1}.periodo-controles select{flex:1}.periodo-nav{padding:.6rem .9rem;min-width:44px}.fechas-acciones{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.fechas-pendiente{font-size:.875rem;color:#b45309;font-weight:600}.fechas-guardado-ok{font-size:.875rem;color:#0f766e;font-weight:600}label{display:block;font-weight:600;margin-bottom:.4rem}select,input[type=date],input[type=text],input[type=number],input[type=password],textarea{width:100%;padding:.6rem .75rem;border:1px solid #cbd5e1;border-radius:8px;font:inherit;font-size:max(16px,1rem);background:#fff;color:#1a1a2e;transition:border-color .15s,box-shadow .15s}select:focus,input[type=date]:focus,input[type=text]:focus,input[type=number]:focus,input[type=password]:focus,textarea:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e526}input::placeholder{color:#94a3b8}textarea{min-height:80px;resize:vertical}.error{color:#dc2626;font-size:.875rem;margin-top:.35rem}.fechas-ensayo-picker{display:flex;flex-direction:column;gap:.75rem}.fechas-ensayo-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.fechas-ensayo-header label{margin-bottom:0}.fechas-contador{font-size:.875rem;font-weight:600;color:#4f46e5;background:#eef2ff;padding:.25rem .6rem;border-radius:999px}.fechas-ayuda{margin:0;font-size:.875rem;color:#64748b}.calendario-mes{border:1px solid #e2e8f0;border-radius:10px;padding:.75rem;background:#f8fafc}.calendario-mes-titulo{text-align:center;font-weight:700;margin-bottom:.75rem;color:#334155}.calendario-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.35rem}.calendario-grid-head{margin-bottom:.35rem}.calendario-celda-head{text-align:center;font-size:.75rem;font-weight:700;color:#64748b;padding:.25rem 0}.calendario-celda{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:.875rem}.calendario-celda.vacia{background:transparent}.calendario-celda.dia{border:1px solid #cbd5e1;background:#fff;color:#334155;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.calendario-celda.dia:hover{border-color:#818cf8;background:#eef2ff}.calendario-celda.dia.seleccionada{background:#4f46e5;border-color:#4f46e5;color:#fff;font-weight:700}.calendario-celda.dia.guardada:not(.seleccionada){background:#ccfbf1;border-color:#14b8a6;color:#0f766e}.fechas-aviso{margin:0;font-size:.875rem;color:#b45309}.fechas-seleccionadas{border-top:1px solid #e2e8f0;padding-top:.75rem}.fechas-seleccionadas-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.fechas-vacio{margin:0;font-size:.875rem;color:#94a3b8;font-style:italic}.btn-link{border:none;background:transparent;color:#6366f1;font:inherit;font-size:.875rem;cursor:pointer;text-decoration:underline;padding:0}.fechas-lista{display:flex;flex-wrap:wrap;gap:.5rem}.fecha-chip{display:inline-flex;align-items:center;gap:.4rem;background:#eef2ff;color:#3730a3;padding:.35rem .6rem;border-radius:999px;font-size:.875rem}.fecha-chip button{border:none;background:transparent;cursor:pointer;color:#6366f1;font-size:1rem;line-height:1;padding:0}.fecha-add-row{display:flex;gap:.5rem;margin-top:.5rem}.fecha-add-row input{flex:1}.demografia-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.demografia-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.75rem}.demografia-item output{display:block;font-size:1.5rem;font-weight:700;color:#0f766e}.demografia-item.editable input[type=number]{width:100%;font-size:1.25rem;font-weight:700;color:#0f766e;padding:.5rem .6rem;border:1px solid #cbd5e1;border-radius:6px}.demografia-item.editable input[type=number]:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 2px #eef2ff}.tema-chip.guardado{background:#ecfdf5;color:#065f46}.repertorio-input,.matricula-panel{display:flex;flex-direction:column;gap:.75rem}.matricula-panel h3{margin:0}.nota-regla{font-size:.875rem;color:#64748b;background:#f0fdf4;border-left:3px solid #22c55e;padding:.5rem .75rem;margin-bottom:1rem}.total-activos{margin-top:1rem;padding-top:.75rem;border-top:1px solid #e2e8f0}.obras-list{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}.obra-item label{display:flex;align-items:center;gap:.5rem;font-weight:400;cursor:pointer}.asistencia-grid{overflow-x:auto;-webkit-overflow-scrolling:touch}.asistencia-table{width:100%;border-collapse:collapse;font-size:.875rem}.asistencia-table th,.asistencia-table td{border:1px solid #e2e8f0;padding:.4rem .5rem;text-align:center}.asistencia-table th{background:#f1f5f9}.asistencia-table td:first-child{text-align:left;white-space:nowrap}.btn{padding:.6rem 1.2rem;border:none;border-radius:6px;font:inherit;font-weight:600;cursor:pointer}.btn-primary{background:#4f46e5;color:#fff}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#e2e8f0;color:#334155}.alert-success{background:#ecfdf5;border:1px solid #6ee7b7;color:#065f46;padding:1rem;border-radius:8px;margin-bottom:1rem}.alert-error{background:#fef2f2;border:1px solid #fca5a5;color:#991b1b;padding:1rem;border-radius:8px;margin-bottom:1rem}.estudiante-inactivo{color:#94a3b8}.estudiante-activo{color:#0f766e;font-weight:600}@media(max-width:768px){.app,.admin-layout{padding:1.5rem 1rem 3rem}.demografia-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media(max-width:640px){.app,.admin-layout{padding:1.25rem .85rem 2.5rem}.app-header h1,.admin-header h1,.admin-edit-header h2{font-size:1.4rem;line-height:1.25}.admin-header,.admin-edit-header,.reportes-lista-header,.reporte-detalle-header,.fechas-ensayo-header,.detalle-meta{flex-direction:column;align-items:stretch}.admin-header,.admin-edit-header{gap:.85rem}.admin-header-actions,.admin-acciones,.fechas-acciones{flex-wrap:wrap}.admin-header-actions .btn,.reportes-lista-header .btn{flex:1;min-width:0}.reportes-filtros{flex-direction:column;gap:.5rem}.periodo-selector{flex-wrap:wrap}.btn{min-height:44px}.nav-btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center}.app-nav{flex-wrap:wrap}.app-nav .nav-btn{flex:1 1 calc(50% - .5rem);text-align:center}.reporte-detalle-overlay{padding:0;align-items:flex-end}.reporte-detalle{max-width:100%;max-height:92vh;border-radius:16px 16px 0 0;padding:1.25rem}.reportes-tabla,.asistencia-table{font-size:.8rem}.reportes-tabla th,.reportes-tabla td{padding:.55rem .65rem}.demografia-grid{grid-template-columns:repeat(2,1fr)}.demografia-item output{font-size:1.25rem}.calendario-grid{gap:.25rem}.calendario-celda{font-size:.8rem}.reporte-mensual-form section{padding:1rem}}@media(max-width:380px){.demografia-grid{grid-template-columns:1fr}}
