/* ============================================================
 * Smile V2 — Product detail page (PrestaShop port of Claude handoff)
 * Source: design_handoff/02_styles_full.css §Product detail (lines 1190-1469) verbatim
 * PS adapters at the bottom.
 * ============================================================ */

/* === Handoff canonical (verbatim) ====================================== */
.pdp { padding: 32px 0 80px; }
.pdp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
@media (max-width: 960px) { .pdp-grid { grid-template-columns: 1fr; gap: 32px; } }

.gallery { display: grid; grid-template-columns: 80px 1fr; gap: 14px; }
.gallery-thumbs { display: flex; flex-direction: column; gap: 10px; padding: 0; margin: 0; list-style: none; }
.gallery-thumbs button {
  aspect-ratio: 3/4;
  border-radius: 6px;
  overflow: hidden;
  background: var(--line-2);
  border: 1.5px solid transparent;
  position: relative;
  cursor: pointer;
  padding: 0;
}
.gallery-thumbs button.on { border-color: var(--ink); }
.gallery-thumbs button img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gallery-main {
  aspect-ratio: 3/4;
  border-radius: var(--r-md);
  background: var(--line-2);
  overflow: hidden;
  position: relative;
}
.gallery-main img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.4s var(--ease);
  display: block;
}
.gallery-main.zoomed img { transform: scale(1.6); cursor: zoom-out; }
.gallery-main:not(.zoomed) img { cursor: zoom-in; }
@media (max-width: 720px) {
  .gallery { grid-template-columns: 1fr; }
  .gallery-thumbs { flex-direction: row; order: 2; overflow-x: auto; }
  .gallery-thumbs button { width: 64px; flex-shrink: 0; }
}

.pdp-info h1 {
  font-family: var(--f-display);
  font-size: clamp(28px, 3.2vw, 38px);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin-bottom: 12px;
  color: var(--ink);
  line-height: 1.1;
}
.pdp-price {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 12px;
  font-family: var(--f-body);
}
.pdp-price .cur { font-size: 26px; font-weight: 500; color: var(--ink); font-variant-numeric: tabular-nums; }
.pdp-price .old { font-size: 16px; color: var(--ink-3); text-decoration: line-through; }
.pdp-price .pct {
  background: var(--burgundy);
  color: #fff;
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 4px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.pdp-rating {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--ink-2);
  margin-bottom: 28px;
}
.pdp-rating .stars { color: var(--champagne); display: inline-flex; gap: 1px; }
.pdp-rating a { border-bottom: 1px solid currentColor; }

.pdp-block { padding: 18px 0; border-bottom: 1px solid var(--line); }
.pdp-block .lbl {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.pdp-block .lbl small { font-weight: 400; color: var(--ink-2); text-transform: none; letter-spacing: 0.01em; }
.pdp-block .lbl .link { color: var(--burgundy); cursor: pointer; border-bottom: 1px solid currentColor; padding-bottom: 1px; text-transform: none; letter-spacing: 0; font-weight: 500; }

.color-pick { display: flex; gap: 10px; flex-wrap: wrap; }
.color-pick .sw {
  width: 32px; height: 32px;
  border-radius: 50%;
  cursor: pointer;
  border: 1px solid rgba(43,40,38,0.12);
  transition: transform 0.15s;
  position: relative;
  display: inline-block;
}
.color-pick .sw:hover { transform: scale(1.08); }
.color-pick .sw.on { box-shadow: 0 0 0 1.5px var(--ink), 0 0 0 3.5px var(--bg); }

.size-pick { display: flex; gap: 8px; flex-wrap: wrap; }
.size-pick button {
  min-width: 52px;
  height: 44px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  font-size: 14px;
  font-weight: 500;
  transition: all 0.15s;
  cursor: pointer;
  color: var(--ink);
  font-family: var(--f-body);
}
.size-pick button:hover { border-color: var(--ink); }
.size-pick button.on { background: var(--ink); border-color: var(--ink); color: #fff; }
.size-pick button.out { color: var(--ink-3); position: relative; cursor: not-allowed; }
.size-pick button.out::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom right, transparent calc(50% - 1px), var(--ink-3) calc(50% - 1px), var(--ink-3) calc(50% + 1px), transparent calc(50% + 1px));
  opacity: 0.4;
}

.stock-ind {
  font-size: 13px;
  color: var(--ink-2);
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
}
.stock-ind .pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: #4CAF50;
  position: relative;
  flex-shrink: 0;
}
.stock-ind.low .pulse { background: var(--champagne); }
.stock-ind.out .pulse { background: var(--error, #C4302B); }
.stock-ind .pulse::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 1px solid currentColor;
  opacity: 0.4;
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0% { transform: scale(0.8); opacity: 0.6; }
  100% { transform: scale(1.6); opacity: 0; }
}

.pdp-actions {
  display: flex;
  gap: 10px;
  padding: 24px 0;
}
.pdp-actions .btn-primary { flex: 1; }

.trust-badges {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  padding: 16px 0;
  margin-bottom: 8px;
}
.trust-badges .tb {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
  padding: 12px;
  border-radius: 8px;
  background: var(--surface-2);
  font-size: 11px;
  color: var(--ink-2);
  line-height: 1.3;
}
.trust-badges .tb svg { color: var(--burgundy); }
.trust-badges .tb b { color: var(--ink); font-weight: 600; font-size: 12px; }

.accordion-item { border-bottom: 1px solid var(--line); }
.accordion-head {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 0;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--ink);
  font-family: var(--f-body);
}
.accordion-head .ic { transition: transform 0.2s; font-size: 18px; line-height: 1; }
.accordion-head.open .ic,
details[open] > summary .ic { transform: rotate(45deg); }
.accordion-body { display: none; padding: 0 0 20px; font-size: 14px; color: var(--ink-2); line-height: 1.65; }
.accordion-body.open { display: block; }
.accordion-body ul { padding-left: 18px; margin: 8px 0; }

/* Sticky mobile bottom CTA */
.sticky-cta { display: none; }
@media (max-width: 720px) {
  .sticky-cta {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: #fff;
    border-top: 1px solid var(--line);
    padding: 12px 16px;
    gap: 8px;
    z-index: 30;
    align-items: center;
  }
  .sticky-cta .price { font-weight: 600; flex-shrink: 0; font-variant-numeric: tabular-nums; }
  .sticky-cta .btn-primary { flex: 1; height: 44px; padding: 0 16px; font-size: 13px; }
  .sticky-cta .wa-circle {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: #25D366;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  body.has-sticky-cta { padding-bottom: 80px; }
}

/* Reviews */
.reviews { display: grid; grid-template-columns: 280px 1fr; gap: 56px; padding-top: 24px; }
.reviews-side .big { font-family: var(--f-display); font-size: 56px; font-weight: 500; line-height: 1; display: flex; align-items: baseline; gap: 4px; }
.reviews-side .big small { font-size: 18px; color: var(--ink-2); font-family: var(--f-body); font-weight: 400; }
.reviews-side .stars { color: var(--champagne); font-size: 16px; margin: 8px 0 4px; }
.reviews-side .count { font-size: 13px; color: var(--ink-2); margin-bottom: 24px; }
.reviews-side .bar-row { display: grid; grid-template-columns: 16px 1fr 28px; gap: 10px; align-items: center; font-size: 12px; color: var(--ink-2); margin-bottom: 6px; }
.reviews-side .bar { height: 4px; background: var(--line); border-radius: 4px; overflow: hidden; }
.reviews-side .bar i { display: block; height: 100%; background: var(--champagne); }
.reviews-list { display: flex; flex-direction: column; gap: 24px; }
.review { padding-bottom: 24px; border-bottom: 1px solid var(--line); }
.review .head { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.review .av { width: 36px; height: 36px; border-radius: 50%; background: var(--rose); color: var(--burgundy); display: inline-flex; align-items: center; justify-content: center; font-weight: 600; font-size: 13px; }
.review .nm { font-size: 14px; font-weight: 500; }
.review .meta { font-size: 12px; color: var(--ink-2); }
.review .stars { color: var(--champagne); font-size: 13px; }
.review p { margin: 6px 0 8px; font-size: 14px; line-height: 1.5; color: var(--ink); }
.review .tags { display: flex; gap: 6px; font-size: 11px; color: var(--ink-2); letter-spacing: 0.04em; }
@media (max-width: 860px) { .reviews { grid-template-columns: 1fr; gap: 24px; } }


/* ============================================================
 * PrestaShop adapters
 * Map BEM smile_v2 classes and PS native markup to handoff visual styles.
 * ============================================================ */

/* shell wrapper */
.pdp .shell { max-width: var(--max-w, 1280px); margin: 0 auto; padding: 0 24px; }

/* === Gallery: map .pdp-gallery (BEM) to handoff .gallery === */
.pdp-gallery {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 14px;
  align-items: start;
}
@media (max-width: 720px) {
  .pdp-gallery { grid-template-columns: 1fr; }
}

.pdp-gallery__thumbs {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0;
  margin: 0;
}
@media (max-width: 720px) {
  .pdp-gallery__thumbs { flex-direction: row; order: 2; overflow-x: auto; }
}

.pdp-gallery__thumb {
  width: 80px;
  aspect-ratio: 3/4;
  border-radius: 6px;
  overflow: hidden;
  background: var(--line-2);
  border: 1.5px solid transparent;
  cursor: pointer;
  padding: 0;
  display: block;
  position: relative;
  flex-shrink: 0;
}
@media (max-width: 720px) {
  .pdp-gallery__thumb { width: 64px; }
}
.pdp-gallery__thumb.is-active,
.pdp-gallery__thumb:hover { border-color: var(--ink); }
.pdp-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Main image: when it's a wrapper div */
.pdp-gallery__main:not(img) {
  aspect-ratio: 3/4;
  border-radius: var(--r-md);
  background: var(--line-2);
  overflow: hidden;
  position: relative;
}
.pdp-gallery__main:not(img) img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.4s var(--ease);
  display: block;
}
/* Main image: when img.pdp-gallery__main IS the image directly */
img.pdp-gallery__main {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--r-md);
  background: var(--line-2);
}
.pdp-gallery__main.is-zoomed img,
img.pdp-gallery__main.is-zoomed { transform: scale(1.6); cursor: zoom-out; }
.pdp-gallery__main:not(.is-zoomed) img,
img.pdp-gallery__main:not(.is-zoomed) { cursor: zoom-in; }

/* === PDP info adapters === */
.pdp-info { font-family: var(--f-body); color: var(--ink); }

/* Flags (Nuevo / Sale tags) */
.pdp-flags {
  display: flex;
  gap: 6px;
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
}
.pdp-flag {
  display: inline-block;
  padding: 4px 10px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 4px;
  background: var(--ink);
  color: #fff;
}
.pdp-flag--new { background: var(--burgundy); }
.pdp-flag--on-sale,
.pdp-flag--discount { background: var(--champagne); color: var(--ink); }

/* Lead / short description */
.pdp-lead {
  color: var(--ink-2);
  font-size: 14px;
  line-height: 1.6;
  margin: 0 0 20px;
}

/* Stock indicator */
.pdp-stock {
  font-size: 13px;
  color: var(--ink-2);
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 12px 0;
}
.pdp-stock .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.pdp-stock .dot.ok { background: #4CAF50; }
.pdp-stock .dot.low { background: var(--champagne); }
.pdp-stock .dot.out { background: var(--error, #C4302B); }

/* PDP accordions: map <details class="pdp-acc"> to handoff .accordion-item */
.pdp-acc {
  border-bottom: 1px solid var(--line);
}
.pdp-acc > summary {
  list-style: none;
  cursor: pointer;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 0;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  font-family: var(--f-body);
  color: var(--ink);
}
.pdp-acc > summary::-webkit-details-marker { display: none; }
.pdp-acc > summary::after {
  content: "+";
  font-size: 18px;
  line-height: 1;
  transition: transform 0.2s;
}
.pdp-acc[open] > summary::after { transform: rotate(45deg); }
.pdp-acc__body {
  padding: 0 0 20px;
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.65;
}
.pdp-acc__body ul { padding-left: 18px; margin: 8px 0; }

/* === PS product variants (color + size) === */
.product-variants { padding: 18px 0; border-bottom: 1px solid var(--line); }
.product-variants .product-variants-item { margin-bottom: 16px; }
.product-variants .product-variants-item:last-child { margin-bottom: 0; }
.product-variants .control-label {
  display: block;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 12px;
}

/* Size variant (uses <select>): convert to size-pick buttons via JS or style the select */
.product-variants select.form-control {
  height: 44px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 0 14px;
  font-size: 14px;
  background: #fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%232B2826' fill='none' stroke-width='1.5' stroke-linecap='round'/></svg>") no-repeat right 14px center;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 36px;
  width: 100%;
  max-width: 200px;
  color: var(--ink);
  font-family: var(--f-body);
  cursor: pointer;
}
.product-variants select:focus { outline: none; border-color: var(--ink); }

/* Color variants (ul > li.input-container with radio + .color swatch) */
.product-variants ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.product-variants ul .input-container { margin: 0; }
.product-variants ul .input-container label {
  display: inline-block;
  cursor: pointer;
  position: relative;
}
.product-variants ul .input-color {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.product-variants ul .input-container .color {
  display: block;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(43,40,38,0.12);
  cursor: pointer;
  transition: transform 0.15s;
}
.product-variants ul .input-container .color:hover { transform: scale(1.08); }
.product-variants ul .input-container .input-color:checked + .color {
  box-shadow: 0 0 0 1.5px var(--ink), 0 0 0 3.5px var(--bg);
}

/* Add-to-cart button (PS .btn.add-to-cart) */
.product-add-to-cart {
  padding: 24px 0;
  border-bottom: 1px solid var(--line);
}
.product-add-to-cart .add .add-to-cart,
.product-add-to-cart .btn.add-to-cart {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  height: 48px !important;
  padding: 0 32px !important;
  background: var(--ink) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 999px !important;
  font-family: var(--f-body) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  cursor: pointer !important;
  transition: transform 0.15s, background 0.15s, box-shadow 0.15s !important;
  width: auto !important;
  min-width: 200px !important;
  text-decoration: none !important;
}
.product-add-to-cart .add-to-cart:hover {
  transform: translateY(-1px) !important;
  background: var(--burgundy) !important;
  box-shadow: 0 4px 12px -4px rgba(0,0,0,0.2) !important;
}
.product-add-to-cart .add-to-cart:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Quantity input (PS Bootstrap touchspin) */
.product-quantity { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.product-quantity .control-label {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ink);
}
.product-quantity .qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  height: 36px;
  overflow: hidden;
  background: #fff;
}
.product-quantity .bootstrap-touchspin {
  border: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  display: inline-flex;
  align-items: center;
}
.product-quantity .input-group-addon,
.product-quantity .input-group-addon.bootstrap-touchspin-prefix,
.product-quantity .input-group-addon.bootstrap-touchspin-postfix { display: none !important; }
.product-quantity .input-group .form-control,
.product-quantity input#quantity_wanted {
  width: 44px !important;
  height: 36px !important;
  border: 0 !important;
  background: transparent !important;
  text-align: center !important;
  font-size: 14px !important;
  font-variant-numeric: tabular-nums !important;
  padding: 0 !important;
  box-shadow: none !important;
  color: var(--ink) !important;
}
.product-quantity .input-group-btn-vertical {
  display: inline-flex !important;
  flex-direction: row !important;
  order: -1;
}
.product-quantity .btn.btn-touchspin,
.product-quantity .js-touchspin {
  width: 36px !important;
  height: 36px !important;
  background: transparent !important;
  border: 0 !important;
  color: var(--ink-2) !important;
  padding: 0 !important;
  font-size: 16px !important;
  cursor: pointer !important;
  position: static !important;
}
.product-quantity .btn.btn-touchspin:hover:not(.is-disabled):not(:disabled) {
  color: var(--ink) !important;
  background: var(--bg) !important;
}
.product-quantity .btn.btn-touchspin.is-disabled {
  opacity: 0.3 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}
.product-quantity .btn.bootstrap-touchspin-up::before {
  content: "+";
  display: inline-block;
}
.product-quantity .btn.bootstrap-touchspin-down::before {
  content: "−";
  display: inline-block;
}
.product-quantity .btn.btn-touchspin .material-icons,
.product-quantity .btn.btn-touchspin i { display: none !important; }

/* Hide hooks/blocks that don't fit the Claude design */
.pdp .leo-list-product-reviews,
.pdp .leo-compare-wishlist-button,
.pdp .product-flags-list { display: none !important; }

/* ============================================================
 * 2026-05-27 — Cross-sell "Los clientes que adquirieron también compraron"
 * Bloque .featured-products en footer del PDP usando .smile-card markup.
 * Source: design_handoff_smile_responsive_qa
 * ============================================================ */

.featured-products {
  margin: 64px 0 24px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  clear: both !important;
}
.featured-products h2 {
  font-family: var(--f-display, "Playfair Display", Georgia, serif) !important;
  font-size: clamp(22px, 2.5vw, 28px) !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
  color: var(--ink, #2B2826) !important;
  margin: 0 0 24px !important;
  padding: 0 !important;
  text-transform: none !important;
  text-align: left !important;
  border: 0 !important;
}
.featured-products .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 24px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
@media (max-width: 1024px) {
  .featured-products .products { grid-template-columns: repeat(3, 1fr) !important; gap: 20px !important; }
}
@media (max-width: 720px) {
  .featured-products .products { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }
  .featured-products { margin: 40px 0 16px !important; }
}
@media (max-width: 400px) {
  .featured-products .products { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
}

/* .smile-card override dentro de featured-products (asegurar consistencia con category) */
.featured-products .smile-card {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}
.featured-products .smile-card__ph {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 3 / 4 !important;
  overflow: hidden !important;
  border-radius: 10px !important;
  background: var(--line-2, #F0E8DE) !important;
}
.featured-products .smile-card__img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform 0.4s var(--ease, ease) !important;
}
.featured-products .smile-card:hover .smile-card__img {
  transform: scale(1.04) !important;
}
.featured-products .smile-card__meta {
  padding: 0 2px !important;
}
.featured-products .smile-card__name {
  font-family: var(--f-body, Inter, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: 0.005em !important;
  color: var(--ink, #2B2826) !important;
  margin: 0 0 6px !important;
  line-height: 1.35 !important;
  text-transform: none !important;
}
.featured-products .smile-card__name a {
  color: inherit !important;
  text-decoration: none !important;
}
.featured-products .smile-card__name a:hover {
  color: var(--burgundy, #6B2C2C) !important;
}
.featured-products .smile-card__row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
}
.featured-products .smile-card__price {
  font-family: var(--f-body) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
  font-variant-numeric: tabular-nums !important;
}
.featured-products .smile-card__swatches {
  display: inline-flex !important;
  gap: 4px !important;
  align-items: center !important;
}
.featured-products .smile-card__sw {
  width: 12px !important;
  height: 12px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(43, 40, 38, 0.12) !important;
  display: inline-block !important;
  flex-shrink: 0 !important;
}

/* Wrapper page-footer-meta — sin estilos legacy */
.page-footer-meta {
  background: transparent !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}





/* ============================================================
 * Smile · Qty stepper (Claude Design canon)
 * Spec: design_handoff_smile_v2/COMPONENTS.md §qty-stepper
 *      + design_handoff_smile_prestashop/02_styles_full.css (.qty)
 *      + design_handoff_smile_responsive_qa (hit-target ≥44px mobile)
 *
 * Reemplaza Bootstrap touchspin con un componente nativo Claude Design.
 * Layout horizontal: [−] [input] [+] en pill rounded.
 *
 * Markup esperado:
 *   <div class="smile-qty" data-qty-stepper>
 *     <button class="smile-qty__btn" data-qty-dec><svg>−</svg></button>
 *     <input class="smile-qty__input" type="number" data-qty-input ...>
 *     <button class="smile-qty__btn" data-qty-inc><svg>+</svg></button>
 *   </div>
 * ============================================================ */

.smile-qty {
  display: inline-flex !important;
  align-items: stretch !important;
  border: 1px solid var(--line, #E8DFD6) !important;
  border-radius: 999px !important;
  background: #fff !important;
  height: 44px !important;
  overflow: hidden !important;
  width: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
}
@media (min-width: 960px) {
  .smile-qty { height: 40px !important; }
}

.smile-qty__btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 44px !important;
  height: 100% !important;
  min-width: 44px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: var(--ink-2, #6B6360) !important;
  cursor: pointer !important;
  border-radius: 0 !important;
  transition: background 0.15s var(--ease, ease), color 0.15s var(--ease, ease) !important;
  flex: 0 0 auto !important;
  position: relative !important;
}
@media (min-width: 960px) {
  .smile-qty__btn { width: 36px !important; min-width: 36px !important; }
}

.smile-qty__btn:hover:not(:disabled) {
  background: var(--surface-2, #FAF7F2) !important;
  color: var(--ink, #2B2826) !important;
}
.smile-qty__btn:active:not(:disabled) {
  background: var(--line-2, #F0E8DE) !important;
}
.smile-qty__btn:disabled {
  opacity: 0.3 !important;
  cursor: not-allowed !important;
}
.smile-qty__btn:focus-visible {
  outline: 2px solid var(--burgundy, #6B2C2C) !important;
  outline-offset: -2px !important;
  z-index: 1 !important;
}

.smile-qty__btn svg {
  display: block !important;
  width: 14px !important;
  height: 14px !important;
  pointer-events: none !important;
  stroke: currentColor !important;
}

.smile-qty__input {
  flex: 0 0 auto !important;
  width: 48px !important;
  height: 100% !important;
  border: 0 !important;
  border-left: 1px solid var(--line, #E8DFD6) !important;
  border-right: 1px solid var(--line, #E8DFD6) !important;
  background: #fff !important;
  text-align: center !important;
  font-family: var(--f-body, Inter, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--ink, #2B2826) !important;
  -webkit-text-fill-color: var(--ink, #2B2826) !important;
  font-variant-numeric: tabular-nums !important;
  padding: 0 !important;
  margin: 0 !important;
  outline: none !important;
  appearance: textfield !important;
  -moz-appearance: textfield !important;
  text-indent: 0 !important;
  visibility: visible !important;
  opacity: 1 !important;
  display: block !important;
}
.smile-qty__input::-webkit-outer-spin-button,
.smile-qty__input::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}
.smile-qty__input:focus {
  background: var(--surface-2, #FAF7F2) !important;
}

/* Cuando Bootstrap touchspin envuelve el input (antes de que JS lo destruya),
   ocultar los buttons vertical que touchspin añade para no duplicar UI */
.smile-qty .input-group-btn-vertical,
.smile-qty + .input-group-btn-vertical,
.input-group.bootstrap-touchspin > .input-group-btn-vertical {
  display: none !important;
}
.input-group.bootstrap-touchspin:not(.smile-qty) {
  /* Si quedó un wrapper touchspin sin smile-qty, no estilizar — solo asegurar invisible */
  display: contents !important;
}

/* ============================================================
 * Smile · Accordion (Claude Design canon)
 * Spec: design_handoff_smile_v2/COMPONENTS.md §accordion
 * Markup: <details class="smile-accordion__item"><summary class="smile-accordion__head">...</summary>...</details>
 * ============================================================ */

.smile-accordion {
  display: flex !important;
  flex-direction: column !important;
  margin: 32px 0 !important;
  border: 0 !important;
  padding: 0 !important;
}

.smile-accordion__item {
  border-top: 1px solid var(--line, #E8DFD6) !important;
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  list-style: none !important;
}
.smile-accordion__item:last-child {
  border-bottom: 1px solid var(--line, #E8DFD6) !important;
}

.smile-accordion__head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 16px !important;
  padding: 20px 0 !important;
  margin: 0 !important;
  cursor: pointer !important;
  list-style: none !important;
  font-family: var(--f-body, Inter, sans-serif) !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  letter-spacing: 0.005em !important;
  color: var(--ink, #2B2826) !important;
  text-transform: none !important;
  transition: color 0.18s var(--ease, ease) !important;
  user-select: none !important;
}
.smile-accordion__head::-webkit-details-marker,
.smile-accordion__head::marker {
  display: none !important;
  content: "" !important;
}
.smile-accordion__head:hover {
  color: var(--burgundy, #6B2C2C) !important;
}
.smile-accordion__head:focus-visible {
  outline: 2px solid var(--burgundy, #6B2C2C) !important;
  outline-offset: 4px !important;
}
.smile-accordion__head > span:first-child {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.smile-accordion__chevron {
  flex-shrink: 0 !important;
  transition: transform 0.22s var(--ease, ease) !important;
  color: var(--ink-2, #6B6360) !important;
}
.smile-accordion__item[open] > .smile-accordion__chevron,
.smile-accordion__item[open] > .smile-accordion__head .smile-accordion__chevron {
  transform: rotate(180deg) !important;
}

.smile-accordion__body {
  padding: 4px 0 24px !important;
  color: var(--ink-2, #6B6360) !important;
  font-family: var(--f-body, Inter, sans-serif) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  border: 0 !important;
}
.smile-accordion__body > * { color: inherit; }
.smile-accordion__body p { margin: 0 0 12px !important; line-height: 1.6 !important; }
.smile-accordion__body p:last-child { margin-bottom: 0 !important; }
.smile-accordion__body strong, .smile-accordion__body b { color: var(--ink, #2B2826) !important; font-weight: 600 !important; }

/* Data sheet (features) dentro de accordion body */
.smile-accordion__body .data-sheet {
  display: grid !important;
  grid-template-columns: max-content 1fr !important;
  gap: 6px 24px !important;
  margin: 8px 0 0 !important;
}
.smile-accordion__body .data-sheet dt {
  font-weight: 600 !important;
  color: var(--ink, #2B2826) !important;
  margin: 0 !important;
  font-size: 13px !important;
  text-transform: none !important;
}
.smile-accordion__body .data-sheet dd {
  margin: 0 !important;
  color: var(--ink-2, #6B6360) !important;
  font-size: 13px !important;
}

/* Product manufacturer / reference / condition pequeños */
.smile-accordion__body .product-manufacturer,
.smile-accordion__body .product-reference,
.smile-accordion__body .product-condition,
.smile-accordion__body .product-availability-date,
.smile-accordion__body .product-quantities {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
  padding: 6px 0 !important;
  font-size: 13px !important;
  margin: 0 !important;
}
.smile-accordion__body .label {
  font-weight: 500 !important;
  color: var(--ink-2) !important;
  margin: 0 !important;
  text-transform: none !important;
  font-size: 13px !important;
}

/* Attachment items */
.smile-accordion__body .attachments,
.smile-accordion__body .attachment {
  margin: 0 !important;
  padding: 0 !important;
}
.smile-accordion__body .attachment {
  padding: 12px 0 !important;
  border-bottom: 1px solid var(--line-2, #F0E8DE) !important;
}
.smile-accordion__body .attachment:last-child {
  border-bottom: 0 !important;
}
.smile-accordion__body .attachment h4 {
  margin: 0 0 4px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  font-family: var(--f-body) !important;
}
.smile-accordion__body .attachment h4 a,
.smile-accordion__body .smile-link {
  color: var(--burgundy, #6B2C2C) !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

/* Mobile: padding más compacto */
@media (max-width: 720px) {
  .smile-accordion { margin: 24px 0 !important; }
  .smile-accordion__head { padding: 16px 0 !important; font-size: 14px !important; }
  .smile-accordion__body { padding-bottom: 18px !important; font-size: 13px !important; }
}

/* ============================================================
 * Smile · Stock-indicator (Claude Design canon)
 * Spec: design_handoff_smile_v2/COMPONENTS.md §stock-indicator
 *
 * Markup canon:
 *   <div class="smile-stock-indicator smile-stock-indicator--in">
 *     <span class="smile-stock-indicator__dot"></span>
 *     <span>En stock</span>
 *   </div>
 *
 * Variants: --in (verde), --low (champagne), --out (rojo).
 * Pre-existing .pdp-stock en product.tpl recibe el mismo styling.
 * ============================================================ */
.smile-stock-indicator,
.pdp-stock {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
  background: var(--surface-2, #FAF7F2) !important;
  font-family: var(--f-body, Inter, sans-serif) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
  color: var(--ink, #2B2826) !important;
  line-height: 1 !important;
  margin: 0 !important;
  text-transform: none !important;
}
.smile-stock-indicator__dot,
.pdp-stock .dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: #5BA15C !important;
  display: inline-block !important;
  flex-shrink: 0 !important;
  position: relative !important;
}
.smile-stock-indicator--in .smile-stock-indicator__dot,
.pdp-stock .dot { background: #5BA15C !important; }
.smile-stock-indicator--low .smile-stock-indicator__dot,
.pdp-stock .dot.low { background: var(--champagne, #B8924F) !important; }
.smile-stock-indicator--out .smile-stock-indicator__dot,
.pdp-stock .dot.out { background: var(--burgundy, #6B2C2C) !important; }
.smile-stock-indicator--low::after,
.pdp-stock.is-low::after { content: ""; }
.smile-stock-indicator--in,
.pdp-stock.is-in,
.pdp-stock:not(.is-low):not(.is-out) {
  background: #E8F0E5 !important;
  color: #2E5C3F !important;
}
.smile-stock-indicator--low,
.pdp-stock.is-low {
  background: #FFF8E5 !important;
  color: #8a6914 !important;
}
.smile-stock-indicator--out,
.pdp-stock.is-out {
  background: #F5E0DE !important;
  color: var(--burgundy-deep, #501F1F) !important;
}

/* Si el pdp-stock dot tiene .low, asumir bg amber */
.pdp-stock:has(.dot.low) {
  background: #FFF8E5 !important;
  color: #8a6914 !important;
}
.pdp-stock:has(.dot.out) {
  background: #F5E0DE !important;
  color: var(--burgundy-deep, #501F1F) !important;
}

/* Dot pulse animation (low + out) */
@keyframes smile-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.4); opacity: 0.6; }
}
.smile-stock-indicator--low .smile-stock-indicator__dot,
.smile-stock-indicator--out .smile-stock-indicator__dot,
.pdp-stock .dot.low,
.pdp-stock .dot.out {
  animation: smile-pulse 1.8s ease-in-out infinite !important;
}
@media (prefers-reduced-motion: reduce) {
  .smile-stock-indicator__dot,
  .pdp-stock .dot {
    animation: none !important;
  }
}

/* ============================================================
 * Smile · Rating-stars (Claude Design canon)
 * Spec: design_handoff_smile_v2/COMPONENTS.md §rating-stars
 *
 * Markup canon:
 *   <div class="smile-rating" data-rating-value="4.5" aria-label="4.5 de 5">
 *     <span class="smile-rating__star is-filled"></span>
 *     <span class="smile-rating__star is-filled"></span>
 *     <span class="smile-rating__star is-filled"></span>
 *     <span class="smile-rating__star is-filled"></span>
 *     <span class="smile-rating__star is-half"></span>
 *   </div>
 *
 * Override for LeoFeature reviews module markup (jQuery RateIt or similar).
 * ============================================================ */
.smile-rating,
.product-rating,
.rateit-range,
.starrating {
  display: inline-flex !important;
  align-items: center !important;
  gap: 2px !important;
  vertical-align: middle !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.smile-rating__star {
  width: 16px;
  height: 16px;
  background-color: var(--line, #E8DFD6);
  display: inline-block;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27><path d=%27M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z%27/></svg>") center/contain no-repeat;
  mask: url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27><path d=%27M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z%27/></svg>") center/contain no-repeat;
  flex-shrink: 0;
}
.smile-rating__star.is-filled {
  background-color: var(--champagne, #B8924F);
}
.smile-rating__star.is-half {
  background: linear-gradient(90deg, var(--champagne, #B8924F) 50%, var(--line, #E8DFD6) 50%);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27><path d=%27M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z%27/></svg>") center/contain no-repeat;
  mask: url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27><path d=%27M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z%27/></svg>") center/contain no-repeat;
}

.smile-rating__value {
  font-family: var(--f-body, Inter) !important;
  font-size: 13px !important;
  color: var(--ink-2, #6B6360) !important;
  font-variant-numeric: tabular-nums !important;
  margin-left: 6px !important;
}

/* ============================================================
 * 2026-05-27 — Cross-sell PDP HIDE temporal
 * Reporte: "Los clientes que adquirieron también compraron" sin
 *   formato satisfactorio. Pendiente: rediseñar sistema completo de
 *   recomendaciones (cross-sell + upsell + similares + recientes).
 * Plan completo en /root/SMILE_RECOMMENDATIONS_PLAN.md y memoria.
 * Quitar este display:none cuando se reactive con el design final.
 * ============================================================ */
.featured-products,
.page-footer-meta .featured-products,
footer.page-footer-meta {
  display: none !important;
}


/* ============================================================
 * .img-badges — over-the-image badge stack (PDP gallery).
 * Spec: design_handoff_smile_outofstock. Both "New" and "Sold out"
 * live here; if both apply they stack vertically.
 * ============================================================ */
.pdp-gallery__cover-wrap {
  position: relative;
  display: block;
}
.pdp-gallery__cover-wrap .img-badges {
  position: absolute;
  top: 20px;
  left: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 2;
  pointer-events: none;
}
.pdp-gallery__cover-wrap .img-badges:empty { display: none; }

.ibadge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-body, "Inter", sans-serif);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 7px 13px;
  border-radius: 6px;
}
.ibadge--new {
  background: var(--burgundy, #6B2C2C);
  color: #fff;
}
.ibadge--sold {
  background: rgba(43, 40, 38, 0.88);
  color: #fff;
  gap: 7px;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}
.ibadge--sold .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--rose, #E8C5C5);
}

/* ============================================================
 * Sold-out state — qty stepper + add-to-cart button.
 * Per spec: same layout, only visual disabled state changes.
 * ============================================================ */
.smile-qty--disabled {
  opacity: 0.5;
}
.smile-qty--disabled .smile-qty__btn,
.smile-qty--disabled .smile-qty__input {
  cursor: not-allowed;
  color: var(--ink-3, #A39A92);
}
.smile-qty--disabled .smile-qty__btn:disabled {
  pointer-events: none;
}

.product-add-to-cart .add-to-cart--sold,
.product-add-to-cart .add-to-cart[disabled] {
  background: var(--surface-2, #FAF7F2) !important;
  color: var(--ink-3, #A39A92) !important;
  border: 1px solid var(--line, #E8DFD6) !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
  transform: none !important;
}
.product-add-to-cart .add-to-cart--sold:hover,
.product-add-to-cart .add-to-cart[disabled]:hover {
  background: var(--surface-2, #FAF7F2) !important;
  color: var(--ink-3, #A39A92) !important;
  box-shadow: none !important;
  transform: none !important;
}


/* === PDP color swatch — soporta tanto .color (con HEX inline) como spans sin clase (fallback champagne) === */
/* Base box para AMBOS casos (CON o SIN HEX) */
.product-variants ul .input-container .input-color + span {
  display: block;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(43,40,38,.12);
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
  position: relative;
  box-sizing: border-box;
}
/* SIN .color (no HEX en BO): aplicar degradado champagne como fallback.
   No tocamos .color para que el background-color inline gane. */
.product-variants ul .input-container .input-color + span:not(.color) {
  background-image: linear-gradient(135deg, #EADfca, #CDAE78);
}
.product-variants ul .input-container .input-color + span:hover { transform: scale(1.08); }
.product-variants ul .input-container .input-color:checked + span {
  box-shadow: 0 0 0 2px var(--bg, #FAF7F2), 0 0 0 4px var(--champagne, #B8924F);
}
.product-variants ul .input-container .input-color + span .sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}
