/* ═══════════════════════════════════════════════════════════════════════════════
   RUTA.CSS — Estilos específicos de la página de ruta
   ══════════════════════════════════════════════════════════════════════════════*/

.btn-back-header {
  color:white; display:flex; align-items:center; padding:6px 8px;
  border-radius:var(--radius-sm); background:rgba(255,255,255,.15);
  border:1.5px solid rgba(255,255,255,.3); margin-right:4px;
  transition:background .2s;
}
.btn-back-header:hover { background:rgba(255,255,255,.25) }

.ruta-panel { padding-bottom: 24px }

.ruta-grid {
  display:grid;
  grid-template-columns: 2fr 140px 1fr auto;
  gap:14px;
  align-items:end;
}
.ruta-grid .campo-wide   { grid-column: 1 / -1 }
.ruta-grid .campo-buscar { grid-column: 1 / -1 }
.ruta-campo-combustible  { grid-column: 1 }
.ruta-campo-desvio       { grid-column: 2 }
.ruta-campo-horario      { grid-column: 3 }

/* Quitar label vacío en horario en escritorio para que quede alineado */
.ruta-campo-horario .btn-horario { width:100% }

/* ── Responsive móvil ────────────────────────────────────────────────── */
@media (max-width:600px) {
  .ruta-grid { grid-template-columns: 1fr 1fr }
  .ruta-grid .campo-wide   { grid-column: 1 / -1 }
  .ruta-grid .campo-buscar { grid-column: 1 / -1 }
  .ruta-campo-combustible  { grid-column: 1 / -1 }
  .ruta-campo-desvio       { grid-column: 1 }
  .ruta-campo-horario      { grid-column: 2 }
}

/* ── Resumen de ruta ─────────────────────────────────────────────────────────── */
.ruta-resumen {
  display:flex; gap:16px; flex-wrap:wrap;
  padding:20px 24px; margin:0 0 8px;
}
.ruta-stat {
  background:var(--blanco); border:1.5px solid var(--g200);
  border-radius:var(--radius-sm); padding:14px 20px;
  display:flex; align-items:center; gap:12px; flex:1; min-width:140px;
}
.ruta-stat-icon { font-size:28px }
.ruta-stat-label { font-size:11px; color:var(--g400); font-weight:600; text-transform:uppercase; letter-spacing:.4px }
.ruta-stat-valor { font-family:"Syne",sans-serif; font-size:22px; font-weight:800; color:var(--texto); line-height:1 }

/* ── Título de sección ───────────────────────────────────────────────────────── */
.ruta-section-title {
  font-family:"Syne",sans-serif; font-size:18px; font-weight:800;
  padding:0 24px 12px; color:var(--texto);
}

/* ── Tabla de gasolineras ────────────────────────────────────────────────────── */
.ruta-tabla-wrap { margin-bottom:8px }

.ruta-tabla {
  width:100%; border-collapse:collapse;
  font-family:"DM Sans",sans-serif; font-size:14px;
}
.ruta-tabla thead th {
  padding:10px 16px; text-align:left;
  background:var(--g100); color:var(--g500);
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.4px;
  border-bottom:2px solid var(--g200);
  position:sticky; top:0;
}
.ruta-tabla tbody tr {
  border-bottom:1px solid var(--g100);
  transition:background .15s; cursor:pointer;
}
.ruta-tabla tbody tr:hover { background:var(--g100) }
.ruta-tabla tbody tr.fila-top { background:linear-gradient(to right,#f0fdf4,var(--blanco)) }
.ruta-tabla tbody tr.fila-top:hover { background:#dcfce7 }
.ruta-tabla td { padding:12px 16px; vertical-align:middle; color:var(--texto) }

.ruta-tabla-overflow { overflow-x:auto; border-radius:var(--radius-sm); border:1.5px solid var(--g200); margin:0 24px }

.td-logo { display:flex; align-items:center; gap:10px; white-space:nowrap }
.td-nombre { font-weight:700; font-size:14px }
.td-ubicacion { font-size:12px; color:var(--g500); margin-top:2px }
.td-precio { font-family:"Syne",sans-serif; font-size:18px; font-weight:800; color:var(--texto); white-space:nowrap }
.td-precio.precio-min { color:var(--verde) }
.td-dist { font-size:13px; color:var(--g500); white-space:nowrap }
.td-km-ruta { font-size:12px; color:var(--g400); margin-top:2px }
.btn-ver-gas {
  background:var(--azul); color:white; border:none;
  padding:6px 14px; border-radius:6px; font-size:12px; font-weight:600;
  font-family:"DM Sans",sans-serif; cursor:pointer; white-space:nowrap;
  transition:opacity .2s;
}
.btn-ver-gas:hover { opacity:.85 }
.badge-tramo {
  display:inline-block; background:var(--azul); color:white;
  font-size:10px; font-weight:700; padding:2px 7px; border-radius:99px;
  margin-left:6px; opacity:.7;
}

/* ── Mapa ────────────────────────────────────────────────────────────────────── */
.ruta-mapa-wrap { margin-bottom:40px }
#mapa-ruta {
  height:480px; margin:0 24px;
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
}

/* ── Marker de gasolinera en ruta ────────────────────────────────────────────── */
.marker-ruta {
  display:flex; align-items:center; justify-content:center;
  padding:4px 8px; border-radius:99px; color:white;
  font-size:11px; font-weight:700; box-shadow:0 2px 8px rgba(0,0,0,.3);
  white-space:nowrap; font-family:"DM Sans",sans-serif; border:2px solid white;
}
.marker-ruta-top { box-shadow:0 2px 12px rgba(22,163,74,.6); border-color:#bbf7d0 }
.marker-origen, .marker-destino {
  font-size:20px; filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));
}

/* ── Estado / error ──────────────────────────────────────────────────────────── */
#estado-ruta { padding:0 24px }

/* ── Dark mode ───────────────────────────────────────────────────────────────── */
body.dark .ruta-stat { background:var(--blanco); border-color:var(--g200) }
body.dark .ruta-tabla thead th { background:var(--g100); color:var(--g500) }
body.dark .ruta-tabla tbody tr.fila-top { background:linear-gradient(to right,#0d2a18,var(--blanco)) }
body.dark .ruta-tabla tbody tr.fila-top:hover { background:#0d2a18 }
body.dark .ruta-tabla-overflow { border-color:var(--g200) }
body.dark .ruta-tabla tbody tr { border-color:var(--g200) }

/* ── Responsive ──────────────────────────────────────────────────────────────── */
@media (max-width:600px) {
  .ruta-resumen { padding:16px; gap:10px }
  .ruta-stat { min-width:120px; padding:12px 14px }
  .ruta-stat-valor { font-size:18px }
  .ruta-tabla-overflow { margin:0 14px }
  #mapa-ruta { height:320px; margin:0 14px }
  .ruta-section-title { padding:0 14px 10px }
  .td-ubicacion { display:none }
  .td-km-ruta { display:none }
}

/* ── Paginación ──────────────────────────────────────────────────────────────── */
.paginacion {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 24px; border-top:1px solid var(--g200); flex-wrap:wrap; gap:10px;
}
.btn-pag {
  background:var(--blanco); border:1.5px solid var(--g200); color:var(--texto);
  padding:8px 18px; border-radius:var(--radius-sm); font-size:13px; font-weight:600;
  font-family:"DM Sans",sans-serif; cursor:pointer; transition:background .2s;
}
.btn-pag:hover:not(:disabled) { background:var(--g100) }
.btn-pag:disabled { opacity:.4; cursor:default }
.pag-info { font-size:13px; color:var(--g500); text-align:center }
.pag-info-simple { padding:12px 24px; font-size:13px; color:var(--g400); text-align:right }

body.dark .btn-pag { background:var(--blanco); border-color:var(--g200) }
body.dark .paginacion { border-color:var(--g200) }

/* ── Marcas ruta ─────────────────────────────────────────────────────────────── */
.ruta-marcas-wrap {
  padding: 0 24px 16px;
  position: relative;
}
@media (max-width:600px) { .ruta-marcas-wrap { padding: 0 14px 14px } }
