body.fuel-page {
  background:
    radial-gradient(circle at top right, rgba(18, 56, 79, 0.08), transparent 24%),
    radial-gradient(circle at left 18%, rgba(143, 60, 42, 0.08), transparent 24%),
    linear-gradient(180deg, #f7f4ee 0%, var(--bg) 100%);
}

.fuel-main {
  padding-bottom: 56px;
}

.fuel-shell {
  display: grid;
  gap: 28px;
}

.fuel-hero {
  display: grid;
  gap: 16px;
}

.fuel-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--brand);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.fuel-kicker::before {
  content: "";
  width: 38px;
  height: 1px;
  background: rgba(143, 60, 42, 0.34);
}

.fuel-hero h1 {
  max-width: min(82%, 1120px);
  margin: 0;
  font-size: clamp(2.35rem, 4.5vw, 4.2rem);
  line-height: 0.96;
  letter-spacing: -0.04em;
}

.fuel-excerpt {
  max-width: 74ch;
  margin: 0;
  color: var(--muted);
  font-size: 1.12rem;
  line-height: 1.72;
}
:root{
    --bg:#f4f0e9;
    --surface:#ffffff;
    --surface-soft:#fcfaf7;
    --surface-accent:#f3ede5;
    --border:#e4dccf;
    --border-strong:#d6cbbb;
    --text:#17212b;
    --muted:#5e6875;
    --brand:#8f3c2a;
    --brand-soft:#f4e4dc;
    --accent:#12384f;
    --accent-soft:#edf3f6;
    --red:#8f3c2a;
    --amber:#8a5200;
    --green:#1a5c3a;
    --red-bg:#f4e4dc;
    --amber-bg:#fef6e6;
    --green-bg:#e8f5ee;
    --shadow-sm:0 8px 24px rgba(21,26,31,.06);
    --shadow-md:0 20px 42px rgba(21,26,31,.08);
    --radius-xl:18px;--radius-lg:14px;--radius-md:10px;--radius-sm:8px;
    --fd:'Newsreader',Georgia,serif;
    --fb:'Instrument Sans','Helvetica Neue',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    background:
        radial-gradient(circle at top left,rgba(143,60,42,.08),transparent 24%),
        linear-gradient(180deg,#f7f4ee 0%,var(--bg) 100%);
    color:var(--text);font-family:var(--fb);font-size:16px;line-height:1.55;
    -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
a:hover{color:var(--accent)}

/* ── Layout ── */
.ag-bencinas{
    /* width:min(1180px,calc(100% - 40px)); */
    /* margin:0 auto; */
    padding:2rem 0;
}

/* ── Section kicker estilo Autoguía ── */
.section-kicker{
    color:var(--brand);
    text-transform:uppercase;
    letter-spacing:.14em;
    font-size:.85rem;
    font-weight:700;
    margin-bottom:.6rem;
    display:block;
}
.section-label{
    font-family:var(--fd);
    font-size:1.9rem;
    font-weight:700;
    color:var(--text);
    margin-bottom:1.4rem;
    line-height:1.05;
    display:flex;align-items:baseline;gap:.75rem;
}
.section-label small{
    font-family:var(--fb);
    font-size:.9rem;
    font-weight:600;
    color:var(--muted);
    letter-spacing:0;
    margin-left:auto;
}

/* ── Semáforos ── */
.semaforos-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    margin-bottom:2.5rem;
}
@media(max-width:900px){
    .semaforos-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:580px){
    .semaforos-grid{grid-template-columns:1fr}
}
.semaforo-card{
    background:rgba(255,255,255,.82);
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:transform 180ms ease,box-shadow 180ms ease,border-color 180ms ease;
}
.semaforo-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(18,56,79,.12)}
.semaforo-header{
    padding:1rem 1.25rem;
    display:flex;align-items:center;justify-content:space-between;
    border-bottom:1px solid var(--border);
    background:var(--surface-soft);
}
.semaforo-chip{
    font-family:var(--fb);font-size:.85rem;font-weight:700;
    padding:.32rem .9rem;border-radius:999px;color:#fff;
    letter-spacing:.08em;text-transform:uppercase;
}
.semaforo-promedio{text-align:right;font-size:13px;color:var(--muted);line-height:1.3}
.semaforo-promedio strong{display:block;font-size:1.25rem;font-family:var(--fd);font-weight:700;color:var(--brand)}

.semaforo-rows{padding:.1rem 0}
.semaforo-row{
    display:flex;align-items:center;gap:.7rem;
    padding:.8rem 1.25rem;
    border-bottom:1px solid var(--surface-accent);
    transition:background 120ms;
}
.semaforo-row:last-child{border-bottom:none}
.semaforo-row:hover{background:var(--surface-soft)}

.traffic-light{display:flex;flex-direction:column;gap:3px;flex-shrink:0}
.tl-dot{width:10px;height:10px;border-radius:50%;opacity:.14}
.tl-dot.on{opacity:1;box-shadow:0 0 5px currentColor}
.tl-red{background:#c0392b;color:#c0392b}
.tl-amber{background:#c07c00;color:#c07c00}
.tl-green{background:#1a6b3a;color:#1a6b3a}

.sema-logo{width:30px;height:30px;border-radius:5px;object-fit:contain;
    border:1px solid var(--border);background:var(--surface-soft);flex-shrink:0}
.sema-ph{width:30px;height:30px;border-radius:5px;background:var(--surface-accent);
    border:1px solid var(--border);flex-shrink:0;
    display:flex;align-items:center;justify-content:center;font-size:15px}

.row-info{flex:1;min-width:0}
.row-label{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.lbl-red{color:#8f3c2a}.lbl-amber{color:#8a5200}.lbl-green{color:#1a5c3a}
.row-location{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-location a{color:var(--muted)}.row-location a:hover{color:var(--accent)}
.row-price{font-family:var(--fd);font-size:1.55rem;font-weight:700;flex-shrink:0}
.pr-red{color:#8f3c2a}.pr-amber{color:#8a5200}.pr-green{color:#1a5c3a}

/* ── Favoritos ── */
.favs-section{
    background:rgba(255,255,255,.82);
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    box-shadow:var(--shadow-sm);
    padding:1.5rem;
    margin-bottom:2.5rem;
}
.favs-header{margin-bottom:1.1rem;display:flex;align-items:baseline;gap:.75rem}
.favs-title{
    font-family:var(--fd);font-size:1.5rem;font-weight:700;color:var(--text);line-height:1.05;
}
.favs-sub{font-size:.95rem;color:var(--muted)}

.favs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:14px}
.fav-card{
    background:var(--surface-soft);
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:transform 180ms ease,box-shadow 180ms ease,border-color 180ms ease;
    display:flex;flex-direction:column;
}
.fav-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(18,56,79,.12)}
.fav-map{height:130px;width:100%;background:var(--surface-accent);flex-shrink:0;cursor:pointer}
.fav-map-empty{display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--muted)}
.fav-info{padding:.8rem .9rem;display:flex;flex-direction:column;gap:.35rem;flex:1}
.fav-top{display:flex;align-items:flex-start;gap:.55rem}
.fav-logo-wrap{width:40px;height:40px;border-radius:var(--radius-sm);flex-shrink:0;
    border:1px solid var(--border);background:var(--surface);
    display:flex;align-items:center;justify-content:center;overflow:hidden}
.fav-logo-wrap img{width:100%;height:100%;object-fit:contain}
.fav-meta{flex:1;min-width:0}
.fav-nombre{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fav-loc{font-size:13px;color:var(--muted)}
.fav-act{font-size:10px;color:var(--muted);opacity:.7}
.fav-badge{font-size:9px;font-weight:700;letter-spacing:.08em;padding:.15rem .5rem;
    border-radius:999px;text-transform:uppercase;flex-shrink:0;align-self:flex-start}
.fav-badge-ok{background:var(--green-bg);color:var(--green)}
.fav-badge-ko{background:var(--red-bg);color:var(--red)}
.fav-precios{display:flex;gap:.3rem;flex-wrap:wrap}
.fav-pill{background:rgba(18,56,79,.05);border:1px solid var(--border);border-radius:999px;
    padding:.18rem .6rem;font-size:13px;display:flex;gap:.25rem;align-items:center}
.fav-pill .tp{color:var(--muted)}.fav-pill .vl{font-weight:600;color:var(--text)}
.fav-foot{display:flex;justify-content:space-between;align-items:center;
    margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border)}
.btn-unfav{
    background:transparent;border:1px solid var(--border-strong);border-radius:var(--radius-md);
    padding:.25rem .6rem;font-size:11px;font-weight:600;cursor:pointer;
    color:var(--muted);font-family:var(--fb);
    transition:transform 180ms ease,border-color 180ms ease;
}
.btn-unfav:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-1px)}

.empty-favs{text-align:center;padding:2rem;
    background:var(--surface-soft);border:1px dashed var(--border-strong);
    border-radius:var(--radius-sm);color:var(--muted);font-size:13px;margin-bottom:2rem}
.empty-favs .icon{font-size:1.8rem;display:block;margin-bottom:.4rem}

/* ── Buscador ── */
.search-wrap{
    background:rgba(255,255,255,.82);
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    box-shadow:var(--shadow-sm);
    padding:1.25rem;
    margin-bottom:2rem;
}
.search-tabs{
    display:flex;gap:.25rem;margin-bottom:1.1rem;
    border-bottom:1px solid var(--border);padding-bottom:0;
}
.search-tab{
    font-size:.9rem;font-weight:600;padding:.5rem 1rem;cursor:pointer;
    color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;
    transition:color 180ms ease,border-color 180ms ease;user-select:none;
    font-family:var(--fb);
}
.search-tab.active{color:var(--brand);border-bottom-color:var(--brand)}
.search-tab:hover{color:var(--accent)}

.panel{display:none}.panel.active{display:block}
.search-bar{display:flex;gap:.6rem;margin-bottom:.9rem}
#search-input{
    flex:1;background:var(--surface);
    border:1px solid var(--border);border-radius:var(--radius-sm);
    padding:.65rem 1rem;color:var(--text);font-family:var(--fb);font-size:14px;
    outline:none;transition:border-color 180ms ease;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
}
#search-input:focus{border-color:rgba(18,56,79,.34)}
#search-input::placeholder{color:var(--muted)}
.search-filters{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.9rem}
.filter-chip{
    background:var(--surface);border:1px solid var(--border-strong);border-radius:999px;
    padding:.3rem .85rem;font-size:.85rem;font-weight:600;color:var(--muted);
    cursor:pointer;font-family:var(--fb);
    transition:transform 180ms ease,border-color 180ms ease,background 180ms ease;
}
.filter-chip:hover{transform:translateY(-1px);border-color:rgba(18,56,79,.24);box-shadow:var(--shadow-sm)}
.filter-chip.active{
    background:linear-gradient(180deg,#f6e4db,#f3d8cc);
    border-color:rgba(143,60,42,.28);color:var(--brand);
}

/* Navegador región */
.nav-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.9rem;flex-wrap:wrap}
.nav-breadcrumb{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:.3rem;flex:1}
.nav-breadcrumb span{cursor:pointer;transition:color 180ms}.nav-breadcrumb span:hover{color:var(--accent)}
.nav-breadcrumb .sep{color:var(--border-strong)}
.nav-breadcrumb .active-crumb{color:var(--text);font-weight:600;cursor:default}
.nav-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem}
.nav-btn{
    background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);
    padding:.55rem .8rem;cursor:pointer;text-align:left;font-family:var(--fb);
    font-size:.9rem;font-weight:600;color:var(--text);
    transition:transform 180ms ease,border-color 180ms ease,box-shadow 180ms ease;
    display:flex;align-items:center;gap:.4rem;
}
.nav-btn:hover{transform:translateY(-1px);border-color:rgba(18,56,79,.24);box-shadow:var(--shadow-sm)}
.nav-btn .nav-emoji{font-size:.95rem;flex-shrink:0}
.nav-btn .nav-count{margin-left:auto;font-size:.7rem;color:var(--muted);font-weight:400}

/* Marcas */
.marcas-search{
    width:100%;background:var(--surface);
    border:1px solid var(--border);border-radius:var(--radius-sm);
    padding:.6rem 1rem;font-family:var(--fb);font-size:.88rem;
    color:var(--text);outline:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
    transition:border-color 180ms;margin-bottom:.9rem;
}
.marcas-search:focus{border-color:rgba(18,56,79,.34)}
.marcas-search::placeholder{color:var(--muted)}
.marcas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(105px,1fr));gap:.7rem;margin-bottom:.6rem}
.marca-btn{
    background:rgba(255,255,255,.82);border:1px solid var(--border);
    border-radius:var(--radius-sm);padding:.65rem .4rem .55rem;
    cursor:pointer;font-family:var(--fb);font-size:.82rem;font-weight:600;
    color:var(--muted);
    transition:transform 180ms ease,border-color 180ms ease,box-shadow 180ms ease,background 180ms ease;
    display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center;
}
.marca-btn:hover{transform:translateY(-1px);border-color:rgba(18,56,79,.22);box-shadow:var(--shadow-sm);color:var(--accent)}
.marca-btn.active{
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(243,237,229,.92));
    border-color:rgba(18,56,79,.2);color:var(--accent);
    box-shadow:0 0 0 3px rgba(18,56,79,.08);
}
.marca-logo-wrap{width:52px;height:52px;border-radius:var(--radius-sm);overflow:hidden;
    background:var(--surface-soft);border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center}
.marca-logo-wrap img{width:100%;height:100%;object-fit:contain}
.marca-nombre{max-width:82px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.marca-count{font-size:.75rem;font-weight:400;color:var(--muted)}
.marca-btn.active .marca-count,.marca-btn:hover .marca-count{color:var(--accent)}
.marca-btn.hidden{display:none}

/* Resultados */
#search-results,#nav-results,#marca-results{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));
    gap:14px;max-height:520px;overflow-y:auto;padding-right:.2rem;margin-top:.9rem}
#search-results::-webkit-scrollbar,#nav-results::-webkit-scrollbar,#marca-results::-webkit-scrollbar{width:3px}
#search-results::-webkit-scrollbar-thumb,#nav-results::-webkit-scrollbar-thumb,#marca-results::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:2px}
.search-ph{grid-column:1/-1;text-align:center;padding:2rem;color:var(--muted);font-size:1rem}
.search-ph .icon{font-size:1.8rem;display:block;margin-bottom:.4rem}

/* Cards estación */
.estacion-card{
    background:rgba(255,255,255,.82);border:1px solid var(--border);
    border-radius:var(--radius-sm);padding:.85rem 1rem;
    box-shadow:var(--shadow-sm);
    transition:transform 180ms ease,box-shadow 180ms ease,border-color 180ms ease;
}
.estacion-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(18,56,79,.12)}
.estacion-card-header{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.4rem}
.est-logo{width:38px;height:38px;border-radius:var(--radius-sm);flex-shrink:0;
    border:1px solid var(--border);background:var(--surface-soft);
    display:flex;align-items:center;justify-content:center;overflow:hidden}
.est-logo img{width:100%;height:100%;object-fit:contain}
.est-logo .ph{font-size:16px}
.est-info{flex:1;min-width:0}
.est-nombre{font-size:.95rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.est-loc{font-size:.85rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.btn-fav{
    background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);
    padding:.2rem .5rem;font-size:13px;cursor:pointer;color:var(--muted);flex-shrink:0;
    transition:transform 180ms ease,border-color 180ms ease;
}
.btn-fav:hover,.btn-fav.active{transform:translateY(-1px);border-color:var(--brand);color:var(--brand)}
.est-precios{display:flex;gap:.28rem;flex-wrap:wrap;margin:.4rem 0}
.precio-pill{
    background:rgba(18,56,79,.05);border:1px solid var(--border);border-radius:999px;
    padding:.2rem .55rem;font-size:.85rem;display:flex;gap:.25rem;align-items:center}
.precio-pill .tp{color:var(--muted)}.precio-pill .vl{font-weight:600;color:var(--text)}
.card-actions{display:flex;justify-content:space-between;align-items:center;
    margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border)}
.badge{font-size:.75rem;font-weight:700;letter-spacing:.08em;padding:.2rem .6rem;border-radius:999px;text-transform:uppercase}
.badge-ok{background:var(--green-bg);color:var(--green)}.badge-ko{background:var(--red-bg);color:var(--red)}

/* Botón principal */
.btn{
    display:inline-flex;align-items:center;justify-content:center;
    min-height:38px;padding:9px 16px;
    background:var(--accent);color:#fff;border:1px solid transparent;
    border-radius:var(--radius-md);font-family:var(--fb);font-size:.8rem;font-weight:600;
    cursor:pointer;text-decoration:none;
    box-shadow:0 10px 24px rgba(18,56,79,.16);
    transition:transform 180ms ease,box-shadow 180ms ease,background 180ms ease;
}
.btn:hover{background:#0f2c3e;transform:translateY(-1px);box-shadow:var(--shadow-sm);color:#fff;text-decoration:none}
.btn-sm{min-height:36px;padding:7px 14px;font-size:.82rem}

.loader{display:inline-block;width:14px;height:14px;border:2px solid var(--border);
    border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
#toast{position:fixed;bottom:1.25rem;right:1.25rem;
    background:rgba(255,255,255,.96);border:1px solid var(--border);
    border-radius:var(--radius-md);padding:.65rem 1.1rem;
    font-size:.85rem;font-family:var(--fb);color:var(--text);
    box-shadow:var(--shadow-md);z-index:999;
    transform:translateY(80px);opacity:0;transition:all .3s;pointer-events:none}
#toast.show{transform:translateY(0);opacity:1}
@media(max-width:640px){
    .ag-bencinas{width:calc(100% - 24px)}
    .nav-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr))}
}
