:root{--primary-dark:#1f2937;--primary-darker:#111827;--bg-light:#f3f4f6;--text-dark:#1f2937;--text-light:#6b7280;--border-light:#e5e7eb;--white:#fff;--estado-operativo:#90ee90;--estado-no-operativo:#ff8080;--estado-para-levantar:#ff8000;--estado-tareas-programadas:#ff0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-light);color:var(--text-dark);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5}input,select,textarea,button{font-family:inherit;font-size:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.sidebar{color:#fff;z-index:100;background:linear-gradient(#1f2937 0%,#111827 100%);flex-direction:column;width:260px;height:100vh;display:flex;position:fixed;top:0;left:0;box-shadow:2px 0 8px #00000026}.sidebar-header{text-align:center;border-bottom:1px solid #ffffff1a;padding:2rem 1.5rem}.sidebar-logo{width:120px;height:auto;margin-bottom:.75rem}.sidebar-title{color:#f9fafb;margin:0;font-size:1.125rem;font-weight:600}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-link{color:#d1d5db;border-left:3px solid #0000;align-items:center;padding:.875rem 1.5rem;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover{color:#fff;background:#ffffff0d}.nav-link.active{color:#60a5fa;background:#3b82f626;border-left-color:#3b82f6}.nav-icon{margin-right:.75rem;font-size:1.25rem}.nav-icon-svg{flex-shrink:0;width:20px;height:20px;margin-right:.75rem}.nav-text{font-size:.9375rem;font-weight:500}.sidebar-footer{border-top:1px solid #ffffff1a;padding:1rem 1.5rem}.user-info{border-bottom:1px solid #ffffff0d;margin-bottom:.75rem;padding-bottom:.75rem}.user-name{color:#f9fafb;margin-bottom:.25rem;font-size:.875rem;font-weight:600}.user-role{color:#9ca3af;font-size:.75rem}.logout-btn{color:#fca5a5;cursor:pointer;background:#ef44441a;border:1px solid #ef44444d;border-radius:6px;align-items:center;width:100%;padding:.75rem;font-size:.9375rem;transition:all .2s;display:flex}.logout-btn:hover{color:#fecaca;background:#ef444433;border-color:#ef444480}@media (width<=768px){.sidebar{width:70px}.sidebar-title,.nav-text,.user-info,.logout-btn .nav-text{display:none}.sidebar-header{padding:1.5rem .5rem}.sidebar-logo{width:50px}.nav-link,.logout-btn{justify-content:center;padding:.875rem .5rem}.nav-icon,.nav-icon-svg{margin-right:0}}.main-layout{background:#f3f4f6;min-height:100vh;display:flex}.main-content{flex:1;margin-left:260px;padding:2rem;overflow-x:hidden}@media (width<=768px){.main-content{margin-left:70px;padding:1rem}}.login-container{background:linear-gradient(135deg,#1f2937 0%,#111827 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:#fff;border-radius:12px;width:100%;max-width:420px;padding:2.5rem;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:180px;height:auto;margin-bottom:1rem}.login-header h1{color:#1f2937;margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.login-header p{color:#6b7280;margin:0;font-size:.9375rem}.login-form{margin-top:2rem}.login-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:1.5rem;padding:.875rem;font-size:.875rem}.form-group input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .2s}.form-group input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{cursor:not-allowed;background:#f3f4f6}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:6px;width:100%;margin-top:.5rem;padding:.875rem;font-size:1rem;font-weight:600;transition:all .2s}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{cursor:not-allowed;background:#9ca3af}@media (width<=480px){.login-card{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}}.stat-card{color:#fff;cursor:default;border-radius:12px;padding:24px}.stat-card-content{justify-content:space-between;align-items:flex-start;display:flex}.stat-card-info{flex:1}.stat-card-title{opacity:.9;font-size:13px;font-weight:500}.stat-card-value{margin-top:8px;font-size:32px;font-weight:700;line-height:1.1}.stat-card-subtitle{opacity:.8;margin-top:4px;font-size:13px}.stat-card-icon{background-color:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-card-icon svg{color:#fff}.modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:600px;max-height:85vh;animation:.3s ease-out modalFadeIn;display:flex;box-shadow:0 20px 60px #0000004d}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)translateY(-20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{color:#1f2937;background:#fff;border-bottom:1px solid #d1d5db;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-header h2{color:#374151;letter-spacing:-.01em;margin:0;font-size:1.2rem;font-weight:600}.modal-close{cursor:pointer;color:#6b7280;background:0 0;border:1px solid #d1d5db;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:24px;line-height:1;transition:all .2s;display:flex}.modal-close:hover{color:#374151;background:#f3f4f6;border-color:#9ca3af}.modal-body{flex:1;padding:20px 24px;overflow-y:auto}.tabla-container{overflow-x:auto}.tabla-detalles{border-collapse:collapse;width:100%;font-size:.9rem}.tabla-detalles thead{z-index:10;background:linear-gradient(135deg,#f3f4f6 0%,#e5e7eb 100%);position:sticky;top:0}.tabla-detalles th{text-align:left;color:#374151;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:2px solid #d1d5db;padding:10px 8px;font-size:.75rem;font-weight:700}.tabla-detalles th:first-child{padding-left:12px}.tabla-detalles th:last-child{padding-right:12px}.tabla-detalles td{border-bottom:1px solid #e5e7eb;padding:10px 8px}.tabla-detalles td:first-child{padding-left:12px}.tabla-detalles td:last-child{padding-right:12px}.tabla-detalles tbody tr{transition:background-color .2s}.tabla-detalles tbody tr:hover{background-color:#f9fafb}.tabla-detalles td.fecha{color:#1f2937;white-space:nowrap;font-weight:600}.tabla-detalles td.numero{text-align:center;color:#1f2937;min-width:50px;font-weight:600}.tabla-detalles td.porcentaje{width:35%;min-width:120px}.porcentaje-wrapper{align-items:center;gap:8px;display:flex}.porcentaje-valor{color:#6366f1;text-align:right;min-width:48px;font-size:.9rem;font-weight:700}.barra-progreso{background-color:#e5e7eb;border-radius:3px;flex:1;height:6px;overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.barra-fill{background:linear-gradient(90deg,#6366f1 0%,#8b5cf6 100%);border-radius:3px;height:100%;transition:width .5s ease-out}.barra-fill.promedio{background:linear-gradient(90deg,#10b981 0%,#059669 100%)}.tabla-detalles tfoot{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border-top:3px solid #f59e0b}.fila-promedio td{color:#92400e;padding:12px 8px;font-size:.95rem}.fila-promedio td:first-child{padding-left:12px}.fila-promedio td:last-child{padding-right:12px}.fila-promedio .porcentaje-valor{color:#059669;font-size:1rem}@media (width<=768px){.modal-content{max-width:95%;max-height:90vh}.modal-header{padding:16px 18px}.modal-header h2{font-size:1.1rem}.modal-body{padding:16px 18px}.tabla-detalles{font-size:.85rem}.tabla-detalles th,.tabla-detalles td{padding:8px 6px}.tabla-detalles th:first-child,.tabla-detalles td:first-child{padding-left:8px}.tabla-detalles th:last-child,.tabla-detalles td:last-child{padding-right:8px}.tabla-detalles td.porcentaje{min-width:100px}.porcentaje-valor{min-width:42px;font-size:.85rem}}.operatividad-chart-container{background:#fff;border-radius:8px;margin-bottom:2.5rem;padding:2rem;box-shadow:0 1px 3px #0000001a}.chart-header{border-bottom:2px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1rem}.chart-header h2{color:#1f2937;margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.chart-header p{color:#6b7280;margin:0;font-size:.9375rem}.chart-controls{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;display:flex}.control-section{flex-direction:column;gap:.75rem;display:flex}.control-label{color:#374151;font-size:.9375rem;font-weight:600}.fecha-range{flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem;display:flex}.fecha-input-group{align-items:center;gap:.5rem;display:flex}.fecha-input-group label{color:#4b5563;min-width:50px;font-size:.875rem;font-weight:500}.fecha-input{color:#1f2937;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;min-width:150px;padding:.5rem .75rem;font-size:.875rem;transition:all .2s}.fecha-input:hover{border-color:#9ca3af}.fecha-input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11a}.fecha-presets{flex-wrap:wrap;gap:.75rem;display:flex}.preset-btn{color:#4b5563;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.preset-btn:hover{color:#6366f1;background:#f9fafb;border-color:#6366f1}.preset-btn:active{transform:scale(.98)}.dias-checkboxes{flex-wrap:wrap;gap:.75rem;display:flex}.checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;display:flex}.checkbox-input{cursor:pointer;accent-color:#6366f1;width:18px;height:18px;margin-right:.5rem}.checkbox-text{background:#fff;border:1px solid #e5e7eb;border-left:4px solid;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;transition:all .2s}.checkbox-input:checked~.checkbox-text{background:#f0f9ff;box-shadow:0 1px 3px #0000001a}.hora-selectors{flex-wrap:wrap;gap:1.5rem;display:flex}.hora-selector{align-items:center;gap:.5rem;display:flex}.hora-select{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;min-width:100px;padding:.5rem 1rem;font-size:.875rem}.btn-actualizar{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:6px;align-self:flex-start;padding:.75rem 2rem;font-weight:600;transition:all .2s}.btn-actualizar:hover:not(:disabled){background:#4f46e5;transform:translateY(-1px)}.btn-actualizar:disabled{cursor:not-allowed;background:#9ca3af}.chart-wrapper{height:420px;margin-top:1rem;position:relative}.chart-loading,.chart-error,.chart-empty{flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:100%;display:flex}.spinner{border:4px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.chart-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1.5rem}@media (width<=768px){.operatividad-chart-container{padding:1.5rem}.chart-wrapper{height:300px}}.comparativa-bases-container{background:#fff;border-radius:8px;margin-bottom:2.5rem;padding:2rem;box-shadow:0 1px 3px #0000001a}.comparativa-bases-container .chart-header{border-bottom:2px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1rem}.comparativa-bases-container .chart-header h2{color:#1f2937;margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.comparativa-bases-container .chart-header p{color:#6b7280;margin:0;font-size:.9375rem;font-weight:500}.comparativa-bases-container .chart-wrapper{height:450px;min-height:450px;position:relative}.comparativa-bases-container .chart-loading,.comparativa-bases-container .chart-error,.comparativa-bases-container .chart-empty{flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:100%;display:flex}.comparativa-bases-container .chart-loading p{color:#6b7280;margin:0;font-size:1rem}.comparativa-bases-container .spinner{border:4px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.comparativa-bases-container .chart-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;height:auto;min-height:100px;padding:1.5rem;font-size:.9375rem}.comparativa-bases-container .chart-empty{color:#9ca3af;font-size:1rem;font-style:italic}@media (width<=768px){.comparativa-bases-container{padding:1.5rem}.comparativa-bases-container .chart-header h2{font-size:1.25rem}.comparativa-bases-container .chart-wrapper{height:350px;min-height:350px}}@media (width<=480px){.comparativa-bases-container{padding:1rem}.comparativa-bases-container .chart-header h2{font-size:1.125rem}.comparativa-bases-container .chart-header p{font-size:.875rem}.comparativa-bases-container .chart-wrapper{height:300px;min-height:300px}}.dashboard-container{max-width:1400px}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:#1f2937;margin:0 0 .5rem;font-size:2rem;font-weight:700}.dashboard-header p{color:#6b7280;margin:0;font-size:1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2.5rem;display:grid}.loading,.error-message{text-align:center;color:#6b7280;padding:2rem;font-size:1.125rem}.bases-section{background:#fff;border-radius:8px;margin-bottom:2.5rem;padding:2rem;box-shadow:0 1px 3px #0000001a}.bases-section h2{color:#1f2937;margin:0 0 1.5rem;font-size:1.5rem;font-weight:600}.bases-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.base-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;transition:all .2s;box-shadow:0 1px 3px #0000001a}.base-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px #00000026}.base-title{text-align:center;color:#1f2937;border-bottom:2px solid #e5e7eb;margin:0 0 .5rem;padding-bottom:.75rem;font-size:1.25rem;font-weight:700}.base-total{text-align:center;color:#6b7280;margin-bottom:1rem;font-size:.9375rem;font-weight:600}.base-stats{flex-direction:column;gap:.75rem;display:flex}.base-stat{background:#f9fafb;border-left:3px solid #0000;border-radius:6px;justify-content:space-between;align-items:center;padding:.625rem .875rem;font-size:.9375rem;transition:all .2s;display:flex}.base-stat:hover{background:#f3f4f6}.base-stat.operativo{border-left-color:#10b981}.base-stat.no-operativo{border-left-color:#ef4444}.base-stat.para-levantar{border-left-color:#f59e0b}.base-stat.tareas{border-left-color:#eab308}.stat-label{color:#374151;font-weight:500}.stat-value{color:#1f2937;font-size:1.25rem;font-weight:700}.novedades-section{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.novedades-section h2{color:#1f2937;margin:0 0 1.5rem;font-size:1.5rem;font-weight:600}.novedades-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.novedad-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;justify-content:space-between;align-items:center;padding:1rem;transition:all .2s;display:flex}.novedad-card:hover{background:#f3f4f6;border-color:#d1d5db;transform:translateY(-2px)}.novedad-name{color:#374151;font-size:.875rem;font-weight:500}.novedad-count{color:#3b82f6;font-size:1.5rem;font-weight:700}@media (width<=768px){.stats-grid,.bases-grid,.novedades-grid{grid-template-columns:1fr}.dashboard-header h1{font-size:1.5rem}}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:8px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-editar{width:100%;max-width:600px}.modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2{color:#1f2937;margin:0;font-size:1.25rem;font-weight:600}.modal-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:2rem;line-height:1;transition:all .2s;display:flex}.modal-close:hover{color:#374151;background:#f3f4f6}.modal-form{padding:1.5rem}.form-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:1.5rem;padding:.875rem;font-size:.875rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}.form-group{margin-bottom:1.25rem}.form-group label{color:#374151;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{box-sizing:border-box;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:.625rem .875rem;font-family:inherit;font-size:.9375rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{color:#6b7280;background:#f3f4f6}.form-group textarea{resize:vertical;min-height:80px}.form-group small{color:#6b7280;margin-top:.25rem;font-size:.75rem;display:block}.modal-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:6px;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;transition:all .2s}.btn-primary{color:#fff;background:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-primary:disabled{cursor:not-allowed;background:#9ca3af}.btn-secondary{color:#374151;background:#fff;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#f9fafb}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}@media (width<=640px){.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.modal-auditoria{flex-direction:column;width:100%;max-width:1000px;max-height:90vh;display:flex}.modal-body{flex:1;min-height:0;padding:1.5rem;overflow-y:auto}.loading-message,.error-message,.empty-message{text-align:center;color:#6b7280;padding:2rem}.error-message{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px}.auditoria-table-wrapper{margin-bottom:0;overflow-x:auto}.auditoria-table{border-collapse:collapse;width:100%;font-size:.875rem}.auditoria-table thead{z-index:10;background:#f9fafb;position:sticky;top:0}.auditoria-table th{text-align:left;color:#374151;white-space:nowrap;border-bottom:2px solid #e5e7eb;padding:.75rem;font-weight:600}.auditoria-table td{color:#1f2937;border-bottom:1px solid #f3f4f6;padding:.75rem}.auditoria-table tbody tr:hover{filter:brightness(.97)}.fecha-cell{white-space:nowrap;font-weight:500}.estado-cell{font-weight:600}.novedad-cell,.base-cell{font-weight:500}.auditoria-estadisticas{z-index:20;background:#f9fafb;border-top:2px solid #e5e7eb;grid-template-columns:repeat(3,1fr);gap:.75rem;padding:.75rem;display:grid;position:sticky;bottom:0}.estadistica-card{text-align:center;background:#fff;border:1.5px solid;border-radius:6px;padding:.5rem .75rem;transition:transform .2s;box-shadow:0 1px 2px #0000000d}.estadistica-card:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.estadistica-card.operativo{background:linear-gradient(#fff,#f0fdf4);border-color:#22c55e}.estadistica-card.no-operativo{background:linear-gradient(#fff,#fef2f2);border-color:#ef4444}.estadistica-card.para-levantar{background:linear-gradient(#fff,#fffbeb);border-color:#f59e0b}.estadistica-header{text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin-bottom:.25rem;font-size:.625rem;font-weight:700}.estadistica-card.operativo .estadistica-header{color:#16a34a}.estadistica-card.no-operativo .estadistica-header{color:#dc2626}.estadistica-card.para-levantar .estadistica-header{color:#d97706}.estadistica-valor{color:#1f2937;margin-bottom:.125rem;font-size:1.125rem;font-weight:700;line-height:1.2}.estadistica-porcentaje{color:#6b7280;font-size:.8125rem;font-weight:600}.modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;padding:1.5rem;display:flex}@media (width<=768px){.modal-auditoria{max-width:100%}.auditoria-table{font-size:.75rem}.auditoria-table th,.auditoria-table td{padding:.5rem}.obs-cell{max-width:150px}.porcentaje-label{font-size:.75rem}.auditoria-porcentajes-bar{height:40px}}.estado-flota-container{max-width:1600px}.page-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.btn-exportar-excel{color:#fff;cursor:pointer;white-space:nowrap;background:#10b981;border:none;border-radius:6px;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:600;transition:all .2s;box-shadow:0 1px 3px #0000001a}.btn-exportar-excel:hover{background:#059669;box-shadow:0 2px 5px #00000026}.btn-exportar-excel:active{transform:translateY(1px)}.filtros-section{background:#fff;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.filtros-row{grid-template-columns:2fr 1fr 1.5fr 1fr auto;align-items:center;gap:1rem;display:grid}.filtro-buscar,.filtro-select{border:1px solid #d1d5db;border-radius:6px;padding:.625rem .875rem;font-size:.9375rem;transition:all .2s}.filtro-buscar:focus,.filtro-select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.btn-limpiar{color:#374151;cursor:pointer;white-space:nowrap;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;transition:all .2s}.btn-limpiar:hover{background:#e5e7eb;border-color:#9ca3af}.tabla-section{background:#fff;border-radius:8px;flex-direction:column;max-height:calc(100vh - 320px);display:flex;overflow:hidden;box-shadow:0 1px 3px #0000001a}.loading-message,.error-message,.empty-message{text-align:center;color:#6b7280;padding:3rem 1rem;font-size:1rem}.error-message{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin:1.5rem}.tabla-wrapper{flex:1;max-height:100%;overflow:auto}.internos-table{border-collapse:collapse;width:100%;font-size:.875rem}.internos-table thead{z-index:10;background:#f9fafb;border-bottom:2px solid #e5e7eb;position:sticky;top:0}.internos-table th{text-align:left;color:#374151;white-space:nowrap;padding:.75rem .625rem;font-size:.8125rem;font-weight:600}.internos-table td{color:#1f2937;border-bottom:1px solid #f3f4f6;padding:.75rem .625rem;font-size:.8125rem}.internos-table tbody tr:hover{opacity:.9;box-shadow:0 2px 4px #0000001a}.fila-operativo{background-color:#90ee90!important}.fila-no-operativo{color:#fff;background-color:#ff8080!important}.fila-no-operativo td{color:#fff}.fila-no-operativo .interno-cell{color:#fff;font-weight:700}.fila-para-levantar{color:#fff;background-color:#ff8000!important}.fila-para-levantar td{color:#fff}.fila-para-levantar .interno-cell{color:#fff;font-weight:700}.fila-tareas-programadas{background-color:#ff0!important}.interno-cell{color:#3b82f6;font-weight:600}.dominio-cell{font-weight:500}.obs-cell{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.fecha-cell{white-space:nowrap;color:#6b7280;font-size:.8125rem}.usuario-cell{color:#6b7280;font-size:.8125rem}.acciones-cell{white-space:nowrap}.btn-accion{cursor:pointer;background:#f3f4f6;border:none;border-radius:4px;margin-right:.375rem;padding:.375rem .625rem;font-size:1rem;transition:all .2s}.btn-accion:hover{transform:scale(1.1)}.btn-ver:hover{background:#dbeafe}.btn-editar:hover{background:#fef3c7}.btn-accion:last-child{margin-right:0}@media (width<=1200px){.filtros-row{grid-template-columns:1fr 1fr;gap:.75rem}.btn-limpiar{grid-column:1/-1}}@media (width<=768px){.filtros-row{grid-template-columns:1fr}.internos-table{font-size:.75rem}.internos-table th,.internos-table td{padding:.5rem}.obs-cell{max-width:120px}.page-header h1{font-size:1.5rem}}.pagination-container{background:#fff;border-radius:8px;justify-content:space-between;align-items:center;margin-top:1.5rem;padding:1rem;display:flex;box-shadow:0 1px 3px #0000001a}.pagination-info{color:#6b7280;font-size:.875rem}.pagination-controls{align-items:center;gap:.25rem;display:flex}.pagination-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;min-width:36px;height:36px;padding:.5rem;font-size:.875rem;font-weight:500;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#d1d5db}.pagination-btn.active{color:#fff;background:#1f2937;border-color:#1f2937}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-dots{color:#9ca3af;-webkit-user-select:none;user-select:none;padding:0 .5rem}@media (width<=768px){.pagination-container{flex-direction:column;gap:1rem}.pagination-info{font-size:.75rem}.pagination-btn{min-width:32px;height:32px;font-size:.75rem}}.usuarios-container{max-width:1400px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.page-header h1{color:#1f2937;margin:0 0 .5rem;font-size:2rem;font-weight:700}.page-header p{color:#6b7280;margin:0;font-size:1rem}.btn-nuevo{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:none;border-radius:6px;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;transition:all .2s}.btn-nuevo:hover{background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.buscar-section{background:#fff;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.input-buscar{border:1px solid #d1d5db;border-radius:6px;width:100%;padding:.625rem .875rem;font-size:.9375rem;transition:all .2s}.input-buscar:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.tabla-section{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.usuarios-table{border-collapse:collapse;width:100%;font-size:.875rem}.usuarios-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.usuarios-table th{text-align:left;color:#374151;white-space:nowrap;padding:.875rem;font-weight:600}.usuarios-table td{color:#1f2937;border-bottom:1px solid #f3f4f6;padding:.875rem}.usuarios-table tbody tr:hover{background:#f9fafb}.usuario-cell{color:#3b82f6;font-weight:600}.nombre-cell{font-weight:500}.nivel-badge{white-space:nowrap;border-radius:4px;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;display:inline-block}.nivel-0{color:#6b7280;background:#f3f4f6}.nivel-1{color:#1e40af;background:#dbeafe}.nivel-2{color:#065f46;background:#d1fae5}.nivel-99{color:#92400e;background:#fef3c7}.fecha-cell{color:#6b7280;font-size:.8125rem}.modal-usuario{width:100%;max-width:500px}@media (width<=768px){.page-header{flex-direction:column;align-items:stretch}.btn-nuevo{width:100%}.usuarios-table{font-size:.75rem}.usuarios-table th,.usuarios-table td{padding:.5rem}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1f2937;background:#f3f4f6;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{min-height:100vh}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}
