:root {
  --amarillo: #F5C518;
  --amarillo-dark: #d4a800;
  --gris-oscuro: #3D4354;
  --negro: #1a1a1a;
  --blanco: #FFFFFF;
  --gris-fondo: #f5f5f5;
  --gris-borde: #e0e0e0;
  --gris-texto: #555;
  --gris-muted: #999;
  --verde-wpp: #25D366;
}
/* ===================== [FUENTE] BoosterNext FY ===================== */
/* Autoalojada. Solo dos archivos: Regular (400) y Medium. El Medium cubre el
   rango 500-900, asi que cualquier "negrita" del diseno (600/700/800/900) usa
   el Medium real — sin bold ni extrabold, y sin negrita sintetica del navegador.
   Los .woff2 van en la raiz de public_html (misma carpeta que index.html). */
@font-face {
  font-family: 'BoosterNext FY';
  src: url('booster-next-fy-regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BoosterNext FY';
  src: url('booster-next-fy-medium.woff2') format('woff2');
  font-weight: 500 900;
  font-style: normal;
  font-display: swap;
}
/* =================================================================== */

* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'BoosterNext FY', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-synthesis: none; -webkit-font-synthesis: none; background: var(--gris-fondo); color: var(--negro); }

/* ===================== [BLOQUE 1] HEADER ESTILO LANDING ===================== */
/* Se eliminó la franja navy del hero: el título y el CTA viven ahora dentro del
   header, sobre blanco. El header crece en alto si hace falta y envuelve en móvil. */
.header {
  background: white;
  border-bottom: 3px solid var(--amarillo);
  padding: 12px 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  flex-wrap: wrap;
  position: sticky; top: 0; z-index: 100;
  box-shadow: 0 2px 8px rgba(0,0,0,0.07);
}
.header-left { display: flex; align-items: center; gap: 16px; min-width: 0; }
.logo-img { height: 48px; object-fit: contain; flex-shrink: 0; }
.header-titles { min-width: 0; }
.header-h1 {
  font-size: 21px; font-weight: 900; color: var(--gris-oscuro);
  text-transform: uppercase; letter-spacing: 0.5px; line-height: 1.1;
}
.header-h1 span { color: var(--amarillo-dark); }
.header-sub { font-size: 11px; color: var(--gris-muted); font-weight: 600; margin-top: 3px; }
.header-right { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.header-badge {
  background: var(--amarillo); color: var(--gris-oscuro);
  font-size: 11px; font-weight: 800; padding: 5px 14px;
  border-radius: 20px; letter-spacing: 0.5px; text-transform: uppercase;
}
.header-tagline { font-size: 11px; color: var(--gris-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
/* CTA principal de WhatsApp: más grande y llamativo que antes. */
.btn-wpp-hero {
  display: flex; align-items: center; gap: 8px;
  background: var(--verde-wpp); color: white;
  padding: 12px 22px; border-radius: 10px; font-size: 14px; font-weight: 800;
  border: none; cursor: pointer; font-family: 'BoosterNext FY', sans-serif;
  text-transform: uppercase; letter-spacing: 0.3px;
  box-shadow: 0 4px 12px rgba(37,211,102,0.28);
  transition: background 0.18s ease, transform 0.12s ease, box-shadow 0.18s ease;
}
.btn-wpp-hero:hover { background: #1ebe5d; box-shadow: 0 6px 18px rgba(37,211,102,0.36); transform: translateY(-1px); }
.btn-wpp-hero:active { transform: translateY(0); }
/* =================== FIN [BLOQUE 1] HEADER ESTILO LANDING =================== */

.toolbar {
  background: white; padding: 12px 28px;
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  border-bottom: 1px solid var(--gris-borde);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.search-wrap { flex: 1; min-width: 180px; position: relative; }
.search-wrap svg { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: var(--gris-muted); }
.toolbar input {
  width: 100%; padding: 9px 12px 9px 36px;
  background: var(--gris-fondo); border: 1.5px solid var(--gris-borde);
  border-radius: 8px; color: var(--negro); font-size: 13px;
  font-family: 'BoosterNext FY', sans-serif; outline: none; font-weight: 500;
  transition: border-color 0.2s;
}
.toolbar input:focus { border-color: var(--amarillo); background: white; }
.toolbar input::placeholder { color: var(--gris-muted); font-weight: 400; }
.toolbar select {
  padding: 9px 12px; background: var(--gris-fondo);
  border: 1.5px solid var(--gris-borde); border-radius: 8px;
  color: var(--negro); font-size: 13px; font-family: 'BoosterNext FY', sans-serif;
  outline: none; cursor: pointer; min-width: 150px; font-weight: 500;
}
.toolbar select:focus { border-color: var(--amarillo); }
/* [A3] Filtro por proveedor RETIRADO. Antes (F1-5) había un #providerFilter
   oculto que se revelaba con ?ver=interno; el cliente lo quitó y ahora el
   proveedor se identifica con la etiqueta gris pequeña de cada tarjeta
   (.card-prov, más abajo). Se eliminaron las reglas #providerFilter y
   body.modo-interno #providerFilter. */

.stats-bar {
  background: white; padding: 8px 28px;
  display: flex; gap: 16px; align-items: center;
  border-bottom: 1px solid var(--gris-borde); flex-wrap: wrap;
}
.stat { font-size: 12px; color: var(--gris-muted); font-weight: 500; }
.stat strong { color: var(--gris-oscuro); font-weight: 700; }
.stat-sep { color: var(--gris-borde); }
/* [BLOQUE 7] Mensaje del asesor en la barra de estado (reemplaza el viejo
   "Stock actualizado en tiempo real"). Resalta en navy sobre fondo amarillo claro. */
.stat-asesor {
  color: var(--gris-oscuro); font-weight: 700;
  background: #fffaf0; border: 1px solid var(--amarillo);
  padding: 3px 10px; border-radius: 20px;
}

/* ============================ [A4] FILTROS (Opción 2) ============================
   Botón "Filtros" en la toolbar que abre/cierra un panel con TODOS los filtros
   (categoría, color, stock, actualización, precio mín/máx e inventario). Sustituye
   a los selects que antes vivían sueltos en la toolbar. Look "panel estilo Marpico":
   barra limpia arriba; filtros ordenados en cuadrícula al abrir. */
.btn-filtros {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 16px; background: var(--amarillo); color: var(--gris-oscuro);
  border: none; border-radius: 8px; cursor: pointer;
  font-family: 'BoosterNext FY', sans-serif; font-size: 13px; font-weight: 700;
  transition: background 0.15s;
}
.btn-filtros:hover { background: var(--amarillo-dark); }
.btn-filtros svg { flex-shrink: 0; }
.filtros-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--gris-oscuro); color: white;
  border-radius: 9px; font-size: 11px; font-weight: 700; line-height: 1;
}
.filter-panel {
  background: white; padding: 16px 28px 18px;
  border-bottom: 1px solid var(--gris-borde);
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
  animation: filterSlide 0.18s ease-out;
}
@keyframes filterSlide {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.filter-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px 16px;
}
.filter-field { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.filter-field label {
  font-size: 11px; font-weight: 700; color: var(--gris-oscuro);
  text-transform: uppercase; letter-spacing: 0.4px;
}
.filter-panel select,
.filter-panel input {
  width: 100%; padding: 9px 12px;
  background: var(--gris-fondo); border: 1.5px solid var(--gris-borde);
  border-radius: 8px; color: var(--negro); font-size: 13px;
  font-family: 'BoosterNext FY', sans-serif; outline: none; font-weight: 500;
  transition: border-color 0.2s;
}
.filter-panel select { cursor: pointer; }
.filter-panel select:focus,
.filter-panel input:focus { border-color: var(--amarillo); background: white; }
.filter-panel input::placeholder { color: var(--gris-muted); font-weight: 400; }
/* Oculta las flechitas del input numérico para un look más limpio. */
.filter-panel input[type=number]::-webkit-outer-spin-button,
.filter-panel input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.filter-panel input[type=number] { -moz-appearance: textfield; }
.filter-actions {
  display: flex; justify-content: flex-end; gap: 10px; margin-top: 16px;
}
.btn-aplicar {
  padding: 9px 22px; background: var(--gris-oscuro); color: white;
  border: none; border-radius: 8px; cursor: pointer;
  font-family: 'BoosterNext FY', sans-serif; font-size: 13px; font-weight: 700;
  transition: opacity 0.15s;
}
.btn-aplicar:hover { opacity: 0.88; }
.btn-limpiar {
  padding: 9px 18px; background: white; color: var(--gris-texto);
  border: 1.5px solid var(--gris-borde); border-radius: 8px; cursor: pointer;
  font-family: 'BoosterNext FY', sans-serif; font-size: 13px; font-weight: 600;
  transition: all 0.15s;
}
.btn-limpiar:hover { border-color: var(--gris-muted); color: var(--negro); }
/* En móvil: el botón Filtros ocupa todo el ancho y los botones del panel se apilan. */
@media (max-width: 600px) {
  .btn-filtros { width: 100%; justify-content: center; }
  .filter-panel { padding: 14px 16px 16px; }
  .filter-actions { flex-direction: column-reverse; }
  .btn-aplicar, .btn-limpiar { width: 100%; }
}
/* =================== FIN [A4] FILTROS =================== */

.loading-bar { height: 3px; background: #eee; overflow: hidden; }
.loading-bar-inner { height: 100%; background: var(--amarillo); animation: loadAnim 1.5s ease-in-out infinite; }
@keyframes loadAnim { 0%{width:0;margin-left:0} 50%{width:60%;margin-left:20%} 100%{width:0;margin-left:100%} }

/* ===================== [PASO 3] TARJETA ESTILO LANDING ===================== */
/* Tarjeta más grande y aireada (como palamarca.co): imagen amplia en panel
   redondeado, sombra suave en vez de borde marcado, más espacio interno. */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(248px, 1fr));
  gap: 22px; padding: 26px 28px;
}

.card {
  background: white; border: 1px solid #ececed;
  border-radius: 18px; overflow: hidden;
  box-shadow: 0 1px 2px rgba(61,67,84,0.04), 0 8px 24px rgba(61,67,84,0.06);
  transition: box-shadow 0.25s ease, transform 0.18s ease, border-color 0.2s ease;
  display: flex; flex-direction: column; cursor: pointer;
}
.card:hover {
  border-color: #e4e4e6;
  box-shadow: 0 4px 10px rgba(61,67,84,0.08), 0 18px 40px rgba(61,67,84,0.13);
  transform: translateY(-4px);
}

/* Panel de imagen: inset redondeado sobre fondo muy claro, como la landing. */
.card-img-wrap {
  position: relative; background: #f7f7f8;
  height: 236px; margin: 14px 14px 0;
  border-radius: 14px; overflow: hidden;
}
/* [FIX ENCUADRE ORG-3] La imagen entra directo a su tamaño final.
   La transición es SOLO para el zoom del hover, no para el ajuste de carga. */
.card-img-wrap img {
  display: block;
  width: 100%; height: 100%;
  object-fit: contain; object-position: center;
  padding: 16px;
  transition: transform 0.35s ease;
  will-change: transform;
}
.card:hover .card-img-wrap img { transform: scale(1.04); }
.no-img {
  width: 100%; height: 236px; margin: 14px 14px 0; border-radius: 14px;
  background: #f0f0f0; display: flex; align-items: center; justify-content: center;
  color: #ccc; font-size: 40px;
}

.stock-pill {
  position: absolute; top: 12px; right: 12px;
  font-size: 10px; font-weight: 800; padding: 4px 10px; border-radius: 20px;
  letter-spacing: 0.2px; box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.sok { background: #e8f5e9; color: #2e7d32; }
.slow { background: #fff8e1; color: #f57f17; }
.sout { background: #ffebee; color: #c62828; }
/* [NUEVO] Cinta "NUEVO" TURBO: gradiente animado (rojo->naranja->amarillo) + destello que
   cruza + glow pulsante. Arriba a la IZQUIERDA (la de stock va a la derecha, no chocan).
   Reversible quitando este bloque (y la estructura de la cinta en app.js). */
.card-nuevo {
  position: absolute; top: 12px; left: 12px; z-index: 2;
  display: flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 900; letter-spacing: 0.7px; text-transform: uppercase; color: #fff;
  padding: 5px 13px; border-radius: 20px; overflow: hidden;
  background: linear-gradient(120deg,#FF2D55,#FF7A00,#F5C518,#FF7A00,#FF2D55);
  background-size: 300% 100%;
  animation: cnSlide 3s linear infinite, cnGlow 1.7s infinite;
}
.card-nuevo .cn-star { animation: cnTwinkle 1.1s infinite; }
.card-nuevo .cn-sweep {
  position: absolute; top: 0; left: -70%; width: 45%; height: 100%;
  background: linear-gradient(120deg,transparent,rgba(255,255,255,0.8),transparent);
  transform: skewX(-20deg); animation: cnShine 2.4s infinite;
}
@keyframes cnSlide { 0% { background-position: 0% 50%; } 100% { background-position: 300% 50%; } }
@keyframes cnGlow {
  0%   { box-shadow: 0 2px 8px rgba(255,140,0,0.5), 0 0 0 0 rgba(255,140,0,0.6); }
  70%  { box-shadow: 0 2px 8px rgba(255,140,0,0.5), 0 0 0 13px rgba(255,140,0,0); }
  100% { box-shadow: 0 2px 8px rgba(255,140,0,0.5), 0 0 0 0 rgba(255,140,0,0); }
}
@keyframes cnShine { 0% { left: -70%; } 55%, 100% { left: 140%; } }
@keyframes cnTwinkle { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.35; transform: scale(0.7); } }
/* [NUEVO] Respeta a quien prefiere menos movimiento (accesibilidad) */
@media (prefers-reduced-motion: reduce) {
  .card-nuevo, .card-nuevo .cn-star, .card-nuevo .cn-sweep { animation: none; }
}

/* ===================== [TEMPORADA] Render público de campañas "De temporada" =====================
   3 piezas: chip(s) destacado(s), banner (imagen estilo A / color estilo C) y cinta en la tarjeta
   (abajo-izq, convive con NUEVO arriba-izq y stock arriba-der). Alineado con la grilla (28px).
   Reversible quitando este bloque y los bloques [TEMPORADA] de app.js. */
/* El hero (chips + banner) va a TODO EL ANCHO del catálogo (sin márgenes laterales),
   alineado con la grilla (28px). */
.temp-slot { padding: 18px 28px 0; }
.temp-slot[hidden] { display: none; }

/* Chips destacados (uno por campaña activa). El color de cada campaña entra por --tcol. */
.temp-chips { display: flex; flex-wrap: wrap; gap: 9px; margin-bottom: 14px; }
.temp-chip {
  display: inline-flex; align-items: center; gap: 7px; cursor: pointer;
  font-family: inherit; font-size: 13px; font-weight: 800; letter-spacing: 0.2px;
  padding: 8px 16px; border-radius: 22px; border: 2px solid var(--tleg, #1a1a1a);
  background: var(--blanco); color: var(--tleg, #1a1a1a);
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease, color .12s ease;
}
.temp-chip:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,0.12); }
.temp-chip.active { background: var(--tcol, #1a1a1a); border-color: var(--tcol, #1a1a1a); color: var(--ttxt, #fff); }
.temp-chip .tchip-ico { font-size: 15px; line-height: 1; }
.temp-chip .tchip-x { font-weight: 900; font-size: 15px; margin-left: 1px; opacity: .9; }

/* Banner / carrusel de campañas. El carrusel es el "marco": tiene la proporción (8:1) y
   recorta los bordes; los slides se cruzan con fundido. La imagen del banner debe exportarse
   PANORÁMICA (ancha y bajita) a 1600x200 (8:1) para que se vea COMPLETA, sin recortar. */
.temp-carousel {
  position: relative; width: 100%; aspect-ratio: 8 / 1;
  border-radius: 18px; overflow: hidden; box-shadow: 0 6px 22px rgba(61,67,84,0.12);
}
.tc-track { position: absolute; inset: 0; }
.tc-slide { position: absolute; inset: 0; opacity: 0; pointer-events: none; transition: opacity .5s ease; }
.tc-slide.tc-on { opacity: 1; pointer-events: auto; }

.temp-banner { position: relative; height: 100%; cursor: pointer; }
.tc-slide .temp-banner { border-radius: 0; box-shadow: none; }

/* Estilo A: imagen panorámica que llena el marco. */
.temp-banner-img { height: 100%; }
.temp-banner-img .tb-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center; display: block;
}
.temp-banner-img .tb-overlay {
  position: relative; height: 100%; display: flex; align-items: flex-end;
  padding: 16px 26px; color: #fff;
  /* Sombra SOLO en la parte baja (donde va el texto): la imagen se ve clara arriba
     (el hombre se aprecia) y el texto sigue legible. El texto lleva sombra propia. */
  background: linear-gradient(to top, rgba(0,0,0,0.60) 0%, rgba(0,0,0,0.16) 30%, rgba(0,0,0,0) 56%);
  text-shadow: 0 1px 4px rgba(0,0,0,0.55);
}
/* Estilo C: bloque de color sólido (sin imagen). */
.temp-banner-color { height: 100%; padding: 16px 28px; display: flex; align-items: center; }

.tb-meta { display: flex; flex-direction: column; gap: 5px; }
.tb-kicker { font-size: 10.5px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; opacity: .92; }
.tb-nombre { font-size: 25px; font-weight: 900; line-height: 1.05; display: inline-flex; align-items: center; gap: 10px; }
.tb-ico { font-size: 25px; line-height: 1; }
.tb-fechas { font-size: 13.5px; font-weight: 700; opacity: .95; text-transform: none; }

/* Flechas y puntos del carrusel (solo cuando hay más de una campaña activa). */
.temp-carousel:not(.is-multi) .tc-arrow,
.temp-carousel:not(.is-multi) .tc-dots { display: none; }
.tc-arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 3;
  width: 34px; height: 34px; border: none; border-radius: 50%; cursor: pointer; padding: 0;
  background: rgba(0,0,0,0.30); color: #fff; font-size: 20px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
}
.tc-arrow:hover { background: rgba(0,0,0,0.5); }
.tc-prev { left: 12px; }
.tc-next { right: 12px; }
.tc-dots { position: absolute; bottom: 10px; right: 16px; z-index: 3; display: flex; gap: 7px; }
.tc-dot {
  width: 9px; height: 9px; border-radius: 50%; border: none; cursor: pointer; padding: 0;
  background: rgba(255,255,255,0.55); transition: transform .15s ease, background .15s ease;
}
.tc-dot.on { background: #fff; transform: scale(1.25); }

/* Cinta de campaña en la tarjeta (abajo-izquierda). El color entra inline desde app.js. */
.card-temporada {
  position: absolute; bottom: 12px; left: 12px; z-index: 2;
  display: inline-flex; align-items: center; gap: 5px; max-width: calc(100% - 24px);
  font-size: 10.5px; font-weight: 900; letter-spacing: 0.3px; text-transform: uppercase;
  padding: 5px 12px; border-radius: 18px; box-shadow: 0 2px 6px rgba(0,0,0,0.18);
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
}
.card-temporada .ct-ico { font-size: 12px; line-height: 1; }
.card-temporada .ct-mas { margin-left: 5px; padding: 1px 5px; border-radius: 8px; background: rgba(255,255,255,0.28); font-weight: 900; font-size: 9.5px; }

@media (max-width: 900px) { .temp-carousel { aspect-ratio: 5 / 1; } }
@media (max-width: 600px) {
  .temp-slot { padding: 14px 16px 0; }
  .temp-carousel { aspect-ratio: 3 / 1; }
  .temp-banner-img .tb-overlay { padding: 12px 16px; }
  .temp-banner-color { padding: 14px 16px; }
  .tc-arrow { width: 28px; height: 28px; font-size: 17px; }
  .tb-nombre { font-size: 18px; }
  .tb-ico { font-size: 18px; }
}
/* ===================== FIN [TEMPORADA] ===================== */
/* [CARGA-COMPLETA] Modal a pantalla completa cuando el catálogo cargó incompleto. Reversible. */
.carga-modal-overlay {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(26,26,26,0.74);
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.carga-modal-box {
  background: #fff; border-radius: 18px; max-width: 380px; width: 100%;
  padding: 30px 26px; text-align: center; box-shadow: 0 14px 44px rgba(0,0,0,0.32);
}
.carga-modal-emoji { font-size: 38px; line-height: 1; }
.carga-modal-tit { font-size: 19px; font-weight: 800; color: var(--gris-oscuro); margin: 14px 0 8px; }
.carga-modal-txt { font-size: 14px; color: var(--gris-texto); margin: 0 0 22px; line-height: 1.5; }
.carga-modal-btn {
  background: var(--amarillo); color: var(--gris-oscuro);
  border: none; border-radius: 12px; padding: 13px 32px;
  font-size: 15px; font-weight: 800; cursor: pointer;
}
.carga-modal-btn:hover { background: var(--amarillo-dark); }
/* [PP] Píldora neutra para productos propios "sobre pedido" / "consultar" */
.spedido { background: #eaf0fb; color: #2b4a8b; }
/* [PP] Precio "Cotización personalizada" (sin "+ IVA") en tarjeta y modal */
.card-price-pedido { font-size: 17px; font-weight: 800; color: #2b4a8b; }
.modal-price-pedido { font-size: 22px; font-weight: 800; color: #2b4a8b; }
/* [PP] Prefijo "Desde " antes del precio */
.price-prefijo { font-size: 0.72em; font-weight: 700; opacity: .8; margin-right: 2px; }
/* [PP] Nota dentro de la ficha de variantes (sobre pedido / kit) */
.variant-note { font-size: 13px; color: #3b4250; background: #f4f6fa; border: 1px solid #e6e9f0; border-radius: 10px; padding: 11px 13px; line-height: 1.5; }
/* [PP] Colores disponibles de un kit (solo para mostrar) */
.kit-colors { font-size: 13px; color: #3b4250; margin-bottom: 9px; display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.kit-color-chip { display: inline-flex; align-items: center; gap: 5px; background: #f4f6fa; border: 1px solid #e6e9f0; border-radius: 20px; padding: 3px 10px 3px 7px; font-size: 12px; font-weight: 600; }

.card-body { padding: 16px 18px 6px; flex: 1; display: flex; flex-direction: column; gap: 7px; }
.card-code {
  display: inline-block; align-self: flex-start;
  background: var(--amarillo); color: var(--gris-oscuro);
  font-size: 10px; font-weight: 800; letter-spacing: 1px;
  padding: 3px 9px; border-radius: 7px; text-transform: uppercase;
}
.card-name { font-size: 14px; font-weight: 800; color: var(--gris-oscuro); line-height: 1.32; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 37px; }
/* [A3] La línea de categoría ahora es una fila: la categoría puede truncarse
   con "..." mientras la etiqueta del proveedor (PMC/OP/PMS/PMP) queda SIEMPRE
   visible al final, en texto gris pequeño y discreto (estilo categoría). */
.card-cat { display: flex; align-items: baseline; gap: 5px; font-size: 11px; color: var(--gris-muted); font-weight: 500; }
.card-cat .cc-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.card-prov { flex-shrink: 0; font-weight: 800; letter-spacing: 0.5px; color: var(--gris-muted); }

.card-variants { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 2px; }
.color-dot { width: 15px; height: 15px; border-radius: 50%; border: 1.5px solid rgba(0,0,0,0.12); }
/* [BLOQUE 5] Puntito resaltado: el(los) color(es) que coinciden con el filtro. */
.color-dot.matched { box-shadow: 0 0 0 2px var(--blanco), 0 0 0 3.5px var(--amarillo-dark); transform: scale(1.12); }

.card-techs { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 2px; }
.tech-icon { width: 18px; height: 18px; border-radius: 4px; background: #f0f0f0; overflow: hidden; }
.tech-icon img { width: 100%; height: 100%; object-fit: cover; }

.card-footer { padding: 10px 18px 18px; display: flex; flex-direction: column; gap: 9px; }
.btn-ver {
  width: 100%; padding: 11px 12px;
  background: var(--amarillo); color: var(--gris-oscuro);
  border: none; border-radius: 11px;
  font-size: 13px; cursor: pointer; font-family: 'BoosterNext FY', sans-serif;
  font-weight: 800; letter-spacing: 0.2px;
  transition: background 0.18s ease, transform 0.12s ease;
}
.btn-ver:hover { background: var(--amarillo-dark); }
.btn-ver:active { transform: scale(0.99); }
/* "Cotizar" como enlace sutil de WhatsApp (estilo landing), no botón pesado. */
.wa-link {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  color: var(--gris-oscuro); text-decoration: none;
  font-size: 12px; font-weight: 600; cursor: pointer;
  transition: color 0.15s ease;
}
.wa-link svg { color: var(--verde-wpp); flex-shrink: 0; }
.wa-link:hover { color: var(--verde-wpp); }

.pagination {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; padding: 20px 28px; background: white;
  border-top: 1px solid var(--gris-borde); flex-wrap: wrap;
}
.page-btn {
  padding: 8px 16px; background: white; border: 1.5px solid var(--gris-borde);
  border-radius: 8px; color: var(--negro); cursor: pointer;
  font-size: 13px; font-family: 'BoosterNext FY', sans-serif; font-weight: 600; transition: all 0.15s;
}
.page-btn:hover:not(:disabled) { background: var(--amarillo); border-color: var(--amarillo); color: var(--gris-oscuro); }
.page-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.page-info { font-size: 13px; color: var(--gris-muted); font-weight: 500; }

.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 200; align-items: center; justify-content: center; padding: 16px; }
.modal-overlay.open { display: flex; }
.modal { background: white; border-radius: 16px; max-width: 1280px; width: 100%; max-height: 92vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,0.25); }
.modal-header { padding: 16px 24px; background: var(--amarillo); border-radius: 16px 16px 0 0; display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.modal-close { background: none; border: none; color: var(--gris-oscuro); font-size: 24px; cursor: pointer; line-height: 1; opacity: 0.7; }
.modal-close:hover { color: var(--negro); opacity: 1; }
.modal-body { padding: 22px 24px; }
/* [PASO 3 — MODAL 2 COLUMNAS estilo landing] imagen + galería a la izquierda,
   info + precio a la derecha. En móvil se apilan. */
.modal-grid { display: grid; grid-template-columns: 1.25fr 1fr; gap: 24px; align-items: start; }
.modal-col-left { min-width: 0; }
.modal-col-right { min-width: 0; display: flex; flex-direction: column; }
/* ===================== [PASO 3 / F1-4] GALERÍA DEL MODAL ===================== */
/* Estilo landing: imagen principal grande con flechas y TODAS las miniaturas en
   una tira horizontal (con scroll si hay muchas). El clic en un color salta a la
   imagen de ese color. */
.modal-imgs { display: flex; flex-direction: column; gap: 12px; margin-bottom: 16px; }
.modal-main {
  position: relative;
  background: #f7f7f8; border-radius: 14px; height: 520px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; border: 1px solid var(--gris-borde);
}
/* [FIX MODAL-IMG] width/height:100% para que el marco no dependa del tamaño real
   de la foto ni de cuándo termina de cargar. */
.modal-main img { width: 100%; height: 100%; object-fit: contain; padding: 16px; }
.modal-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,0.92); border: 1px solid var(--gris-borde);
  color: var(--gris-oscuro); cursor: pointer;
  align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  transition: background 0.15s ease, transform 0.12s ease; z-index: 2;
}
.modal-nav:hover { background: #fff; }
.modal-nav:active { transform: translateY(-50%) scale(0.94); }
.modal-nav.prev { left: 10px; }
.modal-nav.next { right: 10px; }
.modal-thumbs {
  display: flex; flex-direction: row; gap: 8px;
  overflow-x: auto; padding-bottom: 4px; scrollbar-width: thin;
}
.modal-thumb {
  flex: 0 0 66px; width: 66px; height: 66px;
  background: #f7f7f8; border-radius: 9px; overflow: hidden; cursor: pointer;
  border: 2px solid var(--gris-borde); transition: border-color 0.15s ease;
}
.modal-thumb:hover, .modal-thumb.active { border-color: var(--amarillo); }
.modal-thumb img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
/* =================== FIN [PASO 3 / F1-4] GALERÍA DEL MODAL =================== */
.modal-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.mfield label { font-size: 10px; color: var(--gris-muted); text-transform: uppercase; letter-spacing: 1px; display: block; margin-bottom: 3px; font-weight: 700; }
.mfield p { font-size: 14px; color: var(--negro); font-weight: 600; }
.modal-desc { margin-bottom: 14px; padding: 12px; background: var(--gris-fondo); border-radius: 8px; font-size: 13px; color: var(--gris-texto); line-height: 1.6; }
.mlabel { font-size: 10px; color: var(--gris-muted); text-transform: uppercase; letter-spacing: 1px; font-weight: 700; margin-bottom: 7px; }
.modal-techs { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 14px; }
.modal-tech { display: flex; align-items: center; gap: 5px; background: var(--gris-fondo); padding: 4px 10px; border-radius: 20px; font-size: 11px; color: var(--gris-texto); border: 1px solid var(--gris-borde); font-weight: 600; }
.modal-tech img { width: 15px; height: 15px; border-radius: 3px; }

.modal-variants-grid { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.variant-row {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px; border-radius: 8px;
  background: var(--gris-fondo); border: 1.5px solid var(--gris-borde);
  cursor: pointer; transition: border-color 0.15s;
}
.variant-row:hover, .variant-row.active { border-color: var(--amarillo); background: #fffde7; }
.variant-color-dot { width: 22px; height: 22px; border-radius: 50%; border: 2px solid rgba(0,0,0,0.1); flex-shrink: 0; }
.variant-info { flex: 1; }
.variant-name { font-size: 12px; font-weight: 700; color: var(--gris-oscuro); }
.variant-sku { font-size: 10px; color: var(--gris-muted); font-weight: 500; }
.variant-stock { font-size: 12px; font-weight: 700; text-align: right; }
.vs-ok { color: #2e7d32; }
.vs-low { color: #f57f17; }
.vs-out { color: #c62828; }

.modal-wpp { width: 100%; padding: 13px; background: var(--verde-wpp); color: white; border: none; border-radius: 10px; font-size: 14px; font-weight: 800; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; font-family: 'BoosterNext FY', sans-serif; text-transform: uppercase; letter-spacing: 0.5px; }
.modal-wpp:hover { background: #1ebe5d; }

.empty-state { grid-column: 1/-1; text-align: center; padding: 60px 20px; color: var(--gris-muted); }
.empty-state h3 { font-size: 18px; margin-bottom: 6px; font-weight: 600; }

/* [BLOQUE 1] Footer retirado por ahora (se rediseña en la próxima tanda).
   Las reglas .footer / .footer span se eliminaron junto con el elemento. */

/* ===================== [PRECIOS] PASO 2 + PASO 3 ===================== */
/* Precio en la TARJETA */
.card-price-wrap { margin-top: 1px; }
.price-line { line-height: 1.15; }
.card-price {
  font-size: 19px; font-weight: 900; color: var(--gris-oscuro);
  line-height: 1.15;
}
.card-price .price-iva {
  font-size: 9px; font-weight: 700; color: var(--gris-muted);
  text-transform: uppercase; letter-spacing: 0.5px; margin-left: 3px;
}
.card-price-consultar {
  font-size: 14px; font-weight: 800; color: var(--amarillo-dark);
  text-transform: uppercase; letter-spacing: 0.3px;
}
/* Toggle sutil "ver con IVA" (tarjeta y modal) */
.price-iva-toggle {
  display: inline-block; margin-top: 3px;
  background: none; border: none; padding: 0;
  color: var(--gris-muted); font-family: 'BoosterNext FY', sans-serif;
  font-size: 10.5px; font-weight: 600; cursor: pointer;
  text-decoration: underline; text-underline-offset: 2px;
  transition: color 0.15s ease;
}
.price-iva-toggle:hover { color: var(--amarillo-dark); }
.price-tapa {
  font-size: 10.5px; color: var(--gris-texto); font-weight: 600;
  margin-top: 4px; line-height: 1.3;
}

/* Precio en el MODAL */
.modal-price-box {
  margin: 0 0 18px; padding: 16px 18px;
  background: #fffdf3; border: 1.5px solid var(--amarillo);
  border-radius: 14px;
}
.modal-price { font-size: 28px; font-weight: 900; color: var(--gris-oscuro); line-height: 1.05; }
.modal-price .price-iva {
  font-size: 12px; font-weight: 700; color: var(--gris-muted);
  text-transform: uppercase; letter-spacing: 0.5px; margin-left: 6px;
}
.modal-price-consultar {
  font-size: 20px; font-weight: 800; color: var(--amarillo-dark);
  text-transform: uppercase; letter-spacing: 0.3px;
}
.modal-iva-toggle { margin-top: 8px; font-size: 12px; }
.modal-price-tapa {
  font-size: 12px; color: var(--gris-texto); font-weight: 600;
  margin-top: 9px; line-height: 1.4;
}
/* Línea legal: SOLO en el modal, una vez (no se repite en las tarjetas). */
.modal-price-legal {
  font-size: 11px; color: var(--gris-muted); font-weight: 500;
  margin-top: 11px; padding-top: 10px; line-height: 1.45;
  border-top: 1px dashed rgba(61,67,84,0.18);
}

/* Etiqueta Botella/Tapa (variedad real) en la fila de variante del modal */
.variant-variedad {
  font-size: 10px; color: var(--amarillo-dark); font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.5px; margin-top: 1px;
}
/* =================== FIN [PRECIOS] PASO 2 + PASO 3 =================== */

/* ===================== [BLOQUE 7] ÚLTIMA ACTUALIZACIÓN ===================== */
/* Cada producto muestra cuándo se re-trajo por última vez. El puntito de color
   indica la frescura: verde (<24 h), ámbar (24-72 h), gris (>72 h o sin dato). */

/* En la TARJETA: línea discreta debajo de la categoría. */
.card-updated {
  display: flex; align-items: center; gap: 6px;
  font-size: 10.5px; font-weight: 600; color: var(--gris-muted);
  line-height: 1.3; margin-top: 1px;
}
.upd-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gris-muted); flex-shrink: 0;
}
.upd-fresh   { color: #2e7d32; }
.upd-fresh   .upd-dot { background: #2e7d32; }
.upd-aging   { color: #b8860b; }
.upd-aging   .upd-dot { background: #f5a623; }
.upd-stale   { color: #c62828; }
.upd-stale   .upd-dot { background: #c62828; }
.upd-unknown { color: var(--gris-muted); }
.upd-unknown .upd-dot { background: var(--gris-borde); }

/* En el MODAL: dentro de la caja del precio, antes del mensaje del asesor. */
.modal-updated {
  display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
  font-size: 12.5px; font-weight: 700; color: var(--gris-oscuro);
  margin-top: 11px; line-height: 1.4;
}
.modal-updated .upd-dot { width: 9px; height: 9px; }
.modal-updated.upd-fresh { color: #2e7d32; }
.modal-updated.upd-aging { color: #b8860b; }
.modal-updated.upd-stale { color: #c62828; }
.modal-updated.upd-unknown { color: var(--gris-muted); }
.modal-updated-abs { color: var(--gris-muted); font-weight: 500; font-size: 11.5px; }

/* Mensaje del asesor en el modal (debajo de la fecha). */
.modal-asesor {
  font-size: 12px; font-weight: 700; color: var(--gris-oscuro);
  background: #fffaf0; border: 1px solid var(--amarillo);
  border-radius: 9px; padding: 8px 11px; margin-top: 9px; line-height: 1.4;
}
/* =================== FIN [BLOQUE 7] ÚLTIMA ACTUALIZACIÓN =================== */

@media(max-width:600px) {
  .header, .toolbar, .grid, .stats-bar, .pagination { padding-left: 14px; padding-right: 14px; }
  /* [BLOQUE 1] Header compacto en móvil. */
  .header { padding-top: 10px; padding-bottom: 10px; }
  .header-tagline { display: none; }
  .header-h1 { font-size: 17px; }
  .header-sub { display: none; }
  .btn-wpp-hero { padding: 10px 16px; font-size: 13px; }
  /* [PASO 3] Tarjeta en móvil: dos columnas cómodas, imagen y aire proporcionales. */
  .grid { grid-template-columns: repeat(auto-fill, minmax(158px, 1fr)); gap: 14px; padding-top: 16px; padding-bottom: 16px; }
  .card-img-wrap, .no-img { height: 178px; margin: 10px 10px 0; }
  .card-body { padding: 12px 13px 4px; gap: 6px; }
  .card-footer { padding: 8px 13px 14px; }
  .card-name { font-size: 13px; min-height: 34px; }
  .card-price { font-size: 17px; }
  .btn-ver { padding: 10px 10px; }
  /* [BLOQUE 7] La fecha se mantiene legible y compacta en móvil. */
  .card-updated { font-size: 10px; }
}

/* [PASO 3 — MODAL 2 COLUMNAS] En pantallas medianas/chicas las dos columnas se
   apilan (imagen arriba, info abajo) y la imagen baja de alto. */
@media(max-width:760px) {
  .modal-grid { grid-template-columns: 1fr; gap: 16px; }
  .modal-main { height: 360px; }
}
@media(max-width:600px) {
  .modal-overlay { padding: 10px; }
  .modal-body { padding: 16px 16px; }
  .modal-main { height: 260px; }
}
