/* =========================================================
   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); }



/* ===== 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{
  display: flex; gap: var(--ing-gap); overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 6px; margin-inline: -6px; -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.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; }



/* ===============================
   FOOTER (precio + CTA)
   =============================== */
/* Footer siempre visible, con margen al borde inferior */
.card-auto__footer{
  position:absolute;
  left: var(--pad-x);
  right: var(--pad-x);
  bottom: 12px;                 /* margen respecto del borde final */
  height: var(--footer-h);
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  margin:0;
}

.card-auto .precio {
  color:#fff;
  font-weight:900;
  font-size:1.06rem;
  white-space:nowrap;
  padding:.25rem .55rem;
  border-radius:10px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(37,211,102,0.6);
  transition: box-shadow .3s ease, border-color .3s ease;
}

.card-auto .precio:hover {
  border-color: #25d366;
  box-shadow: 0 0 10px rgba(37,211,102,0.7);
}

.card-auto .ver-mas{
  color: var(--primary); font-weight:800; white-space:nowrap;
  display:inline-flex; gap:.35rem; align-items:center;
  padding:.38rem .72rem; border-radius:999px;
  border:1px solid color-mix(in oklab, var(--primary) 55%, #000 45%);
  background: radial-gradient(120% 120% at 30% 0%, rgba(255,160,26,.12), rgba(255,160,26,0) 70%);
  box-shadow: 0 6px 16px rgba(0,0,0,.25);
  transition: color var(--t-base), background var(--t-base),
              border-color var(--t-base), filter var(--t-base),
              text-shadow var(--t-base), transform var(--t-fast);
}
.card-auto .ver-mas .flecha{ transform: translateX(0); transition: transform .22s ease; }
.card-auto:hover .ver-mas .flecha, .card-auto .ver-mas:hover .flecha{ transform: translateX(6px); }
.btn:active{ transform: translateY(1px); }

/* ===============================
   Responsivo fino
   =============================== */
@media (max-width: 720px){
  .card-auto__title-link{ font-size: 1rem; }
  .card-auto__meta, .card-auto__sub{ font-size: .88rem; }
}


/* ===== FIX: "Ver más" como pill button en HOME (slicer) ===== */
.home-bloque .slicer .card-auto .ver-mas,
.home-bloque .slicer .card-auto .ver-mas:link,
.home-bloque .slicer .card-auto .ver-mas:visited{
  display: inline-flex !important;
  align-items: center;
  gap: .4rem;
  font-weight: 700;
  font-size: .92rem;
  color: var(--primary);
  padding: .38rem .78rem !important;
  line-height: 1;                 /* evita alto extra */
  border-radius: 8px !important; /* fuerza forma pill */
  border: 1px solid color-mix(in oklab, var(--primary) 55%, #000 45%) !important;
  background: rgba(255,255,255,.03) !important;
  box-shadow: 0 2px 6px rgba(0,0,0,.25);
  text-decoration: none;
  appearance: none;
}

.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);
}


/* ===== Pill "Ver más" también en catálogo ===== */
.catalogo .grid-autos .card-auto .ver-mas,
.catalogo .grid-autos .card-auto .ver-mas:link,
.catalogo .grid-autos .card-auto .ver-mas:visited{
  display:inline-flex !important;
  align-items:center;
  gap:.4rem;
  font-weight:700;
  font-size:.92rem;
  color: var(--primary);
  padding:.38rem .78rem !important;
  line-height:1;
  border-radius:8px !important;
  border:1px solid color-mix(in oklab, var(--primary) 55%, #000 45%) !important;
  background: rgba(255,255,255,.03) !important;
  box-shadow: 0 2px 6px rgba(0,0,0,.25);
  text-decoration:none;
  appearance:none;
}
.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;
}/* 1) Blur SOLO cuando se hoverea la imagen (no toda la tarjeta) */
.card-auto__media:hover .card-auto__img{
  transform: scale(1.03);
  filter: blur(2px) brightness(0.98) saturate(1.05);
}



/* 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;
}

/* Creamos sheen en el body */
.card-auto__body::before{
  content:""; 
  position:absolute; 
  left:0; 
  right:0; 
  bottom:0; 
  height: 55%;              /* ocupa solo la mitad inferior */
  z-index:0;                /* detrás del contenido */
  pointer-events:none;
  background:
    linear-gradient(100deg,
      transparent 0%,
      rgba(255,255,255,.08) 40%,
      rgba(255,255,255,.15) 50%,
      rgba(255,255,255,.10) 60%,
      transparent 100%);
  transform: translateX(-120%) skewX(-15deg);
  opacity: 0;
  transition: transform .6s ease, opacity .25s ease;
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
}
.card-auto:hover .card-auto__body::before{
  opacity:1;
  transform: translateX(120%) skewX(-15deg);
}
/* ===== 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 */
}


/* 7) Responsive: mantiene jerarquía sin “pesar” en mobile */
@media (max-width: 680px){
  .card-auto__media:hover .card-auto__img{
    /* bajamos apenas el efecto para móviles */
    transform: scale(1.02);
    filter: blur(1.5px) brightness(0.985) saturate(1.04);
  }
  .card-auto .ver-mas{ box-shadow:none; }
}

/* 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; }

/* Catálogo: ocultar WA si no lo querés en las cards */
.catalogo .card-auto .cta-wa,
.catalogo .card-auto a[href*="wa.me"],
.catalogo .card-auto a[href*="api.whatsapp.com"] {
  display: none !important;
}

/* Asegurar que “Ver más” luzca igual que Home */
.catalogo .card-auto .ver-mas {
  color: var(--bg);
  background: var(--primary);
  border-radius: 10px;
  padding: 6px 10px;
  text-decoration: none;
  font-weight: 700;
  border: 1px solid var(--primary-border);
  transition: background .2s ease, transform .12s ease;
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}
.catalogo .card-auto .ver-mas:hover {
  background: var(--primary-hover);
  transform: translateY(-1px);
}
/* En todas las cards: Ver más = link de texto */
.card-auto .ver-mas {
  background: none !important;
  border: none !important;
  color: var(--primary)!important;
  font-weight: 600;
  font-size: .95rem;
  padding: 0;
  border-radius: 0;
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  text-decoration: none;
  transition: color .2s ease;
}

.card-auto .ver-mas .flecha {
  font-size: 1rem;
  color: var(--primary);
  transition: transform .2s ease;
}

.card-auto .ver-mas:hover {
  color: var(--primary-hover);
}

.card-auto .ver-mas:hover .flecha {
  transform: translateX(2px);
}

/* ===== A11y helper ===== */
.sr-only {
  position:absolute!important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ===== Paginación Autobacs ===== */
.paginacion {
  display: flex;
  justify-content: center;
  margin: clamp(18px, 4vw, 36px) 0;
}
.paginacion .nav-links {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(180deg, #151515 0%, #0f0f0f 100%);
  border: 1px solid color-mix(in oklab, var(--primary-border) 65%, black 35%);
  border-radius: 14px;
  padding: 6px;
  box-shadow: 0 10px 28px rgba(0,0,0,.45);
}

/* Botón base */
.paginacion .page-numbers {
  position: relative;
  display: grid;
  place-items: center;
  min-width: 42px;
  height: 42px;
  padding: 0 10px;
  color: var(--fg);
  text-decoration: none;
  font-weight: 700;
  border-radius: 10px;
  border: 1px solid transparent;
  background: rgba(255,255,255,0.02);
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
}
.paginacion .page-numbers:hover,
.paginacion .page-numbers:focus-visible {
  transform: translateY(-1px);
  border-color: var(--primary-border);
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--primary-hover) 35%, transparent),
              0 12px 26px rgba(0,0,0,.45);
  outline: none;
}

/* Número actual */
.paginacion .page-numbers.current,
.paginacion .page-numbers[aria-current="page"] {
  background: var(--primary);
  color: var(--bg);
  border-color: var(--primary-border);
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--primary-hover) 40%, transparent),
              0 0 18px var(--primary-glow) inset;
}

/* Puntos suspensivos */
.paginacion .page-numbers.dots {
  color: var(--muted);
  background: transparent;
  border: 1px dashed rgba(255,255,255,.12);
  cursor: default;
}

/* Prev / Next con chevrons */
.paginacion .prev,
.paginacion .next {
  width: 42px; padding: 0; /* que queden pildoritas */
  border: 1px solid color-mix(in oklab, var(--primary-border) 65%, black 35%);
  background: rgba(255,255,255,0.03);
}
.paginacion .prev::before,
.paginacion .next::before {
  content: ""; width: 18px; height: 18px;
  background: var(--fg);
  -webkit-mask: var(--abx-chevron) center/contain no-repeat;
  mask: var(--abx-chevron) center/contain no-repeat;
}
.paginacion .prev { --abx-chevron: 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='15 18 9 12 15 6'/></svg>"); }
.paginacion .next { --abx-chevron: 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='9 18 15 12 9 6'/></svg>"); }

/* Hover estado en prev/next */
.paginacion .prev:hover, .paginacion .next:hover {
  background: var(--primary);
  border-color: transparent;
}
.paginacion .prev:hover::before, .paginacion .next:hover::before {
  background: var(--bg);
}

/* Línea diagonal dorada (sutil, como tus cards) */
.paginacion .nav-links::after {
  content: "";
  position: absolute;
  width: 1px;
  height: 180%;
  top: -40%; left: 50%;
  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;
}

/* Compacto en mobile */
@media (max-width: 560px) {
  .paginacion .nav-links { gap: 6px; padding: 4px; }
  .paginacion .page-numbers { min-width: 36px; height: 36px; }
  .paginacion .prev, .paginacion .next { width: 36px; }
}





/* =======================================================
   SINGLE VEHÍCULO • Autobacs (optimizado brand-first)
   Scope: .veh-single
   ======================================================= */
/* ==== Galería Vehículo: máxima nitidez y cobertura ==== */
.veh-gal__viewport {
  position: relative;
  overflow: hidden;
  border-radius: var(--card-radius, 12px); /* opcional, estilo redondeado */
}

.veh-gal__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  /* Blur-up: se ve el LQIP como bg hasta que cargue */
  background-size:cover;
  background-position:center;
  transition: filter
  .25s ease, opacity .25s ease;
  filter: saturate(1.03);
}

/* Cuando el navegador ya cargó la imagen real, ocultamos el LQIP */
.veh-gal__img.has-lqip {
  /* el LQIP como bg se mantiene pero pasa desapercibido al cubrirlo la imagen definitiva */
}

/* Hover opcional para dar vida */
.veh-gal__viewport:hover .veh-gal__img {
  transform: scale(1.02);
  filter: brightness(0.98) saturate(1.03);
}

/* Ajustes para slides múltiples */
.veh-gal__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .4s ease;
}
.veh-gal__slide.is-active {
  opacity: 1;
  position: relative;
  z-index: 2;
}

/* Algunos themes meten un icono con ::before o un <i>/<svg>. 
   Dejamos SOLO tu SVG inline (class="icon"). */
.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;
}

/* Layout del botón con TU SVG */
.veh-single .veh-cta .btn{
  display:inline-flex; align-items:center; gap:.55rem; line-height:1;
}
.veh-single .veh-cta .btn .icon{
  width:20px; height:20px; flex:0 0 auto; margin:0; color:#f5f5f5;
}

/* Por si el theme aplica un background-image al botón, lo neutralizamos */
.veh-single .btn--wpp{ background-image:none!important; }

/* Nota: verás ::after en el <a> en DevTools: es el brillo diagonal del botón, no un icono extra. */


/* =========================================
   FIX 2: Galería sin zoom/blur al hover
   ========================================= */

/* Anula el efecto de zoom/blur definido arriba en tu hoja */
@media (hover:hover){
  .veh-single .veh-gal__viewport:hover .veh-gal__img,
  .veh-single .veh-gal__img:hover{
    transform:none!important;
    filter:none!important;
    transition:none!important;
  }
}

/* ==== FIX hard: flechas de la galería siempre por arriba y clickeables ==== */
.veh-single .veh-gal__viewport{
  position: relative; /* base del stacking */
  isolation: isolate; /* evita que pseudos de ancestros las tapen */
}
.veh-single .veh-gal__viewport{ position:relative; isolation:isolate; }
.veh-single .veh-gal__slide,
.veh-single .veh-gal__img{ pointer-events:none !important; z-index:1; }
.veh-single .veh-gal__arrow{ pointer-events:auto !important; z-index:99 !important; }

/* Los slides e imagen NO deben interceptar clicks (swipe lo escucha el viewport) */
.veh-single .veh-gal__slide,
.veh-single .veh-gal__img{
  pointer-events: none !important;
  z-index: 1;
}

/* Flechas por encima de todo y con click garantizado */
.veh-single .veh-gal__arrow{
  pointer-events: auto !important;
  z-index: 99 !important;   /* más alto que cualquier overlay/pseudo */
}

/* Por si algún pseudo hace overlay: que no intercepte eventos */
.veh-single .u-glow-border::after,
.veh-single .veh-gal__viewport::before,
.veh-single .veh-gal__viewport::after{
  pointer-events: none !important;
}

/* Boton Whatsapp Functions*/
/* Botón flotante — look “glass” oscuro + glow de marca */
.abx-wa{
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 999px;

  /* vidrio oscuro */
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  /* borde fino en tu línea + tinte de marca */
  border: 1px solid color-mix(in oklab, var(--line, rgba(255,255,255,.12)) 70%, var(--brand, #ffa01a) 30%);

  color: #fff;
  box-shadow:
    0 8px 24px rgba(0,0,0,.45),
    0 0 0 1px rgba(0,0,0,.2) inset,
    0 0 22px color-mix(in oklab, var(--brand, #ffa01a) 28%, transparent);

  transition: transform .22s ease, box-shadow .25s ease, border-color .2s ease, background .2s ease;
  z-index: 9999;
}

.abx-wa:hover{
  transform: translateY(-2px) scale(1.04);
  background: rgba(0,0,0,.68);
  border-color: color-mix(in oklab, var(--brand, #ffa01a) 55%, #000 45%);
  box-shadow:
    0 12px 34px rgba(0,0,0,.55),
    0 0 28px color-mix(in oklab, var(--brand, #ffa01a) 38%, transparent);
}

.abx-wa svg{ display:block; }             /* nítido */
@media (prefers-reduced-motion: reduce){
  .abx-wa{ transition:none; }
  .abx-wa:hover{ transform:none; }
}
/* Variante “verde sólido” */
.abx-wa{
  background: #25d366;
  color: #0b0b0b;
  border-color: color-mix(in oklab, #25d366 60%, #000 40%);
  box-shadow: 0 10px 22px rgba(37,211,102,.35), 0 0 16px rgba(37,211,102,.35);
}
.abx-wa:hover{
  background: #2fe27a;
  box-shadow: 0 14px 32px rgba(37,211,102,.45), 0 0 22px rgba(37,211,102,.45);
}

.abx-wa__icon{ display:block; width:22px; height:22px; }



/* -------- TOKENS (brand) -------- */
.veh-single{
  --brand: #ffa01a;                 /* color marca */
  --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;

  --shadow-lg:0 16px 32px rgba(0,0,0,.45);
  --shadow-sm:0 8px 18px rgba(0,0,0,.26);
}

/* -------- UTILS -------- */
.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);
}
/* glow sin animación (fijo, elegante) */
.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;  /* sin movimiento */
}

/* Botón base (se usa en CTAs) */
.veh-single .u-btn{
  position:relative; display:flex; align-items:center; justify-content:center;
  height:clamp(48px,6.2vw,56px); padding-inline:clamp(14px,3.6vw,22px);
  border-radius:14px; font-weight:900; letter-spacing:.2px; color:#f5f5f5!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 .u-btn:hover,
.veh-single .u-btn:focus-visible{
  transform:translateY(-2px);
  box-shadow: 0 16px 34px rgba(0,0,0,.45);
  outline:0;
}
.veh-single .u-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 .u-btn:hover::after{ opacity:.5; }

/* -------- LAYOUT -------- */
.veh-single .container,
.veh-single .container-xl{ width:min(1280px,96vw); margin-inline:auto; }
.veh-single .veh-hero-grid{
  display:grid; gap:20px; grid-template-columns:1fr; 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,3fr) minmax(0,2fr); column-gap:24px; }
  .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; }
.veh-single .veh-gal__viewport{
  aspect-ratio:16/9; max-height:min(72vh,720px);
  border-radius:var(--r-lg)!important; overflow:hidden; /* radios iguales */
}
@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; }
}
/* sin diagonales */
.veh-single .veh-gal__viewport::before{ display:none!important; }

.veh-single .veh-gal__slide{ position:absolute; inset:0; opacity:0; pointer-events:none; transition:opacity .25s; }
.veh-single .veh-gal__slide.is-active{ opacity:1; pointer-events:auto; }
.veh-single .veh-gal__img{
  position:absolute; inset:0; width:100%!important; height:100%!important;
  object-fit:cover; object-position:center; border-radius:inherit;
}
@media (hover:hover){
  .veh-single .veh-gal__viewport:hover .veh-gal__img{
    transform:scale(1.02); filter:blur(1px) brightness(.98) saturate(1.02);
    transition:transform .35s ease, filter .25s ease;
  }
}


/* Contador con marca */
.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:var(--panel-1); background:var(--brand); border:1px solid var(--brand-border);
  box-shadow:0 0 0 1px var(--brand-glow), 0 10px 20px -8px var(--brand-glow);
}
@media (max-width:520px){
  .veh-single .veh-gal__count{ font-size:12px; padding:.3rem .55rem; right:10px; bottom:10px; }
}

/* Thumbs */
.veh-single .veh-thumbs.slicer{ margin-top:.75rem; }
.veh-single .veh-thumbs .slicer__track{
  --thumb-w:124px; display:flex; gap:12px; overflow-x:auto; padding:4px;
  -webkit-overflow-scrolling:touch; scroll-snap-type:x proximity; max-width:100%;
}
.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;
}
.veh-single .veh-gal__thumb{
  border-radius:var(--r-sm); border:1px solid var(--line); overflow:hidden;
  background:linear-gradient(90deg,var(--panel-1),var(--panel-2));
  transition: transform .12s, border-color .12s;
}
.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{
  background:rgba(255,255,255,.02); border:1px solid var(--line); border-radius:var(--r-sm); padding:.32rem .6rem;
}

.veh-single .veh-specs{ display:grid; gap:.75rem 1rem; grid-template-columns:repeat(2,minmax(0,1fr)); }
@media (min-width:900px){ .veh-single .veh-specs{ grid-template-columns:repeat(3,minmax(0,1fr)); } }
.veh-single .veh-specs .pair{
  background:rgba(255,255,255,.02); border:1px solid var(--line); border-radius:var(--r-sm); padding:.55rem .7rem;
}
.veh-single .veh-specs .k{ color:var(--text-2); font:600 .78rem/1.2 system-ui,Inter,Arial; letter-spacing:.2px; }
.veh-single .veh-specs .v{ color:var(--text-1); font:800 .98rem/1.1 system-ui,Inter,Arial; }

/* Precio con marca */
.veh-single .veh-price{
  display:inline-block; margin:.35rem 0 1rem; padding:.35rem .7rem;
  border-radius:var(--r-sm); font:900 1.15rem/1.15 system-ui,Inter,Arial;
  color:var(--brand); background:rgba(255,255,255,.06); border:1px solid var(--line-2);
  box-shadow:0 6px 16px rgba(0,0,0,.28);
}

/* === Sin diagonales ni animación de glow === */
.veh-single .u-glow-border::after{ opacity:.55; animation:none!important; }
.veh-single .veh-gal__viewport::before{ display:none!important; }

/* === Imagen a borde y radios consistentes === */
.veh-single .veh-gal__viewport{ overflow:hidden; border-radius:16px!important; }
.veh-single .veh-gal__img{
  width:100%!important; height:100%!important; object-fit:cover; object-position:center; border-radius:inherit;
}

/* === Flechas por encima y con blur === */
.veh-single .veh-gal{ position:relative; }
.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; pointer-events:auto; cursor:pointer;
  background:rgba(0,0,0,.55); backdrop-filter:blur(4px);
  border:1px solid var(--line); color:var(--text-1);
  transition:background .2s, border-color .2s, transform .2s;
}
.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, #ffa01a 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 #ffa01a; }
.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); }

/* === CTA: estilo base directo a .btn (sin reglas vacías) === */
.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;
  height:clamp(48px,6.2vw,56px); padding-inline:clamp(14px,3.6vw,22px);
  border-radius:14px; font-weight:900; letter-spacing:.2px; color:#f5f5f5!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, #ffa01a 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; }

/* Variante WhatsApp (glow sutil verdoso) */
.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);
}

/* Variante Share (borde en marca) */
.veh-single .veh-cta .btn--share{
  border-color:#ffa01a!important;
}

/* Contador con marca (por consistencia) */
.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:#ffa01a; border:1px solid color-mix(in oklab, #ffa01a 85%, #fff 15%);
  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; }
}

/* Por si el panel externo mostraba esquinas rectas */
.veh-single .veh-wrap.u-panel{ border-radius:16px; }

/* Botón WhatsApp con icono */
.veh-single .veh-cta .btn .icon{
  width:20px; height:20px; margin-right:.55rem; flex:0 0 auto;
}
.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);
}
/* Quita cualquier ícono heredado del theme */
.veh-single .btn--wpp::before{ content:none!important; background:none!important; }
.veh-single .btn--wpp > i,
.veh-single .btn--wpp > .iconify,
.veh-single .btn--wpp > svg.iconify{ display:none!important; }

/* Layout del botón + svg inline */
.veh-single .veh-cta .btn{ display:inline-flex; align-items:center; gap:.55rem; }
.veh-single .veh-cta .btn .icon{ width:20px; height:20px; flex:0 0 auto; }

.btn--share .icon-share {
  width: 18px;
  height: 18px;
  margin-right: 6px;
  vertical-align: middle;
}


/* Tarjetitas (specs) más interactivas */
.veh-single .veh-specs .pair{
  position:relative; overflow:hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.015));
  border:1px solid var(--line); border-radius: var(--r-sm);
  transition: border-color .2s ease, box-shadow .22s ease, transform .18s ease, background .22s ease;
}
.veh-single .veh-specs .pair::after{
  /* highlight suave al hover/focus */
  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; }
.veh-single .veh-specs .v{ display:block; margin-top:.15rem; color:var(--text-1); font:800 .98rem/1.1 system-ui,Inter,Arial; }

/* Si tenías desbordes por textos largos (ej. Automática) */
.veh-single .veh-specs .pair .v{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ===== Precio destacado (debajo de chips) ===== */
.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, #ffa01a 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, #ffa01a 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:#ffa01a;
  text-shadow: 0 0 18px rgba(255,160,26,.22);
}

/* ===== Descripción integrada a la tarjeta general ===== */
/* sin sub-tarjeta, solo un separador superior y espaciado */
.veh-single .veh-desc{
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255,255,255,.12);
}
.veh-single .veh-desc__header{ margin-bottom:.6rem; }
.veh-single .veh-desc .u-titulo{
  font-size: clamp(1.05rem, 2.2vw, 1.25rem);
  font-weight: 800; color:#fff; margin:0;
}
.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;
}

/* Opcional: en mobile dar más aire al bloque de desc */
@media (max-width: 768px){
  .veh-single .veh-desc{ margin-top:1rem; padding-top:1rem; }
}


/* -------- DESCRIPCIÓN -------- */
.veh-single .veh-divider{ height:1px; border:0; margin:18px 0 14px; background:rgba(255,255,255,.12); }
.veh-single .veh-desc{ padding:1.5rem; margin-top:1.5rem; border-radius:var(--r-lg); }
.veh-single .veh-desc h2{ margin-bottom:.8rem; font-size:clamp(1.05rem,2.2vw,1.25rem); font-weight:800; color:#fff; }
.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:8px; }

/* -------- FIX OVERFLOW -------- */
.single-vehiculo .veh-single{ width:100%; max-width:none; margin:0 auto; overflow-x:hidden; }
/* por si el panel contenedor de la galería mostraba esquinas "cuadradas" */
.veh-single .veh-wrap.u-panel{ border-radius:var(--r-lg); }


/* ==== FIX: la foto debe llenar y respetar el radio en las 4 esquinas ==== */

/* El viewport debe ser el contenedor de referencia de los slides */
.veh-single .veh-gal__viewport{
  position: relative;           /* CLAVE: los slides absolutas referencian acá */
  border-radius: 16px !important;
  overflow: hidden;             /* recorta imagen dentro del radio */
  line-height: 0;               /* evita posibles gaps de línea */
}

/* El <figure> no debe aportar márgenes ni desbordes */
.veh-single .veh-gal__slide{
  position: absolute; inset: 0; /* ya lo tenías, lo reforzamos aquí */
  margin: 0;                    /* quita margen default del figure */
  border-radius: inherit;       /* por si hubiera sombras/overlays */
  overflow: hidden;
}

/* La imagen llena todo y no deja “cepillo” abajo */
.veh-single .veh-gal__img{
  position: absolute; inset: 0;
  width: 100% !important; height: 100% !important;
  object-fit: cover; object-position: center;
  display: block;               /* elimina gap por baseline inline */
  border-radius: inherit;
}

/* Si usás el halo ::after en .u-glow-border, asegúrate que no tape el radio */
.veh-single .u-glow-border::after{
  border-radius: inherit;       /* ya estaba, lo reafirmamos */
}

/* ===== GUTTER INTERNO + ALINEACIÓN IZQ/DER ===== */
.veh-single{
  /* padding interno del contenedor general (ajustable) */
  --wrap-pad: clamp(12px, 2vw, 18px);
  --col-gap : clamp(18px, 2.2vw, 26px); /* separación entre galería y panel derecho */
}

/* espacio perimetral dentro de la tarjeta general */
.veh-single .veh-wrap.u-panel{
  padding: var(--wrap-pad);
  border-radius: 16px; /* por consistencia visual */
}

/* el grid respeta el mismo ritmo para que ambos queden alineados */
.veh-single .veh-hero-grid{
  gap: var(--wrap-pad);
  column-gap: var(--col-gap);
}

/* la galería respeta el gutter y rellena su columna */
.veh-single .veh-gal{ width: 100%; }

/* por si algún estilo previo había colocado márgenes manuales */
.veh-single .veh-gal__viewport{ margin: 0; }
.veh-single .veh-thumbs.slicer{ margin-top: .75rem; }

/* opcional: un sutil borde al viewport para que “dialogue” con la tarjeta derecha */
.veh-single .veh-gal__viewport{
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
  /* ya tenés borde + glow del u-panel/u-glow-border, esto solo suaviza el interior */
}


/* ===== 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; }
}









































































