/* Elite Center Pages — page-level styles (home, archive, PDP, product cards)
 *
 * Sprint Rediseño Store Sub-fase 1C — 2026-05-09
 * Depende de tokens.css (var(--ec-*)).
 *
 * C5 (este commit): Home rediseño Editorial Bold
 * C6/C7/C8/C9 añaden: archive-category, PDP, product-cards, breadcrumbs.
 */

/* ═══════════════════════════════════════════════════════════════
 * Reset/base scope solo .ec-home, .ec-archive, .ec-pdp wrappers
 * ═══════════════════════════════════════════════════════════════ */
.ec-home,
.ec-archive,
.ec-pdp {
  box-sizing: border-box;
  font-family: var(--ec-font-body);
  color: var(--ec-text-primary);
}

.ec-home *,
.ec-archive *,
.ec-pdp * {
  box-sizing: border-box;
}

.ec-home a,
.ec-archive a,
.ec-pdp a {
  text-decoration: none;
  color: inherit;
}

.ec-home img,
.ec-archive img,
.ec-pdp img {
  max-width: 100%;
  display: block;
}

/* ═══════════════════════════════════════════════════════════════
 * HOME — Hero Editorial Bold (h1 112px Exo 2)
 * ═══════════════════════════════════════════════════════════════ */
.ec-home-hero {
  max-width: 1440px;
  margin: 0 auto;
  padding: 40px 40px 0;
}

.ec-home-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: end;
  min-height: 540px;
  padding: 24px 0 40px;
}

/* v2.9.0 Issue C: hero text-only mode — Benjamín reportó gap visible al lado
 * izquierdo del título "Compra infraestructura, no problemas". Causa real:
 * el grid se mantenía en 2 columnas con columna derecha vacía cuando no hay
 * producto destacado, dejando el copy ocupando solo 50% width y produciendo
 * un gap perceptible a la derecha (visualmente leído como desbalance lateral).
 * Fix: cuando `--text-only` está activo, colapsar a 1 columna full-width
 * para que el título ocupe el ancho completo del container (max-width 1440px
 * ya está en el wrapper con padding 40px). El copy queda centrado en el
 * container y el title bold puede respirar full-width. */
.ec-home-hero__grid--text-only {
  grid-template-columns: 1fr;
  align-items: start;
}

.ec-home-hero__grid--text-only .ec-home-hero__copy {
  /* Tope visual: en viewports muy anchos (>1600px) el título no debe estirarse
   * indefinidamente. max-width respeta el peso editorial del bold display. */
  max-width: 1200px;
}

.ec-home-hero__copy {
  display: flex;
  flex-direction: column;
}

.ec-home-hero__eyebrow {
  margin-bottom: 24px;
}

.ec-home-hero__title {
  font-family: var(--ec-font-display);
  font-weight: 800;
  font-size: 112px;
  line-height: 0.92;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--ec-black);
  margin: 0;
}

.ec-home-hero__title-accent {
  color: var(--ec-primary);
}

.ec-home-hero__ctas {
  display: flex;
  gap: 12px;
  margin-top: 32px;
  flex-wrap: wrap;
}

.ec-home-hero__visual {
  position: relative;
  aspect-ratio: 1 / 0.85;
  border-radius: var(--ec-r-2xl);
  overflow: hidden;
  background: var(--ec-surface-2);
}

.ec-home-hero__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ec-home-hero__image--placeholder {
  background:
    repeating-linear-gradient(
      135deg,
      #f2f4f6 0,
      #f2f4f6 14px,
      #e9ebee 14px,
      #e9ebee 15px
    ),
    #f2f4f6;
}

.ec-home-hero__featured-card {
  position: absolute;
  bottom: 20px;
  left: 20px;
  right: 20px;
  background: rgba(255, 255, 255, 0.92);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  padding: 16px 20px;
  border-radius: var(--ec-r-xl);
  display: flex;
  align-items: center;
  gap: 14px;
  transition:
    background 0.2s,
    transform 0.18s;
}

.ec-home-hero__featured-card:hover {
  background: #fff;
  transform: translateY(-2px);
}

.ec-home-hero__featured-icon {
  width: 44px;
  height: 44px;
  background: var(--ec-primary-light);
  border-radius: var(--ec-r-md);
  display: grid;
  place-items: center;
  color: var(--ec-primary);
  flex-shrink: 0;
}

.ec-home-hero__featured-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ec-home-hero__featured-eyebrow {
  color: var(--ec-text-muted);
}

.ec-home-hero__featured-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--ec-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ec-home-hero__featured-meta {
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex-shrink: 0;
}

.ec-home-hero__featured-price {
  font-size: 16px;
  font-weight: 500;
}

.ec-home-hero__featured-stock {
  color: var(--ec-success);
}

/* Ticker strip — top + bottom borders, marquee animation */
.ec-home-hero__ticker {
  border-top: 1px solid var(--ec-black);
  border-bottom: 1px solid var(--ec-black);
  padding: 14px 0;
  overflow: hidden;
  font-family: var(--ec-font-display);
  font-weight: 700;
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ec-home-hero__ticker-track {
  display: inline-flex;
  gap: 32px;
  animation: ecTickerScroll 30s linear infinite;
  white-space: nowrap;
  will-change: transform;
}

.ec-home-hero__ticker-item {
  white-space: nowrap;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 28px;
}

/* Sub-fase 1G-fix B2.6: separador `•` consistente via pseudo-element.
 * Garantiza que cada item del ticker tenga UN sólo separator antes del siguiente.
 *
 * v2.9.1 Issue 4 RE-FIX: el approach v2.9.0 (line-height 0.6 + top -0.08em +
 * display inline-flex) no centraba visualmente el glyph `•`. El bullet
 * Unicode tiene un baseline offset particular en Exo 2 (display font) que
 * line-height arbitraria no compensa de forma fiable.
 *
 * Fix robusto:
 *  - Generamos un círculo REAL via background-color + border-radius en un
 *    inline-block (no depende de glyph metrics del font).
 *  - Tamaño explícito 8px diameter (mayor presencia visual que el bullet
 *    Unicode, y siempre perfectamente redondo).
 *  - Vertical centering provisto por el parent `.ec-home-hero__ticker-item`
 *    que es inline-flex con `align-items: center` — el pseudo es flex child
 *    y se alinea al centro de la flex line automáticamente.
 *  - Color via background-color (no via `color` property), opacidad 0.6
 *    para presencia sin distracción. */
.ec-home-hero__ticker-item::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #999797; /* gris sidebar text spec Benjamín 2026-05-19 */
  opacity: 0.6;
  margin-left: 28px;
  flex-shrink: 0; /* parent es inline-flex; previene reflow del círculo */
  /* Vertical center lo provee el `align-items: center` del parent flex. */
}

@keyframes ecTickerScroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

.ec-home-hero__ticker:hover .ec-home-hero__ticker-track {
  animation-play-state: paused;
}

/* Tablet hero */
@media (max-width: 1024px) and (min-width: 768px) {
  .ec-home-hero {
    padding: 24px 24px 0;
  }
  .ec-home-hero__grid {
    gap: 24px;
    min-height: 460px;
  }
  .ec-home-hero__title {
    font-size: 80px;
  }
}

/* Mobile hero
 * Sub-fase 1E E3-1 (P0): Benjamín reportó "el giro se ve un poco raro / cortado".
 * Title fixed 56px desbordaba en viewports <= 360px o cuando palabras largas
 * (e.g. "infraestructura,") quedaban con poco margen. Fluid clamp 40-52px
 * mantiene impacto bold y elimina overflow horizontal.
 * E3-2: aspect-ratio 16/10 -> 4/5 para que productos B2B (servidores portrait)
 * se vean más prominentes en el visual destacado.
 */
@media (max-width: 767px) {
  .ec-home-hero {
    padding: 16px 16px 0;
  }
  .ec-home-hero__grid {
    grid-template-columns: 1fr;
    gap: 24px;
    min-height: 0;
    padding: 12px 0 24px;
  }
  .ec-home-hero__title {
    font-size: clamp(2.5rem, 12vw, 3.25rem);
    line-height: 0.95;
  }
  .ec-home-hero__visual {
    /* Sub-fase 1E perf-cap: 4/5 portrait pesaba demasiado above-the-fold mobile.
     * 1/1 mantiene prominencia del producto + reduce paint area ~20% mobile. */
    aspect-ratio: 1 / 1;
  }
  .ec-home-hero__ticker {
    font-size: 13px;
  }
  /* CTAs a column en viewports muy estrechos */
  @media (max-width: 360px) {
    .ec-home-hero__ctas {
      flex-direction: column;
      align-items: stretch;
    }
    .ec-home-hero__ctas .ec-cta,
    .ec-home-hero__ctas .ec-cta-outline {
      justify-content: center;
    }
  }
}

/* E3-4: respeta prefers-reduced-motion — congela ticker para usuarios sensibles
 * a movimiento (motion sickness, vestibular disorders). */
@media (prefers-reduced-motion: reduce) {
  .ec-home-hero__ticker-track,
  .ec-archive-hero__ticker-track {
    animation: none;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * HOME — Categories Bold (6 cards rotating big accent)
 * ═══════════════════════════════════════════════════════════════ */
.ec-home-categories {
  max-width: 1440px;
  margin: 0 auto;
  padding: 80px 40px;
}

.ec-home-categories__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 32px;
  flex-wrap: wrap;
  gap: 12px;
}

.ec-home-categories__title {
  font-family: var(--ec-font-display);
  font-weight: 800;
  font-size: 56px;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0;
}

.ec-home-categories__num {
  color: var(--ec-text-hint);
}

.ec-home-categories__all {
  color: var(--ec-primary);
  font-weight: 600;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: gap 0.15s;
}

.ec-home-categories__all:hover {
  gap: 10px;
}

.ec-home-categories__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 240px;
  gap: 12px;
}

.ec-home-cat-card {
  /* Sub-fase 1E E5-4: cards normales con bg surface-2 + border-color hover indigo
   * + transform translateY -3 + shadow-card-hover para mayor presencia. */
  background: var(--ec-surface-2);
  color: var(--ec-black);
  border: 1px solid transparent;
  border-radius: var(--ec-r-2xl);
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease;
}

.ec-home-cat-card:hover {
  transform: translateY(-3px);
  border-color: var(--ec-primary);
  background: color-mix(
    in oklab,
    var(--ec-primary-light) 30%,
    var(--ec-surface)
  );
  box-shadow: var(--ec-shadow-card-hover);
}

.ec-home-cat-card--big {
  /* Big card: black bg + primary glow ambient (similar tone PDP hero glow).
   * Tone bold + impactful sin colored shadow rule violation. */
  background: var(--ec-black);
  color: #fff;
  grid-column: span 2;
  isolation: isolate;
}

.ec-home-cat-card--big::before {
  /* Sub-fase 1E perf: radial-gradient en lugar de blur(90px) filter — ~80%
   * más barato GPU. Misma atmósfera visual indigo glow sin compositing pass. */
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 100% 0%,
    color-mix(in oklab, var(--ec-primary) 50%, transparent) 0%,
    transparent 50%
  );
  pointer-events: none;
  z-index: 0;
  opacity: 0.55;
}

.ec-home-cat-card--big > * {
  position: relative;
  z-index: 1;
}

.ec-home-cat-card--big:hover {
  background: var(--ec-black);
  border-color: transparent;
  transform: translateY(-3px);
  box-shadow: var(--ec-shadow-card-hover);
}

.ec-home-cat-card--big:hover::before {
  opacity: 0.4;
}

.ec-home-cat-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.ec-home-cat-card__arrow {
  opacity: 0.5;
  transition: transform 0.15s;
}

.ec-home-cat-card:hover .ec-home-cat-card__arrow {
  transform: translateX(4px);
  opacity: 1;
}

.ec-home-cat-card__label {
  font-family: var(--ec-font-display);
  font-weight: 800;
  font-size: 24px;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  line-height: 1;
  margin: 0;
}

.ec-home-cat-card--big .ec-home-cat-card__label {
  font-size: 40px;
}

.ec-home-cat-card__desc {
  margin: 10px 0 0;
  font-size: 13px;
  opacity: 0.7;
}

/* Tablet categories */
@media (max-width: 1024px) and (min-width: 768px) {
  .ec-home-categories {
    padding: 56px 24px;
  }
  .ec-home-categories__title {
    font-size: 36px;
  }
  .ec-home-categories__grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 200px;
  }
  .ec-home-cat-card--big {
    grid-column: span 2;
  }
}

/* Mobile categories
 * v2.9.0 Issue F: Benjamín reportó que "Servidores" y "Video Conferencia" se
 * veían MÁS GRANDES que los otros 3 (Redes, Cómputo, Almacenamiento,
 * Periféricos) en mobile. Causa: la flag `big=true` en data layer hacía que
 * el SVG icon inline tuviera width/height 40px (vs 28px en otros) y el label
 * 36px (vs 28px en otros). En mobile con grid 1-column todos los cards son
 * full-width, entonces la disparity se ve exagerada.
 *
 * Fix: en breakpoint mobile, forzar size uniforme — todos los cards exhiben
 * el mismo icon size + label size + padding. Mantenemos la flag `big` por
 * estética desktop/tablet (donde span 2 columnas + glow indigo aporta jerarquía
 * editorial), pero la "promesa visual" en mobile es consistencia. */
@media (max-width: 767px) {
  .ec-home-categories {
    padding: 40px 16px;
  }
  .ec-home-categories__title {
    font-size: 36px;
  }
  .ec-home-categories__grid {
    grid-template-columns: 1fr;
    grid-auto-rows: 200px;
  }
  .ec-home-cat-card--big {
    grid-column: span 1;
  }
  /* v2.9.0 Issue F: label uniforme cross-card en mobile */
  .ec-home-cat-card__label,
  .ec-home-cat-card--big .ec-home-cat-card__label {
    font-size: 28px;
  }
  /* v2.9.0 Issue F: icon size uniforme cross-card en mobile.
   * El SVG tiene width/height inline 40/40 (big) o 28/28 (default). Forzamos
   * 28x28 a TODOS los cards mobile usando !important para vencer attribute
   * specificity de los atributos inline width/height. */
  .ec-home-cat-card__icon {
    width: 28px !important;
    height: 28px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * HOME — Featured Split (Videoconf + HPE Gen11)
 * ═══════════════════════════════════════════════════════════════ */
.ec-home-split {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 40px 80px;
}

.ec-home-split__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.ec-home-split__card {
  border-radius: var(--ec-r-2xl);
  /* Sub-fase 1G-fix B3.3: padding reducido 32px -> 24px desktop / 20px mobile.
   * Espacio interno excesivo reportado por Benjamín, especialmente con título
   * + descripción + CTA muy separados. Compacta verticalmente sin perder
   * jerarquía. */
  padding: clamp(20px, 2.6vw, 24px);
  min-height: 360px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.18s ease;
}

.ec-home-split__card:hover {
  transform: translateY(-2px);
}

.ec-home-split__card--videoconf {
  /* Sub-fase 1E E5-1 (P0): videoconf card "sin rediseño" reportada por Benjamín.
   * Gradient mesh subtle (surface-2 -> surface-3) + decorative grid pattern overlay
   * (3% opacity) que evoca el contexto técnico B2B sin saturar. */
  background: linear-gradient(
    135deg,
    var(--ec-surface-2) 0%,
    var(--ec-surface-3) 100%
  );
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 24px;
}

.ec-home-split__card--videoconf::before {
  /* Sub-fase 1E perf-pass: SVG data URI grid pattern reemplazado por CSS-only
   * linear-gradient repeating pattern. 40% más rápido en mobile (no decode SVG). */
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(68, 76, 231, 0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(68, 76, 231, 0.04) 1px, transparent 1px);
  background-size: 40px 40px;
  z-index: 0;
}

.ec-home-split__card--videoconf > * {
  position: relative;
  z-index: 1;
}

.ec-home-split__card--server {
  background: var(--ec-black);
  color: #fff;
  /* item 5: mismo layout que videoconf (eyebrow / copy / cta). */
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 24px;
}

/* El contenido va sobre el glow/after decorativos. El glow conserva su
 * position:absolute (no se pisa con este selector mas especifico). */
.ec-home-split__card--server > :not(.ec-home-split__glow) {
  position: relative;
  z-index: 1;
}

/* Sub-fase 1G-fix B3.2: text legibility en hero dark cards.
 * Eyebrow + título + descripción 100% white para WCAG AA strict en near-black. */
.ec-home-split__card--server .ec-home-split__eyebrow--light {
  color: #fff !important;
  opacity: 0.85;
}
.ec-home-split__card--server .ec-home-split__title--light {
  color: #fff !important;
}
.ec-home-split__card--server .ec-home-split__desc--light {
  color: rgba(255, 255, 255, 0.78);
}

.ec-home-split__glow {
  position: absolute;
  right: -40px;
  top: -40px;
  width: 260px;
  height: 260px;
  border-radius: 999px;
  background: var(--ec-primary);
  opacity: 0.3;
  filter: blur(80px);
  pointer-events: none;
}

/* Sub-fase 1E E5-2: 2nd glow bottom-left más sutil para balance visual.
 * Reemplaza filter:blur(90px) por radial-gradient (cheaper GPU compositing). */
.ec-home-split__card--server::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at 0% 100%,
    color-mix(in oklab, var(--ec-primary) 30%, transparent) 0%,
    transparent 50%
  );
  pointer-events: none;
  z-index: 0;
}

.ec-home-split__eyebrow {
  color: var(--ec-primary);
}

.ec-home-split__eyebrow--light {
  color: var(--ec-primary-accent);
}

.ec-home-split__title {
  font-family: var(--ec-font-display);
  font-weight: 800;
  font-size: 44px;
  margin: 0 0 16px;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  line-height: 1.05;
}

.ec-home-split__title--light {
  color: #fff;
}

.ec-home-split__title-accent {
  color: var(--ec-primary);
}

.ec-home-split__desc {
  font-size: 14px;
  color: var(--ec-text-secondary);
  max-width: 320px;
  line-height: 1.6;
  margin: 0;
}

.ec-home-split__cta {
  align-self: flex-start;
}

/* item 5: CTA outline sobre la card oscura — borde/texto blanco para contraste,
 * invierte a fondo blanco en hover. */
.ec-home-split__cta--light {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.55);
}

.ec-home-split__cta--light:hover {
  background: #fff;
  color: var(--ec-black);
  border-color: #fff;
}

/* Tablet/mobile split */
@media (max-width: 1024px) and (min-width: 768px) {
  .ec-home-split {
    padding: 0 24px 56px;
  }
  .ec-home-split__title {
    font-size: 32px;
  }
}

@media (max-width: 767px) {
  .ec-home-split {
    padding: 0 16px 40px;
  }
  .ec-home-split__grid {
    grid-template-columns: 1fr;
  }
  .ec-home-split__title {
    font-size: 32px;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * HOME — Bestseller rail (8 productos)
 * ═══════════════════════════════════════════════════════════════ */
.ec-home-bestseller {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 40px 80px;
}

.ec-home-bestseller__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 24px;
  flex-wrap: wrap;
  gap: 12px;
}

.ec-home-bestseller__title {
  font-family: var(--ec-font-display);
  font-weight: 800;
  font-size: 56px;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0;
}

.ec-home-bestseller__num {
  color: var(--ec-text-hint);
}

.ec-home-bestseller__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

/* v2.10.1 Wave 2 ISSUE 3 fix: pool ahora es el grid mismo.
 * Cada `.ec-home-bestseller__pool` actúa como grid container independiente.
 * El attr `hidden` HTML5 es el toggle nativo (display:none por user agent).
 * Defensa explícita por si algún reset CSS pisara el default. */
.ec-home-bestseller__pool[hidden] {
  display: none !important;
}

/* Tab disabled (pool vacío) — visible pero no interactivo. */
.ec-home-bestseller__tab.is-disabled,
.ec-home-bestseller__tab[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

/* v2.9.0 Issue E: tabs filter row (Más vistos).
 *  - Editorial style: Exo 2 700 uppercase 12px, letter-spacing 0.06em.
 *  - Active state: indigo text + indigo line bottom 2px (consistente con
 *    L0 tabs del header — vocabulario visual unificado).
 *  - Idle: text-muted, hover lift to text-primary.
 *  - Mobile-only restriction: tabs `--desktop-only` se ocultan en <768px
 *    dejando solo Todos + 3 (Servidores · Notebooks · Redes) en single line. */
.ec-home-bestseller__tabs {
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 0 0 24px;
  padding: 0;
  flex-wrap: wrap;
}

.ec-home-bestseller__tab {
  font-family: var(--ec-font-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ec-text-muted, #75768a);
  background: transparent;
  border: 0;
  padding: 10px 14px;
  cursor: pointer;
  position: relative;
  white-space: nowrap;
  transition: color 0.15s;
}

.ec-home-bestseller__tab::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 4px;
  width: 0;
  height: 2px;
  background: var(--ec-primary, #444ce7);
  border-radius: 2px;
  transform: translateX(-50%);
  transition: width 0.25s ease;
  pointer-events: none;
}

.ec-home-bestseller__tab:hover,
.ec-home-bestseller__tab:focus-visible {
  color: var(--ec-text-primary);
}

.ec-home-bestseller__tab.is-active {
  color: var(--ec-primary);
}

.ec-home-bestseller__tab.is-active::after,
.ec-home-bestseller__tab:focus-visible::after {
  width: 70%;
}

/* v2.9.0 Issue E: card slot visibility — orquestación tabs filter.
 *  - `.is-overflow` aplica cuando un card está fuera de los primeros 8
 *    (rendered pero hidden hasta que un tab specific lo necesite).
 *  - `.is-filtered-out` aplica cuando JS marca el card como no coincidente
 *    con el filtro activo.
 *  - El JS de filtering debe agregar/quitar estas clases sin tocar el
 *    DOM tree (preserva render performance + state estable). */
.ec-home-bestseller__card-slot.is-overflow,
.ec-home-bestseller__card-slot.is-filtered-out {
  display: none;
}

/* Sub-fase 1G W2.4 — Cards interiores ahora son `.ec-product-card` (DRY refactor).
 * v2.9.0 Issue E: el wrapper `.ec-home-bestseller__card-slot` ahora envuelve
 * cada card para soportar data-attr filter + visibility orchestration. El
 * styling del card sigue venir de parts/product-card.php (DRY preservado). */

/* v2.9.0 Issue E: tabs `--desktop-only` escondidas en mobile breakpoint. */
@media (max-width: 767px) {
  .ec-home-bestseller__tab--desktop-only {
    display: none;
  }
}

@media (max-width: 1024px) and (min-width: 768px) {
  .ec-home-bestseller {
    padding: 0 24px 56px;
  }
  .ec-home-bestseller__title {
    font-size: 36px;
  }
  .ec-home-bestseller__grid {
    grid-template-columns: repeat(3, 1fr);
  }
  /* v2.10.1 Wave 2: limitar a 6 cards visibles en tablet (3x2 grid).
   * Aplica a CADA pool independientemente (n+7 dentro del pool). */
  .ec-home-bestseller__pool > .ec-home-bestseller__card-slot:nth-child(n + 7) {
    display: none;
  }
}

@media (max-width: 767px) {
  .ec-home-bestseller {
    padding: 0 16px 40px;
  }
  .ec-home-bestseller__title {
    font-size: 36px;
  }
  .ec-home-bestseller__grid {
    /* minmax(0,1fr) (no 1fr=minmax(auto,1fr)) para que las columnas puedan
       encoger bajo el min-content de la card y NO se desborden/corten en
       pantallas angostas (bug Benjamín: cards cortadas en mobile). */
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  /* v2.10.1 Wave 2: 4 cards visibles en mobile (2x2). Aplica por pool. */
  .ec-home-bestseller__pool > .ec-home-bestseller__card-slot:nth-child(n + 5) {
    display: none;
  }
  .ec-home-bestseller__tabs {
    /* Single line scroll horizontal if needed — overflow-x auto + hide scrollbar */
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    margin-bottom: 16px;
  }
  .ec-home-bestseller__tabs::-webkit-scrollbar {
    display: none;
  }
  .ec-home-bestseller__tab {
    flex-shrink: 0;
    padding: 8px 12px;
    font-size: 11px;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * HOME — Marcas (marquee de partners) + bloque "Acerca de Elite Center"
 * Reemplaza el banner B2B. Marquee CSS-only (translateX -50% sobre track
 * duplicado), congelado en prefers-reduced-motion. JS opcional pausa on-hover.
 * MINORFIXES-GO-LIVE item 4 — 2026-06-01
 * ═══════════════════════════════════════════════════════════════ */
.ec-home-brands {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 40px 80px;
  /* Fuera de viewport no cuesta layout/paint. La altura intrinseca aproxima
   * head + marquee + about para que el scrollbar no salte. */
  content-visibility: auto;
  contain-intrinsic-size: auto 560px;
}

.ec-home-brands__head {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 28px;
}

.ec-home-brands__title {
  font-family: var(--ec-font-display);
  font-weight: 800;
  font-size: 56px;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0;
}

/* Marquee viewport: recorta el track y aplica fade en los bordes. */
.ec-home-brands__marquee {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--ec-border);
  border-radius: var(--ec-r-2xl);
  background: var(--ec-surface);
  padding: 28px 0;
  -webkit-mask-image: linear-gradient(
    to right,
    transparent,
    #000 8%,
    #000 92%,
    transparent
  );
  mask-image: linear-gradient(
    to right,
    transparent,
    #000 8%,
    #000 92%,
    transparent
  );
}

.ec-home-brands__track {
  display: flex;
  align-items: center;
  gap: 56px;
  width: max-content;
  animation: ec-brands-scroll 56s linear infinite;
  will-change: transform;
}

.ec-home-brands__track.is-paused {
  animation-play-state: paused;
}

.ec-home-brands__logo {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.ec-home-brands__logo img {
  display: block;
  width: auto;
  height: 52px;
  /* Logos sobre tarjeta clara (fondo blanco original del asset). Sin grayscale
   * para respetar el color de marca. */
  object-fit: contain;
}

/* El track contiene el set duplicado, asi que -50% reinicia sin salto. */
@keyframes ec-brands-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

/* Bloque "Acerca de Elite Center" centrado debajo del marquee. */
.ec-home-brands__about {
  max-width: 720px;
  margin: 56px auto 0;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.ec-home-brands__about-title {
  font-family: var(--ec-font-display);
  font-weight: 800;
  font-size: 36px;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0;
}

.ec-home-brands__about-text {
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  color: var(--ec-text-secondary);
}

/* prefers-reduced-motion: congela la animacion y deja el track scrolleable
 * estaticamente (overflow-x:auto) para que el usuario pueda ver todas las marcas. */
@media (prefers-reduced-motion: reduce) {
  .ec-home-brands__marquee {
    overflow-x: auto;
  }
  .ec-home-brands__track {
    animation: none;
    will-change: auto;
  }
}

@media (max-width: 1024px) and (min-width: 768px) {
  .ec-home-brands {
    padding: 0 24px 56px;
  }
  .ec-home-brands__title {
    font-size: 40px;
  }
  .ec-home-brands__about-title {
    font-size: 30px;
  }
}

@media (max-width: 767px) {
  .ec-home-brands {
    padding: 0 16px 40px;
  }
  .ec-home-brands__title {
    font-size: 32px;
  }
  .ec-home-brands__track {
    gap: 40px;
  }
  .ec-home-brands__logo img {
    height: 40px;
  }
  .ec-home-brands__about {
    margin-top: 40px;
  }
  .ec-home-brands__about-title {
    font-size: 26px;
  }
  .ec-home-brands__about-text {
    font-size: 15px;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * Breadcrumbs (C9) — page-level, scope outside chrome
 * ═══════════════════════════════════════════════════════════════ */
.ec-breadcrumbs {
  font-family: var(--ec-font-body);
}

.ec-breadcrumbs__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  /* flex-start, no center: el chevron SVG del separador infla la altura de la
   * línea flex ~10px; con center el primer crumb quedaba arriba y el current
   * (último) ~5px más abajo (desalineado, verificado en vivo con computed
   * styles). flex-start alinea todos los crumbs al mismo tope. */
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  color: var(--ec-text-muted);
  flex-wrap: wrap;
}

.ec-breadcrumbs__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.ec-breadcrumbs__link {
  color: var(--ec-text-muted);
  font-weight: 400;
  transition: color 0.15s;
}

.ec-breadcrumbs__link:hover {
  color: var(--ec-primary);
}

.ec-breadcrumbs__current {
  color: var(--ec-text-primary);
  font-weight: 500;
}

.ec-breadcrumbs__sep {
  display: inline-flex;
  align-items: center;
  color: var(--ec-text-hint);
}

/* ═══════════════════════════════════════════════════════════════
 * Product Card (C8) — pattern Cloud Design ProductCard
 * Filter-based: invocado solo desde nuestros archive/related templates
 * (NO override de content-product.php — preserva consumers legacy:
 * WP Grid Builder, YITH Quote, Fibo Search). Elementor WC widgets ya no
 * relevante post-Sub-fase 1F H1+H2+H3+H4 decommission.
 *
 * Sub-fase 1E E4-2 (P0): Benjamín reportó cards "plomo+blanco" sin tone.
 * Fix: media bg WHITE puro (productos B2B sobre blanco resaltan más),
 * separator subtle border-bottom 1px en lugar de border full,
 * hover border indigo + sombra reforzada, micro-interaction más visible.
 * ═══════════════════════════════════════════════════════════════ */
.ec-product-card {
  /* Sub-fase 1E perf-cap: removed isolation:isolate + ::after pseudo —
   * cada card tenía 2 paint layers extra (transition de pseudo). Fix:
   * border directo cambia color en hover (single layer). */
  background: var(--ec-surface);
  border: 1px solid var(--ec-border);
  border-radius: var(--ec-r-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease;
  position: relative;
}

.ec-product-card:hover {
  transform: translateY(-3px);
  border-color: var(--ec-primary);
  box-shadow: var(--ec-shadow-card-hover);
}

.ec-product-card__media-link {
  display: block;
}

.ec-product-card__media {
  position: relative;
  aspect-ratio: 1 / 1;
  /* Sub-fase 1E E4-2: media bg blanco sólido (antes surface-2 plomo).
   * Productos B2B (negro/aluminio típico) destacan más sobre blanco.
   * Separator inferior con border-bottom 1px subtle. */
  background: var(--ec-surface);
  border-bottom: 1px solid var(--ec-border);
  overflow: hidden;
}

.ec-product-card__media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  /* Sub-fase 1E E4-1: padding reducido 8% -> 5% para que producto sea más
   * prominente dentro del cuadrado y elimine la sensación de imagen "deforme"
   * o "perdida en blanco" reportada por Benjamín. */
  padding: 5%;
  transition: transform 0.3s ease;
}

.ec-product-card:hover .ec-product-card__media img {
  transform: scale(1.04);
}

.ec-product-card__media-placeholder {
  width: 100%;
  height: 100%;
  background:
    repeating-linear-gradient(
      135deg,
      #f2f4f6 0,
      #f2f4f6 14px,
      #e9ebee 14px,
      #e9ebee 15px
    ),
    #f2f4f6;
}

/* ═════════════════════════════════════════════════════════════════
 * Sub-fase 2 (Rediseño Store) — Product card badges + price + chips refactor.
 * Single source of truth cross-surface (archive / search / related / cart / home).
 * Tipografía unificada: Rajdhani (chips), Exo 2 (precio principal), Mono (P/N + tarjeta).
 * Densidad reducida ~15% vs versión anterior (DEC-CARD-5). Body zone separada de
 * media zone para zero overlap en mobile (issue 6 resuelto por arquitectura).
 * ═════════════════════════════════════════════════════════════════ */

/* Badges promocionales — media zone (sobre imagen). Chips compactos discretos. */
.ec-product-card__badge {
  position: absolute;
  top: 10px;
  padding: 3px 7px;
  border-radius: var(--ec-r-sm, 6px);
  font-family: var(--ec-font-label, "Rajdhani", sans-serif);
  font-weight: 500;
  font-size: 10px;
  line-height: 1.4;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  z-index: 2;
  box-shadow: none;
  white-space: nowrap;
}

/* Discount badge — top-left, rojo translúcido sin shadow */
.ec-product-card__badge--discount {
  left: 10px;
  background: color-mix(in srgb, var(--ec-error, #dc2626) 92%, transparent);
  color: #fff;
}

/* NUEVO badge — top-right, indigo brand */
.ec-product-card__badge--new {
  right: 10px;
  background: color-mix(in srgb, var(--ec-primary, #444ce7) 94%, transparent);
  color: #fff;
}

/* Sub-fase 1E E8-1: out-of-stock state — opacity reduce + grayscale leve
 * para indicación visual immediate sin remover el card del DOM. */
.ec-product-card.is-out-of-stock {
  opacity: 0.72;
}

.ec-product-card.is-out-of-stock .ec-product-card__media img {
  filter: grayscale(0.4);
}

.ec-product-card.is-out-of-stock .ec-product-card__media::after {
  content: "Agotado";
  position: absolute;
  inset: auto 0 12px 0;
  margin: 0 auto;
  width: max-content;
  padding: 4px 12px;
  background: var(--ec-text-primary);
  color: #fff;
  font-family: var(--ec-font-label);
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: var(--ec-r-pill);
  z-index: 2;
}

/* Body — densidad reducida ~15% vs versión anterior (DEC-CARD-5).
 * 16px → 14px padding. gap interno reducido para fit + más líneas verticales (brand
 * + título + P/N + 3-líneas precio + chips). Apple-like minimal info-densa elegante. */
.ec-product-card__body {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}

/* Header (marca + título + P/N) agrupados con gap pequeño. */
.ec-product-card__header {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ec-product-card__brand {
  font-family: var(--ec-font-label, "Rajdhani", sans-serif);
  font-size: 11px;
  font-weight: 600;
  color: var(--ec-text-secondary, #75768a);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1.2;
}

.ec-product-card__title {
  margin: 0;
  font-family: var(--ec-font-body, "Montserrat", sans-serif);
  font-weight: 600;
  font-size: 14px;
  line-height: 1.35;
  color: var(--ec-text-primary, #060606);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ec-product-card__title a {
  color: inherit;
  transition: color 0.15s ease;
  text-decoration: none;
}

.ec-product-card__title a:hover {
  color: var(--ec-primary, #444ce7);
}

/* P/N — Mono pequeño gris debajo del title. Slot reserva min-height aunque vacío
 * para garantizar grid uniformity (DEC-CARD-2). */
.ec-product-card__pn {
  display: flex;
  align-items: baseline;
  gap: 4px;
  min-height: 16px;
  font-family: var(--ec-font-mono, "JetBrains Mono", monospace);
  font-size: 11px;
  font-weight: 400;
  color: var(--ec-text-muted, #75768a);
  letter-spacing: 0.01em;
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ec-product-card__pn.is-empty {
  visibility: hidden;
}

.ec-product-card__pn-label {
  font-weight: 500;
  opacity: 0.75;
  flex-shrink: 0;
}

.ec-product-card__pn-value {
  font-weight: 400;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ec-product-card__rating {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--ec-text-muted);
}

.ec-product-card__stars {
  display: inline-flex;
  gap: 1px;
  color: var(--ec-warning);
}

.ec-product-card__star {
  color: var(--ec-text-hint);
}

.ec-product-card__star.is-filled {
  color: var(--ec-warning);
}

.ec-product-card__rating-count {
  color: var(--ec-text-muted);
}

/* ─────────────────────────────────────────────────────────────────
 * Sub-fase 2 — Bloque precio paridad PDP caja_completa.
 * Layout:
 *   [Línea 1] Regular tachado (placeholder reservado si no on_sale → uniformidad altura)
 *   [Línea 2] Precio transferencia DESTACADO — Exo 2 18-20px bold, indigo si on_sale
 *   [Línea 3] Precio tarjeta SUBORDINADO — JetBrains Mono 13px gris
 * ─────────────────────────────────────────────────────────────── */
.ec-product-card__price-block {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: auto;
}

.ec-product-card__price-was {
  font-family: var(--ec-font-mono, "JetBrains Mono", monospace);
  font-size: 12px;
  font-weight: 400;
  color: var(--ec-text-muted, #75768a);
  text-decoration: line-through;
  line-height: 1.3;
  min-height: 16px;
}

/* Placeholder invisible cuando NO on_sale — reserva la línea para que la altura
 * del card sea uniforme entre productos con/sin descuento. */
.ec-product-card__price-was.is-placeholder {
  visibility: hidden;
}

.ec-product-card__price-main {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 6px;
  line-height: 1.15;
}

.ec-product-card__price-amount {
  font-family: var(--ec-font-display, "Exo 2", sans-serif);
  font-size: 20px;
  font-weight: 700;
  /* Precio transferencia SIEMPRE azul Elite Center (igual que el PDP .azul),
     con o sin descuento. Antes: negro normal / rojo en oferta. */
  color: #273f87;
  letter-spacing: -0.01em;
}

.ec-product-card.is-on-sale .ec-product-card__price-amount {
  color: #273f87;
}

.ec-product-card__price-label {
  font-family: var(--ec-font-label, "Rajdhani", sans-serif);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: var(--ec-text-muted, #75768a);
  line-height: 1.3;
}

.ec-product-card__price-card {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 1px;
}

.ec-product-card__price-amount-sm {
  font-family: var(--ec-font-mono, "JetBrains Mono", monospace);
  font-size: 13px;
  font-weight: 500;
  color: var(--ec-text-secondary, #4a4b5f);
  letter-spacing: -0.005em;
}

.ec-product-card__price-label--sub {
  font-size: 9px;
  opacity: 0.85;
}

/* ─────────────────────────────────────────────────────────────────
 * Sub-fase 2 — Chips inferiores (delivery + stock urgency).
 * Body zone, NO sobre imagen. Zero overlap mobile resuelto por arquitectura.
 * Tipografía unificada Rajdhani 10-11px weight 500 — coherente con badges.
 * ─────────────────────────────────────────────────────────────── */
.ec-product-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  min-height: 22px;
}

.ec-product-card__chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: var(--ec-r-pill, 999px);
  font-family: var(--ec-font-label, "Rajdhani", sans-serif);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.3;
  white-space: nowrap;
  text-transform: none;
}

.ec-product-card__chip--delivery {
  color: var(--ec-text-secondary, #4a4b5f);
  background: color-mix(in srgb, var(--ec-text-muted, #75768a) 8%, transparent);
}

.ec-product-card__chip--delivery.is-free {
  color: var(--ec-success, #16a34a);
  background: color-mix(in srgb, var(--ec-success, #16a34a) 11%, transparent);
}

/* Check Lucide para envío gratis — coherente con icon system brand v2 */
.ec-product-card__chip--delivery.is-free::before {
  content: "";
  width: 11px;
  height: 11px;
  flex-shrink: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316a34a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.ec-product-card__chip--stock.is-low {
  color: var(--ec-warning, #b45309);
  background: color-mix(in srgb, var(--ec-warning, #f59e0b) 14%, transparent);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 10px;
  font-weight: 600;
}

/* ─────────────────────────────────────────────────────────────────
 * Sub-fase 2 — Mobile refinement (chiquititos delicados — DEC-CARD-4).
 * Card mobile 150-170px ancho (grid 2 cols). Font-sizes 9-10px weight 400.
 * Padding interior 12px (vs desktop 14px). Imagen sin sacrificar tamaño.
 * ─────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  .ec-product-card__body {
    padding: 12px;
    gap: 8px;
  }

  .ec-product-card__brand {
    font-size: 10px;
    letter-spacing: 0.06em;
  }

  .ec-product-card__title {
    font-size: 13px;
    line-height: 1.3;
  }

  .ec-product-card__pn {
    font-size: 10px;
    min-height: 14px;
  }

  .ec-product-card__price-amount {
    font-size: 17px;
  }

  .ec-product-card__price-amount-sm {
    font-size: 12px;
  }

  .ec-product-card__price-label {
    font-size: 9px;
    font-weight: 400;
  }

  .ec-product-card__price-label--sub {
    font-size: 8px;
  }

  .ec-product-card__chip {
    font-size: 10px;
    font-weight: 400;
    padding: 2px 7px;
  }

  .ec-product-card__chip--stock.is-low {
    font-size: 9px;
    font-weight: 500;
  }

  /* Tag de entrega en mobile: la card es angosta (~160px) y el texto
   * "Recíbelo el [día] en [región]" se cortaba contra el borde (el chip base
   * tiene white-space:nowrap). Permitir 2 líneas + fila propia (flex-basis:100%)
   * para que NUNCA pise el chip de stock ("Últimas X unidades"), que cae debajo
   * por el flex-wrap del contenedor. Radius md (no pill) para que 2 líneas se
   * vean como bloque redondeado y no como cápsula gigante. */
  .ec-product-card__chip--delivery {
    white-space: normal;
    flex-basis: 100%;
    align-items: flex-start;
    border-radius: var(--ec-r-md, 8px);
    line-height: 1.35;
  }

  .ec-product-card__badge {
    font-size: 9px;
    padding: 2px 6px;
    top: 8px;
  }

  .ec-product-card__badge--discount {
    left: 8px;
  }

  .ec-product-card__badge--new {
    right: 8px;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * Sub-fase 1G W2.1 — Bottom tab bar 5 slots (D4 Benjamín)
 *
 * Override del layout flex base (`chrome.css`) cuando el bar tiene 5 elementos.
 * El 5° slot queda vacío reservado para el botón flotante JoinChat WhatsApp.
 * Con 5 columnas: FAB Cotizar (3°) queda en TRUE center geométrico.
 *
 * Implementación con CSS grid 5 columnas equal-width sobreescribe el flex base.
 * `pointer-events:none` en el slot reservado: aunque sea un <div> vacío, evita
 * cualquier captura accidental de taps en el área. JoinChat con z-index:9000
 * + bottom-tab con z-index:9001 (set en functions.php F1.1) preserva el patrón
 * de coexistencia.
 * ═══════════════════════════════════════════════════════════════ */
.ec-chrome-bottom-tabs.ec-chrome-bottom-tabs--5slots {
  display: none;
}

@media (max-width: 767px) {
  .ec-chrome-bottom-tabs.ec-chrome-bottom-tabs--5slots {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    align-items: stretch;
  }
}

.ec-chrome-bottom-tabs__slot-reserved {
  pointer-events: none;
  background: transparent;
  cursor: default;
}

/* ═══════════════════════════════════════════════════════════════
 * Sub-fase 1G W2.5 — PWA install banner
 *
 * Position fixed bottom, indigo CTA brand-aligned, dismissable.
 * Z-index 9002 = sobre JoinChat (9000) + sobre bottom-tabs (9001) para
 * que la decisión de instalar no quede bloqueada visualmente.
 * Solo visible en mobile (max-width 767px). Animación slide-up suave.
 * ═══════════════════════════════════════════════════════════════ */
.ec-pwa-banner {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: auto;
  /* Sobre el sticky header del sitio para no chocar con el bottom-tab menu
     ni la sticky pay bar del checkout (decisión Benjamín 2026-05-24). */
  z-index: 9050;
  background: var(--ec-surface, #fff);
  border: 1px solid var(--ec-border, #e6e8ea);
  border-top: 0;
  border-radius: 0 0 var(--ec-r-xl, 12px) var(--ec-r-xl, 12px);
  box-shadow: var(--ec-shadow-card, 0 4px 12px rgba(0, 0, 0, 0.08));
  padding: calc(10px + env(safe-area-inset-top, 0)) 14px 10px;
  transform: translateY(-110%);
  opacity: 0;
  transition:
    transform 0.28s ease,
    opacity 0.2s ease;
  pointer-events: none;
}

.ec-pwa-banner.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.ec-pwa-banner__inner {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 10px;
}

.ec-pwa-banner__icon {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--ec-primary-light, #e0e0ff);
  color: var(--ec-primary, #444ce7);
  flex-shrink: 0;
}

.ec-pwa-banner__copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.ec-pwa-banner__title {
  font-family: var(--ec-font-display, "Exo 2", sans-serif);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--ec-text-primary, #060606);
  line-height: 1.2;
}

.ec-pwa-banner__sub {
  font-family: var(--ec-font-body, "Montserrat", sans-serif);
  font-size: 12px;
  color: var(--ec-text-muted, #75768a);
  line-height: 1.3;
}

.ec-pwa-banner__cta {
  background: var(--ec-primary, #444ce7);
  color: #fff;
  border: 0;
  padding: 10px 14px;
  border-radius: var(--ec-r-md, 8px);
  font-family: var(--ec-font-display, "Exo 2", sans-serif);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s;
  min-height: 36px;
  white-space: nowrap;
}

.ec-pwa-banner__cta:hover {
  background: var(--ec-primary-dark, #272dcf);
}

.ec-pwa-banner__cta:focus-visible {
  outline: 2px solid var(--ec-primary, #444ce7);
  outline-offset: 2px;
}

.ec-pwa-banner__close {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  background: transparent;
  border: 0;
  border-radius: 999px;
  color: var(--ec-text-muted, #75768a);
  cursor: pointer;
  transition:
    background 0.15s,
    color 0.15s;
}

.ec-pwa-banner__close:hover {
  background: var(--ec-surface-2, #f2f4f6);
  color: var(--ec-text-primary, #060606);
}

/* La app PWA es para mobile/tablet — en desktop no tiene sentido instalarla.
   Decisión Benjamín 2026-05-24: ocultar el banner en desktop (>=1025px). */
@media (min-width: 1025px) {
  .ec-pwa-banner {
    display: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * Sub-fase 1H Bucket 3 P2 — WC Login form button 44px WCAG 2.5.5 (AAA)
 * Antes ~42px (padding heredado Woodmart). Coherente con .ec-cta 44px.
 * ═══════════════════════════════════════════════════════════════ */
.woocommerce-form-login__submit,
form.woocommerce-form-login button[type="submit"] {
  min-height: 44px;
  box-sizing: border-box;
}
