.layout-container{min-height:100vh;display:flex;background:var(--bg)}.sidebar{position:fixed;left:0;top:0;height:100vh;background:var(--surface);transition:width .3s cubic-bezier(.4,0,.2,1);overflow:hidden;z-index:1000;box-shadow:var(--shadow-md);border-right:1px solid var(--border)}.sidebar.collapsed{width:72px}.sidebar.expanded{width:240px}.sidebar-logo{display:flex;align-items:center;justify-content:center;gap:12px;padding:18px 12px;border-bottom:1px solid var(--border)}.sidebar-logo-img{width:200px;height:200px;object-fit:contain;max-width:100%}.sidebar.expanded .sidebar-logo-img{width:200px;height:200px}.sidebar.collapsed .sidebar-logo-img{width:40px;height:40px}.logo-icon{font-size:28px;min-width:38px;display:flex;justify-content:center}.logo-text{white-space:nowrap;letter-spacing:.5px;font-size:16px}.nav-menu{display:flex;flex-direction:column;padding:8px 0}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;color:var(--text-secondary);transition:all .2s;position:relative;white-space:nowrap;text-decoration:none;cursor:pointer}.nav-item:hover{background-color:var(--surface-2);color:var(--text-primary)}.nav-item.active{background-color:#1d4ed814;color:var(--primary);border-left:3px solid var(--primary)}.nav-icon{min-width:38px;display:flex;justify-content:center;align-items:center}.nav-text{font-size:14px;font-weight:600}.sidebar.collapsed .nav-text{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .nav-item{justify-content:center;padding:12px 8px}.main-wrapper{flex:1;margin-left:72px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.main-wrapper.expanded{margin-left:240px}.dashboard-header{background:var(--surface);padding:14px 24px;box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border)}.header-content{display:flex;justify-content:space-between;align-items:center;gap:16px}.header-title{display:flex;align-items:center;gap:12px}.header-title h1{font-size:16px;color:var(--text-primary);font-weight:700;letter-spacing:.5px;margin:0}.header-brand span{display:block;font-size:12px;color:var(--text-secondary);margin-top:2px}.header-actions{display:flex;align-items:center;gap:14px}.user-role-badge{padding:6px 12px;background-color:var(--surface-2);color:var(--text-secondary);border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;border:1px solid var(--border)}.user-name{font-weight:600;color:var(--text-primary);font-size:14px}.icon-button{background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);width:34px;height:34px;border-radius:10px;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:pointer}.icon-button:hover{background:#eef2ff;color:var(--primary)}.sidebar-toggle{background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}.sidebar-toggle:hover{background:#eef2ff;color:var(--primary)}.main-content{flex:1;padding:24px;overflow-y:auto}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.login-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:480px;padding:40px;border:1px solid var(--border)}.login-header{text-align:center;margin-bottom:28px}.login-logo{width:380px;height:auto;margin-bottom:-45px;display:block;margin-left:auto;margin-right:auto}.login-header p{color:var(--text-secondary);font-size:18px;font-weight:600;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.form-group input{padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px;transition:all .2s}.password-field{position:relative;display:flex;align-items:center}.password-field input{padding-right:40px;width:100%}.toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;padding:4px;cursor:pointer}.toggle-password:hover{color:var(--primary)}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1d4ed81f}.form-group input:disabled{background-color:#f1f5f9;cursor:not-allowed}.error-message{padding:12px;background-color:#fee2e2;color:#991b1b;border-radius:8px;font-size:14px;border:1px solid #fecaca}.login-button{padding:14px;background-color:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:16px;font-weight:600;transition:all .2s;margin-top:8px}.login-button:hover:not(:disabled){background-color:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow)}.login-button:disabled{background-color:#94a3b8;cursor:not-allowed}.login-footer{margin-top:32px;text-align:center;padding-top:24px;border-top:1px solid var(--border)}.login-footer p{color:var(--text-secondary);font-size:13px}.dashboard-container{padding:0}.welcome-section{display:none}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:24px}.stat-card{background:var(--surface);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);transition:all .3s;border:1px solid var(--border)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-blue{border-left:4px solid #3b82f6}.stat-card-green{border-left:4px solid #10b981}.stat-card-orange{border-left:4px solid #f59e0b}.stat-card-purple{border-left:4px solid #8b5cf6}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.stat-icon{background:var(--surface-2);width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:12px;color:var(--primary)}.stat-badge{padding:4px 10px;background-color:var(--surface-2);color:var(--text-secondary);border-radius:12px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px}.stat-info{display:flex;flex-direction:column;gap:4px}.stat-value{font-size:32px;font-weight:700;color:var(--text-primary);line-height:1}.stat-info h3{font-size:14px;color:var(--text-secondary);font-weight:500}.info-panel{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.dashboard-panel{margin-bottom:24px}.panel-header{background:var(--surface-2);padding:14px 20px;border-bottom:1px solid var(--border)}.panel-header h3{font-size:16px;color:var(--text-primary);font-weight:600}.panel-body{padding:20px}.panel-body p{color:var(--text-secondary);line-height:1.8;margin-bottom:8px;font-size:14px}.panel-body p:last-child{margin-bottom:0}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:20px}.quick-action{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 16px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}.quick-action:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.alertas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.alerta-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:10px}.alerta-info{display:grid;gap:4px;color:var(--text-secondary)}.nuevo-estudiante-container{padding:32px;max-width:1200px;margin:0 auto}.form-header{margin-bottom:32px}.form-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.form-header p{color:var(--text-secondary);font-size:16px}.estudiante-form{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:32px;border:1px solid var(--border)}.form-section{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--border)}.form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section h2{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:24px}.foto-section{display:flex;justify-content:center;align-items:center;min-height:200px;padding:20px}.foto-placeholder{display:flex;flex-direction:column;align-items:center;gap:20px;padding:30px;border:2px dashed var(--border);border-radius:12px;background:var(--surface-2);width:100%;max-width:450px}.btn-camera{display:flex;align-items:center;gap:8px;padding:12px 24px;background-color:var(--primary);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-camera:hover{background-color:#2563eb;transform:translateY(-1px)}.btn-camera.btn-secondary{background-color:#fff;color:#3b82f6;border:2px solid #3b82f6}.btn-camera.btn-secondary:hover{background-color:#eff6ff}.botones-foto{display:flex;flex-direction:row!important;gap:10px;justify-content:center;align-items:center;width:100%}.camera-container{display:flex;flex-direction:column;gap:20px;align-items:center;width:100%}.camera-video{width:100%;max-width:640px;aspect-ratio:4 / 3;object-fit:cover;border-radius:12px;box-shadow:0 4px 12px #00000026;background:#1e293b;transform:scaleX(-1)}.camera-controls{display:flex;gap:12px}.btn-capture{display:flex;align-items:center;gap:8px;padding:12px 24px;background-color:#10b981;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-capture:hover:not(:disabled){background-color:#059669}.btn-capture:disabled{background-color:#94a3b8;cursor:not-allowed;opacity:.6}.btn-cancel{padding:12px 24px;background-color:#fff;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background-color:#f8fafc}.foto-preview{display:flex;flex-direction:column;gap:20px;align-items:center;width:100%}.foto-preview img{max-width:400px;width:100%;height:auto;border-radius:12px;box-shadow:0 4px 12px #00000026;border:3px solid #3b82f6}.foto-actions{display:flex;gap:16px;align-items:center;justify-content:center;flex-wrap:wrap}.btn-recapture{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:#f59e0b;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-recapture:hover{background-color:#d97706}.foto-ok{display:flex;align-items:center;gap:8px;padding:10px 20px;background-color:#d1fae5;color:#065f46;border-radius:8px;font-size:14px;font-weight:600}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:14px;font-weight:500;color:#1e293b}.form-group input,.form-group select{padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:15px;transition:all .2s;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled,.form-group select:disabled{background-color:#f1f5f9;cursor:not-allowed}.radio-group{display:flex;gap:24px;flex-wrap:wrap}.radio-label,.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:15px;color:#1e293b}.radio-label input[type=radio],.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.summary-section{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;padding:24px;border:2px solid #3b82f6}.summary-box{display:flex;flex-direction:column;gap:16px}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff;border-radius:8px}.summary-label{font-size:16px;font-weight:500;color:#475569}.summary-value{font-size:24px;font-weight:700;color:#1e40af}.error-message{padding:12px 16px;background-color:#fee2e2;color:#991b1b;border-radius:8px;font-size:14px;border:1px solid #fecaca;margin-bottom:20px}.habeas-section{margin-top:8px;padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2)}.habeas-text{margin:6px 0 0 26px;font-size:12px;color:var(--text-secondary)}.form-actions{display:flex;justify-content:flex-end;gap:16px;margin-top:32px;padding-top:24px;border-top:1px solid #e2e8f0}.btn-primary,.btn-secondary{padding:12px 32px;border-radius:8px;font-size:16px;font-weight:600;transition:all .2s;border:none;cursor:pointer}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-primary:disabled{background-color:#94a3b8;cursor:not-allowed}.btn-secondary{background-color:#fff;color:#475569;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background-color:#f8fafc;border-color:#cbd5e1}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.nuevo-estudiante-container{padding:16px}.estudiante-form{padding:20px}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:2px solid #e2e8f0;background:linear-gradient(135deg,#1e3a8a,#1e40af);border-radius:16px 16px 0 0}.modal-header h2{color:#fff;font-size:22px;font-weight:700;margin:0}.btn-close{background:#fff3;border:none;color:#fff;width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-close:hover{background:#ffffff4d;transform:scale(1.1)}.estudiante-info-header{display:flex;align-items:center;gap:16px;padding:20px 24px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.estudiante-avatar{width:64px;height:64px;border-radius:12px;object-fit:cover;border:3px solid #3b82f6}.estudiante-info-header h3{font-size:18px;font-weight:700;color:#1e293b;margin:0 0 4px}.estudiante-info-header p{font-size:14px;color:#64748b;margin:2px 0}.matricula-badge{display:inline-block;padding:4px 10px;background:#dbeafe;color:#1e40af;border-radius:6px;font-size:12px;font-weight:600;margin-top:4px}.modal-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;color:#334155;margin-bottom:8px;font-size:14px}.form-select,.form-input,.form-textarea{width:100%;padding:12px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:15px;font-family:inherit;transition:all .2s;background:#fff}.form-select:focus,.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input.readonly{background:#f1f5f9;color:#64748b;cursor:not-allowed}.form-textarea{resize:vertical;min-height:80px;text-transform:uppercase}.input-with-icon{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#94a3b8}.input-with-icon .form-input{padding-left:44px}.valor-formateado{margin-top:6px;font-size:18px;font-weight:700;color:#10b981}.help-text{display:block;margin-top:4px;color:#64748b;font-size:12px}.radio-group{display:flex;flex-direction:column;gap:12px}.radio-label{display:flex;align-items:center;gap:10px;padding:12px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s}.radio-label:hover{background:#f8fafc;border-color:#cbd5e1}.radio-label input[type=radio]{width:20px;height:20px;cursor:pointer;accent-color:#3b82f6}.radio-label input[type=radio]:checked+span{font-weight:600;color:#1e40af}.radio-label span{font-size:15px;color:#475569}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;font-weight:500}.modal-actions{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0}.btn-secondary,.btn-primary{flex:1;padding:12px 18px;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-secondary{background:#f8fafc;color:#334155;border:1px solid #cbd5e1}.btn-secondary:hover{background:#eef2f7}.btn-primary{background:#3b82f6;color:#fff;border:1px solid #2563eb}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.estudiantes-container{padding:32px;max-width:1400px;margin:0 auto}.search-section{margin-bottom:24px}.search-box{position:relative;max-width:600px}.search-input{width:100%;padding:14px 14px 14px 48px;border:1px solid var(--border);border-radius:12px;font-size:16px;transition:all .2s}.search-results{margin-top:12px}.results-count{font-size:14px;color:#64748b;font-weight:500}.estudiantes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.estudiante-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s ease;border:1px solid var(--border);overflow:hidden}.estudiante-card.collapsed{box-shadow:0 1px 3px #00000014}.estudiante-card.expanded{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.estudiante-card.collapsed:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.estudiante-card.collapsed .card-header{border-bottom:none}.estudiante-card.expanded .card-header{border-bottom:1px solid var(--border)}.estudiante-foto{flex-shrink:0}.estudiante-foto img{width:80px;height:80px;border-radius:12px;object-fit:cover;box-shadow:var(--shadow-sm)}.estudiante-info{flex:1;min-width:0;margin-right:12px}.estudiante-info h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.info-row .saldo{color:#f59e0b}.btn-definir{display:flex;align-items:center;gap:6px;padding:8px 16px;background-color:#10b981;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-definir:hover{background-color:#059669;transform:translateY(-1px)}.btn-ver{display:flex;align-items:center;gap:6px;padding:8px 16px;background-color:#fff;color:#3b82f6;border:1px solid #3b82f6;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-ver:hover{background-color:#3b82f6;color:#fff}.loading-container,.empty-state{text-align:center;padding:60px 20px;color:#64748b}.empty-state p{font-size:18px;margin-bottom:20px}.btn-clear{padding:10px 20px;background-color:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-clear:hover{background-color:#2563eb}.error-message{padding:16px 20px;background-color:#fee2e2;color:#991b1b;border-radius:12px;font-size:14px;border:1px solid #fecaca;margin-bottom:24px}.estudiantes-container .pagination .pagination-btn{padding:10px 20px;background-color:#3b82f6!important;color:#fff!important;border:none!important;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;min-width:120px}.estudiantes-container .pagination .pagination-btn:disabled{background-color:#cbd5e1!important;color:#475569!important;border:1px solid #94a3b8!important;opacity:1;cursor:not-allowed}.pagination-info{display:flex;flex-direction:column;align-items:center;gap:4px}.pagination-info span:first-child{font-size:16px;font-weight:600;color:#1e293b}.total-registros{font-size:13px;color:#64748b}@media (max-width: 768px){.estudiantes-container{padding:16px}.header-content{flex-direction:column;align-items:flex-start;gap:16px}.btn-nuevo{width:100%;justify-content:center}.estudiantes-grid{grid-template-columns:1fr}}.estudiante-detalle-container{padding:32px;max-width:1400px;margin:0 auto}.btn-back{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:15px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s}.btn-back:hover{background:var(--surface-2);border-color:var(--border)}.header-actions{display:flex;gap:12px}.btn-action{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--primary);border:none;border-radius:8px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s}.btn-action:hover{background:var(--primary-600);transform:translateY(-1px)}.info-principal{display:flex;gap:32px;align-items:center;background:var(--surface);padding:32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:24px;border:1px solid var(--border)}.foto-grande img{width:180px;height:180px;border-radius:16px;object-fit:cover;border:4px solid var(--primary);box-shadow:var(--shadow-sm)}.foto-placeholder-grande{width:180px;height:180px;border-radius:16px;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;color:#fff}.info-basica h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.info-basica .cedula{font-size:16px;color:#64748b;font-weight:500;margin-bottom:4px}.info-basica .matricula{font-size:14px;color:#94a3b8;font-weight:500;margin-bottom:12px}.detalle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.detalle-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0}.detalle-card h2{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:#1e293b;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.info-rows{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.info-row .label{display:flex;align-items:center;gap:6px;font-size:14px;color:#64748b;font-weight:500}.info-row .value{font-size:14px;color:#1e293b;font-weight:600;text-align:right}.badge-categoria{padding:6px 12px;background:#dbeafe;color:#1e40af;border-radius:8px;font-size:13px;font-weight:700}.saldo-pendiente{color:#f59e0b!important;font-size:16px!important}.progreso-bar{position:relative;width:100%;height:32px;background:#f1f5f9;border-radius:8px;overflow:hidden;margin-top:8px}.progreso-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);transition:width .3s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:12px}.progreso-practica{background:linear-gradient(90deg,#10b981,#34d399)}.progreso-text{position:absolute;top:50%;right:12px;transform:translateY(-50%);font-size:13px;font-weight:700;color:#1e293b;text-shadow:0 0 4px white}.btn-pago{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;margin-top:16px;background:#10b981;border:none;border-radius:8px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s}.btn-pago:hover{background:#059669;transform:translateY(-1px)}.badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-info{background-color:#dbeafe;color:#1e40af}.badge-primary{background-color:#e0e7ff;color:#3730a3}.badge-success{background-color:#d1fae5;color:#065f46}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-secondary{background-color:#f1f5f9;color:#475569}.badge-directo{background-color:#dbeafe;color:#1e40af}.badge-referido{background-color:#fef3c7;color:#92400e;max-width:100%}.telefono-ref{font-size:11px;opacity:.8}.origen-badge-container{margin:8px 0}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.error-container p{font-size:18px;color:#64748b}.historial-pagos-section{margin-top:20px;padding-top:20px;border-top:2px solid #e2e8f0}.historial-title{font-size:16px;font-weight:700;color:#1e293b;margin-bottom:16px}.historial-lista{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.pago-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px;transition:all .2s}.pago-item:hover{background:#f1f5f9;border-color:#cbd5e1}.pago-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.pago-fecha{display:flex;align-items:center;gap:6px;font-size:13px;color:#64748b;font-weight:500}.pago-monto{font-size:15px;font-weight:700;color:#10b981}.pago-metodo-simple{margin-top:4px}.badge-metodo{display:inline-block;padding:4px 10px;background:#dbeafe;color:#1e40af;border-radius:6px;font-size:12px;font-weight:600}.pago-mixto-desglose{margin-top:8px;padding:8px;background:#fff;border-radius:6px}.mixto-label{font-size:11px;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;display:block}.detalle-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid #f1f5f9}.detalle-item:last-child{border-bottom:none}.detalle-metodo{flex:0 0 120px;font-size:12px;font-weight:600;color:#475569}.detalle-monto{flex:1;font-size:13px;font-weight:700;color:#10b981}.detalle-ref{font-size:11px;color:#94a3b8;font-style:italic}@media (max-width: 768px){.estudiante-detalle-container{padding:16px}.detalle-header{flex-direction:column;gap:16px;align-items:flex-start}.info-principal{flex-direction:column;text-align:center}.detalle-grid{grid-template-columns:1fr}.info-row{flex-direction:column;align-items:flex-start;gap:4px}.info-row .value{text-align:left}}.caja-container{padding:24px;max-width:1400px;margin:0 auto}.caja-header{margin-bottom:24px}.caja-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0}.loading{display:flex;justify-content:center;align-items:center;height:400px;font-size:18px;color:#6b7280}.caja-cerrada-card{background:var(--surface);border-radius:12px;padding:48px;text-align:center;box-shadow:var(--shadow-sm);max-width:500px;margin:100px auto;border:1px solid var(--border)}.icon-warning{color:#f59e0b;margin-bottom:24px}.caja-cerrada-card h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.caja-cerrada-card p{color:var(--text-secondary);margin-bottom:32px}.caja-resumen-grid-main{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}@media (max-width: 1024px){.caja-resumen-grid-main{grid-template-columns:1fr}}.stat-card{background:var(--surface);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:16px;transition:transform .2s,box-shadow .2s;border:1px solid var(--border)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card.highlight{background:linear-gradient(135deg,#1d4ed8,#1e40af);color:#fff}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center}.stat-label{font-size:14px;color:var(--text-secondary);margin:0 0 4px}.stat-card.highlight .stat-label{color:#ffffffe6}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.stat-value.success{color:#16a34a}.stat-value.danger{color:#dc2626}.stat-value-large{font-size:32px;font-weight:700;color:#fff;margin:0}.stat-sublabel{font-size:12px;color:var(--text-secondary);margin-top:4px}.stat-card.highlight .stat-sublabel{color:#fffc}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-bottom:24px}.stat-small{background:var(--surface);border-radius:var(--radius-md);padding:12px 16px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.stat-small-label{font-size:13px;color:var(--text-secondary);font-weight:500}.stat-small-value{font-size:16px;font-weight:700;color:var(--text-primary)}.stat-small-value.success{color:#16a34a}.stat-small-value.danger{color:#dc2626}.seccion-caja-fisica{margin-bottom:32px;padding:24px;background:#f8fafc;border-radius:var(--radius-lg);border:1px solid #e2e8f0}.metodos-digitales-section{margin-bottom:32px;padding:24px;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border)}.metodo-grupo{margin-bottom:24px}.metodo-grupo:last-child{margin-bottom:0}.metodo-grupo-titulo{font-size:16px;font-weight:600;color:var(--text-secondary);margin:0 0 12px;padding-left:8px;border-left:4px solid var(--primary)}.section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.section-title-main{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 12px;display:flex;align-items:center;gap:8px}.section-title-main.collapsable{cursor:pointer;-webkit-user-select:none;user-select:none;padding:12px;border-radius:8px;transition:all .2s;justify-content:space-between;background:#f8fafc}.section-title-main.collapsable:hover{background:#f1f5f9;transform:translateY(-1px)}.chevron-icon{transition:transform .3s ease;flex-shrink:0}.chevron-icon.rotated{transform:rotate(-90deg)}.section-subtitle-white{font-size:14px;color:var(--text-secondary);margin:0 0 20px;font-weight:500;padding:8px 12px;background:var(--surface-2);border-radius:6px;border-left:3px solid var(--primary)}.metodos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#374151;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-weight:500}.pago-mixto-container{border:2px dashed #e5e7eb;border-radius:8px;padding:16px;margin-top:12px;background:#f9fafb}.detalle-pago-row{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start}.btn-icon-danger{background:#fee2e2;color:#dc2626;border:none;border-radius:6px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-icon-danger:hover{background:#fecaca;transform:scale(1.05)}.btn-secondary-small{background:#fff;color:#4b5563;border:1px solid #d1d5db;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;margin-bottom:12px}.btn-secondary-small:hover{background:#f9fafb;border-color:#9ca3af}.total-mixto{background:#fff;border:2px solid #10b981;border-radius:8px;padding:12px 16px;text-align:center;margin-top:12px}.total-mixto strong{font-size:18px;color:#059669}@media (max-width: 1024px){.metodos-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.metodos-grid{grid-template-columns:1fr}}.metodo-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 3px #0000001a;border-left:4px solid #e5e7eb;transition:transform .2s,box-shadow .2s}.metodo-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.metodo-card.nequi{border-left-color:#ff0080}.metodo-card.daviplata{border-left-color:#e63946}.metodo-card.transferencia{border-left-color:#2563eb}.metodo-card.tarjetas{border-left-color:#f59e0b}.metodo-card.credismart{border-left-color:#8b5cf6;background:#faf5ff}.metodo-card.sistecredito{border-left-color:#06b6d4;background:#ecfeff}.metodo-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.metodo-icon{font-size:24px}.metodo-nombre{font-size:14px;font-weight:600;color:#6b7280}.metodo-monto{font-size:22px;font-weight:700;color:#1f2937;margin:0}.metodo-detalle{font-size:11px;color:#9ca3af;margin:4px 0 0}.creditos-section{margin-bottom:24px;padding:20px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.metodo-card-total{background:#1d4ed8;border-radius:12px;padding:16px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;box-shadow:0 4px 6px #0000001a}.metodo-total-label{font-size:12px;font-weight:700;color:#ffffffe6;text-transform:uppercase;letter-spacing:.5px;margin:0}.metodo-total-monto{font-size:26px;font-weight:800;color:#fff;margin:0}.section-subtitle{font-size:14px;color:var(--text-secondary);margin:0 0 16px;font-weight:500;background:var(--surface-2);padding:8px 12px;border-radius:6px;border-left:3px solid var(--primary)}.resumen-general{margin-bottom:32px;padding:24px;background:#f8fafc;border-radius:16px;border:1px solid #e2e8f0}.stat-summary{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 4px #0000000d;transition:transform .2s,box-shadow .2s}.stat-summary:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.stat-summary-icon{font-size:36px;line-height:1}.stat-summary-content{flex:1;display:flex;flex-direction:column;gap:4px}.stat-summary-label{font-size:13px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.stat-summary-value{font-size:24px;font-weight:700;color:#1f2937}.stat-summary-value-large{font-size:32px;font-weight:800;color:#7c3aed}.stat-summary-detalle{font-size:11px;color:#9ca3af}.modal-large{max-width:800px!important;max-height:90vh;overflow-y:auto}.arqueo-transacciones{background:#f8fafc;border:2px solid #cbd5e1;border-radius:12px;padding:20px;margin-bottom:24px}.arqueo-transacciones h4{font-size:18px;font-weight:700;color:#1e293b;margin:0 0 16px;text-align:center}.transacciones-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.transaccion-grupo{background:#fff;border-radius:8px;padding:16px;border:1px solid #e2e8f0}.transaccion-grupo h5{font-size:14px;font-weight:700;color:#475569;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.transaccion-detalle{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px}.transaccion-detalle span{color:#64748b;font-weight:500}.transaccion-detalle strong{color:#1e293b;font-weight:700}.transaccion-total{display:flex;justify-content:space-between;align-items:center;padding:12px;margin-top:12px;background:#f1f5f9;border-radius:6px;font-size:14px;font-weight:700}.transaccion-total span{color:#334155}.transaccion-total strong{color:#0f172a;font-size:16px}.transaccion-grupo.resumen{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-color:#a78bfa}.arqueo-resumen{background:#f0fdf4;border:2px solid #22c55e;border-radius:12px;padding:20px;margin-bottom:24px}.arqueo-resumen h4{font-size:16px;font-weight:700;color:#166534;margin:0 0 16px}.arqueo-grid{display:grid;gap:12px}.arqueo-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#fff;border-radius:8px}.arqueo-item.highlight{background:linear-gradient(135deg,#166534,#22c55e);padding:16px}.arqueo-label{font-size:14px;font-weight:600;color:#4b5563}.arqueo-item.highlight .arqueo-label{color:#fff;font-size:15px}.arqueo-value{font-size:18px;font-weight:700;color:#1f2937}.arqueo-value-large{font-size:28px;font-weight:800;color:#fff}.arqueo-nota{font-size:12px;color:#166534;margin:16px 0 0;padding:8px 12px;background:#fff;border-radius:6px;border-left:3px solid #22c55e}.arqueo-conteo{margin-bottom:24px}.arqueo-conteo h4{font-size:16px;font-weight:700;color:#1f2937;margin:0 0 12px}.form-input-large{font-size:24px;font-weight:700;text-align:center;padding:16px;border:3px solid #3b82f6}.form-input-large:focus{border-color:#1d4ed8;box-shadow:0 0 0 4px #3b82f61a}.arqueo-diferencia{margin-bottom:24px}.diferencia-card{padding:20px;border-radius:12px;text-align:center}.diferencia-card.exacto{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:3px solid #10b981}.diferencia-card.sobrante{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:3px solid #3b82f6}.diferencia-card.faltante{background:linear-gradient(135deg,#fee2e2,#fecaca);border:3px solid #ef4444}.diferencia-card h4{font-size:20px;font-weight:800;margin:0 0 12px}.diferencia-card.exacto h4{color:#065f46}.diferencia-card.sobrante h4{color:#1e40af}.diferencia-card.faltante h4{color:#991b1b}.diferencia-monto{font-size:36px;font-weight:900;margin:8px 0}.diferencia-card.exacto .diferencia-monto{color:#065f46}.diferencia-card.sobrante .diferencia-monto{color:#1e40af}.diferencia-card.faltante .diferencia-monto{color:#991b1b}.diferencia-detalle{font-size:13px;font-weight:600;color:#4b5563;margin:8px 0 0}.btn-danger{background-color:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-danger:disabled{background-color:#9ca3af;cursor:not-allowed}.btn-action.btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c)}.btn-action.btn-danger:hover{background:linear-gradient(135deg,#b91c1c,#991b1b)}text-transform: uppercase; letter-spacing: .5px; } .metodo-monto{font-size:24px;font-weight:700;color:#16a34a;margin:0}.actions-bar{display:flex;gap:12px;margin-bottom:24px}.btn-action{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:10px 16px;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.btn-action:hover{background:#f9fafb;border-color:#667eea;color:#667eea}.main-content-grid{display:grid;gap:24px}.search-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.search-section h2{font-size:20px;font-weight:600;color:#1f2937;margin:0 0 20px}.search-bar{display:flex;gap:12px;margin-bottom:24px}.search-input{flex:1;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-search{padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;cursor:pointer;transition:background .2s}.btn-search:hover:not(:disabled){background:#5568d3}.btn-search:disabled{opacity:.6;cursor:not-allowed}.estudiante-info-card{border:1px solid #e5e7eb;border-radius:12px;padding:20px;background:#f9fafb}.estudiante-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.estudiante-foto{width:80px;height:80px;border-radius:8px;object-fit:cover;border:2px solid white;box-shadow:0 2px 4px #0000001a}.estudiante-datos{flex:1}.estudiante-datos h3{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px}.estudiante-datos p{font-size:14px;color:#6b7280;margin:4px 0}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;margin-top:8px}.badge-verde{background:#dcfce7;color:#16a34a}.badge-azul{background:#dbeafe;color:#2563eb}.badge-amarillo{background:#fef3c7;color:#d97706}.badge-rojo{background:#fee2e2;color:#dc2626}.badge-gris{background:#f3f4f6;color:#6b7280}.financial-info{margin-bottom:20px}.info-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #e5e7eb}.info-row:last-child{border-bottom:none}.info-row.highlight{background:#fff;padding:12px 16px;border-radius:8px;margin:12px 0;border:none;box-shadow:0 1px 3px #0000001a}.info-row span{font-size:14px;color:#6b7280}.info-row strong{font-size:14px;color:#1f2937}.info-row strong.success{color:#16a34a}.info-row strong.danger{color:#dc2626}.pago-form{background:#fff;border-radius:8px;padding:20px}.pago-form h4{font-size:16px;font-weight:600;color:#1f2937;margin:0 0 16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-input,.form-select{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.form-input:focus,.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-primary-large{padding:14px 32px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary-large:hover{background:#5568d3}.btn-primary-full{width:100%;padding:12px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary-full:hover:not(:disabled){background:#5568d3}.btn-primary-full:disabled{opacity:.6;cursor:not-allowed}.btn-primary{padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#5568d3}.btn-secondary{padding:10px 20px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f9fafb}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:background .2s}.btn-icon:hover{background:#f3f4f6}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h3{font-size:18px;font-weight:600;color:#1f2937;margin:0}.modal-body{padding:24px}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px;border-top:1px solid #e5e7eb}.modal-footer .btn-secondary,.modal-footer .btn-danger{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:10px;font-size:14px;font-weight:600;min-width:120px;transition:all .2s}@media (max-width: 768px){.caja-resumen-grid{grid-template-columns:1fr}.estudiante-header{flex-direction:column;align-items:center;text-align:center}.modal-box{margin:16px;max-width:calc(100% - 32px)}}.caja-fuerte-container{padding:2rem;max-width:1600px;margin:0 auto;background:var(--bg);min-height:100vh}.caja-fuerte-resumen{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:20px}.resumen-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.resumen-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.resumen-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.resumen-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#eef2ff;color:var(--primary)}.resumen-icon.success{background:#dcfce7;color:var(--success)}.resumen-icon.primary{background:#dbeafe;color:var(--primary)}.resumen-icon.warning{background:#fef3c7;color:var(--warning)}.resumen-card h3{margin:0 0 8px;font-size:14px;color:var(--text-secondary)}.resumen-valor{font-size:20px;font-weight:700;color:var(--text-primary)}.resumen-subdetalle{margin-top:10px;padding-top:8px;border-top:1px dashed #e2e8f0;display:flex;flex-direction:column;gap:6px}.detalle-row{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:#475569}.detalle-row strong{color:#0f172a;font-weight:600}.caja-fuerte-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:20px}.caja-fuerte-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm);margin-bottom:16px}.caja-fuerte-section h2{margin:0 0 12px;font-size:16px;color:var(--text-primary)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.form-grid input,.form-grid select,.filtros input,.filtros select{padding:10px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface)}.section-actions{display:flex;gap:10px;margin-top:12px}.inventario-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.inventario-item{display:flex;align-items:center;justify-content:space-between;gap:4px;border:1px solid var(--border);border-radius:var(--radius-md);padding:8px;background:var(--surface-2)}.denom-control{display:flex;align-items:center;gap:2px;min-width:70px;justify-content:flex-end}.denom-control input{width:48px;text-align:center}.inventario-item.readonly{background:var(--surface-2);justify-content:space-between}.inventario-item .cantidad{font-weight:600;color:var(--text-secondary)}.inventario-item .denom{font-weight:600;color:var(--text-primary);min-width:56px}.inventario-total{margin-top:12px;font-weight:700}.mov-denoms{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.mov-denoms h3{margin:0 0 10px;font-size:14px;color:var(--text-primary)}.filtros{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:12px}.tabla-movimientos table{width:100%;border-collapse:collapse}.tabla-movimientos th,.tabla-movimientos td{border-bottom:1px solid var(--border);padding:10px;text-align:left;font-size:14px}.tabla-movimientos thead th{background:var(--surface-2);color:var(--text-secondary)}.tabla-movimientos .acciones{display:flex;gap:8px}.no-data{text-align:center;color:var(--text-secondary);padding:16px}.historial-cajas-container{padding:2rem;max-width:1400px;margin:0 auto}.historial-header{margin-bottom:24px}.header-title-section{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.header-title-section svg{color:var(--primary)}.historial-header h1{font-size:28px;color:var(--text-primary);margin:0}.header-subtitle{color:var(--text-secondary);margin:0;font-size:14px}.filtros-section{display:flex;gap:1rem;align-items:flex-end;margin-bottom:24px;padding:1.5rem;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.filtro-grupo{display:flex;flex-direction:column;gap:.5rem}.filtro-grupo label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.input-fecha{padding:.625rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;min-width:180px}.input-fecha:focus{outline:none;border-color:var(--primary)}.btn-filtrar,.btn-limpiar{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-filtrar{background:var(--primary);color:#fff}.btn-filtrar:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-limpiar{background:var(--surface-2);color:var(--text-primary)}.tabla-container{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--border)}.tabla-historial{width:100%;border-collapse:collapse;font-size:.875rem}.tabla-historial thead{background:var(--primary-color);color:#fff}.tabla-historial th{padding:1rem;text-align:left;font-weight:600;white-space:nowrap}.tabla-historial tbody tr{border-bottom:1px solid var(--border-color);transition:background .2s}.tabla-historial tbody tr:hover{background:var(--gray-50)}.tabla-historial td{padding:1rem;white-space:nowrap}.monto-positivo{color:var(--success-color);font-weight:600}.monto-efectivo{color:var(--primary-color);font-weight:600}.diferencia{font-weight:600}.diferencia.exacta{color:var(--success-color)}.diferencia.sobrante{color:var(--info-color)}.diferencia.faltante{color:var(--danger-color)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-cerrada{background:var(--success-light);color:var(--success-dark)}.badge-abierta{background:var(--warning-light);color:var(--warning-dark)}.btn-ver-detalle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-ver-detalle:hover{background:var(--primary-hover);transform:translateY(-1px)}.loading-container,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:var(--text-muted)}.empty-state svg{color:var(--text-muted);margin-bottom:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content-historial{background:#fff;border-radius:12px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header-historial{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:#fff;z-index:10}.modal-header-historial h2{margin:0;color:var(--text-dark);font-size:1.5rem}.btn-cerrar-modal{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s}.btn-cerrar-modal:hover{background:var(--gray-100);color:var(--text-dark)}.modal-body-historial{padding:1.5rem}.seccion-detalle{margin-bottom:2rem;padding:1.5rem;background:var(--gray-50);border-radius:8px}.seccion-detalle h3{margin:0 0 1rem;color:var(--text-dark);font-size:1.125rem;display:flex;align-items:center;gap:.5rem}.seccion-colapsable h3{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s}.seccion-colapsable h3:hover{color:var(--primary-color)}.titulo-colapsable{display:flex;justify-content:space-between;align-items:center}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.875rem;color:var(--text-muted);font-weight:500}.info-value{font-size:1rem;color:var(--text-dark);font-weight:600}.info-value.destacado{color:var(--primary-color);font-size:1.125rem}.transacciones-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.metodo-grupo{background:#fff;padding:1rem;border-radius:6px;border:1px solid var(--border-color)}.metodo-grupo h4{margin:0 0 .75rem;color:var(--text-dark);font-size:.875rem;font-weight:600;text-transform:uppercase;border-bottom:2px solid var(--primary-color);padding-bottom:.5rem}.metodo-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.875rem}.metodo-item span:first-child{color:var(--text-muted)}.metodo-item .monto{font-weight:600;color:var(--text-dark)}.metodo-item .monto.negativo{color:var(--danger-color)}.seccion-arqueo{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.seccion-arqueo h3{color:#fff}.arqueo-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.arqueo-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#ffffff1a;border-radius:6px}.arqueo-item.full-width{grid-column:1 / -1;background:#fff3}.arqueo-label{font-size:.875rem;opacity:.9}.arqueo-value{font-size:1.25rem;font-weight:700}.arqueo-value.destacado{font-size:1.5rem}.diferencia-valor{font-size:1.5rem!important}.diferencia-valor.exacta{color:#4ade80}.diferencia-valor.sobrante{color:#60a5fa}.diferencia-valor.faltante{color:#f87171}.seccion-totales{background:#fff;border:2px solid var(--primary-color)}.total-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.total-item:last-child{border-bottom:none}.total-item span:first-child{font-weight:600;color:var(--text-dark)}.total-valor{font-size:1.125rem;font-weight:700}.total-valor.positivo{color:var(--success-color)}.total-valor.negativo{color:var(--danger-color)}.destacado-total{background:var(--primary-light);padding:1rem!important;margin:-1.5rem -1.5rem 0;border-radius:0 0 8px 8px}.destacado-total span{color:var(--primary-color)}.observacion-item{margin-bottom:1rem}.observacion-item:last-child{margin-bottom:0}.observacion-item strong{display:block;margin-bottom:.5rem;color:var(--text-dark)}.observacion-item p{margin:0;padding:.75rem;background:#fff;border-left:3px solid var(--primary-color);border-radius:4px;color:var(--text-muted)}.acciones-modal{display:flex;justify-content:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.btn-pdf{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--danger-color);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-pdf:hover:not(:disabled){background:var(--danger-hover);transform:translateY(-2px);box-shadow:0 4px 12px #dc26264d}.btn-pdf:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1200px){.info-grid,.transacciones-grid{grid-template-columns:1fr}}@media (max-width: 768px){.historial-cajas-container{padding:1rem}.filtros-section{flex-direction:column;align-items:stretch}.input-fecha{min-width:100%}.tabla-container{overflow-x:auto}.modal-content-historial{width:95%;max-height:95vh}.arqueo-grid{grid-template-columns:1fr}}.reportes-container{padding:2rem;max-width:1600px;margin:0 auto;background:var(--bg);min-height:100vh}.reportes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:1.5rem;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.header-titulo{display:flex;align-items:center;gap:1rem}.header-titulo svg{color:var(--primary)}.header-titulo h1{margin:0;font-size:28px;color:var(--text-primary);font-weight:700}.header-titulo p{margin:0;color:var(--text-secondary);font-size:.875rem}.btn-exportar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.reportes-actions{display:flex;align-items:center;gap:10px}.btn-exportar.secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-exportar.secondary:hover:not(:disabled){background:var(--surface-2);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-exportar:hover:not(:disabled){background:var(--primary-600);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-exportar:disabled{opacity:.5;cursor:not-allowed}.filtros-periodo{background:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:24px;border:1px solid var(--border)}.filtros-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:var(--text-primary)}.filtros-header h3{margin:0;font-size:1.125rem;font-weight:600}.filtros-botones{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.filtro-btn{padding:.625rem 1.25rem;background:var(--surface-2);border:2px solid transparent;border-radius:8px;color:var(--text-secondary);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s}.filtro-btn:hover:not(:disabled){background:#eef2ff}.filtro-btn.activo{background:var(--primary);color:#fff;border-color:var(--primary)}.filtro-btn:disabled{opacity:.5;cursor:not-allowed}.filtros-personalizado{display:flex;gap:1rem;align-items:flex-end;padding:1rem;background:var(--surface-2);border-radius:var(--radius-md);margin-bottom:1rem;border:1px solid var(--border)}.filtro-fecha{display:flex;flex-direction:column;gap:.5rem}.filtro-fecha label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.filtro-fecha input{padding:.625rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem}.filtro-fecha input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1d4ed81f}.btn-aplicar-filtros{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.btn-aplicar-filtros:hover:not(:disabled){background:var(--primary-600)}.btn-aplicar-filtros:disabled{opacity:.5;cursor:not-allowed}.filtro-comparar{border-top:1px solid var(--border);padding-top:1rem}.filtro-comparar label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-secondary);font-size:.875rem;font-weight:500}.filtro-comparar input[type=checkbox]{width:18px;height:18px;cursor:pointer}.kpis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:24px}.kpi-card{background:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s;border:1px solid var(--border)}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.kpi-icono{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px}.kpi-titulo{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.kpi-valor{font-size:2rem;font-weight:700;color:#111827;margin-bottom:.75rem;display:flex;align-items:baseline;gap:.25rem}.kpi-unidad{font-size:1.25rem;font-weight:600;color:#6b7280}.kpi-cambio{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;padding:.5rem;border-radius:6px}.kpi-cambio-texto{color:#6b7280;font-weight:400;font-size:.75rem}.tendencia-positiva{background:#d1fae5;color:#065f46}.tendencia-negativa{background:#fee2e2;color:#991b1b}.tendencia-neutral{background:#f3f4f6;color:#374151}.graficos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.grafico-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.grafico-grande{grid-column:span 2}.grafico-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.grafico-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#111827}.grafico-subtitle{font-size:14px;color:var(--text-secondary)}.grafico-stats{display:flex;gap:1.5rem;font-size:.875rem}.grafico-stats span{color:#6b7280;font-weight:500}.loading-estado,.error-estado{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;min-height:400px}.loading-estado p,.error-estado p{margin-top:1rem;color:#6b7280;font-size:1.125rem}.error-estado svg{color:#ef4444}.spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 1200px){.graficos-grid{grid-template-columns:1fr}.grafico-grande{grid-column:span 1}}@media (max-width: 768px){.reportes-container{padding:1rem}.reportes-header{flex-direction:column;gap:1rem;align-items:flex-start}.header-titulo h1{font-size:1.5rem}.kpis-grid{grid-template-columns:1fr}.filtros-botones{flex-direction:column}.filtro-btn{width:100%}.filtros-personalizado{flex-direction:column;align-items:stretch}.btn-aplicar-filtros{width:100%;justify-content:center}}.tabla-estudiantes-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-top:1.5rem}.tabla-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.tabla-titulo{display:flex;align-items:center;gap:.75rem;color:#111827}.tabla-titulo svg{color:#2563eb}.tabla-titulo h3{margin:0;font-size:1.125rem;font-weight:600}.tabla-count{background:#f3f4f6;padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:600;color:#374151}.tabla-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#9ca3af}.tabla-empty svg{margin-bottom:1rem;opacity:.5}.tabla-empty p{margin:0;color:#6b7280}.tabla-scroll{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb}.tabla-estudiantes{width:100%;border-collapse:collapse;font-size:.875rem}.tabla-estudiantes thead{background:#f9fafb}.tabla-estudiantes th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;white-space:nowrap}.tabla-estudiantes td{padding:.875rem 1rem;border-bottom:1px solid #f3f4f6;color:#1f2937}.tabla-estudiantes tbody tr:hover{background:#f9fafb}.tabla-estudiantes tbody tr:last-child td{border-bottom:none}.td-nombre{font-weight:500;color:#111827}.td-fecha{color:#6b7280;font-size:.8125rem}.td-monto{font-weight:600;font-family:Courier New,monospace;text-align:right}.td-monto-success{color:#059669}.td-concepto{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-referido{font-style:italic;color:#6b7280}.badge{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge-primary{background:#dbeafe;color:#1e40af}.badge-secondary{background:#f3f4f6;color:#4b5563}.badge-success{background:#d1fae5;color:#065f46}.badge-danger{background:#fee2e2;color:#991b1b}.badge-warning{background:#fef3c7;color:#92400e}.badge-info{background:#e0f2fe;color:#075985}.badge-category{background:#f3e8ff;color:#6b21a8;font-weight:700}.badge-referido{background:#fef9c3;color:#854d0e}.badge-directo{background:#dbeafe;color:#1e40af}.badge-mixto{background:linear-gradient(135deg,#dbeafe,#fef3c7);color:#1e40af}.badge-nequi{background:#ffe4e6;color:#be123c}.badge-daviplata{background:#fee2e2;color:#991b1b}.saldo-pendiente{color:#dc2626;font-weight:600}.saldo-pagado{color:#16a34a;font-weight:600}.text-muted{color:#9ca3af;font-style:italic}.ranking-referidos-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-top:2rem}.ranking-header-clickable{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;cursor:pointer;transition:background-color .2s;border-radius:12px}.ranking-header-clickable:hover{background:#f9fafb}.ranking-header-content{flex:1}.ranking-titulo{display:flex;align-items:center;gap:.75rem;color:#1f2937;margin-bottom:.5rem}.ranking-titulo svg{color:#f59e0b}.ranking-titulo h3{margin:0;font-size:1.25rem;font-weight:700}.ranking-count-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;background:#f59e0b;color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;margin-left:.5rem}.ranking-descripcion{color:#6b7280;font-size:.875rem;margin:0}.collapse-btn{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.collapse-btn:hover{background:#f3f4f6;color:#111827}.ranking-podio{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin:0 2rem 1.5rem}.podio-item{background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #e5e7eb;border-radius:10px;padding:1rem;position:relative;transition:all .3s ease}.podio-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.podio-posicion-1{border-color:gold;background:linear-gradient(135deg,#fffbeb,#fff)}.podio-posicion-2{border-color:silver;background:linear-gradient(135deg,#f9fafb,#fff)}.podio-posicion-3{border-color:#cd7f32;background:linear-gradient(135deg,#fef3c7,#fff)}.podio-medalla{position:absolute;top:-10px;right:1rem;background:#fff;border:2px solid var(--color-medalla);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:0 4px 12px #00000026}.podio-contenido{margin-top:.75rem}.podio-nombre{font-size:1rem;font-weight:700;color:#111827;margin:0 0 .375rem}.podio-telefono{display:flex;align-items:center;gap:.375rem;color:#6b7280;font-size:.8125rem;margin-bottom:.75rem}.podio-stats{display:flex;gap:1rem;margin:.75rem 0;padding:.75rem;background:#fff9;border-radius:6px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.125rem;flex:1}.stat-item svg{color:#2563eb;width:14px;height:14px}.stat-valor{font-size:1rem;font-weight:700;color:#111827}.stat-label{font-size:.625rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.podio-detalles{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.detalle-badge{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:600}.detalle-badge svg{width:12px;height:12px}.ranking-lista{margin:1rem 2rem 2rem;overflow-x:auto}.ranking-table{width:100%;border-collapse:collapse}.ranking-table thead{background:#f9fafb}.ranking-table th{padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;border-bottom:2px solid #e5e7eb}.ranking-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.ranking-table tbody tr:hover{background:#f9fafb}.ranking-table td{padding:1rem;color:#374151}.td-posicion{font-weight:600;text-align:center}.badge-posicion{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f3f4f6;color:#6b7280;border-radius:50%;font-weight:700;font-size:.875rem}.td-nombre-ref{font-weight:600;color:#111827}.td-telefono{color:#6b7280;font-size:.875rem}.td-count{text-align:center;font-weight:500}.td-fecha-small{color:#6b7280;font-size:.8125rem}.ranking-empty{padding:4rem 2rem;text-align:center;color:#9ca3af;display:flex;flex-direction:column;align-items:center;gap:1rem}.ranking-empty svg{opacity:.3}.ranking-empty p{font-size:1rem;margin:0}@media (max-width: 768px){.ranking-podio{grid-template-columns:1fr}.ranking-table{font-size:.8125rem}.ranking-table th,.ranking-table td{padding:.625rem .75rem}}.tablas-estudiantes-grid{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}.tabla-empty{padding:4rem 2rem;text-align:center;color:#9ca3af;display:flex;flex-direction:column;align-items:center;gap:1rem}.tabla-empty svg{opacity:.3}.tabla-empty p{font-size:1rem;margin:0}@media (max-width: 768px){.tabla-scroll{border-radius:6px}.tabla-estudiantes{font-size:.8125rem}.tabla-estudiantes th,.tabla-estudiantes td{padding:.625rem .75rem}}.alertas-container{padding:20px}.alertas-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.alertas-header h2{font-size:28px;font-weight:700;color:var(--text-primary);margin:0}.alertas-filter{display:flex;align-items:center;gap:8px}.alertas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.alertas-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:transform .2s ease,box-shadow .2s ease}.alertas-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.alertas-list{margin-top:12px;display:flex;flex-direction:column;gap:10px}.alerta-item{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2)}.alerta-meta{font-size:.85rem;color:var(--text-secondary);margin-top:4px}.alertas-empty,.alertas-loading,.alertas-error{padding:8px 0;color:var(--text-secondary)}.alertas-error{color:#b91c1c}.cierre-container{padding:20px}.cierre-header{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.cierre-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.cierre-fechas{display:flex;align-items:center;gap:8px}.cierre-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:16px}.cierre-card{background:var(--surface);padding:14px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:transform .2s ease,box-shadow .2s ease}.cierre-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.cierre-label{color:var(--text-secondary);font-size:.9rem}.cierre-value{font-size:1.2rem;font-weight:600;margin-top:6px}.cierre-table table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border)}.cierre-table th,.cierre-table td{padding:10px;border-bottom:1px solid var(--border);text-align:left}.cierre-empty,.cierre-loading,.cierre-error{padding:8px 0;color:var(--text-secondary)}.cierre-error{color:#b91c1c}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content-large{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-md);border:1px solid var(--border)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--border);background:var(--surface-2)}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.btn-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.btn-close:hover{background:var(--surface-2);color:var(--text-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;font-family:inherit}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e0e0e0;margin:0 -1.5rem -1.5rem;background:#f8f9fa}.btn-cancel{padding:.75rem 1.25rem;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;color:#334155}.btn-cancel:hover{background:#eef2f7}.btn-primary{padding:.75rem 1.25rem;background:#3b82f6;color:#fff;border:1px solid #2563eb;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-primary:hover:not(:disabled){background:#2563eb}@media (max-width: 640px){.modal-content-large{max-width:100%;border-radius:0;max-height:100vh}.form-row{grid-template-columns:1fr}.categorias-checkbox-grid{grid-template-columns:repeat(2,1fr)}.modal-header,.form-instructor,.form-actions{padding-left:1rem;padding-right:1rem}}.foto-section{min-height:400px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border-radius:var(--radius-lg);padding:2rem}.btn-camera{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:var(--primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s}.btn-camera:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-camera.btn-secondary{background:var(--surface);color:var(--primary);border:2px solid var(--primary)}.btn-camera.btn-secondary:hover{background:var(--surface-2);box-shadow:var(--shadow-sm)}.foto-preview{display:flex;flex-direction:column;align-items:center;gap:1rem}.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--surface);color:var(--primary);border:2px solid var(--primary);border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-secondary:hover{background:var(--surface-2);border-color:var(--primary-600)}.documento-upload-group{background:var(--surface-2);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;border:2px dashed var(--border);transition:border-color .2s}.documento-upload-group:hover{border-color:#667eea}.documento-label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#333;margin-bottom:.75rem;font-size:.95rem}.documento-label svg{color:#667eea}.documento-action{display:flex;justify-content:center}.btn-upload{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-upload:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.documento-cargado{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:#fff;border-radius:8px;color:#16a34a;font-weight:600;border:2px solid #16a34a}.btn-remover{background:#fee2e2;color:#dc2626;border:none;padding:.25rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-remover:hover{background:#fecaca}.error-alert{background:#f8d7da;color:#721c24;padding:.75rem 1rem;border-radius:8px;margin:1rem 1.5rem;border-left:4px solid #f5c6cb;display:flex;align-items:center;gap:.5rem}.instructores-container{padding:32px;max-width:1400px;margin:0 auto}.instructores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.instructor-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s ease;border:1px solid var(--border);overflow:hidden}.instructor-card.collapsed{box-shadow:0 1px 3px #00000014}.instructor-card.expanded{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.instructor-card.collapsed:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.card-header{display:flex;gap:16px;padding:20px;align-items:center;position:relative}.card-header.clickeable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.card-header.clickeable:hover{background-color:var(--surface-2)}.instructor-card.collapsed .card-header{border-bottom:none}.instructor-card.expanded .card-header{border-bottom:1px solid var(--border)}.instructor-foto{flex-shrink:0}.instructor-foto img{width:80px;height:80px;border-radius:12px;object-fit:cover;box-shadow:var(--shadow-sm)}.foto-placeholder{width:80px;height:80px;border-radius:12px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:700}.instructor-info{flex:1;min-width:0;margin-right:12px}.instructor-info h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cedula{font-size:14px;color:var(--text-secondary);font-weight:500;margin-bottom:2px}.matricula{font-size:12px;color:var(--text-secondary);font-weight:500}.chevron-toggle{flex-shrink:0;transition:transform .3s ease;color:var(--text-secondary)}.chevron-toggle.rotated{transform:rotate(-90deg)}.info-row{display:flex;justify-content:space-between;margin-bottom:12px}.info-row:last-child{margin-bottom:0}.info-row .label{font-size:14px;color:var(--text-secondary);font-weight:500}.info-row .value{font-size:14px;color:var(--text-primary);font-weight:600;text-align:right}.rating-inline{display:inline-flex;gap:2px;margin-right:6px;vertical-align:middle}.card-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid #f1f5f9;background:#f8fafc}.card-actions{display:flex;gap:8px;align-items:center}.btn-ver{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text-primary);font-size:13px;font-weight:600;cursor:pointer}.btn-ver:hover{background:var(--surface-2)}.badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-activo{background-color:#d1fae5;color:#065f46}.badge-licencia{background-color:#dbeafe;color:#1e40af}.badge-vacaciones{background-color:#fef3c7;color:#92400e}.badge-inactivo{background-color:#fee2e2;color:#991b1b}.pagination{display:flex;justify-content:center;align-items:center;gap:24px;margin-top:40px;padding:24px 0}.pagination-btn{padding:10px 20px;background-color:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;min-width:120px}.pagination-btn:hover:not(:disabled){background-color:#2563eb;transform:translateY(-1px)}.pagination-btn:disabled{background-color:#cbd5e1;color:#475569;border:1px solid #94a3b8;opacity:1;cursor:not-allowed}.pagination-info{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:14px;color:var(--text-secondary)}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.instructores-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.instructores-header h1{color:var(--text-primary);font-size:28px;font-weight:700}.instructores-filtros{background:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:24px;border:1px solid var(--border)}.filtros-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:1rem;align-items:end}.filtros-row .form-group{margin:0}.filtros-row label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.filtros-row input,.filtros-row select{width:100%;padding:.625rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:.9rem}.btn-limpiar{padding:.625rem 1rem;background:var(--surface-2);color:var(--text-primary);border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:background .2s}.btn-limpiar:hover{background:#eef2ff}.instructores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:24px}.instructor-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:pointer;border:1px solid var(--border)}.instructor-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.instructor-card-header{position:relative;height:140px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.instructor-foto{width:100px;height:100px;border-radius:50%;border:4px solid white;object-fit:cover;background:#fff;box-shadow:0 4px 12px #00000026}.instructor-foto-placeholder{width:100px;height:100px;border-radius:50%;border:4px solid white;background:#fff;display:flex;align-items:center;justify-content:center;color:#667eea;box-shadow:0 4px 12px #00000026}.estado-badge{position:absolute;top:12px;right:12px;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.estado-badge.activo{background:#d4edda;color:#155724}.estado-badge.vacaciones{background:#fff3cd;color:#856404}.estado-badge.licencia_medica{background:#cce5ff;color:#004085}.estado-badge.inactivo{background:#f8d7da;color:#721c24}.doc-alert-badge{position:absolute;top:12px;left:12px;width:36px;height:36px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000026;color:#f59e0b;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.instructor-card-body{padding:1.5rem}.instructor-nombre{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem;text-align:center}.instructor-licencia{font-size:.875rem;color:#666;text-align:center;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.instructor-info-grid{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.info-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#555}.info-item svg{flex-shrink:0;color:#667eea}.categorias-tags{display:flex;flex-wrap:wrap;gap:.5rem}.categoria-tag{padding:.25rem .625rem;background:#e8eaf6;color:#3f51b5;border-radius:12px;font-size:.75rem;font-weight:600}.rating-display{display:flex;align-items:center;gap:.5rem}.stars{display:flex;gap:2px}.star{color:#ffc107}.star.empty{color:#ddd}.rating-number{font-weight:600;color:#1a1a1a}.no-instructores{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.no-instructores svg{color:#ddd;margin-bottom:1rem}.no-instructores h3{color:#666;font-size:1.25rem;margin-bottom:.5rem}.no-instructores p{color:#999}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem}.pagination button{padding:.5rem 1rem;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.pagination button:hover:not(:disabled){background:#667eea;color:#fff;border-color:#667eea}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:#666;font-size:.875rem}.form-instructor{padding:1.5rem}.step-title{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;color:#667eea;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e8eaf6}.categorias-checkbox-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;padding:1rem;background:#f8f9fa;border-radius:8px}.checkbox-categoria{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:background .2s}.checkbox-categoria:hover{background:#e8eaf6}.checkbox-categoria input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.categoria-label{font-weight:600;font-size:.875rem;color:#333}.instructores-container .instructores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.instructores-container .instructor-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s ease;border:1px solid var(--border);overflow:hidden}.instructores-container .instructor-card.collapsed{box-shadow:0 1px 3px #00000014}.instructores-container .instructor-card.expanded{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.instructores-container .instructor-card.collapsed:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.instructores-container .card-header{display:flex;gap:16px;padding:20px;align-items:center;position:relative}.instructores-container .card-header.clickeable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.instructores-container .card-header.clickeable:hover{background-color:var(--surface-2)}.instructores-container .instructor-card.collapsed .card-header{border-bottom:none}.instructores-container .instructor-card.expanded .card-header{border-bottom:1px solid var(--border)}.instructores-container .instructor-foto img{width:80px;height:80px;border-radius:12px;object-fit:cover;box-shadow:var(--shadow-sm)}.instructores-container .foto-placeholder{width:80px;height:80px;border-radius:12px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:700}.instructores-container .instructor-info{flex:1;min-width:0;margin-right:12px}.instructores-container .instructor-info h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.instructores-container .cedula{font-size:14px;color:var(--text-secondary);font-weight:500;margin-bottom:2px}.instructores-container .matricula{font-size:12px;color:var(--text-secondary);font-weight:500}.instructores-container .chevron-toggle{flex-shrink:0;transition:transform .3s ease;color:var(--text-secondary)}.instructores-container .chevron-toggle.rotated{transform:rotate(-90deg)}.instructores-container .card-body{padding:20px}.instructores-container .info-row{display:flex;justify-content:space-between;margin-bottom:12px}.instructores-container .info-row:last-child{margin-bottom:0}.instructores-container .info-row .label{font-size:14px;color:var(--text-secondary);font-weight:500}.instructores-container .info-row .value{font-size:14px;color:var(--text-primary);font-weight:600;text-align:right}.instructores-container .rating-inline{display:inline-flex;gap:2px;margin-right:6px;vertical-align:middle}.instructores-container .card-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid #f1f5f9;background:#f8fafc}.instructores-container .card-actions{display:flex;gap:8px;align-items:center}.instructores-container .btn-ver{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text-primary);font-size:13px;font-weight:600;cursor:pointer}.instructores-container .btn-ver:hover{background:var(--surface-2)}.instructores-container .badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.instructores-container .badge-activo{background-color:#d1fae5;color:#065f46}.instructores-container .badge-licencia{background-color:#dbeafe;color:#1e40af}.instructores-container .badge-vacaciones{background-color:#fef3c7;color:#92400e}.instructores-container .badge-inactivo{background-color:#fee2e2;color:#991b1b}.instructores-container .pagination{display:flex;justify-content:center;align-items:center;gap:24px;margin-top:40px;padding:24px 0}.instructores-container .pagination-btn{padding:10px 20px;background-color:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;min-width:120px}.instructores-container .pagination-btn:hover:not(:disabled){background-color:#2563eb;transform:translateY(-1px)}.instructores-container .pagination-btn:disabled{background-color:#cbd5e1;color:#475569;border:1px solid #94a3b8;opacity:1;cursor:not-allowed}.instructores-container .pagination-info{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:14px;color:var(--text-secondary)}.form-hint{display:block;margin-top:.375rem;font-size:.75rem;color:#999}.error-alert{background:#f8d7da;color:#721c24;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid #f5c6cb}.instructor-detalle-container{padding:2rem;max-width:1200px;margin:0 auto}.detalle-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.btn-volver{padding:.625rem;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-volver:hover{background:#f8f9fa;border-color:#667eea}.detalle-header h1{color:#1a1a1a;font-size:1.75rem;font-weight:700;margin:0}.detalle-content{display:grid;gap:2rem}.info-personal-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.info-personal-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;display:flex;gap:2rem;align-items:center}.detalle-foto{width:120px;height:120px;border-radius:50%;border:5px solid white;object-fit:cover;background:#fff;box-shadow:0 4px 12px #0003}.detalle-foto-placeholder{width:120px;height:120px;border-radius:50%;border:5px solid white;background:#fff;display:flex;align-items:center;justify-content:center;color:#667eea;box-shadow:0 4px 12px #0003}.detalle-info-basica{flex:1;color:#fff}.detalle-info-basica h2{font-size:1.75rem;margin:0 0 .5rem}.detalle-info-basica p{margin:.25rem 0;font-size:.95rem;opacity:.95}.info-personal-body{padding:2rem;display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.info-field{display:flex;flex-direction:column;gap:.375rem}.info-field-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#999;letter-spacing:.5px}.info-field-value{font-size:1rem;color:#1a1a1a;font-weight:500}.info-field-value.categorias{display:flex;flex-wrap:wrap;gap:.5rem}.detalle-acciones{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;display:flex;gap:1rem;justify-content:flex-end}.estadisticas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.estadistica-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:transform .2s}.estadistica-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.estadistica-icono{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.estadistica-icono.azul{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.estadistica-icono.verde{background:linear-gradient(135deg,#56ab2f,#a8e063);color:#fff}.estadistica-icono.naranja{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.estadistica-icono.morado{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.estadistica-info{flex:1}.estadistica-label{font-size:.875rem;color:#666;margin-bottom:.25rem}.estadistica-valor{font-size:1.75rem;font-weight:700;color:#1a1a1a}.distribucion-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem}.distribucion-card h3{margin:0 0 1.5rem;font-size:1.125rem;color:#1a1a1a}.distribucion-bars{display:flex;flex-direction:column;gap:1rem}.distribucion-item{display:flex;flex-direction:column;gap:.5rem}.distribucion-header{display:flex;justify-content:space-between;align-items:center}.distribucion-label{font-weight:600;color:#555;font-size:.875rem}.distribucion-valor{font-weight:700;color:#1a1a1a;font-size:1rem}.distribucion-bar-container{background:#f0f0f0;border-radius:8px;height:24px;overflow:hidden}.distribucion-bar{height:100%;border-radius:8px;transition:width .3s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;color:#fff;font-size:.75rem;font-weight:600}.distribucion-bar.teoricas{background:linear-gradient(90deg,#667eea,#764ba2)}.distribucion-bar.practicas{background:linear-gradient(90deg,#56ab2f,#a8e063)}.loading-container{display:flex;justify-content:center;align-items:center;min-height:400px}@media (max-width: 768px){.instructores-container,.instructor-detalle-container{padding:1rem}.filtros-row,.instructores-grid{grid-template-columns:1fr}.instructores-header{flex-direction:column;align-items:flex-start;gap:1rem}.info-personal-header{flex-direction:column;text-align:center}.info-personal-body,.estadisticas-grid{grid-template-columns:1fr}.detalle-acciones{flex-direction:column}.detalle-acciones button{width:100%}.categorias-checkbox-grid{grid-template-columns:repeat(2,1fr)}}.instructor-detalle-container{padding:2rem;max-width:1400px;margin:0 auto}.detalle-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.btn-back{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;color:var(--text-primary)}.btn-back:hover{background:var(--surface-2);border-color:var(--primary);color:var(--primary)}.header-actions{display:flex;gap:1rem}.btn-action{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.btn-action:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.info-principal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:2.5rem;margin-bottom:24px;display:flex;gap:2rem;align-items:flex-start;border:1px solid var(--border)}.foto-grande{flex-shrink:0}.foto-grande img{width:180px;height:180px;border-radius:50%;object-fit:cover;border:5px solid var(--surface-2);box-shadow:var(--shadow-sm)}.foto-placeholder-grande{width:180px;height:180px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;border:5px solid var(--surface-2);box-shadow:var(--shadow-sm)}.info-basica{flex:1}.info-basica h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.info-basica .cedula{font-size:1rem;color:var(--text-secondary);margin:.25rem 0}.info-basica .licencia{font-size:1rem;color:var(--text-secondary);margin:.25rem 0 1rem}.estado-badge-container{margin:1rem 0;display:flex;gap:.75rem;flex-wrap:wrap}.badge-estado-grande{display:inline-block;padding:.5rem 1.25rem;border-radius:24px;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge-estado-grande.badge-activo{background:#d4edda;color:#155724}.badge-estado-grande.badge-vacaciones{background:#fff3cd;color:#856404}.badge-estado-grande.badge-licencia{background:#cce5ff;color:#004085}.badge-estado-grande.badge-inactivo{background:#f8d7da;color:#721c24}.badge-docs{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;border-radius:24px;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge-docs-completo{background:#d4edda;color:#155724}.badge-docs-incompleto{background:#fff3cd;color:#856404}.badge-docs-vencido{background:#f8d7da;color:#721c24}.badge-docs-proximo_vencer{background:#ffe4e1;color:#d97706}.rating-principal{display:flex;align-items:center;gap:1rem;margin:1rem 0}.estrellas-grande{display:flex;gap:4px}.rating-texto{font-size:1.25rem;font-weight:700;color:#1a1a1a}.especialidad-texto{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:1rem;background:#f8f9fa;border-radius:8px;font-weight:500;color:#555}.estadisticas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:transform .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.stat-icon{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1}.stat-content h3{font-size:2rem;font-weight:700;color:#1a1a1a;margin:0 0 .25rem}.stat-content p{font-size:.875rem;color:#666;margin:0}.detalles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:24px}.detalle-card,.detalle-card-full{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem}.detalle-card-full{grid-column:1 / -1}.detalle-card h2,.detalle-card-full h2{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.info-rows{display:flex;flex-direction:column;gap:1rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8f9fa;border-radius:8px;gap:1rem}.info-row .label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#555;font-size:.875rem}.info-row .label svg{color:#667eea;flex-shrink:0}.info-row .value{color:#1a1a1a;font-weight:500;text-align:right}.categorias-lista{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.badge-categoria-detalle{padding:.375rem .75rem;background:#e8eaf6;color:#3f51b5;border-radius:16px;font-size:.75rem;font-weight:700}.clases-distribucion{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:1.5rem}.clase-tipo{background:linear-gradient(135deg,#f8f9fa,#e8eaf6);border-radius:12px;padding:2rem;text-align:center}.tipo-header{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem;color:#667eea;font-weight:700;font-size:1.125rem}.tipo-valor{font-size:3rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.tipo-porcentaje{font-size:1.25rem;font-weight:600;color:#667eea}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.spinner{width:48px;height:48px;border:4px solid #f0f0f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p,.error-container p{color:#666;font-size:1rem}.error-container svg{margin-bottom:1rem}@media (max-width: 768px){.instructor-detalle-container{padding:1rem}.info-principal{flex-direction:column;align-items:center;text-align:center;padding:1.5rem}.info-basica{width:100%}.detalles-grid,.estadisticas-grid,.clases-distribucion{grid-template-columns:1fr}.detalle-header{flex-direction:column;gap:1rem}.header-actions{width:100%;flex-direction:column}.btn-action{width:100%;justify-content:center}}.alertas-vencimiento{margin-bottom:24px;display:flex;flex-direction:column;gap:1rem}.alerta-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-radius:12px;border-left:4px solid;font-size:.9rem}.alerta-vencido{background:#fee2e2;border-color:#dc2626;color:#7f1d1d}.alerta-proximo{background:#fef3c7;border-color:#f59e0b;color:#78350f}.vigencias-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.vigencia-card{background:#f8f9fa;border-radius:12px;padding:1.5rem;border:2px solid #e5e7eb}.vigencia-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#667eea}.vigencia-header h3{font-size:1rem;font-weight:700;color:#1a1a1a;margin:0}.vigencia-fechas{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.vigencia-fecha{display:flex;justify-content:space-between;align-items:center}.fecha-label{font-weight:600;color:#666;font-size:.875rem}.fecha-valor{font-weight:700;color:#1a1a1a;font-size:.875rem}.vigencia-status{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:8px;font-weight:600;font-size:.875rem}.status-vigente{background:#d4edda;color:#155724}.status-proximo{background:#fff3cd;color:#856404}.status-vencido{background:#f8d7da;color:#721c24}.documentos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.documento-item{background:#f8f9fa;border-radius:12px;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;border:2px solid #e5e7eb;transition:border-color .2s}.documento-item:hover{border-color:#667eea}.documento-info{display:flex;align-items:center;gap:1rem}.documento-info h4{margin:0 0 .25rem;font-size:.95rem;font-weight:700;color:#1a1a1a}.documento-estado{display:flex;align-items:center;gap:.375rem;margin:0;font-size:.8rem;font-weight:600;color:#16a34a}.documento-estado-faltante{display:flex;align-items:center;gap:.375rem;margin:0;font-size:.8rem;font-weight:600;color:#f59e0b}.documento-acciones{display:flex;gap:.5rem}.btn-preview{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s}.btn-preview:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-descargar{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:8px;cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s}.btn-descargar:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.pdf-preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;padding:2rem;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pdf-preview-content{background:#fff;border-radius:16px;width:90%;max-width:1200px;height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.pdf-preview-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #e5e7eb;background:#f8f9fa}.pdf-preview-header h3{margin:0;font-size:1.25rem;font-weight:700;color:#1a1a1a}.pdf-preview-actions{display:flex;gap:.75rem;align-items:center}.btn-cerrar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#f3f4f6;border:none;border-radius:8px;cursor:pointer;color:#666;transition:all .2s}.btn-cerrar:hover{background:#e5e7eb;color:#dc2626}.pdf-preview-body{flex:1;overflow:hidden;background:#525252;position:relative}.pdf-preview-body iframe{border:none;width:100%;height:100%}@media (max-width: 768px){.pdf-preview-modal{padding:0}.pdf-preview-content{width:100%;height:100vh;border-radius:0}.pdf-preview-header{padding:1rem}.pdf-preview-header h3{font-size:1rem}.btn-descargar{padding:.5rem .75rem;font-size:.75rem}.btn-descargar span{display:none}}.vehiculos-container{display:flex;flex-direction:column;gap:20px;padding:32px;max-width:1400px;margin:0 auto}.vehiculos-header{display:flex;justify-content:space-between;align-items:center}.header-title{display:flex;align-items:center;gap:10px}.vehiculos-filtros{display:grid;grid-template-columns:1fr 200px auto;gap:12px;align-items:center}.search-box{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);padding:8px 12px;border-radius:var(--radius-md)}.search-box input{border:none;outline:none;width:100%}.vehiculos-table table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border)}.vehiculos-table th,.vehiculos-table td{padding:12px 10px;border-bottom:1px solid var(--border);text-align:left;font-size:.95rem}.acciones{display:flex;gap:8px}.btn-icon{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:6px;cursor:pointer}.btn-icon.danger{color:#dc2626}.badge{padding:4px 8px;border-radius:999px;font-size:.8rem}.badge-activo{background:#dcfce7;color:#166534}.badge-inactivo{background:#fee2e2;color:#991b1b}.modal-box{background:var(--surface);border-radius:var(--radius-lg);padding:16px;max-width:520px;width:90%;border:1px solid var(--border);box-shadow:var(--shadow-md)}.modal-body{display:grid;gap:12px;margin-top:12px}.form-group.checkbox{flex-direction:row;align-items:center}.form-group input,.form-group select{border:1px solid #e5e7eb;border-radius:6px;padding:8px 10px}.pagination{display:flex;justify-content:center;gap:12px;align-items:center}.vehiculo-detalle-container{display:flex;flex-direction:column;gap:20px}.detalle-header{display:flex;align-items:center;gap:10px}.export-actions{margin-left:auto;display:flex;gap:8px}.vehiculo-info-card{display:grid;grid-template-columns:180px 1fr;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.vehiculo-foto{width:160px;height:120px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}.vehiculo-foto.placeholder{width:160px;height:120px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border-radius:8px;color:var(--text-secondary)}.vehiculo-info-right{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.detalle-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.filtros-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;align-items:end;margin-bottom:12px}.stats-row{display:flex;flex-direction:column;gap:8px}.stat-summary{display:flex;justify-content:space-between;background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;padding:10px 12px}.umbral-row{display:grid;gap:6px;margin-top:6px}.umbral-actions{display:flex;gap:8px;align-items:center}.umbral-actions input{max-width:140px}.stat-summary-content{display:grid;gap:4px}.stat-summary-label{font-weight:600}.stat-summary-detalle{color:#334155}.alertas{margin-top:6px;display:grid;gap:4px}.alerta{color:#b45309;background:#fef3c7;border:1px solid #fcd34d;padding:6px 8px;border-radius:6px}.adjuntos-list{margin-top:8px;display:grid;gap:6px}.adjuntos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px}.adjunto-item{display:grid;gap:4px;align-items:center;justify-items:center;border:1px solid #e5e7eb;border-radius:6px;padding:6px;background:#fff;text-decoration:none;color:inherit;cursor:pointer}.adjunto-item img{width:100%;height:70px;object-fit:cover;border-radius:4px}.lista-items{display:flex;flex-direction:column;gap:12px}.item-card{border:1px solid #e5e7eb;border-radius:8px;padding:12px;background:#f8fafc}.item-header{display:flex;justify-content:space-between;margin-bottom:8px}.item-body{display:grid;gap:6px}.item-footer{margin-top:8px}.repuestos-list ul{margin:6px 0 0 16px}.recibo-link{display:inline-flex;align-items:center;gap:6px;color:#2563eb;background:none;border:none;padding:0;cursor:pointer}.modal-box{background:#fff;border-radius:10px;padding:16px;max-width:560px;width:92%}.modal-adjunto{max-width:820px}.adjunto-preview{width:100%;max-height:70vh;object-fit:contain}.adjunto-iframe{width:100%;height:70vh;border:none}.modal-header,.modal-footer{display:flex;justify-content:space-between;align-items:center}.modal-footer .btn-primary,.modal-footer .btn-secondary,.modal-footer .btn-danger{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:10px;font-size:14px;font-weight:600;min-width:120px;transition:all .2s}.modal-footer .btn-secondary{background:#f8fafc;color:#334155;border:1px solid #cbd5e1}.modal-footer .btn-secondary:hover:not(:disabled){background:#eef2f7}.modal-footer .btn-primary{background:#3b82f6;color:#fff;border:1px solid #2563eb}.modal-footer .btn-primary:hover:not(:disabled){background:#2563eb}.modal-footer .btn-danger{background:#dc2626;color:#fff;border:1px solid #b91c1c}.modal-footer .btn-danger:hover:not(:disabled){background:#b91c1c}.modal-body{display:grid;gap:10px;margin-top:12px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group input,.form-group select,.form-group textarea{border:1px solid #e5e7eb;border-radius:6px;padding:8px 10px}.tarifas-container{display:flex;flex-direction:column;gap:16px;padding:32px;max-width:1400px;margin:0 auto}.tarifas-table table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.tarifas-table th,.tarifas-table td{border-bottom:1px solid var(--border);padding:10px 12px;text-align:left}.btn-icon{background:var(--surface-2);border:1px solid var(--border);padding:6px;border-radius:6px;margin-right:6px;cursor:pointer}.btn-icon.danger{background:#fee2e2;border-color:#fecaca}.usuarios-container{display:flex;flex-direction:column;gap:16px;padding:32px;max-width:1400px;margin:0 auto}.search-input{width:100%;padding:12px 12px 12px 16px;border:1px solid var(--border);border-radius:12px;font-size:15px;transition:all .2s}.usuarios-table table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.usuarios-table th,.usuarios-table td{border-bottom:1px solid var(--border);padding:10px 12px;text-align:left}.modulos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:6px}.modulo-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);font-size:14px;color:var(--text-primary)}.modulo-item input{transform:scale(1.05)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-box{width:90%;max-width:720px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;background:var(--surface-2);border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:18px;color:var(--text-primary);font-weight:700}.modal-body{padding:18px 20px;max-height:70vh;overflow:auto}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border);background:var(--surface-2)}.modal-footer .btn-secondary,.modal-footer .btn-primary{min-width:120px;padding:10px 16px;border-radius:8px;font-weight:600;font-size:14px}.modal-footer .btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text-primary)}.modal-footer .btn-primary{background:var(--primary);color:#fff;border:1px solid var(--primary)}.clases-container{display:flex;flex-direction:column;gap:16px;padding:32px;max-width:1400px;margin:0 auto}.page-header{margin-bottom:8px}.header-content{display:flex;justify-content:space-between;align-items:center}.header-content h1{font-size:28px;font-weight:700;color:var(--text-primary)}.btn-nuevo{display:flex;align-items:center;gap:8px;padding:12px 24px;background-color:var(--primary);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-nuevo:hover{background-color:var(--primary-600);transform:translateY(-1px)}.search-section{display:flex;gap:12px;align-items:center;margin-bottom:8px}.search-box{position:relative;max-width:420px;width:100%}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#94a3b8}.search-input{width:100%;padding:12px 12px 12px 44px;border:1px solid var(--border);border-radius:12px;font-size:15px;transition:all .2s}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1d4ed81f}.btn-search{padding:12px 20px;font-size:14px}.clases-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;display:grid;gap:16px}.clases-header{display:flex;gap:12px;align-items:center}.clases-foto img{width:72px;height:72px;border-radius:8px;object-fit:cover}.clases-foto-placeholder{width:72px;height:72px;border-radius:8px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.clases-info p{margin:2px 0}.clases-progreso,.clases-form{display:grid;gap:12px}.clases-historial{border-top:1px solid var(--border);padding-top:12px;display:grid;gap:8px}.historial-list{display:grid;gap:8px}.historial-item{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;display:grid;gap:4px}.historial-fecha,.historial-obs{color:var(--text-secondary);font-size:12px}.historial-empty{color:var(--text-secondary);font-size:13px}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #1d4ed8;--primary-600: #1e40af;--primary-700: #1e3a8a;--secondary: #64748b;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg: #f5f7fb;--surface: #ffffff;--surface-2: #f8fafc;--text-primary: #0f172a;--text-secondary: #475569;--border: #e5e7eb;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow-md: 0 8px 24px rgba(15, 23, 42, .08);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--primary-color: var(--primary);--primary-dark: var(--primary-600);--secondary-color: var(--secondary);--success-color: var(--success);--danger-color: var(--danger);--warning-color: var(--warning);--bg-color: var(--bg);--card-bg: var(--surface);--border-color: var(--border);--shadow: var(--shadow-sm);--shadow-lg: var(--shadow-md)}body{font-family:Inter,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg);color:var(--text-primary);line-height:1.5}h1,h2,h3,h4{color:var(--text-primary);font-weight:700;letter-spacing:.2px}h1{font-size:28px}h2{font-size:22px}h3{font-size:18px}h4{font-size:16px}.page-header{margin-bottom:24px}.page-header-card{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.25rem 1.5rem}.page-header-title{display:flex;align-items:center;gap:12px}.page-header-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);color:var(--primary)}.page-header-title h1{margin:0;font-size:28px;font-weight:700;color:var(--text-primary)}.page-header-title p{margin:0;font-size:.875rem;color:var(--text-secondary)}.page-header-actions{display:flex;align-items:center;gap:10px}p{color:var(--text-secondary)}label{font-size:13px;font-weight:600;color:var(--text-secondary)}#root{min-height:100vh}button{font-family:inherit;cursor:pointer;border-radius:var(--radius-md);border:1px solid transparent;transition:all .2s ease}input,textarea,select{font-family:inherit;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--text-primary);transition:border .2s ease,box-shadow .2s ease}input,textarea,select{padding:10px 12px;font-size:14px}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1d4ed81f}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}thead th{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary);background:var(--surface-2)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--surface-2)}.card-body{padding:20px}.card-footer{padding:16px 20px;border-top:1px solid var(--border)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border)}.muted{color:var(--text-secondary)}.status-success,.text-success{color:var(--success)}.status-warning,.text-warning{color:var(--warning)}.status-danger,.text-danger{color:var(--danger)}.badge-success{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.badge-warning{background:#fffbeb;border-color:#fcd34d;color:#92400e}.badge-danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.btn,.btn-nuevo,.btn-exportar,.btn-camera,.btn-outline,.btn-guardar,.btn-crear,.btn-editar,.btn-eliminar,.btn-reset,.btn-pagar,.btn-cerrar,.btn-buscar,.btn-add,.filtro-btn,.action-button,.action-btn{background:var(--primary);color:#fff;border:1px solid var(--primary);padding:10px 16px;font-weight:600}.btn-outline,.btn-reset{background:transparent;color:var(--primary);border-color:var(--primary)}.btn:hover,.btn-nuevo:hover,.btn-exportar:hover,.btn-camera:hover,.btn-outline:hover,.btn-guardar:hover,.btn-crear:hover,.btn-editar:hover,.btn-eliminar:hover,.btn-reset:hover,.btn-pagar:hover,.btn-cerrar:hover,.btn-buscar:hover,.btn-add:hover,.filtro-btn:hover,.action-button:hover,.action-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}a{text-decoration:none;color:inherit}
