/* ============================================================
   FAQ ACORDEÓN
   ============================================================ */

/* ============================================================
   POPULARES
   ============================================================ */
.ks-popular {
  margin: 1.25rem 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}
.ks-popular__title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #e67e00;
  white-space: nowrap;
  text-align: center;
}
.ks-popular__title svg { opacity: 0.85; }
.ks-popular__list {
  list-style: none;
  margin: 0;
  padding: 0 0 0.25rem;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 0.35rem;
  overflow-x: auto;
  max-width: 100%;
  scrollbar-width: none;
}
.ks-popular__list::-webkit-scrollbar { display: none; }
.ks-popular__list li { display: flex; }
.ks-popular__link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  text-decoration: none;
  color: #444;
  padding: 0.2rem 0.6rem 0.2rem 0.3rem;
  border-radius: 20px;
  border: 1.5px solid #f0d8b8;
  background: #fff9f4;
  font-size: 0.8rem;
  font-weight: 500;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
  white-space: nowrap;
}
.ks-popular__link:hover {
  border-color: #e67e00;
  color: #bf5500;
  background: #fff3e0;
}
.ks-popular__rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  background: #ffe0b2;
  color: #bf5500;
  font-size: 0.6rem;
  font-weight: 700;
  flex-shrink: 0;
}
.ks-popular__link:hover .ks-popular__rank {
  background: #e67e00;
  color: #fff;
}
.ks-faq {
  margin: 2.5rem 0 1rem;
  border-top: 2px solid rgba(36, 185, 215, 0.15);
  padding-top: 1.8rem;
}

.ks-faq__title {
  font-size: 1.15rem;
  font-weight: 700;
  color: #1a3a4a;
  margin: 0 0 1.2rem;
}

.ks-faq__list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ks-faq__item {
  border: 1px solid rgba(36, 185, 215, 0.2);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  transition: box-shadow 0.2s;
}

.ks-faq__item:hover {
  box-shadow: 0 2px 10px rgba(36, 185, 215, 0.1);
}

.ks-faq__question { margin: 0; }
.ks-faq__toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  padding: 0.85rem 1.1rem;
  border: none;
  background: none;
  cursor: pointer;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  color: #1a4a5a;
  text-align: left;
  user-select: none;
  transition: background 0.15s;
}

.ks-faq__toggle:hover,
.ks-faq__item.ks-open .ks-faq__toggle {
  background: rgba(36, 185, 215, 0.05);
}
.ks-faq__toggle:focus-visible {
  outline: 2px solid var(--ks-primary, #24b9d7);
  outline-offset: -2px;
  border-radius: 2px;
}

.ks-faq__caret {
  flex-shrink: 0;
  color: var(--ks-primary, #24b9d7);
  transition: transform 0.25s;
}

.ks-faq__item.ks-open .ks-faq__caret {
  transform: rotate(180deg);
}

.ks-faq__answer {
  display: none;
  margin: 0;
  padding: 0 1.1rem 1rem;
  font-size: 0.875rem;
  line-height: 1.65;
  color: #4a6070;
  border-top: 1px solid rgba(36, 185, 215, 0.1);
}

.ks-faq__item.ks-open .ks-faq__answer {
  display: block;
}

/* ── Guías HowTo (reutilizan .ks-faq__* pero con iconos + pasos numerados) ── */
.ks-faq--howto .ks-guide__toggle {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.ks-guide__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(36, 185, 215, .12);
  color: var(--ks-primary, #24b9d7);
  transition: background .2s, color .2s;
}
.ks-guide--jump_start .ks-guide__icon     { background: rgba(245, 158, 11, .12); color: #d97706; }
.ks-guide--maintenance .ks-guide__icon    { background: rgba(16, 185, 129, .12); color: #10b981; }
.ks-guide--change_battery .ks-guide__icon { background: rgba(36, 185, 215, .12); color: var(--ks-primary, #24b9d7); }
.ks-faq__item.ks-open .ks-guide__icon {
  background: currentColor;
}
.ks-faq__item.ks-open .ks-guide--change_battery .ks-guide__icon,
.ks-faq__item.ks-open.ks-guide--change_battery .ks-guide__icon,
.ks-faq__item.ks-open.ks-guide--jump_start .ks-guide__icon,
.ks-faq__item.ks-open.ks-guide--maintenance .ks-guide__icon {
  color: #fff;
  background: currentColor;
}
.ks-faq__item.ks-open.ks-guide--change_battery .ks-guide__icon { background: var(--ks-primary, #24b9d7); }
.ks-faq__item.ks-open.ks-guide--jump_start .ks-guide__icon     { background: #d97706; }
.ks-faq__item.ks-open.ks-guide--maintenance .ks-guide__icon    { background: #10b981; }
.ks-guide__title {
  flex: 1;
  font-weight: 600;
  font-size: .98rem;
  line-height: 1.35;
}
.ks-howto__desc {
  margin: 0 0 1rem;
  font-size: .92rem;
  line-height: 1.55;
  color: #4a5369;
  padding: .6rem .8rem;
  background: rgba(36, 185, 215, .06);
  border-left: 3px solid var(--ks-primary, #24b9d7);
  border-radius: 4px;
}
.ks-howto__steps {
  list-style: none;
  counter-reset: ks-step;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .65rem;
}
.ks-howto__step {
  display: flex;
  gap: .75rem;
  align-items: flex-start;
  padding: .6rem .75rem;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  transition: border-color .15s, box-shadow .15s;
}
.ks-howto__step:hover {
  border-color: var(--ks-primary, #24b9d7);
  box-shadow: 0 2px 8px rgba(36, 185, 215, .08);
}
.ks-howto__step-num {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--ks-primary, #24b9d7);
  color: #fff;
  font-size: .82rem;
  font-weight: 700;
  line-height: 1;
}
.ks-guide--jump_start     .ks-howto__step-num { background: #d97706; }
.ks-guide--maintenance    .ks-howto__step-num { background: #10b981; }
.ks-howto__step-body {
  flex: 1;
  min-width: 0;
}
.ks-howto__step-name {
  display: block;
  font-weight: 700;
  font-size: .95rem;
  color: #1f2937;
  margin-bottom: .15rem;
  line-height: 1.3;
}
.ks-howto__step-text {
  display: block;
  font-size: .88rem;
  line-height: 1.5;
  color: #4a5369;
}
.ks-howto__disclaimer {
  display: flex;
  align-items: flex-start;
  gap: .55rem;
  margin: 1rem 0 0;
  padding: .7rem .85rem;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-left: 3px solid #f59e0b;
  border-radius: 6px;
  font-size: .82rem;
  line-height: 1.5;
  color: #78350f;
}
.ks-howto__disclaimer-icon {
  flex-shrink: 0;
  color: #d97706;
  margin-top: 1px;
}

/* ── Quick filter row ── */
.ks-quick-filters-row {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.5rem;
}

/* ── Tooltips ── */
.ks-note {
  font-size: 14px;
  line-height: 1.6;
  color: #333;
}

.ks-tooltip-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ks-tooltip-trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  font: inherit;
  color: #0a58ca;
  cursor: pointer;
}

.ks-tooltip-text-link {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.ks-tooltip-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 17px;
  height: 17px;
  border-radius: 50%;
  background: #0a58ca;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}

.ks-tooltip-box {
  position: absolute;
  left: 0;
  top: calc(100% + 8px);
  z-index: 20;
  width: 320px;
  max-width: min(320px, 85vw);
  padding: 10px 12px;
  border-radius: 8px;
  background: #1f2937;
  color: #fff;
  font-size: 13px;
  line-height: 1.45;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .18);
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
}

.ks-tooltip-box::before {
  content: "";
  position: absolute;
  top: -6px;
  left: 18px;
  width: 12px;
  height: 12px;
  background: #1f2937;
  transform: rotate(45deg);
}

.ks-tooltip-wrap:hover .ks-tooltip-box,
.ks-tooltip-wrap:focus-within .ks-tooltip-box,
.ks-tooltip-wrap.is-open .ks-tooltip-box {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

@media (max-width: 480px) {
  .ks-tooltip-box {
    left: 50%;
    transform: translateX(-50%) translateY(4px);
  }
  .ks-tooltip-wrap:hover .ks-tooltip-box,
  .ks-tooltip-wrap:focus-within .ks-tooltip-box,
  .ks-tooltip-wrap.is-open .ks-tooltip-box {
    transform: translateX(-50%) translateY(0);
  }
  .ks-tooltip-box::before {
    left: 50%;
    margin-left: -6px;
  }
}

/* ── Cart vehicle prompt ───────────────────────────────────── */
.ks-cart-vehicle-prompt {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  background: #fffbe6;
  border: 1px solid #f0d060;
  border-radius: 8px;
  padding: 1rem 1.25rem;
  margin: 1rem 0;
}
.ks-cvp-icon { font-size: 1.6rem; line-height: 1; flex-shrink: 0; }
.ks-cvp-body { flex: 1; }
.ks-cvp-question { margin: 0 0 .6rem; font-size: .95rem; }
.ks-cvp-plate {
  display: inline-block;
  background: #1a1a1a;
  color: #fff200;
  font-weight: 700;
  letter-spacing: .08em;
  padding: 0 .4em;
  border-radius: 3px;
  font-size: .85em;
  margin-left: .25em;
}
.ks-cvp-actions { display: flex; gap: .5rem; flex-wrap: wrap; }
.ks-cvp-btn {
  padding: .4rem .9rem;
  border-radius: 5px;
  border: none;
  cursor: pointer;
  font-size: .88rem;
  font-weight: 600;
  transition: opacity .15s;
}
.ks-cvp-btn:hover { opacity: .85; }
.ks-cvp-btn--yes { background: #2e7d32; color: #fff; }
.ks-cvp-btn--no  { background: #e0e0e0; color: #333; }

/* ── Quick filter: rango de precio ────────────────────────────── */
.ks-filter--range .ks-filter-panel--range { padding: .5rem .25rem .75rem; }
.ks-range-labels {
  display: flex;
  justify-content: space-between;
  font-size: .8rem;
  color: #555;
  margin-bottom: .35rem;
}
.ks-range-track { position: relative; height: 1.5rem; display: flex; align-items: center; }
.ks-range {
  position: absolute;
  width: 100%;
  pointer-events: none;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: transparent;
  outline: none;
}
.ks-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  pointer-events: all;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--bs-primary, #2196f3);
  cursor: pointer;
  border: 2px solid #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.25);
}
.ks-range::-moz-range-thumb {
  pointer-events: all;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--bs-primary, #2196f3);
  cursor: pointer;
  border: 2px solid #fff;
}

/* ══════════════════════════════════════════════════════════════
   MIS VEHÍCULOS
   ══════════════════════════════════════════════════════════════ */
.ks-mv { max-width: 820px; margin: 0 auto; padding: 1rem; }
.ks-mv__title { font-size: 1.6rem; margin-bottom: 1.5rem; }
.ks-mv__section { margin-bottom: 2.5rem; }
.ks-mv__section--recent { opacity: .85; }
.ks-mv__section-title { font-size: 1.1rem; font-weight: 700; margin-bottom: .75rem; border-bottom: 2px solid #e0e0e0; padding-bottom: .35rem; }
.ks-mv__hint { font-size: .85rem; color: #666; margin: -.4rem 0 .75rem; }
.ks-mv__empty { color: #888; font-style: italic; }
.ks-mv__back { display: inline-block; margin-top: 1rem; color: inherit; text-decoration: underline; font-size: .9rem; }
.ks-mv__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .6rem; }

/* Tarjeta */
.ks-mv-card {
  display: flex; align-items: flex-start; gap: 1rem;
  background: #fff; border: 1px solid #e0e0e0; border-radius: 10px;
  padding: .85rem 1rem; transition: box-shadow .15s;
}
.ks-mv-card:hover { box-shadow: 0 2px 10px rgba(0,0,0,.08); }
.ks-mv-card--saved { border-left: 4px solid var(--bs-primary, #2196f3); }
.ks-mv-card__body { flex: 1; display: flex; flex-wrap: wrap; align-items: center; gap: .4rem .75rem; }
.ks-mv-card__plate {
  background: #1a1a1a; color: #fff200; font-weight: 700;
  letter-spacing: .1em; padding: .15em .5em; border-radius: 4px; font-size: .95rem;
}
.ks-mv-card__label { font-weight: 600; font-size: .95rem; }
.ks-mv-card__relacion { font-size: .82rem; color: #555; background: #f5f5f5; padding: .1em .5em; border-radius: 12px; }
.ks-mv-card__no-name { font-style: italic; color: #aaa; }
.ks-mv-card__actions { display: flex; flex-direction: column; align-items: flex-end; gap: .4rem; flex-shrink: 0; }
.ks-mv-card__main-btns { display: flex; gap: .4rem; flex-wrap: wrap; justify-content: flex-end; }

/* Botones */
.ks-mv-card__btn {
  font-size: .8rem; padding: .3rem .7rem; border-radius: 5px; border: none;
  cursor: pointer; transition: opacity .15s; white-space: nowrap; background: #f0f0f0; color: #333;
}
.ks-mv-card__btn:hover { opacity: .8; }
.ks-mv-card__btn--search { background: var(--bs-primary, #2196f3); color: #fff; }
.ks-mv-card__btn--save   { background: #f5a623; color: #fff; }
.ks-mv-card__btn--confirm { background: #2e7d32; color: #fff; }
.ks-mv-card__btn--delete  { background: transparent; color: #c62828; border: 1px solid #c62828; }
.ks-mv-card__btn--delete:hover { background: #c62828; color: #fff; }

/* Formulario rename inline */
.ks-mv-card__rename-form { width: 100%; display: flex; flex-direction: column; gap: .4rem; margin-top: .25rem; }
.ks-mv-card__presets { display: flex; flex-wrap: wrap; gap: .3rem; }
.ks-mv-preset { font-size: .75rem; padding: .2rem .55rem; border-radius: 12px; border: 1px solid #bbb; background: #fff; cursor: pointer; transition: background .12s, color .12s; }
.ks-mv-preset:hover, .ks-mv-preset.is-selected { background: var(--bs-primary, #2196f3); color: #fff; border-color: transparent; }
.ks-mv-card__name-input { width: 100%; padding: .35rem .6rem; border: 1px solid #ccc; border-radius: 5px; font-size: .9rem; }
.ks-mv-card__rename-btns { display: flex; gap: .4rem; }

@media (max-width: 600px) {
  .ks-mv-card { flex-direction: column; }
  .ks-mv-card__actions { align-items: flex-start; width: 100%; }
  .ks-mv-card__main-btns { justify-content: flex-start; }
}

/* ── Auto intro GEO (respuesta directa generada automáticamente) ── */
.ks-auto-intro {
  font-size: 1rem;
  line-height: 1.6;
  color: #333;
  margin: .5rem 0 1rem;
  padding: .75rem 1rem;
  background: #f0f4ff;
  border-left: 3px solid var(--bs-primary, #2196f3);
  border-radius: 0 6px 6px 0;
}
.ks-auto-intro strong { color: #1a1a2e; }

/* ── Pestaña vehículos compatibles (hookDisplayProductExtraContent) ── */
.ks-compat { display: flex; flex-direction: column; gap: .75rem; padding: .5rem 0 .25rem; }
.ks-compat__brands { display: grid; grid-template-columns: repeat(var(--ks-cols-m, 1), 1fr); gap: .75rem; align-items: start; }
@media (min-width: 768px) { .ks-compat__brands { grid-template-columns: repeat(var(--ks-cols-d, 2), 1fr); } }
.ks-compat__search-wrap {
  display: flex;
  align-items: center;
  gap: .6rem;
  position: sticky;
  top: 0;
  z-index: 4;
  background: #fff;
  padding: .4rem 0 .5rem;
  border-bottom: 1px solid #e8eaf4;
}
.ks-compat__search {
  flex: 1;
  border: 1px solid #c8cfe8;
  border-radius: 8px;
  padding: .45rem .8rem;
  font-size: .85rem;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.ks-compat__search:focus { border-color: var(--ks-primary, #24b9d7); box-shadow: 0 0 0 3px rgba(36,185,215,.15); }
.ks-compat__search-count { font-size: .78rem; color: #8a94b8; white-space: nowrap; min-width: 5ch; text-align: right; }
.ks-compat__group {
  border: 1px solid #dde1f0;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(30,36,80,.06);
  transition: box-shadow .2s;
}
.ks-compat__group[open] { box-shadow: 0 4px 14px rgba(30,36,80,.1); }
.ks-compat__brand-row {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .7rem 1rem;
  background: linear-gradient(135deg, #eef2ff 0%, #f6f8ff 100%);
  border-bottom: 1px solid #dde1f0;
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.ks-compat__brand-row::-webkit-details-marker { display: none; }
.ks-compat__brand-logo {
  width: 48px;
  height: 48px;
  object-fit: contain;
  flex-shrink: 0;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,.18));
}
.ks-compat__brand-icon {
  width: 48px;
  height: 48px;
  /* flex-shrink: 0;
  border-radius: 8px;
  background: rgba(180,188,220,.13);
  border: 1.5px dashed rgba(150,160,200,.25); */
}
.ks-compat__brand-meta {
  flex: 1;
  display: flex;
  align-items: center;
  gap: .6rem;
  overflow: hidden;
}
.ks-compat__brand-name {
  font-size: .875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #1e2442;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
a.ks-compat__brand-name:hover { color: var(--bs-primary, #2a5bd7); }
.ks-compat__brand-years {
  font-size: .72rem;
  color: #8a94b8;
  white-space: nowrap;
  flex-shrink: 0;
}
.ks-compat__brand-pill {
  font-size: .7rem;
  font-weight: 700;
  color: #fff;
  background: var(--ks-primary, #24b9d7);
  border-radius: 20px;
  padding: .12rem .55rem;
  flex-shrink: 0;
  white-space: nowrap;
}
.ks-compat__chevron {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(255,255,255,.75);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .72rem;
  color: #888;
  transition: background .2s, color .2s, transform .2s;
}
.ks-compat__chevron::before { content: '▸'; }
details[open] .ks-compat__chevron { background: var(--ks-primary, #24b9d7); color: #fff; transform: rotate(90deg); }
.ks-compat__vehicles {
  display: grid;
  grid-template-columns: repeat(var(--ks-cols-m, 1), 1fr);
  background: #fff;
  /* <table> queda como rejilla: quitamos los comportamientos table-* que
     romperían la disposición de celdas. Acepta <caption> dentro del grid. */
  border-collapse: collapse;
  width: 100%;
}
@media (min-width: 768px) { .ks-compat__vehicles { grid-template-columns: repeat(var(--ks-cols-d, 2), 1fr); } }
/* Semántica real de tabla para Google/LLMs sin romper el layout:
   tbody/tr/td con display:contents → sus hijos (los <a>.ks-compat__vehicle)
   quedan como items directos del grid parent. */
.ks-compat__tbody,
.ks-compat__row,
.ks-compat__cell { display: contents; }
/* Cabecera y caption accesibles para crawlers, invisibles en pantalla. */
.ks-compat__thead,
.ks-compat__caption {
  position: absolute !important;
  width: 1px; height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0; padding: 0; margin: -1px;
}
/* Fix desktop: al abrir una marca en rejilla de varias columnas, que ocupe
   el ancho completo en lugar de compartir fila con la marca vecina. */
@media (min-width: 768px) {
  .ks-compat__brands > .ks-compat__group[open] { grid-column: 1 / -1; }
}
/* ── Sección dinámica: más buscados ── */
.ks-compat__top {
  background: linear-gradient(135deg, #f0f4ff 0%, #f8f9ff 100%);
  border: 1px solid #dde3f5;
  border-radius: 10px;
  padding: .75rem .9rem .8rem;
}
.ks-compat__top-title {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: #9aa2c8;
  margin: 0 0 .6rem;
  display: flex;
  align-items: center;
  gap: .4em;
}
.ks-compat__top-title::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ks-primary, #24b9d7);
  flex-shrink: 0;
}
.ks-compat__top-list {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}
.ks-compat__top-item {
  display: inline-flex;
  align-items: baseline;
  gap: .35em;
  padding: .35rem .8rem .35rem .65rem;
  border-radius: 2rem;
  border: 1.5px solid #cdd5f0;
  background: #fff;
  color: #2b3467;
  font-size: .8rem;
  line-height: 1.3;
  cursor: pointer;
  text-decoration: none;
  box-shadow: 0 1px 3px rgba(30,40,100,.07);
  transition: background .15s, border-color .15s, color .15s, box-shadow .15s, transform .1s;
  user-select: none;
}
.ks-compat__top-item:hover {
  background: #eef2ff;
  border-color: var(--ks-primary, #24b9d7);
  color: #1a2580;
  box-shadow: 0 2px 8px rgba(36,185,215,.18);
  transform: translateY(-1px);
}
.ks-compat__top-item.is-active {
  background: var(--ks-primary, #24b9d7);
  border-color: var(--ks-primary, #24b9d7);
  color: #fff;
  box-shadow: 0 2px 10px rgba(36,185,215,.35);
  transform: translateY(-1px);
}
.ks-compat__top-item.is-active .ks-compat__top-engine,
.ks-compat__top-item.is-active .ks-compat__top-years { opacity: .85; }
.ks-compat__top-name { font-weight: 700; font-size: .82rem; }
.ks-compat__top-engine {
  font-size: .72rem;
  font-weight: 400;
  opacity: .7;
  white-space: nowrap;
}
.ks-compat__top-years {
  font-size: .7rem;
  font-weight: 500;
  opacity: .55;
  white-space: nowrap;
}
.ks-compat__top-item .ks-compat__arrow {
  font-size: .75rem;
  opacity: .4;
  margin-left: .1em;
  align-self: center;
  transition: opacity .15s, transform .15s;
}
.ks-compat__top-item:hover .ks-compat__arrow,
.ks-compat__top-item.is-active .ks-compat__arrow { opacity: .9; transform: translateX(2px); }
.ks-compat__vehicle {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .48rem .9rem;
  border-bottom: 1px solid #f0f2f8;
  border-right: 1px solid #f0f2f8;
  text-decoration: none;
  color: #2a2f4a;
  font-size: .82rem;
  transition: background .12s, color .12s;
}
.ks-compat__vehicle:nth-child(2n) { border-right: none; }
.ks-compat__vehicle:last-child,
.ks-compat__vehicle:nth-last-child(2):nth-child(2n+1) { border-bottom: none; }
.ks-compat__vehicle:hover { background: #eef2ff; color: var(--bs-primary, #2a5bd7); }
.ks-compat__vehicle-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.ks-compat__model { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: flex; align-items: baseline; gap: .3em; }
.ks-compat__year-inline { font-size: .72em; font-weight: 400; color: #8a94b8; flex-shrink: 0; }
.ks-compat__engine { font-size: .75rem; color: #888; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ks-compat__vehicle:hover .ks-compat__engine { color: inherit; opacity: .75; }.ks-compat__year {
  font-size: .68rem;
  font-weight: 600;
  color: #fff;
  background: #8a94b8;
  border-radius: 4px;
  padding: .1rem .35rem;
  white-space: nowrap;
  flex-shrink: 0;
}
.ks-compat__arrow { font-size: .9rem; color: #c8cde6; flex-shrink: 0; transition: color .12s, transform .12s; }
.ks-compat__vehicle:hover .ks-compat__arrow { color: var(--bs-primary, #2a5bd7); transform: translateX(3px); }
@media (max-width: 480px) {
  .ks-compat__brand-row { padding: .6rem .75rem; }
  .ks-compat__brand-logo { width: 40px; height: 40px; }
  .ks-compat__vehicle { padding: .45rem .75rem; }
}

/* ═══════════════════════════════════════════════════════════════════
   Categorías de producto  (start-stop / convencional / auxiliar)
   ═══════════════════════════════════════════════════════════════════ */

/* Paleta por categoría — todas con prefijo ks- para no colisionar con el tema */
:root {
  --ks-cat-ss-color:   #0ea5e9;   /* start-stop  — azul cielo */
  --ks-cat-ss-light:   #e0f4fc;
  --ks-cat-ss-mid:     #bae6fd;
  --ks-cat-cv-color:   #475569;   /* convencional — pizarra */
  --ks-cat-cv-light:   #f1f5f9;
  --ks-cat-cv-mid:     #e2e8f0;
  --ks-cat-av-color:   #7c3aed;   /* auxiliar     — violeta */
  --ks-cat-av-light:   #f5f3ff;
  --ks-cat-av-mid:     #ede9fe;
}

.ks-products-categorized {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-top: 0.5rem;
}

/* ── Tarjeta de sección ─────────────────────────────────────────── */
.ks-cat-section {
  background: #fff;
  border-radius: 14px;
  border: 1px solid rgba(0, 0, 0, 0.09);
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.05);
  position: relative;
  /* Borde izquierdo de color mediante border-left (no ::before para no bloquear overflow) */
}
.ks-cat-section--is_start_stop   { border-left: 4px solid var(--ks-cat-ss-color); }
.ks-cat-section--is_conventional { border-left: 4px solid var(--ks-cat-cv-color); }
.ks-cat-section--auxiliary_value { border-left: 4px solid var(--ks-cat-av-color); }

/* ── Cabecera ───────────────────────────────────────────────────── */
.ks-cat-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem 1rem 1.25rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  cursor: pointer;
  user-select: none;
  transition: background 0.15s;
  border-radius: 13px 13px 0 0;
}
.ks-cat-header:hover { background: rgba(0, 0, 0, 0.018); }

.ks-cat-header__left {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  flex: 1;
  min-width: 0;
}

/* Icono circular */
.ks-cat-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 10px;
  flex-shrink: 0;
}
.ks-cat-section--is_start_stop   .ks-cat-icon { background: var(--ks-cat-ss-light); color: var(--ks-cat-ss-color); }
.ks-cat-section--is_conventional .ks-cat-icon { background: var(--ks-cat-cv-light); color: var(--ks-cat-cv-color); }
.ks-cat-section--auxiliary_value .ks-cat-icon { background: var(--ks-cat-av-light); color: var(--ks-cat-av-color); }

.ks-cat-header__text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}

.ks-cat-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0;
  line-height: 1.3;
}
.ks-cat-section--is_start_stop   .ks-cat-title { color: var(--ks-cat-ss-color); }
.ks-cat-section--is_conventional .ks-cat-title { color: var(--ks-cat-cv-color); }
.ks-cat-section--auxiliary_value .ks-cat-title { color: var(--ks-cat-av-color); }

.ks-cat-desc {
  font-size: 0.78rem;
  color: #6b7280;
  margin: 0;
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Lado derecho: contador + ayuda + caret */
.ks-cat-header__right {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-shrink: 0;
  margin-left: auto;
}

/* Caret de colapso */
.ks-cat-caret {
  display: inline-flex;
  align-items: center;
  color: #9ca3af;
}
.ks-cat-caret__icon {
  transition: transform 0.22s ease;
}
.ks-cat-section--collapsed .ks-cat-caret__icon,
.ks-cat-section--all-hidden .ks-cat-caret__icon {
  transform: rotate(-90deg);
}

/* Colapso: ocultar productos */
.ks-cat-section--collapsed .ks-cat-products,
.ks-cat-section--all-hidden .ks-cat-products {
  display: none;
}
/* Header sin borde inferior cuando está colapsado */
.ks-cat-section--collapsed .ks-cat-header,
.ks-cat-section--all-hidden .ks-cat-header {
  border-bottom: none;
  border-radius: 13px;
}
/* Opacidad reducida cuando sin productos por filtro */
.ks-cat-section--all-hidden { opacity: 0.55; }

.ks-cat-count {
  display: inline-flex;
  align-items: center;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.25rem 0.7rem;
  border-radius: 99px;
}
.ks-cat-section--is_start_stop   .ks-cat-count { background: var(--ks-cat-ss-light); color: var(--ks-cat-ss-color); }
.ks-cat-section--is_conventional .ks-cat-count { background: var(--ks-cat-cv-light); color: var(--ks-cat-cv-color); }
.ks-cat-section--auxiliary_value .ks-cat-count { background: var(--ks-cat-av-light); color: var(--ks-cat-av-color); }

/* Contenedor de productos */
.ks-cat-products {
  padding: 1rem 0.75rem 0.75rem;
}

/* ── Botón de ayuda ─────────────────────────────────────────────── */
.ks-cat-help {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.ks-help-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  /* visual size */
  width: 1.35rem;
  height: 1.35rem;
  padding: 0;
  border-radius: 50%;
  /* amber-tinted info style */
  color: #b45309;
  background: #fef3c7;
  border: 1.5px solid #fcd34d;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.18s, color 0.18s, border-color 0.18s,
              box-shadow 0.18s, transform 0.18s;
  box-shadow: 0 1px 3px rgba(245,158,11,.18);
  /* keep WCAG 2.5.5 touch target without changing visual size */
  position: relative;
}
.ks-help-trigger::before {
  content: '';
  position: absolute;
  inset: -10px;
}
.ks-help-trigger:hover,
.ks-help-trigger:focus-visible {
  background: #f59e0b;
  color: #fff;
  border-color: #d97706;
  box-shadow: 0 3px 10px rgba(245,158,11,.38);
  transform: scale(1.15);
  outline: none;
}

.ks-help-tooltip {
  display: none;
  position: fixed;  /* fixed evita cualquier clipping del contenedor */
  width: min(300px, 88vw);
  background: #1e2533;
  color: #f0f4ff;
  font-size: 0.79rem;
  line-height: 1.55;
  padding: 0.75rem 1rem;
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.22);
  z-index: 9999;
  pointer-events: none;
  white-space: normal;
  text-align: left;
  /* Posición: se calcula desde JS al mostrarse */
  top: 0; left: 0;
}
.ks-help-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 7px solid transparent;
  border-top-color: #1e2533;
}

/* El tooltip se muestra/oculta y posiciona desde JS (position:fixed) */

/* ── Overlay "Recomendada" ────────────────────────────────────────── */
.ks-product-miniature--recommended {
  position: relative;
  overflow: hidden;
}

.ks-recommended-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: linear-gradient(90deg, var(--ks-cat-ss-color) 0%, var(--ks-primary, #24b9d7) 100%);
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.3rem 0.5rem;
  pointer-events: none;
  border-radius: 8px 8px 0 0;
}

.ks-recommended-label {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}
.ks-recommended-label svg { flex-shrink: 0; }

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 575px) {
  .ks-cat-header { padding: 0.85rem 1rem 0.85rem 1.25rem; gap: 0.6rem; }
  .ks-cat-icon   { width: 2rem; height: 2rem; border-radius: 8px; }
  .ks-cat-desc   { display: none; }
  .ks-cat-title  { font-size: 0.95rem; }
}

/* ── Filtrado de productos (ocultar sin tocar style inline) ─── */
.ks-filter-hidden { display: none !important; }

/* ── Verificar compatibilidad ──────────────────────────────── */
.ks-verify-compat {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 1rem;
  border-radius: 8px;
  border: 1.5px solid var(--ks-primary, #24b9d7);
  color: var(--ks-primary-dark, #1a9cb5);
  background: transparent;
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.ks-verify-compat:hover,
.ks-verify-compat:focus-visible {
  background: var(--ks-primary, #24b9d7);
  color: #fff;
  text-decoration: none;
  outline: none;
}
.ks-verify-compat__icon { flex-shrink: 0; display: flex; }
@media (max-width: 575px) {
  .ks-verify-compat { font-size: 0.8125rem; padding: 0.5rem 0.75rem; }
}

.ks-verify-compat-wrapper {
  text-align: center;
  margin: 1rem 0;
}
/* ================================================================
   KS PRODUCT GRID — Tarjetas de baterías con add-to-cart AJAX
   ================================================================ */

.ks-product-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  list-style: none;
  padding: 0;
  margin: .75rem 0 0;
}
@media (min-width: 1200px) { .ks-product-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 860px) { .ks-product-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .ks-product-grid { grid-template-columns: 1fr; } }

.ks-product-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #e5e9ef;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  transition: box-shadow .15s, transform .12s;
}
.ks-product-card:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.11);
  transform: translateY(-2px);
}

/* Card destacado — "Más popular" */
.ks-product-card--popular {
  border-color: #fbbf24;
  box-shadow: 0 2px 12px rgba(251,191,36,.22), 0 2px 8px rgba(0,0,0,.05);
}
.ks-product-card--popular:hover {
  box-shadow: 0 8px 28px rgba(251,191,36,.3), 0 4px 12px rgba(0,0,0,.08);
}

/* Banner superior "Más popular" */
.ks-product-card__popular-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  padding: .42rem .75rem;
  background: linear-gradient(90deg, #f59e0b 0%, #d97706 100%);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1;
  flex-shrink: 0;
}

/* Imagen */
.ks-product-card__img-wrap {
  position: relative;
  display: block;
  background: #f8f9fb;
  aspect-ratio: 4/3;
  overflow: hidden;
}
.ks-product-card__img {
  width: 100%; height: 100%;
  object-fit: contain;
  padding: .5rem;
  transition: transform .2s;
}
.ks-product-card:hover .ks-product-card__img { transform: scale(1.04); }
.ks-product-card__img-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: #c0c8d4;
}

/* Badges */
.ks-product-card__badge {
  position: absolute;
  top: 8px;
  font-size: .68rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  line-height: 1.5;
  letter-spacing: .02em;
}
.ks-product-card__badge--discount {
  left: 8px;
  background: #e53935;
  color: #fff;
}
.ks-product-card__badge--tech {
  right: 8px;
  background: #525DF4;
  color: #fff;
}

/* Cuerpo */
.ks-product-card__body {
  padding: .65rem .75rem .4rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .3rem;
}

/* Specs */
.ks-product-card__specs {
  display: flex;
  flex-wrap: wrap;
  gap: .25rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.ks-spec {
  font-size: .72rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  line-height: 1.5;
  white-space: nowrap;
  color: #fff;
}
.ks-spec--v   { background: #E8743B; }
.ks-spec--ah  { background: #19A979; }
.ks-spec--cca { background: #ED4A7B; }

/* Nombre */
.ks-product-card__name {
  font-size: .82rem;
  font-weight: 600;
  color: #1a2e4a;
  line-height: 1.35;
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.ks-product-card__name:hover { color: #1d5087; text-decoration: underline; }

/* Footer: precio + botón */
.ks-product-card__footer {
  padding: .5rem .75rem .75rem;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: .45rem;
}
.ks-product-card__price-wrap {
  display: flex;
  align-items: baseline;
  gap: .35rem;
}
.ks-product-card__price {
  font-size: 1.15rem;
  font-weight: 800;
  color: #1a2e4a;
  white-space: nowrap;
}
.ks-product-card__price-old {
  font-size: .75rem;
  color: #aaa;
  text-decoration: line-through;
  white-space: nowrap;
}

/* Botón añadir al carrito */
.ks-add-to-cart {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  padding: .55rem .9rem;
  background: #1d5087;
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  transition: background .15s, transform .1s, opacity .15s;
  width: 100%;
  line-height: 1.3;
}
.ks-add-to-cart:hover { background: #2a4a72; transform: translateY(-1px); color: #fff; text-decoration: none; }
.ks-add-to-cart:active { transform: scale(.97); }
.ks-add-to-cart:disabled { opacity: .65; cursor: not-allowed; transform: none; }
.ks-add-to-cart--loading { opacity: .75; }
.ks-add-to-cart--done { background: #27ae60; }
.ks-add-to-cart--link { background: #6b8eb5; }

/* Marca sobre el nombre */
.ks-product-card__brand {
  font-size: .7rem;
  font-weight: 600;
  color: #6b8eb5;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: -.1rem;
}

/* Spinner inline */
.ks-spinner {
  display: inline-block;
  width: 13px; height: 13px;
  border: 2px solid rgba(255,255,255,.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: ks-spin .6s linear infinite;
  flex-shrink: 0;
}
@keyframes ks-spin { to { transform: rotate(360deg); } }

/* Error inline */
.ks-cart-error {
  font-size: .72rem;
  color: #c0392b;
  margin: .2rem 0 0;
}

/* ================================================================
   KS VEHICLE MODAL
   ================================================================ */

.ks-modal-open { overflow: hidden; }

.ks-vmodal {
  position: fixed;
  inset: 0;
  z-index: 9990;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.ks-vmodal[hidden] { display: none; }

.ks-vmodal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.52);
  backdrop-filter: blur(3px);
  cursor: pointer;
}

.ks-vmodal__box {
  position: relative;
  z-index: 1;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.22);
  width: 100%;
  max-width: 420px;
  padding: 1.5rem 1.5rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  animation: ks-modal-in .2s ease;
}
@keyframes ks-modal-in { from { opacity: 0; transform: translateY(12px) scale(.97); } }

.ks-vmodal__header {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
}
.ks-vmodal__header-icon {
  flex-shrink: 0;
  width: 48px; height: 48px;
  background: #eef4ff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #1d5087;
}
.ks-vmodal__added {
  font-size: .78rem;
  font-weight: 600;
  color: #27ae60;
  margin: 0 0 .15rem;
}
.ks-vmodal__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #1a2e4a;
  margin: 0;
  line-height: 1.3;
}
.ks-vmodal__close {
  margin-left: auto;
  flex-shrink: 0;
  background: none;
  border: none;
  color: #8a9bb5;
  cursor: pointer;
  padding: .2rem;
  border-radius: 6px;
  transition: color .15s, background .15s;
}
.ks-vmodal__close:hover { color: #1a2e4a; background: #f0f3f8; }

.ks-vmodal__body { display: flex; flex-direction: column; gap: .5rem; }
.ks-vmodal__desc {
  font-size: .85rem;
  color: #4a5568;
  margin: 0;
  line-height: 1.5;
}
.ks-vmodal__vehicle {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: #f0f5ff;
  border: 1px solid #d0dff5;
  border-radius: 8px;
  padding: .5rem .75rem;
  font-size: .85rem;
  font-weight: 600;
  color: #1d5087;
}

.ks-vmodal__actions {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.ks-vmodal__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  padding: .65rem 1rem;
  border-radius: 9px;
  font-size: .9rem;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: background .15s, transform .1s;
  width: 100%;
}
.ks-vmodal__btn:active { transform: scale(.98); }
.ks-vmodal__btn--primary { background: #1d5087; color: #fff; }
.ks-vmodal__btn--primary:hover { background: #2a4a72; }
.ks-vmodal__btn--primary:disabled { opacity: .65; cursor: not-allowed; }
.ks-vmodal__btn--secondary { background: #f0f3f8; color: #4a5568; }
.ks-vmodal__btn--secondary:hover { background: #e2e8f0; }

.ks-vmodal__feedback {
  font-size: .8rem;
  font-weight: 600;
  padding: .45rem .75rem;
  border-radius: 7px;
  margin: 0;
  text-align: center;
}
.ks-vmodal__feedback--ok    { background: #e8f5e9; color: #2e7d32; }
.ks-vmodal__feedback--error { background: #fdecea; color: #c62828; }

@media (max-width: 480px) {
  .ks-vmodal__box { padding: 1.25rem 1.1rem 1rem; }
  .ks-vmodal__title { font-size: .95rem; }
}

/* ── Vehicle strip (barra de vehículos bajo el menú) ─────────── */
.ks-vstrip {
  background: #1d3d6b;
  color: #fff;
  font-size: .78rem;
  padding: .35rem 0;
  position: relative;
  z-index: 90;
}
.ks-vstrip__inner {
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
}
.ks-vstrip__label {
  display: flex;
  align-items: center;
  gap: .3rem;
  opacity: .75;
  white-space: nowrap;
  flex-shrink: 0;
}
.ks-vstrip__list {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
}
.ks-vstrip__item {
  display: flex;
  align-items: center;
  gap: .25rem;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 20px;
  padding: .18rem .55rem .18rem .65rem;
  transition: background .15s;
}
.ks-vstrip__item:hover,
.ks-vstrip__item:focus-within { background: rgba(255,255,255,.22); }
.ks-vstrip__item--saved { border-color: rgba(255,215,0,.4); }
.ks-vstrip__name {
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  white-space: nowrap;
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
}
a.ks-vstrip__name:hover { text-decoration: underline; }
.ks-vstrip__remove {
  background: none;
  border: none;
  color: rgba(255,255,255,.65);
  cursor: pointer;
  padding: .1rem;
  line-height: 1;
  flex-shrink: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color .15s, background .15s;
}
.ks-vstrip__remove:hover {
  color: #fff;
  background: rgba(255,255,255,.18);
}
.ks-vstrip__manage {
  display: flex;
  align-items: center;
  gap: .3rem;
  color: rgba(255,255,255,.75);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  margin-left: auto;
  padding: .15rem .4rem;
  border-radius: 4px;
  transition: color .15s, background .15s;
}
.ks-vstrip__manage:hover {
  color: #fff;
  background: rgba(255,255,255,.12);
}
@media (max-width: 640px) {
  .ks-vstrip__manage { display: none; }
  .ks-vstrip__name { max-width: 160px; }
}

/* ── Modal: picker multi-vehículo ────────────────────────────── */
.ks-vmodal__picker { margin-top: .75rem; }
.ks-vmodal__picker-label {
  font-size: .8rem;
  color: #6b7280;
  margin: 0 0 .5rem;
}
.ks-vmodal__picker-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .35rem;
  max-height: 180px;
  overflow-y: auto;
}
.ks-vmodal__picker-item {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .55rem .7rem;
  border: 2px solid #e5e7eb;
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
  font-size: .85rem;
}
.ks-vmodal__picker-item:hover { border-color: #1d5087; background: #f0f5ff; }
.ks-vmodal__picker-item--active {
  border-color: #1d5087;
  background: #e8f0fb;
  font-weight: 600;
}
.ks-vmodal__picker-name { flex: 1; }
.ks-vmodal__picker-current { color: #f59e0b; font-size: .8rem; }

/* ── Product card: dimensiones + polo positivo ──────────────── */
.ks-product-card__dims {
  display: flex;
  flex-wrap: wrap;
  gap: .3rem .6rem;
  list-style: none;
  margin: .3rem 0 0;
  padding: 0;
}
.ks-dim {
  display: flex;
  align-items: center;
  gap: .25rem;
  font-size: .72rem;
  color: #6b7280;
  white-space: nowrap;
}
.ks-dim--size { font-variant-numeric: tabular-nums; }
.ks-dim--polo { font-weight: 600; }
.ks-dim--polo-right { color: #1d6a3a; }
.ks-dim--polo-left  { color: #1d4d87; }

/* ── Save vehicle widget (.ks-svw) ───────────────────────────── */
.ks-svw {
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
  background: #f0f5ff;
  border: 1px solid #c7d9f5;
  border-radius: 10px;
  padding: .6rem 1rem;
  margin: .75rem 0 1rem;
  font-size: .83rem;
}
.ks-svw--buscador {
  margin: 0 0 1.25rem;
}
.ks-svw__vehicle {
  display: flex;
  align-items: center;
  gap: .4rem;
  color: #1d3d6b;
  flex: 1;
  min-width: 0;
}
.ks-svw__vehicle strong {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ks-svw__btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  background: #1d5087;
  color: #fff;
  border: none;
  border-radius: 7px;
  padding: .4rem .85rem;
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background .15s, transform .1s;
}
.ks-svw__btn:hover { background: #2a4a72; }
.ks-svw__btn:active { transform: scale(.97); }
.ks-svw__btn:disabled { opacity: .6; cursor: not-allowed; }
.ks-svw__saved-state {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  flex-shrink: 0;
}
.ks-svw__saved-state--done {
  color: #1a6b3a;
  font-weight: 600;
  font-size: .82rem;
}
.ks-svw__saved-state--done svg { fill: #1a6b3a; }
@media (max-width: 480px) {
  .ks-svw { flex-direction: column; align-items: flex-start; gap: .5rem; }
  .ks-svw__btn { width: 100%; justify-content: center; }
}

/* ================================================================
   BREADCRUMB JERÁRQUICO — navegación de selección
   ================================================================ */
.ks-breadcrumb { margin: 0 0 .85rem; }
.ks-breadcrumb__list {
  display: flex; flex-wrap: wrap; list-style: none;
  padding: 0; margin: 0; align-items: center;
  font-size: .78rem;
}
.ks-breadcrumb__item { display: flex; align-items: center; }
.ks-breadcrumb__item + .ks-breadcrumb__item::before {
  content: '›'; color: #94a3b8; margin: 0 .3rem; font-size: .9em; line-height: 1;
}
.ks-breadcrumb__link {
  color: #4a7aad; text-decoration: none;
  padding: .15rem .3rem; border-radius: 4px;
  transition: background .12s, color .12s;
}
.ks-breadcrumb__link:hover { background: #eef2f8; color: #1d5087; }
.ks-breadcrumb__current { color: #1a2e4a; font-weight: 600; padding: .15rem .3rem; }

/* ================================================================
   COMPARADOR — checkbox en tarjeta, barra flotante, modal
   ================================================================ */

/* Checkbox en tarjeta */
.ks-compare-label {
  display: flex; align-items: center; gap: .35rem;
  font-size: .72rem; color: #64748b; cursor: pointer;
  padding: .15rem 0; transition: color .12s; user-select: none;
}
.ks-compare-label:hover { color: #1d5087; }
.ks-compare-cb { width: 14px; height: 14px; accent-color: #1d5087; cursor: pointer; flex-shrink: 0; }

/* Barra flotante */
.ks-compare-bar {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: #1a2e4a; color: #fff; z-index: 1000;
  box-shadow: 0 -4px 20px rgba(0,0,0,.2);
  transform: translateY(100%); transition: transform .25s ease;
}
.ks-compare-bar:not([hidden]) { transform: translateY(0); }
.ks-compare-bar__inner {
  max-width: 1200px; margin: 0 auto; padding: .65rem 1rem;
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
}
.ks-compare-bar__label {
  display: flex; align-items: center; gap: .4rem;
  font-size: .82rem; font-weight: 600; white-space: nowrap; flex-shrink: 0;
}
.ks-compare-bar__items {
  display: flex; gap: .5rem; flex: 1; list-style: none; padding: 0; margin: 0; flex-wrap: wrap; min-width: 0;
}
.ks-compare-bar__item {
  font-size: .73rem; background: rgba(255,255,255,.12); border-radius: 6px;
  padding: .2rem .55rem; display: flex; align-items: center; gap: .3rem;
  max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ks-compare-bar__item-remove {
  background: none; border: none; color: rgba(255,255,255,.6);
  cursor: pointer; padding: 0; line-height: 1; flex-shrink: 0; font-size: 1rem;
}
.ks-compare-bar__item-remove:hover { color: #fff; }
.ks-compare-bar__actions { display: flex; gap: .5rem; flex-shrink: 0; }
.ks-compare-bar__btn {
  padding: .45rem .9rem; border-radius: 8px; font-size: .8rem;
  font-weight: 700; cursor: pointer; border: none; transition: background .15s, opacity .15s;
}
.ks-compare-bar__btn--go { background: #e8a020; color: #fff; }
.ks-compare-bar__btn--go:disabled { opacity: .45; cursor: not-allowed; }
.ks-compare-bar__btn--go:not(:disabled):hover { background: #d4911b; }
.ks-compare-bar__btn--clear { background: rgba(255,255,255,.15); color: #fff; }
.ks-compare-bar__btn--clear:hover { background: rgba(255,255,255,.25); }

/* Modal */
.ks-compare-modal {
  position: fixed; inset: 0; z-index: 1200;
  display: flex; align-items: flex-start; justify-content: center; padding: 2rem 1rem;
}
.ks-compare-modal[hidden] { display: none; }
.ks-compare-modal__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.55); }
.ks-compare-modal__box {
  position: relative; background: #fff; border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25); width: 100%; max-width: 920px;
  max-height: 85vh; display: flex; flex-direction: column;
}
.ks-compare-modal__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.25rem .75rem; border-bottom: 1px solid #e5e9ef;
}
.ks-compare-modal__header h2 { font-size: 1rem; font-weight: 700; color: #1a2e4a; margin: 0; }
.ks-compare-modal__close {
  background: none; border: none; cursor: pointer; color: #64748b;
  padding: .25rem; border-radius: 6px; transition: color .12s, background .12s;
}
.ks-compare-modal__close:hover { color: #1a2e4a; background: #f1f5f9; }
.ks-compare-modal__scroll { overflow: auto; flex: 1; padding: 1rem 1.25rem 1.25rem; }

/* Tabla de comparación (CSS Grid dinámico via JS) */
.ks-compare-table { display: grid; width: 100%; }
.ks-compare-table__cell {
  padding: .6rem .85rem; border-bottom: 1px solid #f1f5f9; font-size: .82rem;
}
.ks-compare-table__cell--head {
  font-weight: 600; color: #64748b; font-size: .71rem; text-transform: uppercase;
  letter-spacing: .04em; background: #f8fafc; position: sticky; left: 0; z-index: 1;
  min-width: 90px;
}
.ks-compare-table__cell--product { text-align: center; min-width: 180px; }
.ks-compare-table__cell--highlight { background: #f0f6ff; }
.ks-compare-table__img { width: 80px; height: 60px; object-fit: contain; margin: 0 auto .4rem; display: block; }
.ks-compare-table__name {
  font-weight: 600; font-size: .78rem; color: #1a2e4a;
  line-height: 1.3; text-decoration: none; display: block; margin-bottom: .3rem;
}
.ks-compare-table__name:hover { text-decoration: underline; }
.ks-compare-table__price { font-size: 1rem; font-weight: 800; color: #1a2e4a; }
.ks-compare-table__spec-val { font-weight: 600; color: #1a2e4a; }
.ks-compare-table__spec-empty { color: #cbd5e1; }
@media (max-width: 575px) {
  .ks-compare-modal { padding: .5rem 0; align-items: flex-end; }
  .ks-compare-modal__box { border-radius: 14px 14px 0 0; max-height: 90vh; }
  .ks-compare-bar__inner { padding: .5rem .75rem; }
  .ks-compare-bar__items { display: none; }
}

/* ================================================================
   TOAST — confirmación de añadir al carrito
   ================================================================ */
.ks-cart-toast {
  position: fixed; top: 1.25rem; left: 50%;
  transform: translateX(-50%) translateY(-130%);
  background: #1a2e4a; color: #fff; border-radius: 10px;
  padding: .6rem 1.1rem; display: flex; align-items: center; gap: .5rem;
  font-size: .82rem; font-weight: 600;
  box-shadow: 0 8px 24px rgba(0,0,0,.22); z-index: 9999;
  pointer-events: none; opacity: 0; white-space: nowrap;
  max-width: min(380px, 90vw); overflow: hidden; text-overflow: ellipsis;
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .25s;
}
.ks-cart-toast strong { font-weight: 800; }
.ks-cart-toast--in  { transform: translateX(-50%) translateY(0); opacity: 1; }
.ks-cart-toast--out { transform: translateX(-50%) translateY(-130%); opacity: 0; }

/* ================================================================
   CROSS-SELL — accesorios relacionados
   ================================================================ */
.ks-crosssell {
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 2px dashed rgba(36, 185, 215, 0.2);
}
.ks-crosssell__heading {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1rem;
  font-weight: 700;
  color: #1a2e4a;
  margin: 0 0 1.25rem;
}
.ks-crosssell__heading svg { color: var(--ks-primary, #24b9d7); flex-shrink: 0; }
.ks-crosssell .ks-cat-section { margin-bottom: 1rem; }
.ks-crosssell .ks-cat-icon--crosssell { color: #e8a020; }

/* Navegación rápida de categorías (baterías + cross-sell) */
.ks-catnav {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 1.5rem;
}
.ks-catnav__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 1rem;
  border: 1.5px solid #e2e8f0;
  border-radius: 10px;
  background: #fff;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  color: #475569;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
  white-space: nowrap;
}
.ks-catnav__btn:hover {
  border-color: var(--xs-color, var(--ks-primary, #24b9d7));
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
  transform: translateY(-1px);
}
.ks-catnav__btn--active {
  border-color: var(--xs-color, var(--ks-primary, #24b9d7));
  background: color-mix(in srgb, var(--xs-color, var(--ks-primary, #24b9d7)) 8%, #fff);
  box-shadow: 0 2px 10px rgba(0,0,0,.1);
}
.ks-catnav__icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.ks-catnav__icon svg { width: 16px; height: 16px; }
.ks-catnav__label { line-height: 1; }

/* ──────────────────────────────────────────────────────────────────
   Badge "Recíbela mañana" + filtro 24h (servicio express) - 1.4.13
────────────────────────────────────────────────────────────────── */
.ks-24h-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #dc3545;
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .3px;
  padding: 3px 8px;
  border-radius: 4px;
  line-height: 1.2;
  text-transform: uppercase;
  white-space: nowrap;
}
.ks-24h-badge svg { fill: currentColor; }

/* Badge flotante en la tarjeta (top-right) */
.ks-product-card > .ks-24h-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 3;
  box-shadow: 0 2px 6px rgba(220, 53, 69, .35);
}
.ks-product-card { position: relative; } /* asegura que el absolute se apoye */

/* Barra del filtro arriba del listado */
.ks-24h-filter-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #fff5f5;
  border: 1px solid #ffc9c9;
  border-left: 4px solid #dc3545;
  padding: 10px 14px;
  border-radius: 8px;
  margin: 0 0 16px;
  flex-wrap: wrap;
}
.ks-24h-filter-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-weight: 600;
  color: #495057;
  margin: 0;
}
.ks-24h-filter-label input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: #dc3545;
  cursor: pointer;
}
.ks-24h-badge--filter { font-size: .78rem; padding: 4px 10px; }
.ks-24h-filter-count { color: #868e96; font-size: .85rem; font-weight: 500; }
.ks-24h-filter-hint {
  color: #6c757d;
  font-size: .82rem;
  flex: 1;
  text-align: right;
  min-width: 200px;
}

/* Cuando el filtro está activo, esconder los NO aptos */
body.ks-only-24h .ks-product-card:not(.ks-product-card--24h) {
  display: none !important;
}
/* Título de categoría puede quedarse "colgado" sin productos — opcional: esconder */
body.ks-only-24h .ks-cat-section:not(:has(.ks-product-card--24h)) {
  display: none;
}

/* Help tooltip del filtro 24h */
.ks-24h-help {
  display: inline-flex;
  align-items: center;
  color: #868e96;
  cursor: help;
  position: relative;
  margin-left: auto;
}
.ks-24h-help:hover,
.ks-24h-help:focus-visible { color: #dc3545; outline: none; }
.ks-24h-help .ks-help-tooltip {
  position: absolute;
  right: 0; top: calc(100% + 8px);
  background: #212529;
  color: #fff;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 400;
  line-height: 1.45;
  width: min(360px, 90vw);
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity .15s, transform .15s;
  z-index: 100;
  white-space: normal;
}
.ks-24h-help:hover .ks-help-tooltip,
.ks-24h-help:focus-visible .ks-help-tooltip,
.ks-24h-help .ks-help-tooltip:hover {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.ks-24h-help .ks-help-tooltip::before {
  content: ''; position: absolute; right: 8px; top: -5px;
  border-left: 6px solid transparent; border-right: 6px solid transparent;
  border-bottom: 6px solid #212529;
}

/* Call-to-action "Recibe mañana…" — banner destacado antes del listado */
.ks-24h-cta {
  display: flex;
  align-items: center;
  gap: 16px;
  background: linear-gradient(135deg, #dc3545 0%, #b71c1c 100%);
  color: #fff;
  padding: 16px 22px;
  border-radius: 12px;
  margin: 0 0 20px;
  box-shadow: 0 4px 16px rgba(220, 53, 69, .25);
  position: relative;
  flex-wrap: wrap;
}
.ks-24h-cta__icon {
  flex-shrink: 0;
  width: 44px; height: 44px;
  background: rgba(255,255,255,.18);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
}
.ks-24h-cta__body {
  flex: 1;
  min-width: 200px;
  display: flex; flex-direction: column; gap: 6px;
}
.ks-24h-cta__headline {
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.25;
  margin: 0;
  letter-spacing: .2px;
}
.ks-24h-cta__toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: .85rem;
  font-weight: 500;
  opacity: .95;
  margin: 0;
  user-select: none;
}
.ks-24h-cta__toggle input[type="checkbox"] {
  width: 16px; height: 16px;
  accent-color: #fff;
  cursor: pointer;
}
.ks-24h-cta__toggle-text { line-height: 1.2; }
.ks-24h-cta__count { opacity: .8; font-weight: 400; margin-left: 2px; }

/* El tooltip de ayuda dentro del CTA rojo necesita contraste blanco */
.ks-24h-cta .ks-24h-help { color: rgba(255,255,255,.8); margin-left: 0; }
.ks-24h-cta .ks-24h-help:hover,
.ks-24h-cta .ks-24h-help:focus-visible { color: #fff; }

/* ──────────────────────────────────────────────────────────────────
   Paginación compartida (nivel-5 + filtros) — 1.4.13
────────────────────────────────────────────────────────────────── */
.ks-pagination {
  margin: 24px 0 0;
  text-align: center;
}
.ks-pagination__summary {
  color: #6c757d;
  font-size: .9em;
  margin: 0 0 12px;
}
.ks-pagination__list {
  display: inline-flex;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 4px;
  flex-wrap: wrap;
  justify-content: center;
}
.ks-pagination__item { margin: 0; }
.ks-pagination__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border: 1px solid #dee2e6;
  border-radius: 6px;
  background: #fff;
  color: #495057;
  font-weight: 500;
  font-size: .95em;
  text-decoration: none;
  transition: border-color .15s, background .15s, color .15s;
}
.ks-pagination__link:hover { border-color: #339af0; color: #1864ab; background: #f8f9fa; }
.ks-pagination__link--current {
  background: #dc3545; color: #fff; border-color: #dc3545;
  cursor: default;
}
.ks-pagination__link--disabled {
  color: #ced4da; cursor: not-allowed; background: #f8f9fa;
}
.ks-pagination__link--disabled:hover { border-color: #dee2e6; color: #ced4da; }
.ks-pagination__item--spacer {
  display: inline-flex; align-items: center;
  padding: 0 8px;
  color: #adb5bd;
  height: 36px;
}
