/* =======================================
   WC Products Showcase — Stylesheet (DRY)
   Handle: wc-products-showcase
   ======================================= */

.wcs-wrapper{
  --grid-gap:24px;
  --grid-col-d:var(--wcs-col-d,4);
  --grid-col-t:var(--wcs-col-t,2);
  --grid-col-m:var(--wcs-col-m,1);
  --sep-opacity:.12;
  --title-lines:2;
  --title-lh:1.3;
  --nav-size:42px;
  --dot-gap:6px;
  --var-gap:8px;
  --var-border:#e2e2e2;
  --btn-r:999px;
}

/* GRID */
.wcs-wrapper.layout-grid{
  display:grid;
  gap:var(--grid-gap);
  grid-template-columns:repeat(var(--grid-col-d),minmax(0,1fr));
}
@media (max-width:1024px){
  .wcs-wrapper.layout-grid{ grid-template-columns:repeat(var(--grid-col-t),minmax(0,1fr)); }
}
@media (max-width:767px){
  .wcs-wrapper.layout-grid{ grid-template-columns:repeat(var(--grid-col-m),minmax(0,1fr)); }
}

/* ITEM */
.wcs-item{ position:relative; display:flex; flex-direction:column; height:100%; }
.wcs-wrapper .wcs-item .wcs-row-top,
.wcs-wrapper .wcs-item .wcs-separator,
.wcs-wrapper .wcs-item .wcs-row-bottom{ flex-shrink:0; }
.wcs-wrapper .wcs-item .wcs-row-bottom{ margin-top:auto; }
.wcs-row{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.wcs-row-top{ align-items:flex-start; margin-top:12px; min-height:calc(var(--title-lines) * 1em * var(--title-lh)); }
.wcs-row-top.title-full{ flex-direction:column; align-items:flex-start; }
.wcs-row-top.title-full .wcs-title,
.wcs-row-top.title-full .wcs-price{ width:100%; }
.wcs-row-top.title-full .wcs-price{ margin-top:5px; }
.wcs-row-bottom{ display:flex; justify-content:space-between; align-items:center; gap:10px; flex-wrap:nowrap; }
.wcs-meta-left, .wcs-meta-right{ flex:1; min-width:0; display:flex; align-items:center; gap:8px; }
@media (min-width:1024px){ .wcs-meta-right{ justify-content:flex-end; } }

/* THUMB */
.wcs-item .wcs-thumb{ position:relative; overflow:hidden; border-radius:0; }
.wcs-thumb-link{ display:block; height:100%; }
.wcs-thumb.thumb--ratio::before{ content:""; display:block; padding-top:calc(100% / (var(--wcs-thumb-ar,16/9))); }
.wcs-thumb.thumb--ratio .wcs-thumb-link{ position:absolute; inset:0; }
.wcs-thumb.thumb--ratio .wcs-img{ position:absolute; inset:0; width:100%; height:100%; display:block; object-fit:cover; transition:transform .35s ease; backface-visibility:hidden; aspect-ratio:auto !important; }
.wcs-thumb.thumb--ratio .wcs-img.second{ opacity:0; transition:opacity .35s ease; }
.wcs-thumb.thumb--ratio:hover .wcs-img.first{ transform:scale(1.03); }
.wcs-thumb.thumb--ratio:hover .wcs-img.second{ opacity:1; }
.wcs-thumb.thumb--auto .wcs-thumb-link{ position:relative; }
.wcs-thumb.thumb--auto .wcs-img.first{ position:static; width:100%; height:auto; display:block; object-fit:contain; aspect-ratio:auto !important; }
.wcs-thumb.thumb--auto .wcs-img.second{ position:absolute; inset:0; width:100%; height:100%; object-fit:inherit; opacity:0; transition:opacity .35s ease; }
.wcs-thumb.thumb--auto:hover .wcs-img.second{ opacity:1; }
.woocommerce ul.products li.product a img,
.wcs-item .wcs-thumb img{ height:auto; aspect-ratio:auto !important; }
@media (prefers-reduced-motion:reduce){
  .wcs-item .wcs-thumb .wcs-img,
  .wcs-item .wcs-thumb .wcs-img.second,
  .wcs-actions{ transition:none !important; }
}

/* WISHLIST */
.wcs-wishlist{ position:absolute; right:12px; top:12px; z-index:3; }
.wcs-wishlist .wcs-heart{ display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:var(--btn-r); background:#fff; box-shadow:0 6px 18px rgba(0,0,0,.08); text-decoration:none; line-height:1; }
.wcs-wishlist .wcs-heart:hover, .wcs-wishlist .wcs-heart:focus-visible{ box-shadow:0 8px 22px rgba(0,0,0,.12); outline:none; }
.wcs-wishlist svg{ background:#fff; border-radius:50%; padding:3px; }

/* ACTIONS */
.wcs-actions{ position:absolute; left:12px; right:12px; bottom:12px; z-index:2; display:flex; gap:10px; opacity:0; transform:translateY(8px); transition:opacity .25s ease, transform .25s ease; }
.wcs-item .wcs-thumb:hover .wcs-actions{ opacity:1; transform:translateY(0); }
@media (hover:none){ .wcs-actions{ opacity:1; transform:none; } }
.wcs-btn{ flex:1 1 auto; text-align:center; font-size:14px; line-height:1; padding:11px 12px; border:1px solid transparent; border-radius:var(--btn-r); text-decoration:none; cursor:pointer; }
.wcs-btn:focus-visible{ outline:2px solid currentColor; outline-offset:2px; }

/* TITLE | PRICE */
.wcs-title,.wcs-price{ margin:0; }
.wcs-title{ flex:1; font-size:16px; line-height:var(--title-lh); display:-webkit-box; -webkit-line-clamp:var(--title-lines); -webkit-box-orient:vertical; overflow:hidden; text-overflow:ellipsis; max-width:100%; word-break:break-word; }
.wcs-title a{ text-decoration:none; display:inline-block; }
.wcs-title a:focus-visible{ outline:2px solid currentColor; outline-offset:2px; }
.wcs-price{ font-weight:bold; white-space:nowrap; line-height:1; display:flex; align-items:center; gap:.35em; flex:0 0 auto; }
.wcs-price del,.wcs-price ins{ color:inherit; }
.wcs-price del{ opacity:.6; }

/* SEPARATOR */
.wcs-separator{ height:1px; width:100%; background:currentColor; opacity:var(--sep-opacity); margin:.5rem 0; padding:var(--wcs-sep-py,0) var(--wcs-sep-px,0); }

/* CATEGORY */
.wcs-cat{ margin:0; }
.wcs-cat a{ display:inline-block; font-size:12px; line-height:1; padding:6px 10px; text-decoration:none; border:1px solid transparent; border-radius:var(--btn-r); }
.wcs-cat a:focus-visible{ outline:2px solid currentColor; outline-offset:2px; }

/* VARIATIONS (text) */
.wcs-variations{ display:flex; flex-wrap:wrap; gap:var(--var-gap); align-items:center; }
.wcs-variations a, .wcs-variation{ display:inline-flex; align-items:center; justify-content:center; min-width:32px; height:32px; padding:0 10px; text-decoration:none; border:1px solid var(--var-border); border-radius:8px; font-size:12px; line-height:1; }
.wcs-variations a:focus-visible{ outline:2px solid currentColor; outline-offset:2px; }

/* SWATCH DOTS */
.wcs-attrdots{ display:flex; flex-wrap:wrap; align-items:center; gap:var(--dot-gap); }
.wcs-dots-hidden{ display:flex; flex-wrap:wrap; gap:var(--dot-gap); margin-left:5px; }
.wcs-dot--more, .wcs-more-btn{ display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; padding:0 8px; border:1px solid #e2e2e2; border-radius:var(--btn-r); background:#f7f7f7; cursor:pointer; line-height:1; font-weight:600; font-size:.85em; transition:background .2s; }
.wcs-dot--more:hover{ background:#ddd; }
.wcs-dot.wcs-dot--color{ border:1px solid rgba(0,0,0,.08); background:#fff; overflow:hidden; width:28px; height:28px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; text-decoration:none; }
.wcs-dot.wcs-dot--color > span{ display:block; width:calc(100% - 6px); height:calc(100% - 6px); border-radius:999px; background:var(--dot-bg,#eee); }
.wcs-dot.wcs-dot--image{ border:1px solid rgba(0,0,0,.08); overflow:hidden; background:#fff; width:28px; height:28px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; text-decoration:none; }
.wcs-dot.wcs-dot--image .wcs-dot-img{ width:100%; height:100%; object-fit:cover; }
.wcs-dot.wcs-dot--text{ padding:0 .6em; min-width:auto; height:auto; border-radius:999px; border:1px solid rgba(0,0,0,.12); font-size:.85em; line-height:1.9; text-decoration:none; }

/* SWIPER NAV */
.wcs-wrapper.layout-carousel{ position:relative; }
.wcs-swiper-nav .wcs-swiper-prev, .wcs-swiper-nav .wcs-swiper-next{ position:absolute; top:50%; transform:translateY(-50%); width:var(--nav-size); height:var(--nav-size); border-radius:var(--btn-r); background:#fff; box-shadow:0 6px 20px rgba(0,0,0,.1); z-index:5; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.wcs-swiper-nav .wcs-swiper-prev{ left:-20px; }
.wcs-swiper-nav .wcs-swiper-next{ right:-20px; }
@media (max-width:767px){
  .wcs-swiper-nav .wcs-swiper-prev{ left:6px; }
  .wcs-swiper-nav .wcs-swiper-next{ right:6px; }
}

/* PAGINATION */
.wcs-pagination ul.page-numbers{ display:flex; gap:20px; justify-content:center; }
.wcs-pagination .page-numbers li{ list-style:none; }
