/* =========================================================
   Elementor WC Product Widget - Styles
   Versió pensada per a 3 layouts: grid / list / masonry
   Nota: aquest CSS NO requereix wrappers extra dins la targeta.
   ========================================================= */

/* ===== Base ===== */
.ewc-product-widget {
  --ewc-gap-x: 20px;
  --ewc-gap-y: 20px;
  gap: var(--ewc-gap-y) var(--ewc-gap-x);
}

/* ===== GRID ===== */
.ewc-product-widget.ewc-grid {
  display: grid;
  grid-template-columns: repeat(var(--ewc-columns, 3), minmax(0, 1fr));
  gap: var(--ewc-gap-y, 20px) var(--ewc-gap-x, 20px);
}

/* =========================================================
   LLISTA (3 columnes sense wrappers: imatge | meta | dreta)
   ========================================================= */
.ewc-product-widget.ewc-list {
  --ewc-list-img-w: 220px;
  --ewc-list-gap-x: 16px;
  --ewc-list-meta-gap-y: 6px;
  --ewc-list-right-gap-y: 8px;
  --ewc-list-min-h: 160px;
}

.ewc-product-widget.ewc-list .ewc-product-item {
  display: grid !important;
  grid-template-columns: var(--ewc-list-img-w) 1fr auto;
  align-items: start;
  column-gap: var(--ewc-list-gap-x);
  row-gap: var(--ewc-list-row-gap, 15px);
  border: 1px solid #eee; /* <- del segon bloc */
  padding: 12px;          /* <- del segon bloc */
  background: #fff;       /* <- del segon bloc */
  border-radius: var(--ewc-card-radius, 0); /* <- del segon bloc */
  min-height: var(--ewc-list-min-h);
}

/* Llista: fem que les columnes mig i dreta siguin columnes flex per poder justificar verticalment */
.ewc-product-widget.ewc-list .ewc-col-mid,
.ewc-product-widget.ewc-list .ewc-col-right {
  display: flex;
  flex-direction: column;
}

/* El gap vertical per cada columna (controlable des de Elementor) */
.ewc-product-widget.ewc-list .ewc-col-mid > * {
  margin-top: 0;
  margin-bottom: var(--ewc-list-meta-gap-y, 6px);
}

.ewc-product-widget.ewc-list .ewc-col-right > * {
  margin-top: 0;
  margin-bottom: var(--ewc-list-right-gap-y, 8px);
}

/* treu l’últim marge de cada columna */
.ewc-product-widget.ewc-list .ewc-col-mid > *:last-child,
.ewc-product-widget.ewc-list .ewc-col-right > *:last-child {
  margin-bottom: 0;
}

/* Columna 1: imatge/slider — ocupa tota l’alçada de la fila */
.ewc-product-widget.ewc-list .ewc-product-thumb {
  grid-column: 1;
  grid-row: 1 / -1;
  border-radius: var(--ewc-thumb-radius, 0);
  overflow: hidden;
  display: block;
  height: 100%;
}

/* Featured (llista) */
.ewc-product-widget.ewc-list .ewc-thumb-featured,
.ewc-product-widget.ewc-list .ewc-thumb-featured a {
  height: 100%;
  display: block;
}

.ewc-product-widget.ewc-list .ewc-thumb-featured img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Hover (llista) */
.ewc-product-widget.ewc-list .ewc-thumb-hover,
.ewc-product-widget.ewc-list .ewc-thumb-hover a,
.ewc-product-widget.ewc-list .ewc-thumb-hover .ewc-img-stack {
  height: 100%;
  display: block;
}

.ewc-product-widget.ewc-list .ewc-thumb-hover .img-primary,
.ewc-product-widget.ewc-list .ewc-thumb-hover .img-hover {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Slider (llista) */
.ewc-product-widget.ewc-list .ewc-thumb-slider,
.ewc-product-widget.ewc-list .ewc-thumb-slider .ewc-slides,
.ewc-product-widget.ewc-list .ewc-thumb-slider .ewc-slide .ewc-slide-link {
  height: 100%;
}

.ewc-product-widget.ewc-list .ewc-thumb-slider .ewc-slide .ewc-slide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Columna 2: meta */
.ewc-product-widget.ewc-list .ewc-product-title,
.ewc-product-widget.ewc-list .ewc-product-cat,
.ewc-product-widget.ewc-list .ewc-product-excerpt {
  grid-column: 2;
  align-self: start;
  margin: 0 0 var(--ewc-list-meta-gap-y) 0;
}

.ewc-product-widget.ewc-list .ewc-product-title {
  margin-bottom: 4px;
}

/* Columna 3: dreta */
.ewc-product-widget.ewc-list .ewc-product-price,
.ewc-product-widget.ewc-list .ewc-product-actions,
.ewc-product-widget.ewc-list .ewc-product-stock {
  grid-column: 3;
  justify-self: end;
  align-self: start;
  margin: 0 0 var(--ewc-list-right-gap-y) 0;
}

/* Responsiu llista */
@media (max-width: 768px) {
  .ewc-product-widget.ewc-list .ewc-product-item {
    grid-template-columns: var(--ewc-list-img-w) 1fr;
    grid-auto-rows: auto;
  }

  .ewc-product-widget.ewc-list .ewc-product-price,
  .ewc-product-widget.ewc-list .ewc-product-actions,
  .ewc-product-widget.ewc-list .ewc-product-stock {
    grid-column: 2;
    justify-self: start;
  }
}

/* Patch anti-herències */
.ewc-product-widget.ewc-list .ewc-product-thumb img {
  display: block;
}

/* ===== MASONRY (CSS columns) ===== */
.ewc-product-widget.ewc-masonry {
  display: block;
  column-count: var(--ewc-columns, 3);
  column-gap: var(--ewc-gap-x, 20px);
}

.ewc-product-widget.ewc-masonry .ewc-product-item {
  display: inline-block;
  width: 100%;
  margin: 0 0 var(--ewc-gap-y, 20px);
  break-inside: avoid;
}

/* ===== Targetes (fora del mode llista) ===== */
.ewc-product-widget:not(.ewc-list) .ewc-product-item {
  border: 1px solid #eee;
  padding: 12px;
  background: #fff;
  border-radius: var(--ewc-card-radius, 0);
  display: flex;
  flex-direction: column;
}

/* ===== Ordre (per si cal en flex / auto-placement) ===== */
.ewc-product-item .ewc-product-thumb { order: var(--ewc-order-thumb, 1); }
.ewc-product-item .ewc-product-cat   { order: var(--ewc-order-cat, 2); }
.ewc-product-item .ewc-product-title { order: var(--ewc-order-title, 3); }
.ewc-product-widget .ewc-product-item .ewc-product-excerpt { order: var(--ewc-order-excerpt, 4); }
.ewc-product-item .ewc-product-price { order: var(--ewc-order-price, 5); }
.ewc-product-item .ewc-product-stock { order: var(--ewc-order-stock, 6); }
.ewc-product-item .ewc-product-actions { order: var(--ewc-order-actions, 7); }
/* si la wishlist és “content_flow” */
.ewc-product-item .ewc-wishlist-flow { order: var(--ewc-order-wishlist, 8); }

/* ===== Thumbnail base (comú) ===== */
.ewc-product-thumb {
  position: relative;
  overflow: hidden;
  line-height: 0;
  user-select: none;
  border-radius: var(--ewc-thumb-radius, 0);
}

.ewc-product-thumb img {
  width: 100%;
  height: auto;
  display: block;
  backface-visibility: hidden;
}

/* FEATURED (zoom) */
.ewc-thumb-featured {
  position: relative;
  overflow: hidden;
}

.ewc-thumb-featured .ewc-zoom-target {
  display: block;
  width: 100%;
  height: auto;
  transform: scale(1);
  transition: transform 250ms ease;
}

.ewc-thumb-featured.is-zoom .ewc-zoom-target:hover {
  transform: scale(var(--ewc-zoom-scale, 1.05));
}

/* HOVER (dues imatges) */
.ewc-thumb-hover .ewc-img-stack {
  position: relative;
  display: block;
  line-height: 0;
}

.ewc-thumb-hover .ewc-img-stack .img-primary {
  position: relative;
  display: block;
  width: 100%;
  height: auto;
}

.ewc-thumb-hover .ewc-img-stack .img-hover {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity var(--ewc-hover-duration, 250ms) ease;
}

.ewc-thumb-hover:hover .ewc-img-stack .img-hover {
  opacity: 1;
}

/* ===== SLIDER (comú) ===== */
.ewc-thumb-slider { position: relative; }

.ewc-thumb-slider .ewc-slides {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-areas: "stack";
  isolation: isolate;
}

.ewc-thumb-slider .ewc-slide {
  grid-area: stack;
  position: relative;
  z-index: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--ewc-slide-fade, 220ms) ease;
}

.ewc-thumb-slider .ewc-slide.is-active {
  z-index: 1;
  opacity: 1;
  pointer-events: auto;
}

.ewc-thumb-slider .ewc-slide .ewc-slide-link {
  display: block;
  line-height: 0;
}

.ewc-thumb-slider .ewc-slide .ewc-slide-img {
  display: block;
  width: 100%;
  height: auto;
}

/* Fletxes */
.ewc-thumb-slider .ewc-slider-prev,
.ewc-thumb-slider .ewc-slider-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--ewc-arrow-hit, 40px);
  height: var(--ewc-arrow-hit, 40px);
  padding: var(--ewc-arrow-pad, 8px);
  cursor: pointer;
  z-index: 3;
  color: var(--ewc-arrow-color, inherit);
  background: var(--ewc-arrow-bg, initial);
  border-radius: var(--ewc-arrow-radius, 0);
}

.ewc-thumb-slider .ewc-slider-prev { left: 8px; }
.ewc-thumb-slider .ewc-slider-next { right: 8px; }

.ewc-thumb-slider .ewc-slider-prev svg,
.ewc-thumb-slider .ewc-slider-next svg {
  width: var(--ewc-arrow-size, 16px);
  height: var(--ewc-arrow-size, 16px);
}

/* RTL: intercanvia posicions */
[dir="rtl"] .ewc-thumb-slider .ewc-slider-prev { right: 8px; left: auto; }
[dir="rtl"] .ewc-thumb-slider .ewc-slider-next { left: 8px; right: auto; }

/* Forma per defecte */
.ewc-thumb-slider.ewc-arrows-style-square .ewc-slider-prev,
.ewc-thumb-slider.ewc-arrows-style-square .ewc-slider-next { border-radius: 0; }

.ewc-thumb-slider.ewc-arrows-style-rounded .ewc-slider-prev,
.ewc-thumb-slider.ewc-arrows-style-rounded .ewc-slider-next { border-radius: 8px; }

.ewc-thumb-slider.ewc-arrows-style-round .ewc-slider-prev,
.ewc-thumb-slider.ewc-arrows-style-round .ewc-slider-next { border-radius: 999px; }

.ewc-thumb-slider.ewc-arrows-style-transparent .ewc-slider-prev,
.ewc-thumb-slider.ewc-arrows-style-transparent .ewc-slider-next { background: transparent; }

/* Dots */
.ewc-thumb-slider .ewc-slider-dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 8px;
  display: flex;
  gap: var(--ewc-dot-gap, 6px);
  justify-content: center;
  z-index: 3;
}

.ewc-thumb-slider .ewc-slider-dots .ewc-dot {
  width: var(--ewc-dot-size, 8px);
  height: var(--ewc-dot-size, 8px);
  border-radius: 999px;
  cursor: pointer;
  border: 0;
  padding: 0;
  background: var(--ewc-dot-bg, rgba(0, 0, 0, .3));
}

.ewc-thumb-slider .ewc-slider-dots .ewc-dot.is-active {
  background: var(--ewc-dot-bg-active, rgba(0, 0, 0, .75));
}

/* Edge zones */
.ewc-thumb-slider .ewc-edge-nav {
  position: absolute;
  top: 0;
  bottom: 0;
  width: var(--ewc-edge-width, 14%);
  z-index: 2;
  cursor: pointer;
}

.ewc-thumb-slider .ewc-edge-prev { left: 0; }
.ewc-thumb-slider .ewc-edge-next { right: 0; }

/* Comptador */
.ewc-thumb-slider .ewc-slider-counter {
  position: absolute;
  top: var(--ewc-counter-offset-y, 8px);
  right: var(--ewc-counter-offset-x, 8px);
  z-index: 4;
  font-size: var(--ewc-counter-fs, 12px);
  line-height: 1.2;
  padding: var(--ewc-counter-pad, 3px 6px);
  background: var(--ewc-counter-bg, rgba(0, 0, 0, .6));
  color: var(--ewc-counter-color, #fff);
  border-radius: var(--ewc-counter-radius, 4px);
}

/* ===== Accions: quantitat + botó a la mateixa línia ===== */
.ewc-product-actions .cart {
  display: inline-flex;
  align-items: center;
  gap: var(--ewc-atc-gap, 8px);
}

/* ===== Elements de text (defaults lleus) ===== */
.ewc-product-title,
.ewc-product-price,
.ewc-product-cat,
.ewc-product-excerpt,
.ewc-product-stock,
.ewc-product-actions {
  margin: 8px 0;
}

.ewc-product-title { font-size: 16px; margin: 0; }
.ewc-product-price { margin: 0; }
.ewc-product-cat a { text-decoration: none; }


/* ===== Wishlist en “content flow” (permet text-align via control) ===== */
.ewc-wishlist-flow { width: 100%; }
.ewc-wishlist-flow .ewc-wishlist-toggle { display: inline-flex; }
/* Wishlist en content_flow (quan s'usa com a bloc) */
/* ===== Load more ===== */
.ewc-load-more-wrap {
  text-align: center;
  margin-top: 20px;
}

.ewc-load-more.button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: transform .2s ease, box-shadow .2s ease;
}

.ewc-load-more .ewc-icon svg {
  width: var(--ewc-lm-icon-size, 18px);
  height: var(--ewc-lm-icon-size, 18px);
  display: inline-block;
}

.ewc-load-more.is-loading {
  pointer-events: none;
  opacity: .65;
}

/* ===== Animacions hover (botons) ===== */
.ewc-product-widget[data-atc-anim] .ewc-product-actions a.button,
.ewc-product-widget[data-atc-anim] .ewc-product-actions .button,
.ewc-product-widget[data-atc-anim] a.button,
.ewc-product-widget[data-atc-anim] .button {
  display: inline-block;
  will-change: transform, box-shadow;
  transition: transform .2s ease, box-shadow .2s ease !important;
}

/* Efectes botons */
.ewc-product-widget[data-atc-anim="scale"] a.button:hover,
.ewc-product-widget[data-atc-anim="scale"] .button:hover { transform: scale(1.03) !important; }

.ewc-product-widget[data-atc-anim="up"] a.button:hover,
.ewc-product-widget[data-atc-anim="up"] .button:hover { transform: translateY(-2px) !important; }

.ewc-product-widget[data-atc-anim="shadow"] a.button:hover,
.ewc-product-widget[data-atc-anim="shadow"] .button:hover { box-shadow: 0 6px 18px rgba(0, 0, 0, .15) !important; }

.ewc-product-widget[data-atc-anim="pulse"] a.button:hover,
.ewc-product-widget[data-atc-anim="pulse"] .button:hover { transform: scale(1.06) !important; }

/* Opcional: replicar efectes al botó "Carrega més" segons data-lm-anim del wrapper del botó */
.ewc-load-more-wrap[data-lm-anim="scale"] .ewc-load-more:hover { transform: scale(1.03); }
.ewc-load-more-wrap[data-lm-anim="up"] .ewc-load-more:hover { transform: translateY(-2px); }
.ewc-load-more-wrap[data-lm-anim="shadow"] .ewc-load-more:hover { box-shadow: 0 6px 18px rgba(0, 0, 0, .15); }
.ewc-load-more-wrap[data-lm-anim="pulse"] .ewc-load-more:hover { transform: scale(1.06); }

/* ===== Wishlist ===== */
.ewc-product-widget { --ewc-wl-size: 18px; }

.ewc-thumb-wrap { position: relative; }

.ewc-wishlist-overlay {
  position: absolute;
  z-index: 3;
  padding: .4em;
}

.ewc-wishlist-overlay.ewc-wl-thumb_top_right { top: 8px; right: 8px; }
.ewc-wishlist-overlay.ewc-wl-thumb_top_left  { top: 8px; left: 8px; }
.ewc-wishlist-overlay.ewc-wl-thumb_bottom_right { bottom: 8px; right: 8px; }
.ewc-wishlist-overlay.ewc-wl-thumb_bottom_left  { bottom: 8px; left: 8px; }

.ewc-wishlist-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: 0;
  background: transparent;
  cursor: pointer;
  border-radius: 50%;
  /* mantenim font-size:0 al botó per eliminar espais de text, però el restablim al fill */
  font-size: 0;
  color: currentColor;
  will-change: transform, box-shadow, color;
  transition: transform .2s ease, box-shadow .2s ease, color .2s ease;
}

/* ✅ Contenidor de la icona: permet SVG i <i> d’Elementor */
.ewc-wishlist-toggle .ewc-wl-icon {
  display: inline-block;
  font-size: 0; /* no interfereix en SVG */
  line-height: 0;
}

/* SVG: mida controlada per la variable */
.ewc-wishlist-toggle .ewc-wl-icon svg,
.ewc-wishlist-toggle svg {
  width: var(--ewc-wl-size);
  height: var(--ewc-wl-size);
  display: block;
}

/* <i> (llibreria d’icones): restablim mida perquè no quedi a 0 */
.ewc-wishlist-toggle .ewc-wl-icon i {
  display: inline-block;
  font-size: var(--ewc-wl-size);
  line-height: 1;
}

/* Estats ON/OFF (dues capes d’icona) */
.ewc-wishlist-toggle .ewc-wl-on { display: none; }
.ewc-wishlist-toggle.is-active .ewc-wl-off { display: none; }
.ewc-wishlist-toggle.is-active .ewc-wl-on { display: inline-block; }

/* Estat actiu + accessibilitat focus */
.ewc-wishlist-toggle.is-active { color: #e63946; }
.ewc-wishlist-toggle:focus { outline: 2px solid; outline-offset: 2px; }

/* Animacions (opcionals) */
.ewc-wishlist-toggle.wl-anim-scale:hover { transform: scale(1.06); }
.ewc-wishlist-toggle.wl-anim-up:hover    { transform: translateY(-2px); }
.ewc-wishlist-toggle.wl-anim-shadow:hover{ box-shadow: 0 6px 18px rgba(0, 0, 0, .15); }
.ewc-wishlist-toggle.wl-anim-pulse:hover { transform: scale(1.09); }

/* Zoom de la portada (featured) — usa les variables creades pels controls */
.ewc-product-widget .ewc-thumb-featured.is-zoom .ewc-zoom-target {
  transition: transform var(--ewc-zoom-duration, 250ms) ease;
  will-change: transform;
}

.ewc-product-widget .ewc-thumb-featured.is-zoom:hover .ewc-zoom-target {
  transform: scale(var(--ewc-zoom-scale, 1.05));
}

/* ===== Qty + ATC: fila a desktop, doble fila en pantalles petites ===== */
.ewc-product-actions .cart {
  display: inline-flex;
  align-items: center;
  gap: var(--ewc-atc-gap, 8px);
  flex-wrap: nowrap; /* desktop: una sola fila */
  justify-content: var(--ewc-actions-justify, flex-start);
}

/* Elements interns NO han d’emplenar tot l’ample */
.ewc-product-actions .ewc-el-qty,
.ewc-product-actions .ewc-el-atc {
  display: inline-flex;
  align-items: center;
}

/* Input de quantitat: amplada raonable + no desbordar */
.ewc-product-actions .cart .qty,
.ewc-product-actions .cart input.qty,
.ewc-product-actions .cart .input-text.qty {
  width: var(--ewc-qty-width, 64px);
  min-width: 56px;
  max-width: 90px;
  text-align: center;
  padding: 6px 8px;
  box-sizing: border-box;
}

/* Botó ATC no s’estira sol per omplir */
.ewc-product-actions .cart .button {
  width: auto;
  max-width: 100%;
}

/* Tablet/mòbil: dues files (qty a dalt, botó a baix) */
@media (max-width: 1024px) {
  .ewc-product-actions .cart {
    flex-wrap: wrap; /* permet 2 línies */
    row-gap: var(--ewc-atc-row-gap, 6px);
  }

  .ewc-product-actions .ewc-el-qty {
    width: 100%;
    justify-content: var(--ewc-actions-justify, flex-start);
  }

  .ewc-product-actions .ewc-el-atc {
    width: 100%;
    justify-content: var(--ewc-actions-justify, flex-start);
  }
}

/* Evita que res sobresurti de la targeta */
.ewc-product-item .ewc-product-actions,
.ewc-product-item .ewc-product-actions .cart {
  overflow: hidden;
}

/* ===== Focus personalitzable per al camp de quantitat ===== */
.ewc-product-widget input.qty:focus,
.ewc-product-widget .qty:focus {
  outline: none;
  box-shadow: 0 0 0 2px var(--ewc-qty-focus, #3b82f6);
  border-color: var(--ewc-qty-focus, #3b82f6);
}

/* ATC: icona + gap (com "Carrega més") */
.ewc-atc-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--ewc-atc-gap, 8px);
}

.ewc-atc-btn .ewc-icon svg,
.ewc-atc-btn .ewc-icon i {
  width: var(--ewc-atc-icon-size, 18px);
  height: var(--ewc-atc-icon-size, 18px);
}

/* Animacions hover opc (mateixes que carrega més) */
.ewc-atc-anim-scale:hover  { transform: scale(1.03); }
.ewc-atc-anim-up:hover     { transform: translateY(-2px); }
.ewc-atc-anim-shadow:hover { box-shadow: 0 6px 18px rgba(0, 0, 0, .15); }
.ewc-atc-anim-pulse:hover  { transform: scale(1.06); }






/* ===== EWC ATC – reset comú per <button> i <a> ===== */
.ewc-product-widget .ewc-atc {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5em;

  /* reset cross-browser perquè <a> i <button> es vegin igual */
  appearance: none;
  -webkit-appearance: none;
  text-decoration: none;
  border: 0;

  /* base visual (pots override des d’Elementor) */
  padding: .65em 1.2em;
  line-height: 1.2;
  cursor: pointer;
  transition: all .2s ease-in-out;
}

.ewc-product-widget .ewc-atc:focus {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

/* Estat desactivat visual (si vols usar-lo en out-of-stock) */
.ewc-product-widget .ewc-atc[aria-disabled="true"],
.ewc-product-widget .ewc-atc.is-out[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: .75;
}

/* Modificador per a variables (si el vols diferenciar algun dia) */
.ewc-product-widget .ewc-atc.is-variable {}

/* Modificador per a sense estoc (visual secundari per defecte) */
.ewc-product-widget .ewc-atc.is-out {
  /* exemple subtil; l’usuari ho podrà canviar des d’Elementor */
  filter: saturate(.85);
}

/* Fix mini retall del botó ATC al costat de la quantitat */
.ewc-product-widget .ewc-el-actions,
.ewc-product-widget .ewc-product-actions,
.ewc-product-widget .ewc-product-actions .cart,
.ewc-product-widget .ewc-product-actions .ewc-el-atc {
  overflow: visible; /* per si algun contenidor tanca el dibuix */
}

/* Coixí minúscul a la dreta del botó */
.ewc-product-widget .ewc-product-actions .ewc-el-atc {
  padding-right: var(--ewc-atc-clip-fix, 3px);
  box-sizing: border-box;
}