body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}.admin-app{color:#e2e8f0;background:#0f1117;min-height:100vh;font-family:inherit;display:flex}.admin-sidebar{background:#1a1d27;border-right:1px solid #2e3248;flex-direction:column;width:220px;min-width:220px;padding:24px 0;display:flex}.admin-logo{border-bottom:1px solid #2e3248;padding:0 20px 24px}.admin-logo-titulo{color:#e2e8f0;font-size:16px;font-weight:700}.admin-logo-sub{color:#8892a4;margin-top:2px;font-size:11px}.admin-nav{flex-direction:column;flex:1;gap:2px;padding:16px 0;display:flex}.admin-nav-link{color:#8892a4;border-radius:0;padding:10px 20px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:block}.admin-nav-link:hover{color:#e2e8f0;background:#22263a}.admin-nav-link.activo{color:#e2e8f0;background:#22263a;border-left:3px solid #4f6ef7}.admin-sidebar-footer{border-top:1px solid #2e3248;flex-direction:column;gap:8px;padding:16px 20px;display:flex}.admin-usuario{color:#8892a4;font-size:12px}.admin-btn-salir{color:#8892a4;cursor:pointer;text-align:center;background:0 0;border:1px solid #2e3248;border-radius:6px;padding:6px;font-size:12px;transition:all .15s}.admin-btn-salir:hover{color:#e2e8f0;background:#2e3248}.admin-contenido{flex:1;padding:32px;overflow-y:auto}.admin-pagina{max-width:900px}.admin-pagina-header{margin-bottom:24px}.admin-pagina-header h1{color:#e2e8f0;font-size:22px;font-weight:700}.admin-card{background:#1a1d27;border:1px solid #2e3248;border-radius:10px;margin-bottom:20px;padding:24px}.admin-card-titulo{color:#8892a4;text-transform:uppercase;letter-spacing:.05em;margin-bottom:20px;font-size:14px;font-weight:600}.admin-form{flex-direction:column;gap:16px;display:flex}.admin-form-fila{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.admin-form-grupo{flex-direction:column;gap:6px;display:flex}.admin-form-grupo label{color:#8892a4;text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:500}.admin-form-grupo input,.admin-form-grupo select,.admin-form-grupo textarea{color:#e2e8f0;background:#0f1117;border:1px solid #2e3248;border-radius:8px;outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.admin-form-grupo input:focus,.admin-form-grupo select:focus,.admin-form-grupo textarea:focus{border-color:#4f6ef7}.admin-form-grupo select option{background:#1a1d27}.admin-form-ayuda{color:#8892a4;margin-top:2px;font-size:11px}.admin-form-seccion{color:#4f6ef7;padding-top:4px;font-size:12px;font-weight:600}.admin-form-acciones{justify-content:flex-end;gap:10px;padding-top:4px;display:flex}.admin-dias{flex-wrap:wrap;gap:6px;display:flex}.admin-dia-btn{color:#8892a4;cursor:pointer;background:0 0;border:1px solid #2e3248;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .15s}.admin-dia-btn:hover{color:#e2e8f0;border-color:#4f6ef7}.admin-dia-btn.activo{color:#fff;background:#4f6ef7;border-color:#4f6ef7}.admin-btn{color:#fff;cursor:pointer;background:#4f6ef7;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .15s}.admin-btn:hover{opacity:.9}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn.secundario{color:#8892a4;background:0 0;border:1px solid #2e3248}.admin-btn.secundario:hover{color:#e2e8f0;background:#2e3248}.admin-btn-editar{color:#8892a4;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #2e3248;border-radius:6px;padding:4px 12px;font-size:12px;transition:all .15s}.admin-btn-editar:hover{color:#4f6ef7;border-color:#4f6ef7}.admin-tabla{border-collapse:collapse;width:100%;font-size:13px}.admin-tabla th{text-align:left;color:#8892a4;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #2e3248;padding:8px 12px;font-size:11px;font-weight:600}.admin-tabla td{color:#e2e8f0;border-bottom:1px solid #2e3248;padding:12px}.admin-tabla tr:last-child td{border-bottom:none}.admin-tabla tr:hover td{background:#22263a}.admin-tabla-vacio{text-align:center;color:#8892a4;padding:32px!important}.admin-dias-texto{color:#8892a4;text-transform:capitalize;font-size:11px}.admin-error{color:#ef4444;background:#ef44441a;border:1px solid #ef4444;border-radius:6px;padding:8px 12px;font-size:13px}.admin-cargando{text-align:center;color:#8892a4;padding:32px}.admin-badge-pendiente{color:#eab308;background:#eab3081a;border-radius:10px;padding:2px 8px;font-size:11px}:root{--fondo:#0f1117;--fondo-panel:#1a1d27;--fondo-tarjeta:#22263a;--borde:#2e3248;--texto:#e2e8f0;--texto-suave:#8892a4;--verde:#22c55e;--verde-fondo:#22c55e14;--amarillo:#eab308;--amarillo-fondo:#eab30814;--rojo:#ef4444;--rojo-fondo:#ef444414;--gris:#64748b;--gris-fondo:#64748b14;--acento:#6366f1}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--fondo);color:var(--texto);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}.pantalla-carga{height:100vh;color:var(--texto-suave);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--borde);border-top-color:var(--acento);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite girar}@keyframes girar{to{transform:rotate(360deg)}}.app{flex-direction:column;min-height:100vh;display:flex}.header{background:var(--fondo-panel);border-bottom:1px solid var(--borde);flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex}.header-titulo{color:var(--texto);font-size:15px;font-weight:600}.header-centro{color:var(--texto-suave);text-transform:capitalize;font-size:13px}.header-derecha{align-items:center;gap:20px;display:flex}.indicador-conexion{align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.indicador-conexion .punto{border-radius:50%;width:7px;height:7px}.indicador-conexion.conectado{color:var(--verde)}.indicador-conexion.conectado .punto{background:var(--verde);animation:2s infinite pulsar}.indicador-conexion.desconectado{color:var(--rojo)}.indicador-conexion.desconectado .punto{background:var(--rojo)}@keyframes pulsar{0%,to{opacity:1}50%{opacity:.4}}.reloj{font-variant-numeric:tabular-nums;color:var(--texto-suave);font-size:13px}.contenido-principal{flex:1;grid-template-columns:1fr 320px;gap:0;height:calc(100vh - 56px);display:grid;overflow:hidden}.panel-rutas{border-right:1px solid var(--borde);padding:20px 24px;overflow-y:auto}.panel-titulo{text-transform:uppercase;letter-spacing:.06em;color:var(--texto-suave);align-items:center;gap:8px;margin-bottom:16px;font-size:13px;font-weight:600;display:flex}.lista-rutas{flex-direction:column;gap:12px;display:flex}.estado-vacio{color:var(--texto-suave);text-align:center;padding:48px 0;font-size:13px}.tarjeta-ruta{background:var(--fondo-tarjeta);border:1px solid var(--borde);border-left-width:4px;border-radius:10px;padding:14px 16px}.tarjeta-ruta.borde-verde{border-left-color:var(--verde)}.tarjeta-ruta.borde-amarillo{border-left-color:var(--amarillo)}.tarjeta-ruta.borde-rojo{border-left-color:var(--rojo)}.tarjeta-ruta.borde-gris{border-left-color:var(--gris)}.tarjeta-cabecera{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.tarjeta-info-principal{align-items:center;gap:10px;display:flex}.tarjeta-nombre{font-size:14px;font-weight:600}.tarjeta-meta{color:var(--texto-suave);margin-top:2px;font-size:12px}.semaforo-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.semaforo-dot.verde{background:var(--verde)}.semaforo-dot.amarillo{background:var(--amarillo)}.semaforo-dot.rojo{background:var(--rojo);animation:1s infinite parpadear}.semaforo-dot.gris{background:var(--gris)}.semaforo-dot.pequeño{width:8px;height:8px}@keyframes parpadear{0%,to{opacity:1}50%{opacity:.3}}.badge-estado{white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;border-radius:20px;padding:3px 8px;font-size:11px;font-weight:600}.badge-estado.estado-en_curso{color:#818cf8;background:#6366f126}.badge-estado.estado-completada{background:var(--verde-fondo);color:var(--verde)}.badge-estado.estado-pendiente{background:var(--amarillo-fondo);color:var(--amarillo)}.badge-estado.estado-sin_ejecucion{background:var(--gris-fondo);color:var(--gris)}.badge-estado.estado-sin_chofer{background:var(--rojo-fondo);color:var(--rojo)}.tarjeta-choferes{flex-direction:column;gap:6px;display:flex}.tarjeta-sin-chofer{color:var(--rojo);padding:8px 0 0;font-size:12px}.fila-chofer{border-radius:6px;grid-template-rows:auto auto;grid-template-columns:1fr auto;gap:2px 8px;padding:8px 10px;display:grid}.fila-chofer.fondo-verde{background:var(--verde-fondo)}.fila-chofer.fondo-amarillo{background:var(--amarillo-fondo)}.fila-chofer.fondo-rojo{background:var(--rojo-fondo)}.fila-chofer.fondo-gris{background:var(--gris-fondo)}.chofer-nombre-wrap{grid-column:1;align-items:center;gap:6px;display:flex}.chofer-nombre{font-size:13px;font-weight:500}.chofer-datos{grid-area:1/2;align-items:center;gap:8px;display:flex}.chofer-eta{color:var(--texto);font-size:12px;font-weight:600}.chofer-distancia{color:var(--texto-suave);font-size:11px}.chofer-razon{color:var(--texto-suave);grid-column:1/-1;margin-top:2px;font-size:11px}.tarjeta-paradas{border-top:1px solid var(--borde);margin-top:10px;padding-top:10px}.paradas-titulo{color:var(--texto-suave);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px}.paradas-lista{flex-wrap:wrap;gap:4px;display:flex}.parada-punto{background:var(--borde);width:24px;height:24px;color:var(--texto-suave);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.parada-punto.completada{background:var(--verde);color:#fff}.panel-alertas{background:var(--fondo-panel);padding:20px 16px;overflow-y:auto}.alertas-lista{flex-direction:column;gap:10px;display:flex}.alertas-vacio{color:var(--texto-suave);flex-direction:column;align-items:center;gap:8px;padding:40px 0;font-size:13px;display:flex}.alertas-vacio-icono{color:var(--verde);font-size:28px}.alerta-item{background:var(--fondo-tarjeta);border:1px solid var(--borde);border-left:3px solid var(--rojo);border-radius:8px;padding:12px}.alerta-cabecera{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.alerta-tipo{color:var(--rojo);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.alerta-hora{color:var(--texto-suave);font-size:11px}.alerta-ruta{margin-bottom:2px;font-size:13px;font-weight:500}.alerta-chofer{color:var(--texto-suave);margin-bottom:10px;font-size:12px}.btn-atender{border:1px solid var(--borde);width:100%;color:var(--texto);cursor:pointer;background:0 0;border-radius:6px;padding:6px;font-size:12px;font-weight:500;transition:background .15s}.btn-atender:hover{background:var(--borde)}.badge-count{background:var(--rojo);color:#fff;text-align:center;border-radius:10px;min-width:18px;padding:1px 6px;font-size:11px;font-weight:700}.badge-count.neutro{background:var(--borde);color:var(--texto-suave)}.login-pantalla{background:var(--fondo);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-caja{background:var(--fondo-panel);border:1px solid var(--borde);border-radius:12px;width:100%;max-width:380px;padding:40px}.login-logo{text-align:center;margin-bottom:32px}.login-logo h1{color:var(--texto);margin-bottom:4px;font-size:20px;font-weight:700}.login-logo p{color:var(--texto-suave);font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.login-campo{flex-direction:column;gap:6px;display:flex}.login-campo label{color:var(--texto-suave);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:500}.login-campo input{background:var(--fondo);border:1px solid var(--borde);color:var(--texto);border-radius:8px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .15s}.login-campo input:focus{border-color:#4f6ef7}.login-error{background:var(--rojo-fondo);border:1px solid var(--rojo);color:var(--rojo);border-radius:6px;padding:8px 12px;font-size:13px}.login-btn{color:#fff;cursor:pointer;background:#4f6ef7;border:none;border-radius:8px;margin-top:4px;padding:12px;font-size:14px;font-weight:600;transition:opacity .15s}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.5;cursor:not-allowed}.header-usuario{color:var(--texto-suave);font-size:13px}.btn-cerrar-sesion{border:1px solid var(--borde);color:var(--texto-suave);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-size:12px;transition:background .15s}.btn-cerrar-sesion:hover{background:var(--borde);color:var(--texto)}
