body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}: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)}
