/* ============================================================================
   Komfy PDP — estilos del rediseño del detalle de producto.
   Cubre: above the fold (gallery + buybox), descripción, "por dentro",
   specs, combos/cross-sell, sticky bar.
   El modal de Medios de pago vive en komfy-payments.css aparte.
   ============================================================================ */

/* ============================================================================
   Helpers locales del PDP — scopeados a contenedores .pdp-* para no chocar
   con clases globales del theme (footer, header).
============================================================================ */
.pdp-top .strike,
.pdp-buy .strike,
.pdp-combo-total .strike { text-decoration: line-through; color: var(--komfy-muted, #6B6B6B); }

.pdp-top .muted,
.pdp-buy .muted,
.pdp-combo-total .muted { color: var(--komfy-muted, #6B6B6B); }

.pdp-buy .caption,
.pdp-combo-total .caption,
.pdp-sticky .caption { font-size: 12px; line-height: 1.4; color: var(--komfy-muted, #6B6B6B); }

/* Eyebrow — pequeño label azul uppercase en cabezales de secciones del PDP */
.pdp-buy .eyebrow,
.pdp-section-head .eyebrow,
.pdp-desc .eyebrow,
.pdp-dimensions .eyebrow {
  font-family: var(--font-body, 'Noto Sans', sans-serif);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 12px;
  color: var(--komfy-blue, #0047BB);
  display: block;
}

/* Komfy underline (subrayado amarillo) en títulos de sección del PDP.
   Footer usa otra variante (border-bottom solido) — la nuestra es ::after
   con barra detrás del texto. Scopeo para no pisar la del footer. */
.pdp-section-head .komfy-underline,
.pdp-desc-title .komfy-underline,
.pdp-dimensions .komfy-underline {
  position: relative;
  display: inline-block;
}
.pdp-section-head .komfy-underline::after,
.pdp-desc-title .komfy-underline::after,
.pdp-dimensions .komfy-underline::after {
  content: '';
  position: absolute;
  left: 4%; right: 4%;
  bottom: -2%;
  height: 14%;
  background: var(--komfy-yellow, #F5C518);
  border-radius: 2px;
  z-index: -1;
}

/* Display heading sizes — usadas dentro de .pdp-section-head y .pdp-buy */
.pdp-buy .display-md,
.pdp-section-head .display-md,
.pdp-desc-title {
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--komfy-carbon, #1C1C1C);
  line-height: 1.02;
  margin: 0;
  font-size: clamp(28px, 3vw, 44px);
}

/* Pill genérico + variante descuento (verde Komfy de la card del listing) */
.pdp-title-row .pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 999px;
  background: var(--komfy-bg-soft, #FBF8F2);
  border: 1px solid var(--komfy-line, #E8E2D6);
  font-size: 13px; font-weight: 500;
}
.pdp-title-row .pill-discount {
  background: #d9f5e1;
  border-color: #a8e0b9;
  color: #1f8a3d;
  font-weight: 700;
}

/* Botón primary del CTA (azul Komfy). Se reusa el de la card si existiese.
   También aplicamos al sticky bar (desktop y mobile) para que quede pill. */
.pdp-buy .btn,
.pdp-combo-total .btn,
.pdp-sticky .btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 22px; border-radius: 999px;
  font-family: var(--font-body, 'Noto Sans', sans-serif);
  font-weight: 600; font-size: 15px;
  transition: transform .15s, background .2s, color .2s;
  white-space: nowrap;
  cursor: pointer; border: 0;
}
.pdp-buy .btn-primary,
.pdp-sticky .btn-primary {
  background: var(--komfy-blue, #0047BB); color: #fff;
}
.pdp-buy .btn-primary:hover,
.pdp-sticky .btn-primary:hover {
  background: var(--komfy-blue-700, #003a99);
  transform: translateY(-1px);
}
.pdp-buy .btn-block { width: 100%; }
.pdp-buy .btn-lg { padding: 18px 28px; font-size: 16px; }

/* Anchor offset para que el header sticky no tape el inicio de la sección
   cuando se scrollea desde el sticky nav. */
.pdp-section[id] { scroll-margin-top: 130px; }

/* ============================================================================
   PDP top — layout above the fold (gallery + buybox)
============================================================================ */
.pdp-top {
  display: grid; grid-template-columns: 1.55fr 1fr; gap: 56px;
  padding: 24px 24px 64px;
  max-width: 1440px;
  margin: 0 auto;
}

/* Gallery — sticky en desktop para que la imagen siga en viewport mientras se
   scrollea el BuyBox. Mantiene su tamaño 1:1 natural. La altura de la columna
   de thumbs matchea la altura de la imagen principal (alto del row del grid),
   y los thumbs cuadrados que no entren se scrollean con flechitas. */
.pdp-gallery {
  display: grid; grid-template-columns: 88px 1fr; gap: 16px;
  position: sticky; top: 130px;
  align-self: flex-start;
  /* align-items: stretch (default) para que la columna izquierda matchee
     la altura del stage 1:1 a la derecha. */
}
/* Wrapper de los thumbs — el JS le sincroniza el max-height al .pdp-thumbs
   interno (= altura del stage - flechas), así el wrapper se sizea natural a su
   contenido sin nunca superar la altura de la imagen principal. */
.pdp-thumbs-wrap {
  display: flex; flex-direction: column;
  gap: 6px;
  align-items: stretch;
  min-height: 0;
}
.pdp-thumbs-arrow {
  background: rgba(255,255,255,.95);
  border: 1px solid var(--komfy-line, #E8E2D6);
  border-radius: 50%;
  width: 32px; height: 32px;
  flex-shrink: 0;
  align-self: center;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: var(--komfy-carbon, #1C1C1C);
  transition: background .15s, border-color .15s, opacity .15s;
}
.pdp-thumbs-arrow:hover { background: #fff; border-color: var(--komfy-carbon, #1C1C1C); }
.pdp-thumbs-arrow.is-disabled { opacity: .3; pointer-events: none; }
.pdp-thumbs {
  display: flex; flex-direction: column; gap: 8px;
  /* flex:1 + min-height:0 → ocupa toda la altura disponible entre las flechas,
     que a su vez matchea la altura de la imagen principal (1:1). El número de
     thumbs visibles depende del viewport; el resto scrollea. */
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  scrollbar-width: none;
}
.pdp-thumbs::-webkit-scrollbar { display: none; }
.pdp-thumb {
  /* Cada thumb es CUADRADO (1:1) basado en el ancho de la columna (88px).
     flex-shrink:0 evita que el flex container los achique cuando hay muchos. */
  aspect-ratio: 1/1;
  flex-shrink: 0;
  padding: 0; border-radius: 10px; overflow: hidden;
  border: 2px solid transparent;
  transition: border-color .15s;
  background: none; cursor: pointer;
}
.pdp-thumb.is-active { border-color: var(--komfy-carbon, #1C1C1C); }
.pdp-thumb img,
.pdp-thumb video {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.pdp-stage { position: relative; }
.pdp-stage-media {
  aspect-ratio: 1/1;
  border-radius: 28px;
  position: relative;
  background: var(--komfy-bg-soft, #FBF8F2);
  /* Track scrolleable horizontal con scroll-snap. En desktop solo se navega
     con click en thumbs (que hace scrollIntoView); en mobile se swipea con
     el dedo. El layout de cada slide es flex: 0 0 100% — siempre se ve
     uno solo a la vez. overflow-x: auto + border-radius clipean correctamente
     en browsers modernos. */
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.pdp-stage-media::-webkit-scrollbar { display: none; }
.pdp-stage-slide {
  flex: 0 0 100%;
  width: 100%;
  aspect-ratio: 1/1;
  scroll-snap-align: center;
  scroll-snap-stop: always;
  position: relative;
}
.pdp-stage-media img,
.pdp-stage-media video {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

/* Botón fullscreen — solo mobile (en desktop la imagen ya se ve grande) */
.pdp-stage-fullscreen {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.85);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  border: 0; padding: 0; cursor: pointer;
  display: none; /* visible solo en mobile */
  align-items: center; justify-content: center;
  color: var(--komfy-carbon, #1C1C1C);
  z-index: 4;
  transition: background .15s, transform .15s;
}
.pdp-stage-fullscreen:hover { background: #fff; transform: scale(1.05); }

/* Progress bar — mismo patrón que .kh-ugc-progress (home shorts).
   Solo visible en mobile, abajo del stage. */
.pdp-stage-progress {
  display: none; /* visible solo en mobile */
  margin: 12px auto 0;
  max-width: 220px;
}
.pdp-stage-progress-track {
  height: 4px; background: #e5e5e5; border-radius: 999px;
  position: relative; overflow: hidden;
}
.pdp-stage-progress-bar {
  position: absolute; top: 0; height: 100%;
  background: var(--komfy-yellow, #F5C518);
  border-radius: 999px;
  left: 0; width: 0;
  transition: left .15s ease-out, width .15s ease-out;
}
.pdp-video-controls {
  display: flex; gap: 8px;
  position: absolute; bottom: 16px; right: 16px;
}
.pdp-vc {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.15); color: #fff;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  border: 0; cursor: pointer;
}
.pdp-vc:hover { background: rgba(255,255,255,.25); }
.pdp-badges {
  position: absolute; top: 16px; left: 16px;
  display: flex; flex-direction: column; gap: 6px;
  align-items: flex-start;
}
.pdp-badges .pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 999px;
  font-size: 13px; font-weight: 500;
}
.pdp-badges .pill-yellow { background: #FFE99A; border: 1px solid var(--komfy-yellow, #F5C518); color: var(--komfy-carbon, #1C1C1C); }
.pdp-badges .pill-discount { background: #d9f5e1; border: 1px solid #a8e0b9; color: #1f8a3d; font-weight: 700; }
.pdp-counter {
  position: absolute; bottom: 16px; left: 16px;
  padding: 6px 12px;
  background: rgba(28,28,28,.7); color: #fff;
  border-radius: 999px;
  font-size: 12px;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
}

/* Buy box */
.pdp-buy { padding: 8px 0 0; }
.pdp-title-row {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 12px; margin-top: 8px;
}
.pdp-title-row h1 { margin: 0; }

.pdp-rating {
    display: inline-flex;
    gap: 6px;
    align-items: center;
    margin-top: 10px;
    font-size: 14px;
    color: inherit;
    text-decoration: none;
}
.pdp-rating:hover .pdp-rating-count { text-decoration: underline; }
.pdp-stars { display: flex; gap: 2px; }
.pdp-rating-count { color: var(--komfy-muted, #6B6B6B); }

/* Cada SVG estrella tiene DOS paths superpuestos: .pdp-star-filled (sólido)
   y .pdp-star-empty (outline). El JS le agrega .is-filled o .is-empty al SVG
   según el rating promedio real. Por default mostramos las "vacías". */
.pdp-rating .pdp-stars .pdp-star .pdp-star-filled { display: none; }
.pdp-rating .pdp-stars .pdp-star .pdp-star-empty { display: block; stroke: var(--komfy-line-strong, #D8D0BF); }

/* Estrella filled (las primeras N según avgRating) → solo se ve el path sólido en negro. */
.pdp-rating.has-reviews .pdp-stars .pdp-star.is-filled .pdp-star-filled {
    display: block;
    fill: var(--komfy-carbon, #1C1C1C);
}
.pdp-rating.has-reviews .pdp-stars .pdp-star.is-filled .pdp-star-empty { display: none; }

/* Estrella empty (las restantes 5-N) → solo se ve el outline en negro tenue. */
.pdp-rating.has-reviews .pdp-stars .pdp-star.is-empty .pdp-star-filled { display: none; }
.pdp-rating.has-reviews .pdp-stars .pdp-star.is-empty .pdp-star-empty {
    display: block;
    stroke: var(--komfy-carbon, #1C1C1C);
}
.pdp-sku { margin-top: 8px; font-size: 13px; color: var(--komfy-muted, #6B6B6B); letter-spacing: .02em; }

.pdp-price { margin-top: 0; }
.pdp-price-main { display: flex; gap: 14px; align-items: baseline; flex-wrap: wrap; }
.pdp-price-from { font-size: 14px; color: var(--komfy-muted, #6B6B6B); font-weight: 500; }
.pdp-price-strike { font-size: 18px; }
.pdp-price-now {
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-size: 56px; font-weight: 700;
  color: var(--komfy-carbon, #1C1C1C);
  line-height: 1;
}
.pdp-price-disclaimer { margin-top: 6px; font-size: 13px; color: var(--komfy-muted, #6B6B6B); line-height: 1.4; }
/* Transferencia: precio en bold, "con Transferencia" en regular, color carbon */
.pdp-price-transfer { font-size: 14px; color: var(--komfy-carbon, #1C1C1C); margin-top: 10px; font-weight: 500; }
.pdp-price-transfer strong { font-weight: 700; }
/* Cuotas: TODO en verde Komfy (igual que la card del listing) */
.pdp-price-cuotas { font-size: 14px; color: #1f8a4d; margin-top: 6px; font-weight: 500; }
.pdp-price-cuotas,
.pdp-price-cuotas * { color: #1f8a4d; }
.pdp-price-cuotas strong,
.pdp-price-cuotas .js-installment-amount,
.pdp-price-cuotas .js-installment-price { font-weight: 700; }
.pdp-price-detail {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; color: var(--komfy-carbon, #1C1C1C);
  margin-top: 12px;
  text-decoration: underline; text-underline-offset: 3px;
  cursor: pointer;
}
.pdp-price-detail:hover { color: var(--komfy-blue, #0047BB); }

/* Sin descuento: ocultar pill y precio strike */
.pdp-buy.no-discount .pdp-title-row .pill-discount,
.pdp-buy.no-discount .pdp-price-strike { display: none; }

/* Variantes (Color/Tapizado/Melamina) */
.pdp-opt {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--komfy-line, #E8E2D6);
}
.pdp-opt-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px;
}
.pdp-opt-label { font-size: 14px; color: var(--komfy-muted, #6B6B6B); }
.pdp-opt-label strong { color: var(--komfy-carbon, #1C1C1C); font-weight: 700; }
.pdp-opt-help {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 13px; color: var(--komfy-blue, #0047BB); font-weight: 600;
  text-decoration: none;
}

.pdp-swatches { display: flex; gap: 8px; flex-wrap: wrap; }
.pdp-sw {
  width: 44px; height: 44px;
  border-radius: 50%;
  padding: 3px;
  border: 2px solid transparent;
  background: #fff;
  transition: border-color .15s;
  cursor: pointer;
}
.pdp-sw span {
  display: block; width: 100%; height: 100%;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,.08);
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}
.pdp-sw.is-on { border-color: var(--komfy-carbon, #1C1C1C); }
.pdp-sw.is-disabled { opacity: .35; cursor: not-allowed; }

/* Cantidad + CTA */
.pdp-cta-row { display: flex; gap: 10px; margin-top: 32px; align-items: stretch; }
/* Forzamos al CTA a hacer flex:1 (no width:100%) para que quede AL LADO del
   qty stepper, no abajo. La clase btn-block de TN setea width:100% que
   destrozaba el layout flex. */
.pdp-cta-row .js-addtocart,
.pdp-cta-row input[type="submit"],
.pdp-cta-row button[type="submit"] {
  flex: 1 1 auto;
  width: auto !important;
}

/* TN cuando hacés click en .js-addtocart oculta el botón y muestra un
   placeholder con "Agregando..." durante el AJAX. El placeholder vuelve a
   esconderse después de ~2s y el botón vuelve. Este "flash" es feo — lo
   ocultamos para que el botón no se mueva durante el flow de add-to-cart. */
.pdp-cta-row .js-addtocart-placeholder,
.pdp-buy .js-addtocart-placeholder,
.pdp-sticky .js-addtocart-placeholder { display: none !important; }
.pdp-cta-row input.js-addtocart:not(.js-addtocart-placeholder),
.pdp-cta-row button.js-addtocart:not(.js-addtocart-placeholder),
.pdp-buy input.js-addtocart:not(.js-addtocart-placeholder),
.pdp-buy button.js-addtocart:not(.js-addtocart-placeholder) {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Alertas de TN dentro del BuyBox (ej. "No hay más stock", "Variante no
   disponible"). TN las inyecta dinámicamente al lado del botón. Las sacamos
   del flex y las hacemos full-width DEBAJO del CTA, con look Komfy. */
.pdp-buy .alert,
.pdp-buy .alert-warning,
.pdp-buy [class*="js-stock"],
.pdp-buy .js-product-form-action-message,
.pdp-buy .js-product-form-stock-availability {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 8px 0 0 !important;
  padding: 14px 16px !important;
  background: #FFF8E1 !important;
  border: 1px solid #F5C518 !important;
  border-radius: 14px !important;
  color: var(--komfy-carbon, #1C1C1C) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  width: 100%;
  /* Si vive dentro del flex .pdp-cta-row, la fuerzo abajo del row */
  order: 100;
  flex: 0 0 100%;
}
/* Ícono de warning antes del texto */
.pdp-buy .alert::before,
.pdp-buy .alert-warning::before {
  content: '';
  flex-shrink: 0;
  width: 20px; height: 20px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231C1C1C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'/%3E%3Cline x1='12' y1='9' x2='12' y2='13'/%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}
/* Si TN inyecta el alert dentro de pdp-cta-row, le permitimos hacer wrap solo
   para ese caso. */
.pdp-cta-row:has(.alert),
.pdp-cta-row:has(.alert-warning),
.pdp-cta-row:has([class*="js-stock"]) { flex-wrap: wrap; }
.pdp-qty {
  display: flex; align-items: center; gap: 12px;
  padding: 0 12px;
  border: 1.5px solid var(--komfy-line, #E8E2D6);
  border-radius: 999px;
  background: #fff;
}
.pdp-qty button {
  padding: 14px 8px;
  background: none; border: 0; cursor: pointer;
  color: var(--komfy-carbon, #1C1C1C);
}
.pdp-qty span,
.pdp-qty input {
  font-weight: 600; min-width: 18px; text-align: center;
  border: 0; background: transparent;
  width: 32px;
  font-family: inherit; font-size: inherit;
}
.pdp-qty input:focus { outline: none; }

/* Bloque delivery (envío / showroom / armado) */
.pdp-delivery {
  margin-top: 32px;
  padding: 20px;
  background: var(--komfy-bg-soft, #FBF8F2);
  border-radius: 20px;
  display: flex; flex-direction: column; gap: 14px;
}
.pdp-delivery-row {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: 14px;
}
.pdp-delivery-row svg { color: var(--komfy-blue, #0047BB); flex-shrink: 0; margin-top: 2px; }
.pdp-delivery-row strong { font-weight: 700; }

/* Card descarga instructivo PDF */
.kf-manual { display: none !important; }
.pdp-pdf[hidden] { display: none !important; }
.pdp-pdf {
  margin: 24px 0;
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px;
  background: #fff;
  border: 1.5px solid var(--komfy-line, #E8E4DE);
  border-radius: var(--r-lg, 16px);
  text-decoration: none;
  transition: border-color .15s, background .15s, transform .15s;
}
.pdp-pdf:hover { border-color: var(--komfy-blue, #0047BB); background: var(--komfy-blue-50, #EBF0FF); transform: translateY(-1px); }
.pdp-pdf-icon {
  width: 44px; height: 44px;
  border-radius: 10px;
  background: var(--komfy-blue-50, #EBF0FF);
  color: var(--komfy-blue, #0047BB);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.pdp-pdf:hover .pdp-pdf-icon { background: var(--komfy-blue, #0047BB); color: #fff; }
.pdp-pdf-body { flex: 1; min-width: 0; }
.pdp-pdf-title { font-weight: 600; font-size: 15px; color: var(--komfy-carbon, #1A1A1A); line-height: 1.2; }
.pdp-pdf-sub { font-size: 12.5px; color: var(--komfy-muted, #8C8578); margin-top: 3px; line-height: 1.2; }
.pdp-pdf-arrow {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--komfy-bg-soft, #FBF8F2);
  color: var(--komfy-carbon, #1A1A1A);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.pdp-pdf:hover .pdp-pdf-arrow { background: var(--komfy-carbon, #1A1A1A); color: #fff; }

/* Card plano con medidas — reutiliza .pdp-pdf pero es un <button> */
.pdp-plano {
  background: transparent;
  font-family: inherit;
  text-align: left;
  width: 100%;
  cursor: pointer;
}
/* Cuando el plano aparece justo después de un instructivo visible, achicar gap */
.pdp-pdf:not([hidden]) + .pdp-plano { margin-top: 0; }
.pdp-plano[hidden] { display: none !important; }

/* ===== PLANO MODAL ===== */
.plano-scrim {
  position: fixed; inset: 0;
  background: rgba(20,20,20,0.62);
  z-index: 10000;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: planoIn .18s ease;
}
.plano-scrim[hidden] { display: none !important; }
.plano-modal {
  background: #fff;
  border-radius: 18px;
  max-width: 980px; width: 100%;
  max-height: 92vh;
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.32);
  animation: planoPop .25s cubic-bezier(.2,.9,.4,1.1);
}
@keyframes planoIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes planoPop { from { opacity: 0; transform: scale(.96) translateY(8px); } to { opacity: 1; transform: scale(1) translateY(0); } }

.plano-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px;
  border-bottom: 1px solid var(--komfy-line, #E8E4DE);
}
.plano-eyebrow {
  font-size: 10.5px; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--komfy-blue, #0047BB);
}
.plano-title {
  margin: 4px 0 0;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 24px; font-weight: 600;
  color: var(--komfy-carbon, #1A1A1A);
  letter-spacing: .005em;
}
.plano-close {
  width: 36px; height: 36px;
  border: none; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--komfy-carbon, #1A1A1A);
  background: transparent;
  cursor: pointer;
  flex-shrink: 0;
}
.plano-close:hover { background: var(--komfy-chalk, #F5F0E8); }

.plano-canvas {
  flex: 1;
  background:
    linear-gradient(rgba(0,71,187,.06) 1px, transparent 1px) 0 0 / 20px 20px,
    linear-gradient(90deg, rgba(0,71,187,.06) 1px, transparent 1px) 0 0 / 20px 20px,
    linear-gradient(rgba(0,71,187,.12) 1px, transparent 1px) 0 0 / 100px 100px,
    linear-gradient(90deg, rgba(0,71,187,.12) 1px, transparent 1px) 0 0 / 100px 100px,
    #FBF8F2;
  padding: 28px 32px;
  overflow: auto;
  display: flex; align-items: center; justify-content: center;
}
.plano-img {
  max-width: 100%; max-height: 70vh;
  display: block;
  border-radius: 6px;
  box-shadow: 0 4px 24px rgba(0,0,0,.10);
}

@media (max-width: 720px) {
  .plano-scrim { padding: 12px; }
  .plano-modal { max-height: 96vh; }
  .plano-head { padding: 14px 18px; }
  .plano-title { font-size: 20px; }
  .plano-canvas { padding: 18px; }
  .plano-img { max-height: 60vh; }
}

/* Mobile — todo a 1 columna */
@media (max-width: 1100px) {
  .pdp-top { grid-template-columns: 1fr; gap: 32px; padding: 16px 16px 48px; }
  .pdp-gallery { position: static; grid-template-columns: 1fr; }
  .pdp-thumbs-wrap { flex-direction: row; align-items: center; gap: 8px; }
  .pdp-thumbs {
    flex-direction: row;
    overflow-x: auto;
    overflow-y: hidden;
    max-height: none;
    order: 2;
    flex: 1;
  }
  .pdp-thumb { min-width: 64px; }
  .pdp-stage { order: 1; }
  /* En tablet/mobile las flechas ya no van — escondidas */
  .pdp-thumbs-arrow { display: none; }
  /* Precio mismo tamaño que el título (display-md → 28px en mobile, hasta
     ~38px en tablet). Strike y "Desde" proporcionalmente más chicos. */
  .pdp-price-now { font-size: clamp(28px, 3vw, 40px); line-height: 1.02; }
  .pdp-price-strike { font-size: 15px; }
  .pdp-price-from { font-size: 13px; }
  .pdp-pdf { padding: 14px; margin: 10px 0 0; }
  .pdp-pdf:not([hidden]) + .pdp-plano { margin-top: 8px; }
  .pdp-pdf-icon { width: 40px; height: 40px; }
  .pdp-pdf-title { font-size: 14px; }
  .pdp-pdf-sub { font-size: 11.5px; }
  .pdp-pdf-arrow { width: 32px; height: 32px; }
}
@media (max-width: 768px) {
  /* Galería: thumbs out, swipe nativo en el stage, progress bar visible,
     botón fullscreen visible. Ver komfy-pdp-top.tpl para el JS. */
  .pdp-thumbs-wrap { display: none !important; }
  .pdp-thumbs { display: none !important; }
  .pdp-stage-fullscreen { display: flex; }
  /* Progress bar pegado al estilo de home shorts pero más visible.
     order:2 + .pdp-stage order:1 → el progress queda abajo del stage en
     el grid de .pdp-gallery (sino renderea arriba porque el default es 0). */
  .pdp-stage { order: 1 !important; }
  .pdp-stage-progress {
    order: 2 !important;
    display: block !important;
    margin: 14px auto 0 !important;
    max-width: 220px;
    padding: 0 4px;
  }
  .pdp-stage-progress-track {
    height: 5px !important;
    background: #E8E2D6 !important;
  }
  .pdp-stage-progress-bar {
    min-width: 24px;
    background: var(--komfy-yellow, #F5C518) !important;
  }
  /* En mobile la imagen arranca pegadita al header — sin margen extra.
     !important para que ningún rule de TN nativo agregue padding-top. */
  .pdp-top { padding: 0 12px 32px !important; gap: 16px !important; margin-top: 0 !important; }
  .pdp-stage-media { border-radius: 18px; }
  /* Precio pegado al rating en mobile (con SKU oculto desde admin, no
     hay nada entre las estrellas y el precio — antes había 12px de aire
     que quedaba como un agujero). */
  .pdp-price { margin-top: 0; }
  /* WhatsApp flotante: oculto solo en PDP mobile (otras páginas y desktop sin tocar) */
  body.template-product .btn-whatsapp.js-btn-fixed-bottom { display: none !important; }
}

/* ============================================================================
   Descripción
============================================================================ */
.pdp-desc {
  max-width: 1440px;
  margin: 0 auto;
  padding: 64px 24px 24px;
}
.pdp-desc .eyebrow { margin-bottom: 12px; }
.pdp-desc-title {
  font-size: clamp(28px, 3vw, 40px);
  margin-bottom: 22px;
  max-width: 720px;
}
/* Bloques ocultos que el admin embebe en product.description para que el JS
   los parsee y renderee en sus secciones (Specs / "Por dentro"). Se ocultan
   para que no aparezcan como texto crudo en la descripción visible. */
.kpdp-specs,
.kpdp-inside,
.pdp-desc-body .kpdp-specs,
.pdp-desc-body .kpdp-inside { display: none !important; }

.pdp-desc-body {
  font-size: 16px;
  line-height: 1.65;
  color: var(--komfy-ink, #2A2A2A);
  max-width: 880px;
}
.pdp-desc-body p { margin: 0 0 20px; }
.pdp-desc-body p strong { color: var(--komfy-carbon, #1C1C1C); font-weight: 700; }
/* Subtítulos h3/h4 dentro del cuerpo de descripción — Barlow Condensed */
.pdp-desc-body h2,
.pdp-desc-body h3,
.pdp-desc-body h4 {
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-size: 22px; font-weight: 600;
  color: var(--komfy-carbon, #1C1C1C);
  margin: 28px 0 14px;
  line-height: 1.2;
}
/* Listas dentro de la descripción — bullets cuadrados verdes con tilde blanca */
.pdp-desc-body ul {
  list-style: none; padding: 0; margin: 0 0 20px;
  display: grid; gap: 10px;
}
.pdp-desc-body ul li {
  padding-left: 28px; position: relative;
  font-size: 15.5px; line-height: 1.55;
  color: var(--komfy-ink, #2A2A2A);
}
.pdp-desc-body ul li::before {
  content: ''; position: absolute; left: 0; top: 6px;
  width: 16px; height: 16px;
  background: #1f8a4d;
  border-radius: 4px;
}
.pdp-desc-body ul li::after {
  content: ''; position: absolute; left: 4px; top: 10px;
  width: 7px; height: 4px;
  border-left: 2px solid #fff; border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
}
@media (max-width: 900px) {
  .pdp-desc { padding: 32px 16px 8px; }
  .pdp-desc-body { font-size: 15px; }
}

/* ============================================================================
   "Por dentro" — sección beige tiza con cards de materiales
============================================================================ */
.pdp-inside {
  background: var(--komfy-tiza, #FAF0E6);
  padding: 56px 0 96px;
  margin-top: 40px;
}
.pdp-inside-container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 24px;
}
.pdp-section-head { max-width: 760px; margin-bottom: 32px; }
.pdp-section-head .eyebrow { margin-bottom: 12px; }
.pdp-section-head .display-md { font-size: clamp(28px, 3vw, 44px); }
.pdp-section-head p {
  margin: 14px 0 0;
  font-size: 15px; line-height: 1.55;
  max-width: 680px;
  color: var(--komfy-muted, #6B6B6B);
}
.pdp-inside-list { display: grid; gap: 14px; }
.pdp-inside-row {
  background: #fff;
  border: 1px solid var(--komfy-line, #E8E2D6);
  border-radius: 28px;
  padding: 28px 32px;
  display: grid; grid-template-columns: minmax(280px, 1fr) 1.6fr;
  gap: 40px; align-items: center;
}
.pdp-inside-eyebrow {
  font-family: var(--font-body, 'Noto Sans', sans-serif);
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--komfy-blue, #0047BB);
  margin-bottom: 8px;
}
.pdp-inside-title {
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-size: 22px; font-weight: 600;
  line-height: 1.2; margin: 0;
  color: var(--komfy-carbon, #1C1C1C);
}
.pdp-inside-facts {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin: 0;
  padding: 0 0 0 24px;
  border-left: 1px solid var(--komfy-line, #E8E2D6);
}
.pdp-inside-fact dt {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--komfy-muted, #6B6B6B);
  margin-bottom: 4px;
}
.pdp-inside-fact dd {
  margin: 0; font-size: 14.5px; font-weight: 500;
  line-height: 1.4; color: var(--komfy-carbon, #1C1C1C);
}
@media (max-width: 900px) {
  .pdp-inside { padding: 32px 0 64px; margin-top: 32px; }
  .pdp-inside-row { grid-template-columns: 1fr; padding: 20px; gap: 16px; }
  .pdp-inside-facts {
    grid-template-columns: 1fr; gap: 12px;
    padding: 16px 0 0; border-left: none;
    border-top: 1px solid var(--komfy-line, #E8E2D6);
  }
  .pdp-inside-fact { display: flex; justify-content: space-between; gap: 12px; }
  .pdp-inside-fact dt { margin-bottom: 0; }
  .pdp-inside-fact dd { text-align: right; }
}

/* ============================================================================
   Reseñas — sección donde JS relocaliza el widget de Avala
============================================================================ */
.pdp-reviews {
  padding: 56px 0 64px;
  margin-top: 40px;
  background: #fff;
}
.pdp-reviews-container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 24px;
}
.pdp-reviews-slot {
  margin-top: 16px;
}
/* Override GLOBAL sobre todas las estrellas de Avala en el sitio.

   Avala las pinta de naranja (#FFA400) en varios sitios:
     - Listing de categorías (cards).
     - Debajo del título del PDP (rating compact).
     - Sumario "X Reseña(s)" arriba del bloque reseñas.
     - Cada reseña individual.

   Usamos CSS `filter` para convertirlas a negro, independiente de cómo
   Avala aplique el color (puede ser `style.color` inline, `fill` en SVG,
   o herencia). `grayscale(100%) brightness(0)` mata cualquier saturación
   y forza negro puro. La diferenciación filled/vacía se mantiene porque
   viene de la FORMA del SVG (sólido vs outline), no del color.

   Fuente: heredada del tema. */
.avala-star,
.avala-star *,
.avala-rating-stars,
.avala-rating-stars *,
.avala-summary-stars,
.avala-summary-stars *,
.avala-review-stars,
.avala-review-stars *,
.stars.avala-review-stars,
.stars.avala-review-stars *,
[class*="avala-stars"],
[class*="avala-stars"] * {
  filter: grayscale(100%) brightness(0) !important;
}

/* Widget sumario "X Reseña" de Avala — usa <ul class="star-row">
   <li class="rating-icon"><svg fill="#FFA400">...</svg></li>.
   Bug de Avala: siempre pinta 5 estrellas llenas idénticas (no diferencia
   filled vs empty según avgRating). Fix: pisar el fill SVG attribute con
   CSS (gana porque !important + descendant selector), y el JS de
   komfy-pdp-reviews agrega `.is-empty` a las li que sobrepasen el rating. */
.pdp-reviews .star-row .rating-icon svg,
.pdp-reviews .star-row .rating-icon svg path {
  fill: var(--komfy-carbon, #1C1C1C) !important;
  stroke: var(--komfy-carbon, #1C1C1C) !important;
}
.pdp-reviews .star-row .rating-icon.is-empty svg,
.pdp-reviews .star-row .rating-icon.is-empty svg path {
  fill: transparent !important;
  stroke: var(--komfy-line-strong, #D8D0BF) !important;
  stroke-width: 1.5 !important;
}
[class*="avala-"],
[class*="avala-"] * {
  font-family: inherit !important;
}
/* Tamaño solo dentro del PDP (no listing) */
.pdp-section .avala-star,
.pdp-section .avala-star .icon,
.pdp-buy .avala-star,
.pdp-buy .avala-star .icon {
  font-size: 14px !important;
}
.pdp-section .avala-star svg,
.pdp-buy .avala-star svg {
  width: 14px !important;
  height: 14px !important;
}
@media (max-width: 900px) {
  .pdp-reviews { padding: 32px 0 48px; margin-top: 32px; }
}

/* Loader visible mientras Avala carga su widget. 3 dots con bounce animation. */
.pdp-reviews-loading {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    padding: 60px 24px;
    min-height: 120px;
}
.pdp-reviews-loading-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--komfy-line-strong, #D8D0BF);
    animation: pdpReviewsDot 1.2s ease-in-out infinite;
}
.pdp-reviews-loading-dot:nth-child(2) { animation-delay: 0.15s; }
.pdp-reviews-loading-dot:nth-child(3) { animation-delay: 0.3s; }
@keyframes pdpReviewsDot {
    0%, 80%, 100% { transform: scale(0.8); opacity: 0.4; }
    40%           { transform: scale(1.2); opacity: 1; }
}

/* Cleanup: Avala inyecta su widget nativo en #reviewsapp o crea contenedores
   sueltos. Lo ocultamos con propiedades múltiples para que no se pueda
   destapar aunque Avala pise display vía JS. */
#reviewsapp {
  position: fixed !important;
  left: -9999px !important;
  top: -9999px !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
  visibility: hidden !important;
}
body > .avala-container,
body > [class*="avala-reviews"]:not(.pdp-reviews):not(.pdp-reviews-slot):not(.pdp-rating):not(.pdp-rating-slot),
body > [class*="customers-reviews"],
body > [id*="avala-reviews"],
body > [id*="customers-reviews"] { display: none !important; }

/* ============================================================================
   Specs — ficha técnica con tabs + bloque WhatsApp
============================================================================ */
.pdp-specs {
  max-width: 1440px;
  margin: 0 auto;
  padding: 64px 24px 96px;
}
.pdp-specs .pdp-section-head { margin-bottom: 28px; }
.pdp-specs-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.pdp-specs-tab {
  padding: 10px 20px; border-radius: 999px;
  background: #fff;
  border: 1px solid var(--komfy-line, #E8E2D6);
  font-weight: 600; font-size: 14px;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
  color: var(--komfy-carbon, #1C1C1C);
  font-family: inherit;
}
.pdp-specs-tab:hover { border-color: var(--komfy-carbon, #1C1C1C); }
.pdp-specs-tab.is-on {
  background: var(--komfy-carbon, #1C1C1C);
  color: #fff;
  border-color: var(--komfy-carbon, #1C1C1C);
}

.pdp-specs-cards { margin-bottom: 48px; }
.pdp-specs-card {
  background: #fff;
  border: 1px solid var(--komfy-line, #E8E2D6);
  border-radius: 20px;
  padding: 32px;
  display: none;
}
.pdp-specs-card.is-on { display: block; }
.pdp-specs-card-title {
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-size: 22px; font-weight: 600;
  color: var(--komfy-carbon, #1C1C1C);
  margin-bottom: 20px; padding-bottom: 16px;
  border-bottom: 1px solid var(--komfy-line, #E8E2D6);
}
.pdp-specs-rows { margin: 0; padding: 0; }
.pdp-spec-row {
  display: flex; justify-content: space-between;
  padding: 14px 0;
  border-bottom: 1px dashed var(--komfy-line, #E8E2D6);
  font-size: 15px;
}
.pdp-spec-row:last-child { border-bottom: none; }
.pdp-spec-row dt { color: var(--komfy-muted, #6B6B6B); margin: 0; }
.pdp-spec-row dd { margin: 0; font-weight: 600; text-align: right; color: var(--komfy-carbon, #1C1C1C); }

/* Bloque azul WhatsApp */
.pdp-dimensions {
  background: var(--komfy-blue, #0047BB);
  color: #fff;
  border-radius: 28px;
  padding: 56px 48px;
  text-align: center;
}
.pdp-dimensions-inner { max-width: 560px; margin: 0 auto; }
.pdp-dimensions .eyebrow { color: var(--komfy-yellow, #F5C518); margin-bottom: 12px; }
.pdp-dimensions h3 {
  color: #fff;
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-weight: 600;
  font-size: clamp(24px, 2.4vw, 32px);
  margin: 0; line-height: 1.15;
}
.pdp-dimensions p {
  color: rgba(255,255,255,.85);
  font-size: 15px; line-height: 1.55;
  margin: 14px 0 0;
}
.btn-wa-komfy {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--komfy-yellow, #F5C518); color: var(--komfy-carbon, #1C1C1C);
  border: none; padding: 14px 28px; border-radius: 999px;
  font-weight: 600; font-size: 15px;
  text-decoration: none; cursor: pointer;
  transition: transform .15s, background .15s;
  margin-top: 22px;
}
.btn-wa-komfy:hover { background: #ffd23a; transform: translateY(-1px); color: var(--komfy-carbon, #1C1C1C); }

@media (max-width: 900px) {
  .pdp-specs { padding: 32px 16px 48px; }
  .pdp-specs-card { padding: 22px; }
  .pdp-dimensions { padding: 36px 24px; }
}

/* ============================================================================
   Combos / Cross-sell
============================================================================ */
.pdp-combos {
  max-width: 1440px;
  margin: 0 auto;
  padding: 64px 24px;
}
.pdp-combos .pdp-section-head { margin-bottom: 32px; }
.pdp-combo-grid {
  display: grid;
  grid-template-columns: 1.3fr auto 1.4fr 1fr;
  gap: 24px;
  align-items: stretch;
}
.pdp-combo-main {
  position: relative;
  background: #fff;
  border: 1px solid var(--komfy-line, #E8E2D6);
  border-radius: 20px;
  overflow: hidden;
}
.pdp-combo-main-img {
  aspect-ratio: 4/3;
  background: var(--komfy-bg-soft, #FBF8F2);
  display: block; width: 100%;
  object-fit: cover;
}
.pdp-combo-main-info { padding: 16px 18px; }
.pdp-combo-main-name { font-weight: 600; font-size: 15px; color: var(--komfy-carbon, #1C1C1C); }
.pdp-combo-main-price {
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-size: 22px; font-weight: 700;
  color: var(--komfy-carbon, #1C1C1C);
  margin-top: 4px;
}
.pdp-combo-tag {
  position: absolute; top: 12px; left: 12px;
  background: var(--komfy-yellow, #F5C518);
  padding: 5px 11px;
  border-radius: 999px;
  font-size: 11px; font-weight: 700;
  color: var(--komfy-carbon, #1C1C1C);
}
.pdp-combo-plus {
  align-self: center;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--komfy-bg-soft, #FBF8F2);
  border: 1px solid var(--komfy-line, #E8E2D6);
  display: flex; align-items: center; justify-content: center;
  color: var(--komfy-muted, #6B6B6B);
}
.pdp-combo-extras { display: flex; flex-direction: column; gap: 10px; }
.pdp-combo-extra {
  display: grid; grid-template-columns: 64px 1fr auto;
  gap: 14px; align-items: center;
  padding: 12px;
  border: 1.5px solid var(--komfy-line, #E8E2D6);
  border-radius: 12px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
  background: #fff;
  position: relative;
}
.pdp-combo-extra:hover { border-color: var(--komfy-line-strong, #D8D0BF); }
.pdp-combo-extra.is-on { border-color: var(--komfy-blue, #0047BB); background: var(--komfy-blue-50, #e8efff); }
.pdp-combo-extra input { position: absolute; opacity: 0; pointer-events: none; }
.pdp-combo-extra-img {
  aspect-ratio: 1/1; width: 64px;
  border-radius: 8px;
  background: var(--komfy-bg-soft, #FBF8F2);
  object-fit: cover;
  display: block;
}
.pdp-combo-extra-name { font-weight: 600; font-size: 14px; color: var(--komfy-carbon, #1C1C1C); }
.pdp-combo-extra-price { font-size: 13px; color: var(--komfy-muted, #6B6B6B); margin-top: 2px; }
.pdp-combo-check {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--komfy-line, #E8E2D6);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: #fff;
  transition: background .15s, border-color .15s;
}
.pdp-combo-check svg { opacity: 0; transition: opacity .15s; }
.pdp-combo-extra.is-on .pdp-combo-check {
  background: var(--komfy-blue, #0047BB);
  border-color: var(--komfy-blue, #0047BB);
}
.pdp-combo-extra.is-on .pdp-combo-check svg { opacity: 1; }
.pdp-combo-total {
  background: var(--komfy-carbon, #1C1C1C);
  color: #fff;
  border-radius: 20px;
  padding: 24px;
  display: flex; flex-direction: column; gap: 16px;
  justify-content: space-between;
}
.pdp-combo-total .caption { color: rgba(255,255,255,.6); font-size: 12px; }
.pdp-combo-total-price {
  display: flex; flex-direction: column; gap: 2px; margin-top: 4px;
}
.pdp-combo-total-amount {
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-size: 32px; font-weight: 700;
  color: var(--komfy-yellow, #F5C518);
  line-height: 1;
}
.pdp-combo-total-cuotas { color: rgba(255,255,255,.7); font-size: 12px; margin-top: 6px; }
.pdp-combo-total .btn {
  background: var(--komfy-yellow, #F5C518);
  color: var(--komfy-carbon, #1C1C1C);
  font-weight: 700;
}
.pdp-combo-total .btn:hover { background: #ffd23a; }

@media (max-width: 1100px) {
  .pdp-combo-grid { grid-template-columns: 1fr; }
  .pdp-combo-plus { display: none; }
}
@media (max-width: 900px) {
  .pdp-combos { padding: 32px 16px; }
}

/* ============================================================================
   Cross-sell (NUEVO diseño card blanca, vive dentro del BuyBox column)
   El #combos antiguo arriba queda como legacy si alguna vez se necesita
   restaurar la versión bundle, pero hoy no se renderea (komfy-pdp-combos.tpl
   genera markup .pdp-cs-* en vez de .pdp-combo-*).

   IMPORTANTE: TN renderea su sección nativa #complementary-products ("Para
   comprar con este producto") en otro lado del template, abajo del PDP.
   Ya no la queremos porque tenemos nuestro cross-sell custom dentro del
   BuyBox. Lo escondemos. #complementary-products es el id natural de TN. */
#complementary-products,
.js-complementary-products,
.section-products-related.js-complementary-products { display: none !important; }

.pdp-cross-sell { margin-top: 32px; }
.pdp-cs-head { margin-bottom: 14px; }
.pdp-cs-head .eyebrow {
  font-family: var(--font-body, 'Noto Sans', sans-serif);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 12px;
  color: var(--komfy-blue, #0047BB);
  display: block;
  margin-bottom: 6px;
}
.pdp-cs-title {
  font-family: var(--font-display, 'Barlow Condensed'), sans-serif;
  font-weight: 700;
  font-size: 22px;
  color: var(--komfy-carbon, #1C1C1C);
  line-height: 1.1;
}

.pdp-cs-list { display: flex; flex-direction: column; gap: 12px; }
.pdp-cs-card {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  align-items: center;
  background: #fff;
  border: 1px solid #EFEEE8;
  border-radius: 14px;
  padding: 12px 12px 12px 12px;
  padding-right: 44px;
  position: relative;
  transition: border-color .15s, box-shadow .15s;
}
.pdp-cs-card:hover { border-color: var(--komfy-line-strong, #D8D0BF); }

.pdp-cs-img {
  width: 110px; height: 110px;
  border-radius: 10px;
  background: var(--komfy-bg-soft, #FBF8F2);
  object-fit: cover;
  flex-shrink: 0;
  display: block;
}

.pdp-cs-info {
  min-width: 0;
  display: flex; flex-direction: column;
  gap: 2px;
}
.pdp-cs-name {
  font-weight: 700;
  font-size: 15px;
  color: var(--komfy-carbon, #1C1C1C);
  text-decoration: none;
  line-height: 1.2;
}
.pdp-cs-name:hover { color: var(--komfy-blue, #0047BB); }
.pdp-cs-price {
  font-size: 14px;
  font-weight: 600;
  color: var(--komfy-carbon, #1C1C1C);
  margin-top: 2px;
}
.pdp-cs-cuotas { font-size: 13px; color: #1f8a4d; font-weight: 500; }
.pdp-cs-cuotas,
.pdp-cs-cuotas * { color: #1f8a4d; }

/* Dropdowns del cross-sell: chips redondeados tipo "Color: Negro ▼" — pure
   <select> styled como pill. Al cambiar dispara image swap del cp. */
.pdp-cs-opts {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 8px;
}
.pdp-cs-opt {
  position: relative;
  display: inline-flex; align-items: center;
}
.pdp-cs-select {
  appearance: none; -webkit-appearance: none;
  background: #fff;
  border: 1px solid var(--komfy-line, #E8E2D6);
  border-radius: 999px;
  padding: 6px 28px 6px 12px;
  font-size: 12px;
  font-family: inherit;
  color: var(--komfy-carbon, #1C1C1C);
  cursor: pointer;
  font-weight: 500;
  line-height: 1.3;
}
.pdp-cs-select:hover { border-color: var(--komfy-line-strong, #D8D0BF); }
.pdp-cs-select:focus,
.pdp-cs-select:active {
  outline: none;
  border-color: var(--komfy-blue, #0047BB);
}
.pdp-cs-chev {
  position: absolute; right: 10px; top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--komfy-muted, #6B6B6B);
}

/* Botón [+] en la esquina superior-derecha de la card: círculo con borde,
   fondo transparente, solo el ícono adentro. Cuando se agrega (.is-added),
   el borde y el ícono se vuelven verde con check. */
.pdp-cs-add {
  position: absolute;
  top: 10px; right: 10px;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: transparent;
  border: 1.5px solid var(--komfy-carbon, #1C1C1C);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: var(--komfy-carbon, #1C1C1C);
  transition: color .15s, border-color .15s, background .15s;
  padding: 0;
}
.pdp-cs-add:hover {
  color: var(--komfy-blue, #0047BB);
  border-color: var(--komfy-blue, #0047BB);
}
.pdp-cs-check-icon { display: none; }
.pdp-cs-card.is-added .pdp-cs-add {
  color: #1f8a4d;
  border-color: #1f8a4d;
}
.pdp-cs-card.is-added .pdp-cs-add-icon { display: none; }
.pdp-cs-card.is-added .pdp-cs-check-icon { display: block; }

@media (max-width: 600px) {
  .pdp-cs-card { grid-template-columns: 90px 1fr; padding: 10px; padding-right: 38px; }
  .pdp-cs-img { width: 90px; height: 90px; }
  .pdp-cs-name { font-size: 14px; }
}

/* ============================================================================
   Sticky bar — barra inferior con thumb + nav anchors + precio + CTA
============================================================================ */
.pdp-sticky {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 40;
  background: #fff;
  border-top: 1px solid var(--komfy-line, #E8E2D6);
  box-shadow: 0 -10px 30px rgba(0,0,0,.06);
  transform: translateY(100%);
  transition: transform .3s ease;
}
.pdp-sticky.is-visible { transform: translateY(0); }
.pdp-sticky-inner {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 24px;
  padding: 14px 24px;
  max-width: 1440px;
  margin: 0 auto;
}
.pdp-sticky-product {
  display: flex; gap: 12px; align-items: center; min-width: 0;
}
.pdp-sticky-img {
  aspect-ratio: 1/1; width: 48px;
  border-radius: 8px;
  flex-shrink: 0;
  object-fit: cover;
  background: var(--komfy-bg-soft, #FBF8F2);
}
.pdp-sticky-product > div:last-child { min-width: 0; }
.pdp-sticky-title {
  font-weight: 600; font-size: 15px;
  color: var(--komfy-carbon, #1C1C1C);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pdp-sticky-meta {
  font-size: 12.5px;
  color: var(--komfy-muted, #6B6B6B);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pdp-sticky-nav { display: flex; gap: 24px; justify-content: center; }
.pdp-sticky-nav a {
  font-size: 14px; font-weight: 500;
  color: var(--komfy-carbon, #1C1C1C);
  padding: 6px 0;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
  text-decoration: none;
}
.pdp-sticky-nav a:hover { color: var(--komfy-blue, #0047BB); }
.pdp-sticky-nav a.is-active {
  color: var(--komfy-blue, #0047BB);
  border-bottom-color: var(--komfy-blue, #0047BB);
}
.pdp-sticky-cta {
  display: flex; gap: 16px; align-items: center; justify-content: flex-end;
}
.pdp-sticky-pricecol { text-align: right; }
.pdp-sticky-price {
  font-weight: 700; font-size: 18px; line-height: 1.1;
  color: var(--komfy-carbon, #1C1C1C);
}
.pdp-sticky-cuotas {
  font-size: 12px; color: #1f8a4d;
  margin-top: 2px; font-weight: 500;
}

@media (max-width: 900px) {
  .pdp-sticky-nav { display: none; }
  .pdp-sticky-inner {
    grid-template-columns: 1fr auto;
    padding: 10px 14px;
    gap: 12px;
  }
  .pdp-sticky-img { width: 40px; }
  .pdp-sticky-cta .btn { padding: 10px 14px; font-size: 13px; }
  .pdp-sticky-cta { gap: 8px; }
}

/* ============================================================================
   Lightbox — fullscreen overlay para ver la imagen del PDP en grande.
   Se abre tocando el botón fullscreen del stage en mobile. Tapa todo: header,
   sticky bar, WhatsApp flotante, banner cuotas. Solo se ve la imagen + el X.
   El track interno usa scroll-snap para swipear entre imágenes; pinch-zoom
   es nativo del browser sobre el <img> con touch-action: pinch-zoom.
============================================================================ */
.pdp-lightbox {
  position: fixed; inset: 0;
  /* Z-index > header (.kh tiene 99999 !important) — sino el menu se ve sobre
     la imagen fullscreen. El sticky bar también queda debajo del lightbox. */
  z-index: 999999;
  background: #000;
  display: none;
  flex-direction: column;
}
.pdp-lightbox.is-open { display: flex; }
/* Body lock — clase específica del lightbox para no afectar otros modales
   (cart, kadd) que usan kf-modal-open con sus propios estilos. */
body.pdp-lightbox-open { overflow: hidden; }

.pdp-lightbox-close {
  position: absolute; top: max(16px, env(safe-area-inset-top, 0px));
  right: 16px;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border: 0; padding: 0; cursor: pointer;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  transition: background .15s, transform .15s;
}
.pdp-lightbox-close:hover { background: rgba(255,255,255,.25); transform: scale(1.05); }

.pdp-lightbox-track {
  flex: 1;
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.pdp-lightbox-track::-webkit-scrollbar { display: none; }
.pdp-lightbox-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  scroll-snap-align: center;
  scroll-snap-stop: always;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  box-sizing: border-box;
}
.pdp-lightbox-slide img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  touch-action: pinch-zoom;
  user-select: none;
  -webkit-user-drag: none;
}
