/* =========================================================
   AUTOBACS • UI CORE (Refactor)
   - Tokens unificados
   - Utilidades
   - Layouts: Header / Footer / Hero
   - Componentes: Slicer, Card, Filtros
   - Páginas: Catálogo, Vehículo, Contacto, Nosotros
   - Responsive unificado
   ========================================================= */

/* ===== Bloque título con barra ===== */
.bloque-ttl {
  display: flex;
  align-items: center;
  gap: 12px;                 /* separación entre barra y texto */
  margin: 32px 0 18px;
}

.bloque-ttl .barra {
  display: inline-block;
  width: 6px;                /* grosor de la barra */
  height: 1.6em;             /* acompaña la altura del h2 */
  background: var(--primary); /* usa tu naranja */
  border-radius: 3px;
  flex-shrink: 0;
}

.bloque-ttl h2 {
  font-size: clamp(1.4rem, 4vw, 2rem);
  font-weight: 700;
  color: var(--fg);
  margin: 0;
}


/* ====== ELEVACIÓN + TIMINGS GLOBALES ====== */
:root{
  --elev-1: 0 6px 18px rgba(0,0,0,.25);
  --elev-2: 0 10px 24px rgba(0,0,0,.35);
  --elev-3: 0 16px 40px rgba(0,0,0,.45);
  --t-fast: .15s;
  --t-base: .2s;
}


/* ====== SLICER: SCROLLBAR DISCRETA (desktop) ====== */
@media (pointer: fine){
  .slicer__track::-webkit-scrollbar{ height:8px }
  .slicer__track::-webkit-scrollbar-thumb{
    background: linear-gradient(90deg, rgba(255,255,255,.16), rgba(255,255,255,.06));
    border-radius: 10px; border: 2px solid transparent; background-clip: padding-box;
  }
  .slicer__track:hover::-webkit-scrollbar-thumb{ background: linear-gradient(90deg, rgba(255,255,255,.26), rgba(255,255,255,.12)); }
}



/* ====== CATÁLOGO: EMPTY STATE ====== */
.cat-empty{
  text-align:center; padding:36px 16px; border:1px solid var(--line);
  border-radius:16px; background: #0f0f0f;
}
.cat-empty .ico{
  width:48px; height:48px; margin:0 auto 10px; border-radius:12px;
  display:grid; place-items:center; background: color-mix(in oklab, var(--primary) 18%, transparent);
  color: var(--primary);
}
.cat-empty p{ margin:.25rem 0 1rem; color:#cfcfcf; }
.cat-empty .btn{ padding:.6rem .9rem; }

/* ====== HOVERS FINALES ====== */
.card-auto:hover .ver-mas{ filter: brightness(1.15); text-shadow:0 0 10px color-mix(in oklab, var(--primary) 45%, transparent); }
.somos-gallery img:hover{ transform: translateY(-2px); box-shadow: var(--elev-2); transition: transform var(--t-base), box-shadow var(--t-base); }
.ft-link{ transition: color var(--t-base), border-color var(--t-base); }

/* ====== HEADER FOCUS/HOVER SUTIL ====== */
.menu > li > a:hover{ box-shadow: inset 0 0 0 1px color-mix(in oklab, #fff 12%, transparent); }

.menu { display: none; }
.menu.is-open { display: block; }

/* ===== Breadcrumb ===== */
.abx-bc {
  position: relative; /* necesario para anclar el ::before */
  display: flex;
  align-items: center;
  gap: 6px;
  justify-content: center;
  padding: 12px 20px;
}

/* ===== Línea glow debajo ===== */
.abx-bc::before {
  content: "";
  position: absolute;
  bottom: 0;        /* justo al borde inferior */
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255,176,46,0.85),
    transparent
  );
  filter: drop-shadow(0 0 8px rgba(255,176,46,0.55));
  z-index: 0; /* debajo de las pills */
}

/* ===== Pills y separadores encima ===== */
.abx-bc .crumb,
.abx-bc .crumb-term,
.abx-bc .sep {
  position: relative;
  z-index: 1;
}

/* ===== Pills ===== */
.abx-bc .crumb {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  margin: 15px 4px;
  color: var(--abx-fg);
  text-decoration: none;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: var(--abx-bg-chip);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
  transition: transform .12s ease, 
              box-shadow .12s ease, 
              background-color .12s ease, 
              color .12s;
}

.abx-bc .crumb:hover {
  background: rgba(255,255,255,.10);
  color: #fff;
  box-shadow: 0 0 12px rgba(255,176,46,.25);
  transform: translateY(-1px);
}

/* ===== Separador (chevron) ===== */
.abx-bc .sep {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.abx-bc .sep::before {
  content: "";
  width: 7px;
  height: 7px;
  border-right: 2px solid var(--abx-dim);
  border-top: 2px solid var(--abx-dim);
  transform: rotate(45deg);
  opacity: .85;
}

/* ===== Icono Home ===== */
.abx-bc .i-home { opacity: .9; }

/* ===== Responsivo ===== */
@media (max-width: 680px) {
  .abx-bc { gap: 8px; padding: 8px 10px; }
  .abx-bc .crumb, .abx-bc .crumb-term {
    padding: 6px 10px;
    font-size: .92rem;
  }
}

/* ===== Accesibilidad: reduce motion ===== */
@media (prefers-reduced-motion: reduce) {
  .abx-bc .crumb { transition: none; }
}


/* ====== “Destacado” cinta alternativa (si preferís ribbon) ======
.card-auto__media{ overflow:visible; } 
.badge-ribbon{
  position:absolute; right:-8px; top:12px; z-index:6;
  padding:.35rem .75rem; font:800 12px/1 system-ui;
  color:#111; background:var(--primary); border:1px solid var(--primary-border);
  border-top-left-radius:6px; border-bottom-left-radius:6px; box-shadow:var(--elev-1);
}
*/


/* -----------------------------
   TOKENS (UN SOLO :root)
   ----------------------------- */
/* ÚNICO :root — combina tokens generales + CTK */
:root{
  /* CTK (contacto) */
  --ctk-max: 1320px;
  --ctk-gap: 36px;
  --ctk-pad: clamp(22px, 2vw, 28px);
  --ctk-icon: clamp(64px, 6vw, 96px);
  --ctk-panel-radius: 22px;
  --ctk-card-radius: 20px;
  --ctk-hour-radius: 16px;

  /* Paleta */
  --bg:#010000; --fg:#fafafa; --muted:#bdbdbd;
  --primary:#f19a20;
  --primary-border: color-mix(in oklab, var(--primary) 55%, #6b3a00 0%);
  --primary-hover:  color-mix(in oklab, var(--primary) 92%, #ffffff 8%);
  --primary-glow:   color-mix(in oklab, var(--primary) 65%, #ffd7a1 35%);

  /* Superficies */
  --card:#111;
  --line: color-mix(in oklab, #ffffff 14%, transparent);
  --radius:16px;           /* radios base */
  --card-radius:18px;      /* radios de card */

  /* Layout */
  --container:1400px; --container-xl:1440px;
  --shadow:0 10px 24px rgba(0,0,0,.35);

  /* Cards */
  --ing-gap:24px; --ing-card-h:410px; --ing-body-h:140px;
  --eye-size:56px; --eye-gap:8px;
}

/* -----------------------------
   RESET + BASE
   ----------------------------- */
*{ box-sizing: border-box; }
html, body{ background: var(--bg); color: var(--fg); font-family: Inter, system-ui, Arial, sans-serif; line-height: 1.4; }
a{ color: inherit; text-decoration: none; }
img{ max-width: 100%; display: block; }

/* Contenedores */
.container{ max-width: var(--container); margin: 0 auto; padding: 0 20px; }
.container-xl{ max-width: min(var(--container-xl), 95vw); margin: 0 auto; padding: 0 20px; }

/* Utilidades */
.u-panel{ background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); }
.u-control{
  width: 100%; background: #101010; color: var(--fg);
  border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; outline: none;
}
.u-control:focus{ border-color: var(--primary); box-shadow: 0 0 0 2px rgba(241,154,32,.18); }
.u-titulo{ display: flex; align-items: center; gap: .8rem; margin: 2rem 0 1rem; }
.u-titulo .barra{ width: 4px; height: 24px; background: var(--primary); border-radius: 2px; }

/* Divisor naranja */
.u-divisor, hr.u-divisor{
  width: 100%; height: 1px; margin: 24px 0; border: 0;
  background: linear-gradient(90deg,
    color-mix(in oklab, var(--primary) 20%, transparent) 0%,
    color-mix(in oklab, var(--primary) 55%, transparent) 35%,
    color-mix(in oklab, var(--primary) 90%, transparent) 75%,
    transparent 100%);
  position: relative;
}
.u-divisor::after, hr.u-divisor::after{
  content: ""; position: absolute; right: 0; top: 50%; transform: translate(50%,-50%);
  width: 140px; height: 14px; pointer-events: none; opacity: .9;
  background: radial-gradient(60px 10px at right center, var(--primary-glow) 0%, color-mix(in oklab, var(--primary) 40%, transparent) 40%, transparent 80%);
}
.u-divisor--simetrico::before{
  content: ""; position: absolute; left: 0; top: 50%; transform: translate(-50%,-50%); width: 140px; height: 14px; opacity: .9;
  background: radial-gradient(60px 10px at left center, var(--primary-glow) 0%, color-mix(in oklab, var(--primary) 40%, transparent) 40%, transparent 80%);
}

/* Botones (unificados) */
.btn,

.btn--wpp,
.btn-wpp{
  background: var(--primary) !important;
  color: #111 !important;
  border: 1px solid var(--primary-border) !important;
  display: inline-block; padding: 12px 16px; border-radius: 12px; font-weight: 700; transition: filter .2s ease;
}
.btn:hover,
.btn--wpp:hover,
.btn-wpp:hover{ filter: brightness(1.06); }
.btn.outline{ background: transparent !important; color: var(--fg) !important; border-color: var(--primary) !important; }
.btn-outline-orange{ background: transparent; color: var(--fg); border: 2px solid var(--primary); }
.btn-outline-orange:hover{ background: color-mix(in oklab, var(--primary) 15%, transparent); box-shadow: 0 0 12px rgba(241,154,32,.4); }

/* WhatsApp FAB */
.abx-wa{
  position: fixed; right: 18px; bottom: 18px; width: 54px; height: 54px;
  display: grid; place-items: center; border-radius: 999px; background: #25d366; color: #fff;
  box-shadow: 0 10px 22px rgba(0,0,0,.4); z-index: 90;
}

/* ============================
   HEADER (desktop base)
   ============================ */
.site-header{
  position: sticky; top: 0; z-index: 1000;
  background: rgba(11,11,11,.8);
  backdrop-filter: saturate(140%) blur(6px);
  border-bottom: 1px solid var(--line, rgba(255,255,255,.08));
  --hdr-h: 88px;
}
.site-header .container{
  display:flex; align-items:center; justify-content:space-between;
  min-height: var(--hdr-h);
}
.brand img, .brand svg, .custom-logo{ height:80px; width:auto; display:block; }

/* Menú desktop */
.menu{
  margin-left:auto; display:flex; align-items:center; gap:34px; list-style:none;
}
.menu > li > a{
  color:#dcdcdc; padding:10px 12px; border-radius:5px;
  font-weight:600; position:relative; transition:background .15s, color .15s;
  text-decoration:none;
}
.menu > li > a:hover{ background: var(--card, rgba(255,255,255,.05)); color:#fff; }
.menu > li.current-menu-item > a,
.menu > li.current_page_parent > a{ color:#fff; }
.menu > li.current-menu-item > a::after,
.menu > li.current_page_parent > a::after{
  content:""; position:absolute; left:0; right:0; bottom:-10px; height:3px;
  background: var(--primary, var(--brand, #ffa01a)); border-radius:2px;
}

/* CTA del menú (Contacto) — oscuro + borde naranja; mismo look en desktop y mobile */
.menu > li.is-cta > a{
  background:#313131; color:var(--brand, #ffa01a);
  border:2px solid var(--brand, #ffa01a);
  border-radius:6px; font-weight:700; padding:10px 18px;
  box-shadow:none; text-decoration:none; transition:all .25s ease;
}
.menu > li.is-cta > a:hover{
  background:#1a1a1a; color:#fff;
  border-color:var(--brand, #ffa01a);
  box-shadow:0 0 12px rgba(255,160,26,.35);
}

/* Botón hamburguesa (desktop oculto) */
.nav-toggle{ display:none; }

/* ============================
   BOTONES (hero/CTA unificados)
   ============================ */
.veh-cta .btn, .hero .btn, .menu > li.is-cta > a, .btn.btn-outline-orange{
  --btn-h:48px; --btn-r:6px; --btn-x:18px;
  display:inline-flex; align-items:center; justify-content:center;
  min-height:var(--btn-h); min-width:180px;
  padding:12px var(--btn-x); border-radius:var(--btn-r);
  border-width:2px; border-style:solid; line-height:1;
  font-weight:800; text-decoration:none !important; box-shadow:none;
  transition:all .25s ease;
}
/* Secundario (Contactanos / outline) */
.btn.btn-outline-orange{ background:#313131; color:var(--brand, #ffa01a); border-color:var(--brand, #ffa01a); }
.btn.btn-outline-orange:hover{ background:#1a1a1a; color:#fff; border-color:var(--brand, #ffa01a); box-shadow:0 0 12px rgba(255,160,26,.35); }
/* Primario (Ver Catálogo) — naranja elegante */
.hero .btn:not(.btn-outline-orange),
.veh-cta .btn:not(.btn-outline-orange){
  background:var(--brand, #ffa01a); color:#111; border-color:var(--brand, #ffa01a);
}
.hero .btn:not(.btn-outline-orange):hover,
.veh-cta .btn:not(.btn-outline-orange):hover{
  background:#ffb947; border-color:#ffb947; color:#000; box-shadow:0 0 14px rgba(255,160,26,.35);
}

/* ============================
   MOBILE (≤980px)
   ============================ */
@media (max-width:980px){
  /* hamburguesa visible */
.nav-toggle{
  display:grid; place-items:center; margin-left:14px;
  width:44px; height:44px;
  border-radius:0;        /* 👈 sin bordes redondeados */
  border:none;            /* 👈 sin borde */
  background:transparent; /* 👈 solo las 3 líneas */
  cursor:pointer; z-index:110;
}
  .nav-toggle span{ width:24px; height:2px; background:#fff; display:block; border-radius:2px; }
  .nav-toggle span + span{ margin-top:6px; }

  /* drawer del menú: debajo del header, NO lo pisa */
  .menu{
    position:absolute; top:100%; left:0; right:0;
    display:none; flex-direction:column; gap:0;
    padding:10px 14px 16px;
    background:
      radial-gradient(120% 80% at 50% -10%, rgba(255,160,26,.10), transparent 40%),
      #0e0e0f;
    border-top:1px solid rgba(255,255,255,.10);
    box-shadow:0 18px 40px rgba(0,0,0,.55);
    z-index:120;
  }
  .site-header.is-open .menu{ display:flex; }

  /* línea de marca superior del drawer */
  .menu::before{
    content:""; position:absolute; left:0; right:0; top:0; height:2px;
    background:linear-gradient(90deg,
      transparent 0%,
      color-mix(in oklab, var(--brand, #ffa01a) 55%, transparent) 18%,
      color-mix(in oklab, var(--brand, #ffa01a) 98%, transparent) 50%,
      color-mix(in oklab, var(--brand, #ffa01a) 55%, transparent) 82%,
      transparent 100%);
    opacity:.95;
  }

  /* ítems — sin subrayado, mismo radio (6px), base oscura */
  .menu > li{ width:100%; }
  .menu > li + li{ margin-top:6px; }
  .menu > li > a,
  .menu > li > a:hover,
  .menu > li > a:active{ text-decoration:none !important; }
  .menu > li > a{
    width:100%; display:flex; align-items:center; justify-content:space-between;
    padding:14px 12px; border-radius:6px;    /* ← igual que CTA */
    background:rgba(255,255,255,.02);
    border:1px solid rgba(255,255,255,.08);
    color:#eaeaea; font-weight:800; letter-spacing:.2px;
  }
  /* hover (solo puntero fino) */
  @media (pointer:fine){
    .menu > li > a:hover{
      color:#fff;
      background:linear-gradient(180deg,
        color-mix(in oklab, var(--brand, #ffa01a) 10%, transparent) 0%,
        color-mix(in oklab, var(--brand, #ffa01a) 4%,  transparent) 100%);
      border-color: color-mix(in oklab, var(--brand, #ffa01a) 25%, #000 75%);
    }
  }

  /* ACTIVO — degradado naranja sutil (no sólido) */
  .menu > li.current-menu-item > a,
  .menu > li.current_page_parent > a{
    background: linear-gradient(
      180deg,
      color-mix(in oklab, var(--brand, #ffa01a) 16%, transparent) 0%,
      color-mix(in oklab, var(--brand, #ffa01a) 8%,  transparent) 100%
    );
    border-color: color-mix(in oklab, var(--brand, #ffa01a) 35%, #000 65%);
    color:#fff;
    box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--brand, #ffa01a) 35%, transparent);
  }

  /* CTA conserva su radio y borde (por si otra regla lo pisa) */
  .menu > li.is-cta > a{ border-radius:6px; }

  /* foco accesible */
  .menu > li > a:focus-visible{
    outline:2px solid color-mix(in oklab, var(--brand, #ffa01a) 85%, #fff 15%);
    outline-offset:2px;
  }

  /* Backdrop + scroll‑lock (usa .nav-backdrop creado por JS) */
/* Backdrop que SOLO cubre el menú, no toda la pantalla */
.nav-backdrop {
  position: absolute;
  top: 100%; /* arranca debajo del header */
  left: 0;
  right: 0;
  bottom: auto;
  height: 100vh;  /* opcional: podés ajustar */
  background: rgba(0, 0, 0, .45);
  backdrop-filter: blur(2px);
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
}


/* cuando el menú está abierto */
.site-header.is-open + .nav-backdrop {
  opacity: 1;
  pointer-events: auto;
}
html.nav-open, html.nav-open body{ overflow:hidden; }
}

/* Estado por defecto desktop (por si hay sobrescrituras abajo) */
@media (min-width:981px){
  .nav-toggle{ display:none !important; }
  .menu{ position:static !important; display:flex !important; flex-direction:row !important; }
}
/* === Unificar CTA (menu y hero) === */
.menu > li.is-cta > a,
.btn.btn-outline-orange {
  background:transparent !important;
  color:var(--brand, #ffa01a) !important;
  border:2px solid var(--brand, #ffa01a) !important;
  border-radius:6px !important;
  margin-top: 10px;
  font-weight:700;
  padding:10px 18px;
  box-shadow:none;
  text-decoration:none !important;
  transition:all .25s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:180px;      /* igual al resto de botones */
  min-height:48px;
}
.menu > li.is-cta > a:hover,
.btn.btn-outline-orange:hover {
  background:#1a1a1a !important;
  color:#fff !important;
  border-color:var(--brand, #ffa01a) !important;
  box-shadow:0 0 12px rgba(255,160,26,.35);
}

/* === Mobile: eliminar subrayado del activo === */
@media (max-width:980px){
  .menu > li.current-menu-item > a::after,
  .menu > li.current_page_parent > a::after {
    display:none !important;
  }
}

/* Botón hamburguesa: sin borde ni radio, solo 3 líneas */
@media (max-width:980px){
  .nav-toggle{
    display:grid; place-items:center; margin-left:14px;
    width:44px; height:44px;
    border:0; background:transparent; box-shadow:none; border-radius:0; /* ⬅️ */
    cursor:pointer; z-index:110;
  }
  .nav-toggle span{
    width:24px; height:2px; background:#fff; display:block; border-radius:0; /* ⬅️ */
  }
  .nav-toggle span + span{ margin-top:6px; }
}

/* Backdrop GLOBAL que cubre siempre todo el viewport */
.nav-backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(2px);
  z-index:100; opacity:1; transition:opacity .2s ease;
}
.nav-backdrop[hidden]{ opacity:0; pointer-events:none; }

/* Al abrir, fijamos el header y el menú al viewport */
@media (max-width:980px){
  .site-header{ position:sticky; top:0; z-index:1000; }

  .site-header.is-open{
    position:fixed; /* ⬅️ deja de “depender” del contenedor */
    top:0; left:0; right:0;
  }

  /* El drawer ahora es fixed y arranca debajo del header */
  .site-header .menu{
    position:fixed; /* ⬅️ antes: absolute */
    top:var(--hdr-h, 88px); left:0; right:0;
    max-height:calc(100vh - var(--hdr-h, 88px));
    overflow:auto;
    display:none;
    flex-direction:column; gap:0;
    padding:10px 14px 16px;
    background:
      radial-gradient(120% 80% at 50% -10%, rgba(255,160,26,.10), transparent 40%),
      #0e0e0f;
    border-top:1px solid rgba(255,255,255,.10);
    box-shadow:0 18px 40px rgba(0,0,0,.55);
    z-index:120; /* sobre el backdrop */
  }
  .site-header.is-open .menu{ display:flex; }

  /* Evitá que la página se desplace por debajo */
  html.nav-open, html.nav-open body{ overflow:hidden; }
}


/* ===== Footer ===== */
.site-footer{background:#0b0b0b;color:#e8e8e8}
.site-footer .container{padding:28px 16px}
.ft-grid{display:grid;gap:28px;grid-template-columns:1.1fr .6fr .9fr}
@media (max-width:1100px){.ft-grid{grid-template-columns:1fr 1fr}}
@media (max-width:720px){.ft-grid{grid-template-columns:1fr}}

.ft-logo img,.ft-logo svg,.site-footer .custom-logo{height:54px;width:auto;display:block;margin:4px 0 8px}
.ft-tag{color:#cfcfcf;max-width:44ch;margin:8px 0 14px}
.ft-social{display:flex;gap:14px}
.ft-social a{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:10px;background:#141414;
  color:#fff;border:1px solid rgba(255,255,255,.12)}
.ft-social a:hover{background:#1c1c1c;border-color:rgba(255,255,255,.2)}

.ft-title{font-weight:800;margin:0 0 10px;color:#fff}
.ft-menu{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.ft-menu a{color:#e8e8e8;text-decoration:none}
.ft-menu a:hover{color:#fff}

.ft-link{color:#e8e8e8;text-decoration:none;border-bottom:1px solid transparent}
.ft-link:hover{color:#fff;border-color:var(--primary)}

.ft-sep{height:2px;background:linear-gradient(90deg,var(--primary) 0%,rgba(41, 41, 41, 0.15) 50%,var(--primary) 100%);opacity:.9}

.ft-bottom{display:flex;align-items:center;justify-content:space-between;padding:14px 16px}
.ft-copy{color:#d6d6d6}
.ft-by{color:#cfcfcf}
.ft-by .ft-mark{font-weight:800;letter-spacing:.8px}
@media (max-width:720px){
  .ft-bottom{flex-direction:column;gap:8px;text-align:center}
}


.site-footer{ position:relative; overflow:visible; isolation:isolate; }
.site-footer .ft-brandline{
  position:absolute; left:0; right:0; top:0;
  height: var(--line-thick, 2px);
  z-index:2; pointer-events:none;
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in oklab, var(--brand, #ffa01a) 55%, transparent) 18%,
    color-mix(in oklab, var(--brand, #ffa01a) 98%, transparent) 50%,
    color-mix(in oklab, var(--brand, #ffa01a) 55%, transparent) 82%,
    transparent 100%
  );
}
.site-footer .ft-brandline::after{
  content:""; position:absolute; left:0; right:0; top:0;
  height: var(--glow-height, 14px);
  z-index:1;
  background: radial-gradient(
    140% 220% at 50% 0%,
    color-mix(in oklab, var(--brand, #ffa01a) 24%, transparent) 0%,
    color-mix(in oklab, var(--brand, #ffa01a) 10%, transparent) 55%,
    transparent 75%
  );
  filter: blur(6px);
}
/* ===== Footer: separador fino y uniforme ===== */
.site-footer .ft-sep{
  height: 1px;              /* línea bien fina */
  background: var(--primary); /* usa tu color de marca */
  opacity: .9;              /* sutil, no chillón */
  border: 0;
  box-shadow: none;         /* sin brillos extra */
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in oklab, var(--brand, #ffa01a) 55%, transparent) 18%,
    color-mix(in oklab, var(--brand, #ffa01a) 98%, transparent) 50%,
    color-mix(in oklab, var(--brand, #ffa01a) 55%, transparent) 82%,
    transparent 100%
  );

}

.social-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  color: var(--accent-color, #25D366); /* el color principal de tu marca */
  background: rgba(255,255,255,0.05); /* leve fondo translúcido */
  backdrop-filter: blur(6px);
  transition: all 0.35s ease;
  position: relative;
  overflow: hidden;
}

.social-icon svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  fill: none;
}

.social-icon:hover {
  color: #fff; /* icono blanco */
  background: var(--accent-color, #f19a20);
  box-shadow: 0 0 15px var(--accent-color, #f19a20); /* efecto glow */
  transform: translateY(-3px) scale(1.05);
}

/* -----------------------------
   HERO (home)
   ----------------------------- */
   /* ===== Hero: divisor inferior elegante ===== */
.hero{
  position: relative;
  overflow: visible;               /* deja respirar el halo */
  --brand: var(--brand, #ffa01a);  /* usa tu token si ya existe */
}

/* línea nítida + fade lateral */
.hero .u-divisor--full{
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: var(--line-thick, 2px);
  border: 0; margin: 0; padding: 0;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in oklab, var(--brand) 55%, transparent) 18%,
    color-mix(in oklab, var(--brand) 98%, transparent) 50%,
    color-mix(in oklab, var(--brand) 55%, transparent) 82%,
    transparent 100%
  );
}

/* halo elegante al centro (más grueso visualmente) */
.hero .u-divisor--full.u-divisor--simetrico::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom: calc(-1 * var(--glow-h, 14px) / 2);
  height: var(--glow-h, 14px);
  background: radial-gradient(
    140% 220% at 50% 100%,
    color-mix(in oklab, var(--brand) 28%, transparent) 0%,
    color-mix(in oklab, var(--brand) 10%, transparent) 55%,
    transparent 75%
  );
  filter: blur(6px);
  pointer-events:none;
}

/* ajuste sutil en mobile */
@media (max-width: 520px){
  .hero .u-divisor--full{ height: 1.5px; }
  .hero .u-divisor--full.u-divisor--simetrico::after{ height: 10px; }
}

.hero{
  min-height: 78vh; display: grid; place-items: center; text-align: center;
  background: url('../img/hero-desktop.jpg') center / cover no-repeat; position: relative; border-bottom: 0;
}
.por-que{padding:40px 0}
.por-que__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.por-que__grid>div{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px}

.somos{padding:40px 0}
.galeria{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gal-item{background:linear-gradient(135deg,#1f1f1f,#0f0f0f);aspect-ratio:16/10;border-radius:12px;border:1px solid var(--line)}

.faq{padding:40px 0;border-top:1px solid var(--line)}
details{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}

@media (max-width: 768px){ .hero{ background-image: url('../img/hero-mobile.jpg'); } }
.hero .u-divisor--full{ position: absolute; left: 0; right: 0; bottom: 0; margin: 0; height: 1px; border: 0; }
.hero-title-primary{ color: var(--primary); font-size: clamp(38px, 6vw, 64px); font-weight: 800; line-height: 1.05; }
.hero-title-secondary{ color: var(--fg); font-size: clamp(38px, 6vw, 64px); font-weight: 800; line-height: 1.05; }

/* ===== Hero: línea inferior elegante (brand line) ===== */
.hero{
  position: relative;
  overflow: visible !important;           /* por si algo la recorta */
  isolation: isolate;                     /* stacking limpio */
  --brand: #ffa01a;                       /* usa tu token si ya existe */
  --line-thick: 2px;                      /* grosor de la línea nítida */
  --glow-height: 14px;                    /* alto del halo */
}

/* Línea nítida con más peso en el centro y fade a los lados */
.hero::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height: var(--line-thick);
  z-index: 1;
  pointer-events:none;
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in oklab, var(--brand) 55%, transparent) 18%,
    color-mix(in oklab, var(--brand) 98%, transparent) 50%,
    color-mix(in oklab, var(--brand) 55%, transparent) 82%,
    transparent 100%
  );
}

/* Halo/Glow elegante centrado */
.hero::before{
  content:"";
  position:absolute; left:0; right:0; bottom: calc(-1 * var(--glow-height) / 2);
  height: var(--glow-height);
  z-index: 0;                              /* por debajo de la línea nítida */
  pointer-events:none;
  background: radial-gradient(
    140% 220% at 50% 100%,
    color-mix(in oklab, var(--brand) 28%, transparent) 0%,
    color-mix(in oklab, var(--brand) 10%, transparent) 55%,
    transparent 75%
  );
  filter: blur(6px);
}

/* Mobile: un toque más fino */
@media (max-width:520px){
  .hero{ --line-thick: 1.5px; --glow-height: 10px; }
}

/* Si mantenés el <hr>, lo ocultamos (queda de “marcador” por si lo necesitás) */
.hero .u-divisor--full{ display:none !important; }


/* =========================================================
   COMPONENTE: SLICER (scroll-snap)
   ========================================================= */
.slicer{ position: relative; margin-block: 8px; }
.slicer__track {
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
}
.slicer__track::-webkit-scrollbar{ display: none; }
.slicer__item{ flex: 0 0 calc(100%/3.5 - var(--ing-gap)*.7); 
                scroll-snap-align: start; 
                background: transparent; 
                border: 0; 
                box-shadow: none; padding: 0; }


/* Flechas */
.slicer__btn{
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 42px; height: 42px; display: grid; place-items: center; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12); background: #141414; color: #fff;
  box-shadow: 0 10px 24px rgba(0,0,0,.45); z-index: 2;
}
.slicer__btn::before{ content: ""; width: 12px; height: 12px; border-top: 2px solid currentColor; border-right: 2px solid currentColor; display: block; }
.slicer__btn.is-prev{ left: -4px; } .slicer__btn.is-prev::before{ transform: rotate(-135deg); }
.slicer__btn.is-next{ right: -4px; } .slicer__btn.is-next::before{ transform: rotate(45deg); }
.slicer__btn[hidden]{ display: none; }


/* ===== SLICER: overrides no-destructivos (solo capa superior) ===== */

/* Aísla el stacking para que las flechas queden verdaderamente arriba */
.slicer{ isolation:isolate; }

/* Por defecto (mobile y tablets chicas): ocultar flechas */
@media (max-width:1023.98px){
  .slicer .slicer__btn{
    display: none !important;
  }
}

/* Desktop: solo mostramos flechas, sin cambiar tu layout ni el ancho de cards */
@media (min-width:1024px){
  .slicer .slicer__btn{
    display: grid;                 /* se ven en desktop */
    pointer-events: auto;          /* aseguran clic encima del carrusel */
    z-index: 9;                    /* por encima de imágenes/hover */
  }

  /* Opcional: scroll suave sin tocar tu overflow-x */
  .slicer .slicer__track{
    scroll-behavior: smooth;
    overscroll-behavior-x: contain; /* evita “rebote” lateral */
  }
}

/* (Opcional) si algún overlay hover tapara las flechas, forzá que no capte clics */
@media (min-width:1024px){
  .slicer .card-auto__hover,
  .slicer .card-auto__stretched{
    pointer-events: none;
  }
}


/* ===============================
   CARD AUTO • Skin Pro (con media sólida)
   =============================== */

:root{
  --card-radius: 18px;
  --primary: #ffa01a;
  --primary-border: #c97a10;
  --t-base: .22s ease;
  --t-fast: .14s ease;
  --abx-fg: #fff;
}

/* Base del card */
.card-auto{
    --pad-x: 16px;          /* padding horizontal del body/footer */
  --pad-y: 12px;          /* padding superior del body */
  --footer-h: 58px;
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
  border-radius: var(--card-radius);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(130deg, rgba(255,255,255,.04) 0%, transparent 18%) 0 0/100% 100% no-repeat,
    radial-gradient(120% 160% at 10% -10%, rgba(255,160,26,.06), transparent 25%),
    radial-gradient(120% 160% at 120% 120%, rgba(255,160,26,.05), transparent 40%),
    #0f0f0f;
  box-shadow: 0 8px 30px rgba(0,0,0,.35);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background-color .22s ease;
}

/* Borde brillante animado */
.card-auto::before{
  content:""; position:absolute; inset:0; padding:1px; border-radius:inherit; z-index:0;
  background: conic-gradient(from 0turn at 50% 50%,
    transparent 0deg,
    color-mix(in oklab, var(--primary) 75%, #fff 10%) 60deg,
    transparent 120deg,
    transparent 240deg,
    color-mix(in oklab, var(--primary) 75%, #fff 10%) 300deg,
    transparent 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: .9; pointer-events:none;
  animation: cardauto-rotate 7s linear infinite;
}
@keyframes cardauto-rotate { to { transform: rotate(1turn); } }

.card-auto:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
  border-color: rgba(255,255,255,.14);
}

/* ===============================
   MEDIA (IMAGEN) – sólida y nítida
   =============================== */
.card-auto__media{
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 24/16 ;          /* <-- definición estable */
}

/* La imagen llena SIEMPRE el frame */
.card-auto__media img,
.card-auto__img{
  position: absolute; inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .35s ease, filter .2s ease;
}

/* Hover sutil sin blur caro */
.card-auto__media:hover .card-auto__img{
  transform: scale(1.02);
  filter: brightness(.98) saturate(1.03);
}

/* Degradé de apoyo para texto/hover */
.card-auto__media::after{
  content:""; position:absolute; left:0; right:0; bottom:0; z-index:3;
  height: clamp(70px,26%,110px);
  background: linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,.22) 45%, rgba(0,0,0,.60) 95%, rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

/* Overlay “Ver más” centrado (opcional) */
.card-auto__hover{
  position:absolute; inset:0; z-index:4;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:700;
  background: rgba(0,0,0,.45);
  opacity:0; transition: opacity .25s ease;
}
.card-auto:hover .card-auto__hover{ opacity:1; }

/* ===============================
   BADGES
   =============================== */
.card-auto__badges{
  position:absolute; left:10px; top:10px; z-index:6;
  display:flex; gap:8px; flex-wrap:wrap; pointer-events:none;
}
.badge{
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.28rem .55rem; border-radius:999px;
  font: 800 12px/1.1 system-ui, Inter, Arial;
  color:#111; background: var(--primary); border:1px solid var(--primary-border);
  box-shadow: 0 6px 16px rgba(0,0,0,.25);
}
.badge--estado{
  color:#fff; background: rgba(0,0,0,.55);
  border-color: rgba(255,255,255,.18);
  backdrop-filter: blur(4px);
}
.badge--destacado{ background: var(--primary); }

/* ===============================
   BODY
   =============================== */
/* Body: más compacto entre bloques y con “aire” a los bordes */
.card-auto__body{
  position: relative;
  /* reservamos lugar para el footer fijo + un colchón extra */
  padding: var(--pad-y) var(--pad-x) calc(var(--footer-h) + 16px);
  /* unificamos bloques: menos separación vertical */
  display: block;
  overflow: hidden;

  /* fondo con brillo cálido sutil (vuelve el glow primario) */
  background:
    radial-gradient(120% 120% at 30% 0%, color-mix(in oklab, var(--primary, #ffa01a) 14%, transparent) 0%,
                                              transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, #141414 65%,
                    color-mix(in oklab, var(--primary, #ffa01a) 8%, #1a1a1a) 100%);
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
}

/* título más cercano al resto y truncado (2 líneas) */
.card-auto__titulo{ margin: 2px 0 4px; }
.card-auto__title-link{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  white-space:normal;
  line-height:1.18;
}
.card-auto:hover .card-auto__title-link{
  color: var(--primary);
  text-shadow: 0 0 10px color-mix(in oklab, var(--primary) 35%, transparent);
}

/* Meta / sub */
/* meta y sub más juntos */
.card-auto__meta,
.card-auto__sub{
  display:flex; flex-wrap:wrap; align-items:center;
  gap: .35rem .55rem;          /* antes era más grande */
  margin-top: 2px;
}
.card-auto__sub{ margin-top: 0; }.card-auto__meta{ color:#d7d7d7; }
.card-auto__sub{ color:#c9c9c9; }

.card-auto__meta .punto, .card-auto__sub .punto{
  width:.45rem; height:.45rem; border-radius:999px; display:inline-block;
  background: radial-gradient(circle at 30% 30%, #fff, var(--primary) 70%);
  box-shadow: 0 0 0 2px rgba(255,160,26,.12);
}

/* Divider sutil antes del footer */
/* meta y sub más juntos */
.card-auto__meta,
.card-auto__sub{
  display:flex; flex-wrap:wrap; align-items:center;
  gap: .35rem .55rem;          /* antes era más grande */
  margin-top: 2px;
}
.card-auto__sub{ margin-top: 0; }





/* ===============================
   Responsivo fino
   =============================== */
@media (max-width: 720px){
  .card-auto__title-link{ font-size: 1rem; }
  .card-auto__meta, .card-auto__sub{ font-size: .88rem; }
}




.home-bloque .slicer .card-auto .ver-mas::before,
.home-bloque .slicer .card-auto .ver-mas::after{
  content: none !important; /* por si hay pseudo-elementos que cambian la forma */
}

.home-bloque .slicer .card-auto .ver-mas .flecha{
  display: inline-block;
  transform: translateX(0);
  transition: transform .22s ease;
}
.home-bloque .slicer .card-auto .ver-mas:hover,
.home-bloque .slicer .card-auto .ver-mas:focus-visible{
  background: color-mix(in oklab, var(--primary) 16%, #000 84%);
  color: #fff;
  border-color: var(--primary);
  box-shadow: 0 4px 12px rgba(0,0,0,.35);
}
.home-bloque .slicer .card-auto .ver-mas:hover .flecha,
.home-bloque .slicer .card-auto .ver-mas:focus-visible .flecha{
  transform: translateX(6px);
}

.catalogo .grid-autos .card-auto .ver-mas .flecha{
  display:inline-block; transform:translateX(0); transition:transform .22s ease;
}
.catalogo .grid-autos .card-auto .ver-mas:hover,
.catalogo .grid-autos .card-auto .ver-mas:focus-visible{
  background: color-mix(in oklab, var(--primary) 16%, #000 84%);
  color:#fff; border-color: var(--primary);
  box-shadow: 0 4px 12px rgba(0,0,0,.35);
}
.catalogo .grid-autos .card-auto .ver-mas:hover .flecha,
.catalogo .grid-autos .card-auto .ver-mas:focus-visible .flecha{
  transform: translateX(6px);
}


/* Stretched link se mantiene detrás para no interferir hovers */
.card-auto__stretched{ position:absolute; inset:0; z-index:0; display:block; }

/* Overlay “ojo” más sutil (manteniendo el tuyo) */
.card-auto__hover{
  position:absolute; inset:0; z-index:4; display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transform: translateY(6px);
  transition: opacity .2s ease, visibility .2s ease, transform .2s ease;
  pointer-events:none;
  background: radial-gradient(260px 220px at center, rgba(0,0,0,.35), rgba(0,0,0,0) 70%);
  border-radius: var(--card-radius);
}
.card-auto__media:is(:hover, :focus-visible, :active) .card-auto__hover{
  opacity:1; visibility:visible; transform:none;
}
/* Stretched link (debajo de media para no bloquear su hover) */
.card-auto__stretched{ position: absolute; inset: 0; z-index: 0; display: block; }

/* Overlay “ojo”: SOLO sobre la imagen */
.card-auto__hover{
  position: absolute; inset: 0; z-index: 4;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden; transform: translateY(6px);
  transition: opacity .2s ease, visibility .2s ease, transform .2s ease;
  pointer-events: none;
  background: radial-gradient(260px 220px at center, rgba(0,0,0,.35), rgba(0,0,0,0) 70%);
  border-radius: var(--card-radius);
}
.card-auto__media:is(:hover, :focus-visible, :active) .card-auto__hover{
  opacity: 1; visibility: visible; transform: none;
}
.card-auto__hover .eye-wrap{
  width: var(--eye-size); height: var(--eye-size);
  display: grid; place-items: center; border-radius: 50%;
  border: 2px solid #9aa0a6; background: rgba(0,0,0,.35); box-shadow: 0 0 10px rgba(0,0,0,.35);
}
.card-auto__hover .eye{ width: calc(var(--eye-size) - 16px); height: calc(var(--eye-size) - 16px); color: #fff; }
.card-auto__hover .hover-text{
  position: absolute; left: 50%; transform: translateX(-50%);
  top: calc(50% + (var(--eye-size)/2) + var(--eye-gap));
  margin: 0; font-weight: 800; color: #fff; text-shadow: 0 1px 0 rgba(0,0,0,.35);
}
/* Más legible en pantallas chicas */
@media (max-width: 680px){
  .card-auto__title-link{ font-size: 1rem; -webkit-line-clamp: 2; }
  .card-auto .precio{ font-size: 1.02rem; }
  .card-auto__meta, .card-auto__sub{ font-size: .88rem; }
}

@media (prefers-reduced-motion: reduce){
  .card-auto, .card-auto *{ transition:none !important; }
  .card-auto::before{ animation:none; }
}

/* ====== CARD AUTO • Presence Boost (add-on) ====== */

/* 0) Micro-optimizaciones */
.card-auto__img{
  width:100%!important;
  height:100%!important;
  object-fit:cover;
  display:block;
}



/* Ajuste del degradé que baja desde la imagen: que no invada demasiado el texto */
.card-auto__media::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0; z-index:1;
  height: clamp(64px, 22%, 100px);
  background: linear-gradient(to bottom,
              rgba(0,0,0,0) 0%,
              rgba(0,0,0,.18) 45%,
              rgba(0,0,0,.52) 90%,
              rgba(0,0,0,.70) 100%);
  pointer-events:none;
}
/* 4) Fondo de la tarjeta con más presencia (granulado + inner shadow) */
.card-auto{
  background:
    /* diagonales */
    linear-gradient(130deg, rgba(255,255,255,.04) 0%, transparent 18%) 0 0/100% 100% no-repeat,
    /* sutil grain */
    radial-gradient(100% 100% at 50% 50%, rgba(255,255,255,.02), rgba(255,255,255,0) 60%) 0 0/100% 100% no-repeat,
    /* radiales cálidos */
    radial-gradient(120% 160% at 10% -10%, rgba(255,160,26,.06), transparent 45%),
    radial-gradient(120% 160% at 120% 120%, rgba(255,160,26,.05), transparent 50%),
    #0f0f0f;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 8px 30px rgba(0,0,0,.35);
}

/* ====== Reflejo en la parte baja de la tarjeta ====== */

/* Quitamos el sheen de la imagen (si ya lo aplicaste) */
.card-auto__media::before{
  content: none !important;
}

/* ===== Fix: solo bullet dorado ===== */
.card-auto__meta .punto,
.card-auto__sub .punto{
  font-size: 0;          /* oculta el caracter textual */
  line-height: 0;
  position: relative;
  width: 8px; height: 8px;
  border-radius: 999px;
  display: inline-block;
  background: radial-gradient(circle at 30% 30%, #fff, var(--primary,#ffa01a) 70%);
  box-shadow: 0 0 0 2px rgba(255,160,26,.15);
  margin: 0 0px;         /* separa los elementos */
}




/* Respeto por reduce-motion */
@media (prefers-reduced-motion: reduce){
  .card-auto__media::before{ transition: none; }
  .card-auto__media:hover .card-auto__img{ transform:none; filter: none; }
}


/* =========================================================
   CATÁLOGO
   ========================================================= */
.catalogo .cat-header{ margin: 12px 0 22px; }
.catalogo .cat-header h1{ font-size: 2.2rem; margin: 0 0 12px; }

/* Barra de filtros (bleed suave) */
.filtros--full{ --pad: max(20px, (100vw - min(var(--container-xl), 95vw)) / 2); margin-inline: calc(var(--pad) * -1); padding-inline: var(--pad); }
.u-filtros{ padding: 16px; }
.u-filtros__grid{ display: grid; grid-template-columns: 1.2fr .6fr .6fr auto; gap: 12px; }
.campo-busqueda{ display: flex; align-items: center; gap: .6rem; background: #101010; border: 1px solid #2a2a2a; border-radius: 10px; padding: 10px 12px; }
.campo-busqueda .icono{ opacity: .75; }
.campo-busqueda input{ width: 100%; background: transparent; border: 0; outline: none; color: var(--fg); }
.campo-select .lbl{ display: block; font-size: .78rem; color: var(--muted); margin: 2px 0 6px; }
.campo-select select{
  width: 100%; appearance: none; background: #101010; color: var(--fg);
  border: 1px solid #2a2a2a; border-radius: 5px; padding: 10px 12px;
}
.campo-select select:focus{ border-color: var(--primary); box-shadow: 0 0 0 2px rgba(245,158,11,.15); }
.acciones-filtros{ display: flex; gap: 10px; align-items: end; }

/* Grilla de cards */
.grid-autos{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }



/* =======================================================
   SINGLE VEHÍCULO • sistema unificado
   ======================================================= */

   
.veh-single{
  --brand: #ffa01a;
  --brand-ghost: color-mix(in oklab, var(--brand) 70%, #000 30%);
  --brand-border: color-mix(in oklab, var(--brand) 85%, #fff 15%);
  --brand-glow: rgba(255,160,26,.35);

  --panel-1:#121212;
  --panel-2:#0d0d0d;
  --text-1:#fff;
  --text-2:#b9b9b9;
  --muted:#c9c9c9;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.12);

  --r-lg:16px;
  --r-md:12px;
  --r-sm:10px;
  --pad-md:20px;
  --wrap-pad: clamp(12px, 2vw, 18px);
  --col-gap: clamp(18px, 2.2vw, 26px);

  --shadow-lg:0 16px 32px rgba(0,0,0,.45);
  --shadow-sm:0 8px 18px rgba(0,0,0,.26);
}

.single-vehiculo .veh-single{
  width:100%;
  max-width:none;
  margin:0 auto;
  overflow-x:hidden;
}

.veh-single .container,
.veh-single .container-xl{
  width:min(1280px,96vw);
  margin-inline:auto;
}

.veh-single .u-panel{
  background: linear-gradient(90deg,var(--panel-1),var(--panel-2));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.03);
}

.veh-single .u-glow-border{
  position:relative;
  isolation:isolate;
}

.veh-single .u-glow-border::after{
  content:"";
  position:absolute;
  inset:0;
  padding:1px;
  border-radius:inherit;
  z-index:0;
  background: conic-gradient(
    from .25turn at 50% 50%,
    transparent 0deg,
    var(--brand-ghost) 70deg,
    transparent 140deg,
    transparent 220deg,
    var(--brand-ghost) 290deg,
    transparent 360deg
  );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity:.55;
  pointer-events:none;
}

.veh-single .veh-wrap.u-panel{
  padding: var(--wrap-pad);
  border-radius: var(--r-lg);
}

.veh-single .veh-hero-grid{
  display:grid;
  grid-template-columns:1fr;
  gap: var(--wrap-pad);
  align-items:start;
}

.veh-single .veh-hero-grid > *{
  min-width:0;
  max-width:100%;
}

@media (min-width:1024px){
  .veh-single .veh-hero-grid{
    grid-template-columns:minmax(0,2.55fr) minmax(360px,1.45fr);
    column-gap:22px;
  }

  .veh-single .veh-panel{
    position:sticky;
    top:calc(var(--header-h,88px) + 12px);
  }
}

/* -------- GALERÍA -------- */

.veh-single .veh-gal{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:10px;
  width:100%;
}

.veh-single .veh-gal__viewport{
  position:relative;
  isolation:isolate;
  aspect-ratio:16 / 9;
  max-height:min(72vh,720px);
  margin:0;
  overflow:hidden;
  line-height:0;
  border-radius:var(--r-lg)!important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
  touch-action: pan-y;
}

@media (min-width:1024px){
  .veh-single .veh-gal__viewport{
    aspect-ratio:16 / 10;
    max-height:min(60vh,560px);
  }
}

@media (max-width:768px){
  .veh-single .container-xl{
    padding-inline:14px;
  }

  .veh-single .veh-gal{
    gap:8px;
  }

  .veh-single .veh-gal__viewport{
    aspect-ratio:4 / 3;
    max-height:none;
    border-radius:14px!important;
  }
}

.veh-single .veh-gal__viewport::before,
.veh-single .veh-gal__viewport::after,
.veh-single .u-glow-border::after{
  pointer-events:none!important;
}

.veh-single .veh-gal__slide{
  position:absolute;
  inset:0;
  margin:0;
  opacity:0;
  z-index:1;
  overflow:hidden;
  border-radius:inherit;
  pointer-events:none !important;
  transition:opacity .25s ease;
}

.veh-single .veh-gal__slide.is-active{
  opacity:1;
  z-index:2;
}

.veh-single .veh-gal__img{
  position:absolute;
  inset:0;
  width:100%!important;
  height:100%!important;
  display:block;
  object-fit:cover;
  object-position:center;
  border-radius:inherit;
  image-rendering:auto;
  pointer-events:none !important;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  transition: transform .28s ease;
}

@media (hover:hover){
  .veh-single .veh-gal__viewport:hover .veh-gal__img{
    transform:scale(1.01);
  }
}

.veh-single .veh-gal__count{
  position:absolute;
  right:14px;
  bottom:14px;
  z-index:10;
  padding:.35rem .6rem;
  border-radius:999px;
  font:800 13px/1.1 system-ui,Inter,Arial;
  color:#121212;
  background:var(--brand);
  border:1px solid var(--brand-border);
  box-shadow:
    0 0 0 1px rgba(255,160,26,.35),
    0 10px 20px -8px rgba(255,160,26,.35);
}

@media (max-width:520px){
  .veh-single .veh-gal__count{
    font-size:12px;
    padding:.3rem .55rem;
    right:10px;
    bottom:10px;
  }
}

.veh-single .veh-gal__arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:30;
  width:46px;
  height:46px;
  border-radius:999px;
  display:grid;
  place-items:center;
  cursor:pointer;
  pointer-events:auto !important;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px);
  border:1px solid var(--line);
  color:var(--text-1);
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}

.veh-single .veh-gal__arrow.is-prev{ left:14px; }
.veh-single .veh-gal__arrow.is-next{ right:14px; }

.veh-single .veh-gal__arrow:hover{
  background:rgba(0,0,0,.72);
  border-color:color-mix(in oklab, var(--brand) 55%, #000 45%);
  transform:translateY(-50%) scale(1.05);
}

.veh-single .veh-gal__arrow:focus-visible{
  outline:0;
  box-shadow:0 0 0 2px var(--panel-1), 0 0 0 4px var(--brand);
}

.veh-single .veh-gal__arrow::before{
  content:"";
  width:14px;
  height:14px;
  display:block;
  border-top:2px solid currentColor;
  border-right:2px solid currentColor;
}

.veh-single .veh-gal__arrow.is-prev::before{ transform:rotate(-135deg); }
.veh-single .veh-gal__arrow.is-next::before{ transform:rotate(45deg); }

/* -------- THUMBS -------- */

.veh-single .veh-thumbs.slicer{
  margin-top:.75rem;
}

.veh-single .veh-thumbs .slicer__track{
  --thumb-w:124px;
  display:flex;
  gap:12px;
  max-width:100%;
  overflow-x:auto;
  padding:4px;
  scroll-snap-type:x proximity;
  -webkit-overflow-scrolling:touch;
}

@media (min-width:1024px){
  .veh-single .veh-thumbs .slicer__track{
    --thumb-w:112px;
    gap:10px;
  }
}

.veh-single .veh-thumbs .slicer__item{
  flex:0 0 var(--thumb-w)!important;
  width:var(--thumb-w)!important;
  height:calc(var(--thumb-w) * .75)!important;
}

@media (min-width:1024px){
  .veh-single .veh-thumbs .slicer__item{
    height:calc(var(--thumb-w) * .72)!important;
  }
}

.veh-single .veh-gal__thumb{
  border-radius:var(--r-sm);
  overflow:hidden;
  border:1px solid var(--line);
  background:linear-gradient(90deg,var(--panel-1),var(--panel-2));
  transition: transform .12s ease, border-color .12s ease;
}

.veh-single .veh-gal__thumb:hover{
  border-color:var(--brand-ghost);
  transform:translateY(-1px);
}

.veh-single .veh-gal__thumb.is-active{
  border-color:var(--brand);
  box-shadow:0 0 0 1px var(--brand), 0 8px 18px -8px var(--brand-glow);
}

.veh-single .veh-gal__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* -------- PANEL -------- */

.veh-single .veh-panel{
  padding:var(--pad-md);
  border-radius:var(--r-lg);
}

.veh-single .veh-title{
  margin:0 0 .6rem;
  color:var(--text-1);
  font-weight:900;
}

.veh-single .veh-chips{
  display:flex;
  flex-wrap:wrap;
  gap:.4rem;
  margin-bottom:1rem;
  color:#d8d8d8;
  font-weight:700;
  font-size:.9rem;
}

.veh-single .veh-chips .chip{
  padding:.32rem .6rem;
  border-radius:var(--r-sm);
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}

/* -------- PRECIO -------- */

.veh-single .veh-price{
  display:inline-flex;
  align-items:baseline;
  gap:.35rem;
  margin:.25rem 0 1rem;
  padding:.45rem .8rem;
  border-radius:12px;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(180deg, #1a1a1a, #101010);
  border:1px solid color-mix(in oklab, var(--brand) 45%, #fff 12%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 12px 26px rgba(255,160,26,.15),
    0 0 0 1px rgba(255,160,26,.08);
}

.veh-single .veh-price__symbol{
  font:800 clamp(1rem,1.8vw,1.1rem)/1 system-ui,Inter,Arial;
  color:color-mix(in oklab, var(--brand) 88%, #fff 12%);
  transform:translateY(1px);
}

.veh-single .veh-price__num{
  font:900 clamp(1.15rem,2.6vw,1.45rem)/1 system-ui,Inter,Arial;
  letter-spacing:.3px;
  color:var(--brand);
  text-shadow:0 0 18px rgba(255,160,26,.22);
}

/* -------- SPECS -------- */

.veh-single .veh-specs{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.75rem 1rem;
  margin-top:8px;
}

@media (min-width:900px){
  .veh-single .veh-specs{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

.veh-single .veh-specs .pair{
  position:relative;
  overflow:hidden;
  padding:.55rem .7rem;
  border-radius:var(--r-sm);
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.015));
  transition: border-color .2s ease, box-shadow .22s ease, transform .18s ease, background .22s ease;
}

.veh-single .veh-specs .pair::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  pointer-events:none;
  background: linear-gradient(145deg, transparent 20%, color-mix(in oklab, var(--brand) 14%, transparent) 60%, transparent 80%);
  opacity:0;
  transition:opacity .25s ease;
}

.veh-single .veh-specs .pair:hover,
.veh-single .veh-specs .pair:focus-within{
  transform:translateY(-2px);
  border-color: color-mix(in oklab, var(--brand) 35%, #fff 5%);
  box-shadow: 0 10px 24px rgba(0,0,0,.28), 0 0 0 1px color-mix(in oklab, var(--brand) 30%, transparent);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.02));
}

.veh-single .veh-specs .pair:hover::after,
.veh-single .veh-specs .pair:focus-within::after{
  opacity:.8;
}

.veh-single .veh-specs .pair:active{
  transform:translateY(-1px) scale(.995);
}

.veh-single .veh-specs .k{
  display:block;
  color:var(--text-2);
  font:600 .78rem/1.2 system-ui,Inter,Arial;
  letter-spacing:.2px;
}

.veh-single .veh-specs .v{
  display:block;
  margin-top:.15rem;
  color:var(--text-1);
  font:800 .98rem/1.1 system-ui,Inter,Arial;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* -------- CTA -------- */

.veh-single .veh-cta{
  display:grid;
  gap:.8rem;
  padding-top:15px;
}

.veh-single .veh-cta .btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  height:clamp(48px,6.2vw,56px);
  padding-inline:clamp(14px,3.6vw,22px);
  border-radius:14px;
  font-weight:900;
  letter-spacing:.2px;
  line-height:1;
  color:#f5f5f5!important;
  text-decoration:none!important;
  background:
    radial-gradient(120% 100% at 50% 0%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(180deg, #1b1b1b, #0f0f0f) !important;
  border:1px solid color-mix(in oklab, var(--brand) 18%, rgba(255,255,255,.08) 82%) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 10px 24px rgba(0,0,0,.35);
  transition: transform .15s ease, box-shadow .22s ease, background .22s ease;
}

.veh-single .veh-cta .btn:hover,
.veh-single .veh-cta .btn:focus-visible{
  transform:translateY(-2px);
  box-shadow:0 16px 34px rgba(0,0,0,.45);
  outline:0;
}

.veh-single .veh-cta .btn::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(120deg, transparent 20%, rgba(255,255,255,.12) 35%, transparent 55%);
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
}

.veh-single .veh-cta .btn:hover::after{
  opacity:.5;
}

.veh-single .veh-cta .btn .icon{
  width:20px;
  height:20px;
  flex:0 0 auto;
}

.veh-single .btn--wpp{
  background-image:none!important;
}

.veh-single .btn--wpp::before{
  content:none!important;
  background:none!important;
  -webkit-mask:none!important;
          mask:none!important;
  width:0!important;
  height:0!important;
  border:0!important;
  padding:0!important;
}

.veh-single .btn--wpp > i,
.veh-single .btn--wpp > img,
.veh-single .btn--wpp > svg:not(.icon),
.veh-single .btn--wpp > .iconify,
.veh-single .btn--wpp > svg.iconify{
  display:none!important;
}

.veh-single .veh-cta .btn--wpp{
  border-color: color-mix(in oklab, #25d366 28%, #fff 10%)!important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 12px 28px rgba(37,211,102,.18),
    0 0 0 1px rgba(37,211,102,.08);
}

.veh-single .veh-cta .btn--wpp:hover{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 18px 36px rgba(37,211,102,.24),
    0 0 0 1px rgba(37,211,102,.10);
}

.veh-single .veh-cta .btn--share{
  border-color:var(--brand)!important;
}

.btn--share .icon-share{
  width:18px;
  height:18px;
  margin-right:6px;
  vertical-align:middle;
}

/* -------- DESCRIPCIÓN -------- */

.veh-single .veh-divider{
  height:1px;
  border:0;
  margin:18px 0 14px;
  background:rgba(255,255,255,.12);
}

.veh-single .veh-desc{
  margin-top:1.25rem;
  padding:1.5rem;
  padding-top:1.25rem;
  border-top:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-lg);
}

@media (max-width:768px){
  .veh-single .veh-desc{
    margin-top:1rem;
    padding-top:1rem;
  }
}

.veh-single .veh-desc h2,
.veh-single .veh-desc .u-titulo{
  margin:0 0 .6rem;
  color:#fff;
  font-size:clamp(1.05rem,2.2vw,1.25rem);
  font-weight:800;
}

.veh-single .veh-desc__header{
  margin-bottom:.6rem;
}

.veh-single .veh-desc__content{
  color:var(--muted);
  line-height:1.55;
  font-size:.95rem;
}

.veh-single .veh-desc__content img,
.veh-single .veh-desc__content iframe{
  max-width:100%;
  height:auto;
  border-radius:10px;
}

/* =========================================================
   SINGLE • ajuste fino del contenedor de imagen grande
   ========================================================= */

@media (min-width: 1024px) {
  /* más equilibrio entre galería y panel derecho */
  .veh-single .veh-hero-grid {
    grid-template-columns: minmax(0, 2.1fr) minmax(400px, 1.25fr);
    column-gap: 24px;
    align-items: start;
  }

  /* el viewport deja de agrandar de más la foto */
  .veh-single .veh-gal__viewport {
    width: 100%;
    max-width: 860px;
    margin-inline: 0 auto;
    aspect-ratio: 16 / 10;
    max-height: min(54vh, 500px);
  }

  /* thumbs un poco más compactas y proporcionadas */
  .veh-single .veh-thumbs .slicer__track {
    --thumb-w: 100px;
    gap: 10px;
  }

  .veh-single .veh-thumbs .slicer__item {
    flex: 0 0 var(--thumb-w) !important;
    width: var(--thumb-w) !important;
    height: calc(var(--thumb-w) * .68) !important;
  }
}

/* desktop grande: no dejar que crezca demasiado */
@media (min-width: 1400px) {
  .veh-single .veh-gal__viewport {
    max-width: 820px;
    max-height: 480px;
  }
}




/* ===== CONTACTO / NOSOTROS — módulo afinado ===== */


/* Columna izquierda (tarjetas) */
.ctk-left{ display:grid; gap:26px; }
.ctk-card{
  display:grid; grid-template-columns: var(--ctk-icon) 1fr;
  gap:18px; align-items:center; padding:var(--ctk-pad);
  border-radius:var(--ctk-card-radius);
  background:#111; border:1px solid var(--line);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.ctk-ico{
  width:var(--ctk-icon); height:var(--ctk-icon);
  border-radius:18px; display:grid; place-items:center;
  background:var(--primary); color:#111;
}
.ctk-ico svg{ width:clamp(24px, 2.2vw, 44px); height:clamp(24px, 2.2vw, 44px); }
.ctk-ttl{ margin:0 0 6px; color:#fff; font:800 clamp(22px, 2.2vw, 32px)/1.1 system-ui,Inter,Arial; }
.ctk-sub{ margin:0 0 8px; color:#dcdcdc; font-size:clamp(16px, 1.6vw, 20px); }
.ctk-link{ color:#ffb454; font-weight:800; font-size:clamp(16px, 1.6vw, 20px); text-decoration:none; }
.ctk-link:hover{ color:#ffd08e; }


/* HERO Nosotros */
/* ===== Nosotros: hero (imagen izq + copy der) ===== */
.nos-hero {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 24px;
  align-items: center;
  margin: clamp(24px, 6vw, 56px) auto;
}
.nos-hero-img.is-card {
  position: relative; overflow: hidden; border-radius: 18px;
  border: 1px solid color-mix(in oklab, var(--primary-border) 65%, black 35%);
  box-shadow: 0 12px 28px rgba(0,0,0,.45);
}
.nos-hero-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nos-hero-copy .bloque-ttl { display:flex; align-items:center; gap:12px; margin:0 0 10px; }
.nos-hero-copy .bloque-ttl .barra { width:6px; height:1.6em; background:var(--primary); border-radius:3px; }
.nos-hero-copy .lead { color: var(--muted); margin:.4rem 0 1rem; }
.nos-cta { display:flex; gap:10px; flex-wrap:wrap; }

@media (max-width: 960px) {
  .nos-hero { grid-template-columns: 1fr; }
}

.nos-hero{ display:grid; grid-template-columns: 1.1fr 1fr; gap:40px; align-items:center; }
.nos-hero-img img{
  width:100%; height:auto; border-radius:20px; box-shadow:var(--shadow);
  display:block; object-fit:cover;
}
.nos-hero-copy h1{ font-size:44px; line-height:1.08; margin:0 0 14px; }
.nos-hero-copy p{ color:var(--muted); margin:0 0 10px; font-size:18px; }
.nos-cta{ display:flex; gap:12px; margin-top:18px; }
/* no redefinimos .btn global; solo modificadores locales */
.nos-cta .btn{ padding:10px 35px; border-radius:5px; font-weight:700;margin: 10px 0px 0px; }
.btn-amber{ background:var(--primary); color:#111; box-shadow:var(--shadow); }
.btn-outline{ border:1px solid var(--line); color:var(--fg); background:transparent; }

/* BENEFICIOS (scopeado para evitar choques) */
.nosotros-ux .nos-benefits{ display:grid; grid-template-columns: repeat(3, 1fr); gap:var(--gap); }
.nosotros-ux .card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:22px; box-shadow:var(--shadow);
}
.nosotros-ux .card h3{ margin:12px 0 8px; font-size:20px; }
.nosotros-ux .card p{ color:var(--muted); }
.nosotros-ux .ico-circle{
  width:64px; height:64px; border-radius:14px; display:grid; place-items:center;
  background:var(--primary); color:#111; box-shadow:var(--shadow);
}

/* SOMOS + GALERÍA */
.nos-somos{ display:grid; grid-template-columns: .9fr 1.1fr; gap:40px; align-items:center; }
.somos-copy h2{ font-size:34px; margin-bottom:10px; }
.amber{ color:var(--primary); }          /* usa primary para consistencia */
.somos-copy p{ color:var(--muted); }
.somos-gallery{ display:grid; grid-template-columns: repeat(3, 1fr); gap:var(--gap-sm); }
.somos-gallery img{
  width:100%; height:220px; object-fit:cover; border-radius:14px; box-shadow:var(--shadow);
}

/* Título */
.por-que__ttl{
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.1;
  letter-spacing: .2px;
  color: var(--text-1, #fff);
  display: inline-flex;
  align-items: center;
  gap: .5ch;
}

/* Resaltado de marca */
.por-que__ttl .brand{
  color: var(--brand, #ffa01a);
  text-shadow: 0 0 18px rgba(255,160,26,.18);
  white-space: nowrap;
}

/* Detalle opcional: barrita a la izquierda en color marca */
.por-que__ttl::before{
  content:"";
  width: 8px; height: 1.1em;
  border-radius: 6px;
  margin-right: .5rem;
  background: var(--brand, #ffa01a);
  box-shadow: 0 0 0 1px rgba(255,160,26,.16), 0 10px 20px -8px rgba(255,160,26,.25);
}

/* Título de sección reutilizable */
.veh-single .u-section-ttl{
  font-family: "Inter Tight", "Inter", system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.1;
  letter-spacing: .2px;
  color: var(--text-1, #fff);
  display: inline-flex;
  align-items: center;
  gap: .5ch;
  margin: 0 0 .6rem 0; /* mismo ritmo que venís usando */
}

/* Barrita de acento a la izquierda */
.veh-single .u-section-ttl::before{
  content: "";
  width: 8px; height: 1.1em;
  border-radius: 6px;
  margin-right: .5rem;
  background: var(--brand, #ffa01a);
  box-shadow:
    0 0 0 1px color-mix(in oklab, var(--brand, #ffa01a) 55%, #000 45%),
    0 10px 20px -8px rgba(255,160,26,.25);
}

/* Palabra resaltada en color marca */
.veh-single .u-section-ttl .brand{
  color: var(--brand, #ffa01a);
  text-shadow: 0 0 18px rgba(255,160,26,.18);
  white-space: nowrap;
}
/* Título de sección reutilizable */
.veh-single .u-section-ttl{
  font-family: "Inter Tight", "Inter", system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.1;
  letter-spacing: .2px;
  color: var(--text-1, #fff);
  display: inline-flex;
  align-items: center;
  gap: .5ch;
  margin: 0 0 .6rem 0; /* mismo ritmo que venís usando */
}

/* Barrita de acento a la izquierda */
.veh-single .u-section-ttl::before{
  content: "";
  width: 8px; height: 1.1em;
  border-radius: 6px;
  margin-right: .5rem;
  background: var(--brand, #ffa01a);
  box-shadow:
    0 0 0 1px color-mix(in oklab, var(--brand, #ffa01a) 55%, #000 45%),
    0 10px 20px -8px rgba(255,160,26,.25);
}

/* Palabra resaltada en color marca */
.veh-single .u-section-ttl .brand{
  color: var(--brand, #ffa01a);
  text-shadow: 0 0 18px rgba(255,160,26,.18);
  white-space: nowrap;
}

/* Título elegante sin barra, pensado para tu esquema oscuro */
.veh-single .u-title-clean{
  font-family: "Inter Tight", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: clamp(1.6rem, 3.2vw, 2.3rem);
  line-height: 1.1;
  letter-spacing: .2px;
  color: var(--text-1, #fff);
  margin: 0 0 .6rem;
}

/* Por si algún estilo global agrega una barra con ::before, la anulamos */
.veh-single .u-title-clean::before{ content:none !important; }

/* Resaltado de marca (toma tu token) */
.veh-single .u-title-clean .brand{
  color: var(--brand, #ffa01a);
  text-shadow: 0 0 18px rgba(255,160,26,.18);
  white-space: nowrap;
}
/* =========================================
   SOMOS • Título elegante sin barra + brand
   ========================================= */

/* Tokens locales por si este bloque no vive dentro de .veh-single */
.somos{
  --brand: #ffa01a;
  --text-1: #fff;
}

/* Título (sin barra) */
.somos .u-title-clean,
h2.u-title-clean{
  font-family: "Inter Tight", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: clamp(1.6rem, 3.2vw, 2.3rem);
  line-height: 1.1;
  letter-spacing: .2px;
  color: var(--text-1);
  margin: 0 0 .6rem;
}

/* Si algún estilo global agrega barra con ::before, la anulamos acá también */
.somos .u-title-clean::before,
h2.u-title-clean::before{
  content: none !important;
}

/* Resaltado de marca */
.somos .u-title-clean .brand,
h2.u-title-clean .brand{
  color: var(--brand);
  text-shadow: 0 0 18px rgba(255,160,26,.18);
  white-space: nowrap;
}

/* =========================
   CONTACTO • Estilo fino
   ========================= */
.contacto-ux {
  --radius: 14px;
  --pad: 14px;
}

/* Título + subtítulo compactos */
.contacto-ux .ctk-head {
  max-width: 1100px;
  margin: clamp(12px, 4vw, 24px) auto 0;
  padding: 0 16px;
}
.contacto-ux .ctk-page-title {
  font-size: clamp(1.6rem, 3.2vw, 2.1rem);
  margin: 0 0 4px;
}
.contacto-ux .ctk-page-sub {
  color: var(--muted);
  font-size: .95rem;
  margin: 0 0 8px;
}

/* Grid principal: fino y respirado */
.contacto-ux .contacto-grid {
  max-width: 1100px;
  margin: clamp(12px, 4vw, 24px) auto clamp(18px, 5vw, 36px);
  padding: 0 16px;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 16px;
}
@media (max-width: 960px) {
  .contacto-ux .contacto-grid {
    grid-template-columns: 1fr;
  }
}

/* Panel base (afina paddings y bordes) */
.contacto-ux .u-panel {
  background: linear-gradient(180deg, #151515 0%, #0f0f0f 100%);
  border: 1px solid color-mix(in oklab, var(--primary-border) 65%, black 35%);
  border-radius: var(--radius);
  box-shadow: 0 10px 24px rgba(0,0,0,.45);
}

/* -------- Tarjetas pequeñas (WA, IG, Ubicación) -------- */
.contacto-ux .ctk-left {
  display: grid;
  gap: 12px;
}
.contacto-ux .ctk-card {
  position: relative;
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 12px;
  align-items: center;
  padding: var(--pad) 14px;
  overflow: clip;
  isolation: isolate;
  transition: border-color .25s ease, box-shadow .25s ease, transform .15s ease;
}
.contacto-ux .ctk-card:hover {
  transform: translateY(-1px);
  border-color: var(--primary-hover);
  box-shadow: 0 16px 36px rgba(0,0,0,.55);
}
/* Diagonal sutil */
.contacto-ux .ctk-card::after {
  content: "";
  position: absolute;
  width: 1px; height: 180%;
  top: -40%; left: 55%;
  transform: rotate(18deg);
  background: linear-gradient(to bottom, transparent 0%, var(--primary) 15%, var(--primary-glow) 40%, var(--primary) 80%, transparent 100%);
  opacity: .35;
  pointer-events: none;
}

/* Icono compacto con glow leve */
.contacto-ux .ctk-ico {
  width: 36px; height: 36px; border-radius: 10px;
  border: 1px solid color-mix(in oklab, var(--primary-border) 70%, black 30%);
  background:
    radial-gradient(120px 45px at -20% -20%, color-mix(in oklab, var(--primary-glow) 18%, transparent) 0%, transparent 70%),
    rgba(255,255,255,0.02);
  display: grid; place-items: center;
  color: var(--fg);
}
.contacto-ux .ctk-ico svg { width: 18px; height: 18px; }

/* Texto compacto */
.contacto-ux .ctk-body { min-width: 0; }
.contacto-ux .ctk-ttl {
  margin: 0;
  font-size: 1rem;
  line-height: 1.2;
}
.contacto-ux .ctk-sub {
  color: var(--muted);
  font-size: .92rem;
  margin: 2px 0 6px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
/* Link “finito” con flecha, no botón */
.contacto-ux .ctk-link {
  color: var(--primary);
  font-weight: 600;
  font-size: .95rem;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: .3rem;
  transition: color .2s ease, transform .12s ease;
}
.contacto-ux .ctk-link:hover { color: var(--primary-hover); transform: translateX(1px); }

/* -------- Horarios (panel derecho) -------- */
.contacto-ux .ctk-right {
  padding: 14px;
}
.contacto-ux .ctk-hours-hd {
  display: flex; align-items: center; gap: 10px;
  margin: 0 0 10px;
}
.contacto-ux .ctk-hours-hd .ctk-ico { flex: 0 0 34px; width: 34px; height: 34px; }
.contacto-ux .ctk-hours-hd h2 {
  font-size: 1.05rem; margin: 0;
}
.contacto-ux .ctk-hours-grid {
  display: grid; gap: 8px;
}

/* Fila de horario (fina) */
.contacto-ux .ctk-hour {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
}
.contacto-ux .ctk-hour-day {
  font-weight: 700; font-size: .95rem;
}
.contacto-ux .ctk-hour-time {
  color: var(--muted); font-size: .92rem;
}

/* Resaltar “hoy” (JS opcional agrega .is-today) */
.contacto-ux .ctk-hour.is-today {
  border-color: var(--primary-border);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--primary-hover) 40%, transparent);
}
.contacto-ux .ctk-hour.is-today .ctk-hour-day {
  color: var(--primary);
}

/* Compacto en mobile */
@media (max-width: 560px) {
  .contacto-ux .ctk-card { grid-template-columns: 34px 1fr; }
  .contacto-ux .ctk-ico { width: 32px; height: 32px; }
  .contacto-ux .ctk-ico svg { width: 16px; height: 16px; }
  .contacto-ux .ctk-hour { padding: 9px 10px; }
}




/* ===== Por qué elegirnos ===== */
.por-que { padding: clamp(28px, 4vw, 56px) 0; }
.por-que__ttl{
  font: 800 clamp(22px, 3.5vw, 32px)/1.1 system-ui, Inter, Arial;
  margin: 0 0 20px;
}

.pq-grid{
  display: grid;
  gap: clamp(14px, 2vw, 24px);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 1080px){ .pq-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px){  .pq-grid{ grid-template-columns: 1fr; } }

/* Card base */
.pq-card{
  position: relative;
  isolation: isolate;
  border-radius: 18px;
  padding: clamp(18px, 2.4vw, 26px);
  background: #0f0f0f;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 8px 30px rgba(0,0,0,.35);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.pq-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
  border-color: rgba(255,255,255,.14);
}

/* Borde brillante en movimiento */
.pq-card__glow{
  position: absolute; inset: 0; padding: 1px; border-radius: inherit;
  background: conic-gradient(from 0turn at 50% 50%,
    transparent 0deg,
    color-mix(in oklab, var(--primary,#ffa01a) 75%, #fff 10%) 60deg,
    transparent 120deg,
    transparent 240deg,
    color-mix(in oklab, var(--primary,#ffa01a) 75%, #fff 10%) 300deg,
    transparent 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;  mask-composite: exclude; /* deja solo el borde */
  animation: pq-rotate 6s linear infinite;
  opacity: .9;
  pointer-events: none;
}
@keyframes pq-rotate { to { transform: rotate(1turn); } }

/* Ícono */
.pq-ico{
  width: 44px; height: 44px; border-radius: 12px;
  display: grid; place-items: center;
  margin-bottom: 12px;
  background: radial-gradient(100% 100% at 50% 0%,
              rgba(255,160,26,.20), rgba(255,160,26,.06) 60%, transparent 70%);
  border: 1px solid color-mix(in oklab, var(--primary,#ffa01a) 60%, #000 40%);
  color: var(--primary, #ffa01a);
}
.pq-ico svg{ width: 24px; height: 24px; }

/* Texto */
.pq-card h3{
  font: 800 clamp(18px, 2.4vw, 22px)/1.1 system-ui, Inter, Arial;
  margin: 2px 0 8px; color: #fff;
}
.pq-card p{ color:#d9d9d9; margin:0 0 10px; }

/* Bullets finos */
.pq-bullets{
  display:grid; gap:6px; margin:10px 0 0; padding:0; list-style:none;
}
.pq-bullets li{
  color:#bdbdbd; font:600 14px/1.35 system-ui, Inter, Arial;
  position:relative; padding-left:18px;
}
.pq-bullets li::before{
  content:""; position:absolute; left:0; top:.55em;
  width:8px; height:8px; border-radius:999px;
  background: radial-gradient(circle at 30% 30%, #fff, var(--primary,#ffa01a) 70%);
  box-shadow: 0 0 0 2px rgba(255,160,26,.15);
}

/* Accesibilidad: reduce motion */
@media (prefers-reduced-motion: reduce){
  .pq-card__glow{ animation: none; }
  .pq-card{ transition: none; }
}

/* ====== SOMOS ====== */
.somos { padding-block: clamp(40px, 6vw, 80px); }
.somos__grid{
  display:grid; gap:clamp(20px, 3vw, 40px);
  grid-template-columns:minmax(0,1.8fr) minmax(0,1fr);
  align-items:center;
}
@media (max-width: 980px){ .somos__grid{ grid-template-columns:1fr; } }

/* trio visual */
.somos__media{
  display:grid; gap:16px;
  grid-template-columns: 1fr 1.9fr 1fr;
  height:clamp(340px, 48vw, 560px);
}

/* centro */
.somos__center{
  position:relative; overflow:hidden; border-radius:22px;
  background:#0f0f0f; box-shadow:0 24px 70px -28px rgba(0,0,0,.6);
}
.somos__img,
.somos__video{
  width:100%; height:100%; object-fit:cover; display:block;
  opacity:0; transition:opacity .45s ease;
}
.somos__img.is-ready,
.somos__video.is-ready { opacity:1; }

/* laterales */
.somos__side{
  position:relative; border-radius:20px; overflow:hidden;
  background:#121212 center/cover no-repeat;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.04);
}
.somos__side--left::after,
.somos__side--right::after{
  content:""; position:absolute; inset:0; pointer-events:none;
}
.somos__side--left::after{
  background:linear-gradient(to right, rgba(0,0,0,.92) 0 38%, rgba(0,0,0,0) 70%);
}
.somos__side--right::after{
  background:linear-gradient(to left, rgba(0,0,0,.92) 0 38%, rgba(0,0,0,0) 70%);
}

/* texto */
.somos__text h2{
  margin:0 0 .5rem;
  font-size:clamp(26px, 3.4vw, 44px);
  letter-spacing:.2px;
}
.somos__text .lead{
  margin:0; color:#d7d7d7;
  font-size:clamp(16px, 1.5vw, 18px);
  line-height:1.55;
  max-width: 48ch;
}

/* ===== FAQ en listado largo y fino ===== */
.faq {
  background: var(--bg);
  color: var(--fg);
  padding: clamp(40px, 6vw, 80px) 0;
}

.faq .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.faq h2 {
  font-size: clamp(1.8rem, 4vw, 2.5rem);
  margin-bottom: 28px;
}

/* Cada fila ocupa todo el ancho */
.faq details {
  position: relative;
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(90deg, #121212 0%, #0d0d0d 100%);
  padding: 0;
  overflow: clip;
  transition: background .25s ease, border-color .25s ease;
}

.faq details + details { margin-top: 12px; }

/* Hover efecto sutil */
.faq details:hover {
  background: linear-gradient(90deg,
    rgba(255,255,255,.02) 0%,
    rgba(255,255,255,.04) 100%
  );
  border-color: var(--primary-border);
}

/* Línea diagonal dorada decorativa */
.faq details::before {
  content: "";
  position: absolute;
  top: -50%;
  left: -20%;
  width: 1px;
  height: 200%;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    var(--primary) 15%,
    var(--primary-glow) 40%,
    var(--primary) 80%,
    transparent 100%
  );
  transform: rotate(15deg);
  opacity: .4;
  pointer-events: none;
}

/* Summary como fila horizontal */
.faq summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  font-size: 1.05rem;
  font-weight: 600;
  position: relative;
}

.faq summary::-webkit-details-marker { display: none; }

/* Chevron minimal */
.faq summary .chev {
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 1px solid var(--primary-border);
  display: grid; place-items: center;
  transition: transform .25s ease, background .2s ease, border-color .2s ease;
}
.faq summary .chev::before {
  content: "";
  width: 14px; height: 14px;
  background: var(--fg);
  mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' stroke='white' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>")
    center/contain no-repeat;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' stroke='white' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>")
    center/contain no-repeat;
}
.faq details[open] summary .chev { transform: rotate(180deg); }
.faq summary:hover .chev { background: var(--primary); border-color: transparent; }

/* Contenido en línea fino */
.faq details > div {
  padding: 0 22px 18px;
  color: var(--muted);
  line-height: 1.55;
  font-size: .95rem;
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .3s ease;
}
.faq details[open] > div { grid-template-rows: 1fr; }
.faq details > div > * { overflow: hidden; }

/* Bullets */
.faq .bullet {
  display: grid;
  grid-template-columns: 12px 1fr;
  gap: 8px;
  margin: 6px 0;
}
.faq .bullet::before {
  content: "";
  width: 6px; height: 6px; margin-top: .55em;
  border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 6px var(--primary-glow);
}

/* === Fix overlay menú móvil por encima de todo === */
@media (max-width: 980px){
  .site-header .menu{ z-index: 1001; }
}

/* === Mejora gesto en galería (evita scrolling raro en iOS) === */
.veh-gal__viewport{ touch-action: pan-y; }


/* =========================================================
   RESPONSIVE (consolidado)
   ========================================================= */
@media (max-width: 1100px){
  .ft-grid{ grid-template-columns: 1fr 1fr; }
  .ft-bottom{ flex-direction: column; gap: 8px; text-align: center; }
  .contacto-grid{ grid-template-columns: 1fr; gap: 26px; }
}
@media (max-width: 980px){
  .site-header .container{ min-height: 124px; }
  .custom-logo, .brand img{ height: 80px; }
  .nav-toggle{ display: block; }
  .menu{
    position: fixed; top: 94px; left: 0; right: 0; display: none; flex-direction: column; gap: 0;
    background: #0f0f10; border-top: 1px solid rgba(255,255,255,.06); padding: 10px 16px;
  }
  .site-header.is-open .menu{ display: flex; }
  .menu > li{ width: 100%; }
  .menu > li > a{ width: 100%; padding: 14px 6px; }
  .u-filtros__grid, .filtros-grid{ grid-template-columns: 1fr; }
  .grid-autos{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px){
  .nosotros-ux .nos-benefits{ grid-template-columns: 1fr; }
}
@media (max-width: 720px){
  .ft-grid{ grid-template-columns: 1fr; }
  .slicer__btn{ display: none; }
}
@media (max-width: 620px){
  .slicer__item{ flex-basis: 100%; }
  .grid-autos{ grid-template-columns: 1fr; }
}
@media (max-width: 520px){
  :root{ --eye-size: 46px; }
}
@media (max-width: 820px){
  :root{ --eye-size: 52px; }
}

@media (max-width: 1100px){
  .nos-hero, .nos-somos{ grid-template-columns: 1fr; }
}
@media (max-width: 900px){
  .nos-benefits{ grid-template-columns: 1fr; }
  .nos-hero-copy h1{ font-size:36px; }
}








/* ===== WhatsApp floating bubble ===== */

.wa-float-btn{
  position:fixed;
  bottom:22px;
  right:22px;
  z-index:9999;

  width:58px;
  height:58px;
  border-radius:50%;

  background:#25D366;
  display:flex;
  align-items:center;
  justify-content:center;

  color:#fff;
  text-decoration:none;

  box-shadow:0 6px 20px rgba(0,0,0,.35);

  transition:all .25s ease;
}

.wa-float-btn svg{
  width:28px;
  height:28px;
}

/* Hover elegante */
.wa-float-btn:hover{
  transform:scale(1.08);
  box-shadow:0 10px 28px rgba(0,0,0,.45);
  background:#20c05c;
}

/* Glow sutil */
.wa-float-btn::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  box-shadow:0 0 18px rgba(37,211,102,.5);
  opacity:.5;
  z-index:-1;
}

/* Mobile ajuste */
@media (max-width:600px){
  .wa-float-btn{
    width:54px;
    height:54px;
    bottom:18px;
    right:18px;
  }
}

.card-auto__body{
  padding-bottom: calc(var(--footer-h) + 18px);
}

.card-auto__meta,
.card-auto__sub{
  min-height: 22px;
}

.card-auto__sub .trans,
.card-auto__sub .fuel,
.card-auto__sub .km{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.card-auto__img--placeholder{
  width: 100%;
  height: 100%;
  background:
    linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.02)),
    #111;
}



.veh-aside .veh-actions{
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.veh-aside .veh-actions .btn{
  width: 100%;
  justify-content: center;
}

.veh-head__meta{
  color: var(--muted);
  margin-top: 4px;
}

.veh-specs{
  margin-top: 8px;
}


/* =========================================================
   CATÁLOGO • paginación definitiva
   ========================================================= */

.paginacion--catalogo {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: clamp(28px, 4vw, 44px) 0 clamp(18px, 4vw, 34px);
  padding-inline: 12px;
}

.paginacion--catalogo ul.page-numbers {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0;
  padding: 8px;
  list-style: none;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.02) 100%),
    #0d0d0d;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow:
    0 14px 34px rgba(0,0,0,.44),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.paginacion--catalogo ul.page-numbers li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.paginacion--catalogo .page-numbers a,
.paginacion--catalogo .page-numbers span {
  min-width: 46px;
  height: 46px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 700;
  font-size: .98rem;
  line-height: 1;
  color: #fff;
  background: rgba(255,255,255,.03);
  border: 1px solid transparent;
  box-sizing: border-box;
  transition:
    transform .18s ease,
    border-color .18s ease,
    background-color .18s ease,
    box-shadow .18s ease,
    color .18s ease;
}

.paginacion--catalogo .page-numbers a:hover,
.paginacion--catalogo .page-numbers a:focus-visible {
  transform: translateY(-1px);
  color: #fff;
  background: rgba(255,255,255,.06);
  border-color: rgba(255, 153, 0, .55);
  box-shadow:
    0 0 0 1px rgba(255,153,0,.14),
    0 10px 22px rgba(0,0,0,.35);
  outline: none;
}

.paginacion--catalogo .page-numbers .current,
.paginacion--catalogo .page-numbers [aria-current="page"] {
  color: #111;
  background: linear-gradient(180deg, #ffad1f 0%, #ff9800 100%);
  border-color: rgba(255, 166, 0, .75);
  box-shadow:
    0 0 0 1px rgba(255,166,0,.18),
    0 8px 20px rgba(255,140,0,.24);
}

.paginacion--catalogo .page-numbers .prev,
.paginacion--catalogo .page-numbers .next {
  min-width: 50px;
  font-size: 1.28rem;
  font-weight: 500;
  padding-inline: 16px;
}

.paginacion--catalogo .page-numbers .dots {
  min-width: auto;
  padding-inline: 8px;
  color: rgba(255,255,255,.52);
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

@media (max-width: 640px) {
  .paginacion--catalogo {
    margin-top: 24px;
  }

  .paginacion--catalogo ul.page-numbers {
    gap: 8px;
    padding: 6px;
    border-radius: 16px;
  }

  .paginacion--catalogo .page-numbers a,
  .paginacion--catalogo .page-numbers span {
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    border-radius: 12px;
    font-size: .94rem;
  }

  .paginacion--catalogo .page-numbers .prev,
  .paginacion--catalogo .page-numbers .next {
    min-width: 42px;
    padding-inline: 12px;
    font-size: 1.12rem;
  }
}

/* =========================================================
   CATÁLOGO • panel de filtros pulido
   ========================================================= */

.barra-filtros.filtros--full {
  padding: clamp(18px, 2vw, 26px);
  border-radius: 22px;
}

.filtros-catalogo-grid {
  display: grid;
  grid-template-columns: minmax(260px, 2.1fr) repeat(3, minmax(170px, 1fr));
  gap: 16px;
  align-items: end;
}

.filtros-catalogo-grid .campo-busqueda {
  grid-column: 1 / 2;
}

.filtros-catalogo-grid .campo-select,
.filtros-catalogo-grid .campo-busqueda {
  min-width: 0;
}

.filtros-catalogo-grid .campo-select .lbl {
  display: inline-block;
  margin-bottom: 8px;
  font-size: .95rem;
  color: rgba(255,255,255,.82);
}

.filtros-catalogo-grid .u-control {
  width: 100%;
  min-height: 48px;
}

.filtros-catalogo-grid .acciones-filtros--catalogo {
  grid-column: 2 / span 2;
  display: flex;
  align-items: center;
  gap: 12px;
}

.filtros-catalogo-grid .acciones-filtros--catalogo .btn {
  min-width: 120px;
  min-height: 48px;
}

@media (max-width: 1200px) {
  .filtros-catalogo-grid {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
  }

  .filtros-catalogo-grid .campo-busqueda {
    grid-column: 1 / -1;
  }

  .filtros-catalogo-grid .acciones-filtros--catalogo {
    grid-column: 1 / -1;
  }
}

@media (max-width: 720px) {
  .barra-filtros.filtros--full {
    padding: 16px;
    border-radius: 18px;
  }

  .filtros-catalogo-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .filtros-catalogo-grid .campo-busqueda,
  .filtros-catalogo-grid .acciones-filtros--catalogo {
    grid-column: auto;
  }

  .filtros-catalogo-grid .acciones-filtros--catalogo {
    flex-direction: column;
    align-items: stretch;
  }

  .filtros-catalogo-grid .acciones-filtros--catalogo .btn {
    width: 100%;
  }
}


/* =========================================================
   CARD AUTO • sistema unificado de producción
   ========================================================= */

.card-auto {
  --card-radius: 18px;
  --card-border: rgba(255,255,255,.08);
  --card-bg: #0f0f0f;
  --card-shadow: 0 8px 30px rgba(0,0,0,.35);
  --card-shadow-hover: 0 14px 40px rgba(0,0,0,.45);
  --footer-gap: 10px;
  --footer-btn-h: 40px;

  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
  overflow: hidden;
  border-radius: var(--card-radius);
  border: 1px solid var(--card-border);
  background:
    linear-gradient(130deg, rgba(255,255,255,.04) 0%, transparent 18%) 0 0/100% 100% no-repeat,
    radial-gradient(120% 160% at 10% -10%, rgba(255,160,26,.06), transparent 25%),
    radial-gradient(120% 160% at 120% 120%, rgba(255,160,26,.05), transparent 40%),
    var(--card-bg);
  box-shadow: var(--card-shadow);
  contain: layout paint style;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.card-auto:hover {
  transform: translateY(-2px);
  box-shadow: var(--card-shadow-hover);
  border-color: rgba(255,255,255,.14);
}

/* borde animado */
.card-auto::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: 1px;
  border-radius: inherit;
  background: conic-gradient(
    from 0turn at 50% 50%,
    transparent 0deg,
    color-mix(in oklab, var(--primary) 75%, #fff 10%) 60deg,
    transparent 120deg,
    transparent 240deg,
    color-mix(in oklab, var(--primary) 75%, #fff 10%) 300deg,
    transparent 360deg
  );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: .85;
  pointer-events: none;
  animation: cardauto-rotate 7s linear infinite;
  z-index: 0;
}

/* reflejo en toda la tarjeta, detrás del contenido */
.card-auto::after {
  content: "";
  position: absolute;
  inset: -12%;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(
    105deg,
    transparent 0%,
    rgba(255,255,255,.04) 32%,
    rgba(255,255,255,.10) 48%,
    rgba(255,255,255,.06) 58%,
    transparent 74%
  );
  transform: translateX(-135%) skewX(-14deg);
  opacity: 0;
  transition: transform .72s ease, opacity .26s ease;
}

.card-auto:hover::after {
  opacity: 1;
  transform: translateX(135%) skewX(-14deg);
}

@keyframes cardauto-rotate {
  to { transform: rotate(1turn); }
}

/* media */
.card-auto__media {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 24 / 16;
  z-index: 1;
}

.card-auto__img,
.card-auto__media img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  display: block;
  object-fit: cover;
  object-position: center;
  transform: translateZ(0);
  will-change: transform, filter;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transition: transform .32s ease, filter .22s ease;
}

/* blur al hover de toda la tarjeta */
.card-auto:hover .card-auto__img,
.card-auto:focus-within .card-auto__img {
  transform: scale(1.024);
  filter: blur(2px) brightness(.92) saturate(1.03);
}

.card-auto__img--placeholder {
  width: 100%;
  height: 100%;
  background:
    linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.02)),
    #111;
}

.card-auto__media::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  height: clamp(64px, 22%, 100px);
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,.18) 45%,
    rgba(0,0,0,.52) 90%,
    rgba(0,0,0,.70) 100%
  );
  pointer-events: none;
}

/* overlay mejorado */
.card-auto__hover {
  position: absolute;
  inset: 0;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity .2s ease, visibility .2s ease, transform .2s ease;
  pointer-events: none;
  background:
    radial-gradient(280px 220px at center, rgba(0,0,0,.38), rgba(0,0,0,0) 72%);
  border-radius: inherit;
}

.card-auto:hover .card-auto__hover,
.card-auto:focus-within .card-auto__hover {
  opacity: 1;
  visibility: visible;
  transform: none;
}

.card-auto__hover .eye-wrap {
  width: clamp(58px, 5vw, 66px);
  height: clamp(58px, 5vw, 66px);
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.82);
  background: rgba(0,0,0,.28);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.06),
    0 12px 28px rgba(0,0,0,.32);
}

.card-auto__hover .eye {
  width: 28px;
  height: 28px;
  color: #fff;
}

.card-auto__hover .hover-text {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: calc(50% + 46px);
  margin: 0;
  padding: .32rem .72rem;
  border-radius: 999px;
  font-size: .92rem;
  font-weight: 800;
  color: #fff;
  background: rgba(0,0,0,.34);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
  text-shadow: 0 1px 0 rgba(0,0,0,.35);
}

/* body */
.card-auto__body {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 16px 16px;
  min-height: 0;
  background:
    radial-gradient(120% 120% at 30% 0%, color-mix(in oklab, var(--primary) 14%, transparent) 0%, transparent 70%),
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, #141414 65%, color-mix(in oklab, var(--primary) 8%, #1a1a1a) 100%);
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
}

.card-auto__titulo {
  margin: 0;
}

.card-auto__title-link {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  white-space: normal;
  line-height: 1.16;
  font-size: clamp(1.02rem, 1.25vw, 1.12rem);
  font-weight: 800;
  color: var(--primary);
}

.card-auto:hover .card-auto__title-link {
  text-shadow: 0 0 10px color-mix(in oklab, var(--primary) 35%, transparent);
}

.card-auto__meta,
.card-auto__sub {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .3rem .55rem;
  margin: 0;
  min-height: 20px;
}

.card-auto__meta {
  color: #d7d7d7;
}

.card-auto__sub {
  color: #c9c9c9;
}

.card-auto__meta .punto,
.card-auto__sub .punto {
  font-size: 0;
  line-height: 0;
  position: relative;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  display: inline-block;
  background: radial-gradient(circle at 30% 30%, #fff, var(--primary) 70%);
  box-shadow: 0 0 0 2px rgba(255,160,26,.15);
  margin: 0;
}

/* footer siempre abajo */
.card-auto__footer {
  position: relative;
  z-index: 3;
  display: grid;
  gap: var(--footer-gap);
  margin-top: auto;
  padding-top: 10px;
}

.card-auto__footer--dual-cta {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

/* base botones */
.card-auto .ver-mas,
.card-auto .ver-mas:link,
.card-auto .ver-mas:visited,
.card-auto .cta-wa,
.card-auto .cta-wa:link,
.card-auto .cta-wa:visited {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  min-height: var(--footer-btn-h);
  padding: .42rem .82rem;
  text-decoration: none;
  font-size: .92rem;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  border-radius: 10px;
  transition:
    transform .18s ease,
    border-color .18s ease,
    background-color .18s ease,
    box-shadow .18s ease,
    color .18s ease;
}

/* CTA naranja */
.card-auto .ver-mas,
.card-auto .ver-mas:link,
.card-auto .ver-mas:visited {
  color: var(--primary);
  border: 1px solid color-mix(in oklab, var(--primary) 55%, #000 45%);
  background: rgba(255,255,255,.03);
  box-shadow: 0 2px 6px rgba(0,0,0,.25);
}

.card-auto .ver-mas:hover,
.card-auto .ver-mas:focus-visible {
  background: color-mix(in oklab, var(--primary) 16%, #000 84%);
  color: #fff;
  border-color: var(--primary);
  box-shadow: 0 4px 12px rgba(0,0,0,.35);
  transform: translateY(-1px);
  outline: none;
}

.card-auto .ver-mas .flecha {
  display: inline-block;
  transform: translateX(0);
  transition: transform .22s ease;
}

.card-auto .ver-mas:hover .flecha,
.card-auto .ver-mas:focus-visible .flecha {
  transform: translateX(6px);
}

/* CTA verde, mismo lenguaje del naranja */
.card-auto .cta-wa,
.card-auto .cta-wa:link,
.card-auto .cta-wa:visited {
  color: #25d366;
  border: 1px solid color-mix(in oklab, #25d366 58%, #000 42%);
  background: rgba(255,255,255,.03);
  box-shadow: 0 2px 6px rgba(0,0,0,.25);
}

.card-auto .cta-wa:hover,
.card-auto .cta-wa:focus-visible {
  color: #fff;
  background: color-mix(in oklab, #25d366 18%, #000 82%);
  border-color: #25d366;
  box-shadow:
    0 0 0 1px rgba(37,211,102,.14),
    0 10px 22px rgba(0,0,0,.35),
    0 0 18px rgba(37,211,102,.14);
  transform: translateY(-1px);
  outline: none;
}

.card-auto .cta-wa .flecha {
  transform: translateX(0);
  transition: transform .22s ease;
}

.card-auto .cta-wa:hover .flecha,
.card-auto .cta-wa:focus-visible .flecha {
  transform: translateX(4px);
}

.card-auto__footer--dual-cta .ver-mas {
  justify-self: end;
}

.card-auto__stretched {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
}

.grid-autos .card-auto,
.slicer .card-auto,
.slicer__slide .card-auto,
.slicer__item .card-auto {
  content-visibility: auto;
  contain-intrinsic-size: 420px 420px;
}

@media (max-width: 640px) {
  .card-auto__footer--dual-cta {
    grid-template-columns: 1fr;
  }

  .card-auto__footer--dual-cta .ver-mas,
  .card-auto__footer--dual-cta .cta-wa {
    width: 100%;
    justify-content: center;
  }

  .card-auto__footer--dual-cta .ver-mas {
    justify-self: stretch;
  }
}

@media (prefers-reduced-motion: reduce) {
  .card-auto,
  .card-auto * {
    transition: none !important;
  }

  .card-auto::before {
    animation: none;
  }

  .card-auto::after {
    opacity: 0 !important;
    transform: none !important;
  }
}


/* =========================================================
   PAGE CATALOGO • cards alineadas al formato unificado
   ========================================================= */

.catalogo .grid-autos {
  align-items: stretch;
}

.catalogo .grid-autos > * {
  min-width: 0;
}

.catalogo .grid-autos .card-auto {
  height: 100%;
}

.catalogo .grid-autos .card-auto__body {
  min-height: 0;
}

.catalogo .grid-autos .card-auto__footer {
  margin-top: auto;
}

.catalogo .grid-autos .card-auto__footer--dual-cta {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.catalogo .grid-autos .card-auto .cta-wa,
.catalogo .grid-autos .card-auto .ver-mas {
  min-height: 40px;
}

.catalogo .grid-autos .card-auto .cta-wa {
  border-radius: 10px;
}

@media (max-width: 640px) {
  .catalogo .grid-autos .card-auto__footer--dual-cta {
    grid-template-columns: 1fr;
  }

  .catalogo .grid-autos .card-auto .cta-wa,
  .catalogo .grid-autos .card-auto .ver-mas {
    width: 100%;
    justify-content: center;
  }
}


/* =========================================================
   SLICERS • cards más contenidas
   ========================================================= */

/* base desktop: que no ocupen media pantalla */
@media (min-width: 1024px) {
  .home-bloque .slicer .slicer__item,
  .veh-rel .slicer .slicer__slide,
  .slicer--autos .slicer__slide {
    flex: 0 0 clamp(280px, 28vw, 360px) !important;
    width: clamp(280px, 28vw, 360px) !important;
    max-width: clamp(280px, 28vw, 360px) !important;
  }

  .home-bloque .slicer .card-auto,
  .veh-rel .slicer .card-auto,
  .slicer--autos .card-auto {
    width: 100%;
    max-width: 100%;
  }

  .home-bloque .slicer .card-auto__media,
  .veh-rel .slicer .card-auto__media,
  .slicer--autos .card-auto__media {
    aspect-ratio: 24 / 16;
  }
}

/* notebook / tablet landscape */
@media (min-width: 768px) and (max-width: 1023px) {
  .home-bloque .slicer .slicer__item,
  .veh-rel .slicer .slicer__slide,
  .slicer--autos .slicer__slide {
    flex: 0 0 clamp(260px, 42vw, 320px) !important;
    width: clamp(260px, 42vw, 320px) !important;
    max-width: clamp(260px, 42vw, 320px) !important;
  }
}

/* mobile: una por vez, pero sin explotar */
@media (max-width: 767px) {
  .home-bloque .slicer .slicer__item,
  .veh-rel .slicer .slicer__slide,
  .slicer--autos .slicer__slide {
    flex: 0 0 min(88vw, 340px) !important;
    width: min(88vw, 340px) !important;
    max-width: min(88vw, 340px) !important;
  }

  .home-bloque .slicer .slicer__track,
  .veh-rel .slicer .slicer__track,
  .slicer--autos .slicer__track {
    padding-inline: 6px;
  }
}


/* =========================
   FIX SLICER HORIZONTAL
   ========================= */

.slicer__track {
  display: flex !important;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
}

.slicer__item,
.slicer__slide {
  flex: 0 0 auto !important;
  scroll-snap-align: start;
}

/* tamaños de cards */
@media (min-width: 1024px) {
  .slicer__item,
  .slicer__slide {
    width: 320px !important;
  }
}

@media (max-width: 1023px) {
  .slicer__item,
  .slicer__slide {
    width: 260px !important;
  }
}

@media (max-width: 767px) {
  .slicer__item,
  .slicer__slide {
    width: 85vw !important;
  }
}


