/*
 * Huuguu v81.29.5 — Woo Product Card Engine
 * One source for Woo product loops: shop, archives, related, upsells and cross-sells.
 * This file must load after legacy/system CSS. Do not duplicate loop card rules elsewhere.
 */

:root {
  --hgg-wc-loop-image-ratio: 4 / 3;
  --hgg-wc-loop-media-title-gap: 16px;
  --hgg-wc-loop-title-excerpt-gap: 8px;
  --hgg-wc-loop-excerpt-actions-gap: 18px;
  --hgg-wc-loop-price-button-gap: 16px;
  --hgg-wc-loop-description-lines: 1;
  --hgg-wc-loop-price-size-default: clamp(1.12rem, 1.1vw, 1.38rem);
  --hgg-wc-loop-price-size-mobile-default: clamp(.86rem, 3.2vw, 1rem);
}

/* Grid */
ul.products,
.woocommerce ul.products,
.woocommerce-page ul.products,
.related.products ul.products,
.upsells.products ul.products,
.cross-sells ul.products,
.single-product .related.products ul.products,
.single-product .upsells.products ul.products,
.woocommerce-cart .cross-sells ul.products {
  display: grid;
  grid-template-columns: repeat(var(--hgg-wc-loop-columns-desktop, var(--hgg-wc-columns-desktop, 3)), minmax(0, 1fr));
  gap: var(--hgg-wc-loop-gap-desktop, var(--hgg-wc-gap-desktop, 32px));
  align-items: stretch;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
}

.related.products ul.products,
.upsells.products ul.products,
.cross-sells ul.products,
.single-product .related.products ul.products,
.single-product .upsells.products ul.products,
.woocommerce-cart .cross-sells ul.products {
  grid-template-columns: repeat(var(--hgg-wc-related-cols-desktop, var(--hgg-wc-loop-columns-desktop, var(--hgg-wc-columns-desktop, 3))), minmax(0, 1fr));
}

ul.products::before,
ul.products::after,
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
  display: none;
  content: none;
}

/* Neutralize WooCommerce native .columns-X widths before the Huuguu grid sizes cards.
   Woo core ships rules such as .woocommerce ul.products.columns-3 li.product { width: 30.75%; }.
   Keep this selector narrow and load it after Woo/legacy CSS so no !important is required. */
.woocommerce ul.products[class*="columns-"] > li.product,
.woocommerce-page ul.products[class*="columns-"] > li.product,
ul.products[class*="columns-"] > li.product,
.related.products ul.products[class*="columns-"] > li.product,
.upsells.products ul.products[class*="columns-"] > li.product,
.cross-sells ul.products[class*="columns-"] > li.product,
.single-product .related.products ul.products[class*="columns-"] > li.product,
.single-product .upsells.products ul.products[class*="columns-"] > li.product,
.woocommerce-cart .cross-sells ul.products[class*="columns-"] > li.product {
  float: none;
  clear: none;
  width: auto;
  max-width: none;
  min-width: 0;
  margin: 0;
}


ul.products > li.product.hgg-wc-product-card,
.woocommerce ul.products > li.product.hgg-wc-product-card,
.woocommerce-page ul.products > li.product.hgg-wc-product-card,
.related.products ul.products > li.product.hgg-wc-product-card,
.upsells.products ul.products > li.product.hgg-wc-product-card,
.cross-sells ul.products > li.product.hgg-wc-product-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-width: 0;
  padding: var(--hgg-wc-loop-card-padding-box, 20px 20px 20px 20px);
  overflow: hidden;
  background: var(--hgg-wc-card-bg, var(--hgg-content-surface-bg, #fff));
  border: var(--hgg-wc-loop-card-border-width, 1px) solid var(--hgg-wc-loop-card-border-color, rgba(23, 32, 51, .08));
  border-radius: var(--hgg-wc-loop-card-radius, 18px);
  box-shadow: var(--hgg-wc-card-shadow, 0 18px 46px rgba(15, 23, 42, .055));
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

ul.products > li.product.hgg-wc-product-card:hover,
.woocommerce ul.products > li.product.hgg-wc-product-card:hover,
.woocommerce-page ul.products > li.product.hgg-wc-product-card:hover,
.related.products ul.products > li.product.hgg-wc-product-card:hover,
.upsells.products ul.products > li.product.hgg-wc-product-card:hover,
.cross-sells ul.products > li.product.hgg-wc-product-card:hover {
  border-color: var(--hgg-wc-loop-card-border-hover-color, var(--hgg-primary, #007721));
  box-shadow: var(--hgg-wc-card-hover-shadow, 0 22px 56px rgba(15, 23, 42, .08));
  transform: translateY(var(--hgg-wc-card-hover-translate-y, -1px));
}

.hgg-wc-product-card__inner,
.hgg-wc-product-card__body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
}

.hgg-wc-product-card__media {
  position: relative;
  margin: 0 0 var(--hgg-wc-loop-media-title-gap, 16px);
  overflow: hidden;
  background: var(--hgg-wc-loop-image-bg, #f7f3ee);
  border: var(--hgg-wc-loop-image-border-width, 0) solid var(--hgg-wc-loop-image-border-color, rgba(23, 32, 51, .08));
  border-radius: var(--hgg-wc-loop-image-radius, 12px);
}

.hgg-wc-product-card__image-link,
.hgg-wc-product-card__image-wrap {
  display: block;
  width: 100%;
  color: inherit;
  text-decoration: none;
}

.hgg-wc-product-card__media img,
ul.products > li.product.hgg-wc-product-card .hgg-wc-product-card__media img,
.woocommerce ul.products > li.product.hgg-wc-product-card .hgg-wc-product-card__media img,
.woocommerce-page ul.products > li.product.hgg-wc-product-card .hgg-wc-product-card__media img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: var(--hgg-wc-loop-image-ratio, 4 / 3);
  margin: 0;
  border-radius: inherit;
  object-fit: cover;
}

.hgg-wc-product-card__body {
  align-items: stretch;
  text-align: var(--hgg-wc-archive-content-align, center);
}

.hgg-wc-product-card__title,
ul.products > li.product .woocommerce-loop-product__title,
.woocommerce ul.products > li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products > li.product .woocommerce-loop-product__title {
  margin: 0 0 var(--hgg-wc-loop-title-excerpt-gap, 8px);
  padding: 0;
  color: var(--hgg-wc-loop-title-color, var(--hgg-heading-color, var(--hgg-text, #111827)));
  font-size: var(--hgg-wc-loop-title-size, clamp(1rem, 1.1vw, 1.14rem));
  font-weight: var(--hgg-wc-loop-title-weight, 800);
  line-height: 1.16;
}

.hgg-wc-product-card__title a,
.woocommerce-loop-product__title a {
  color: inherit;
  text-decoration: none;
}

.hgg-wc-product-card__excerpt,
.woocommerce-loop-product__description {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--hgg-wc-loop-description-color, var(--hgg-text-muted, #24304b));
  font-size: var(--hgg-wc-loop-description-size, 13px);
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: var(--hgg-wc-loop-description-lines, 1);
}

.hgg-wc-product-card__actions {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  align-items: var(--hgg-wc-loop-button-align-items, center);
  justify-content: flex-end;
  gap: var(--hgg-wc-loop-price-button-gap, 16px);
  width: 100%;
  margin-top: auto;
  padding-top: var(--hgg-wc-loop-excerpt-actions-gap, 18px);
}

.hgg-wc-product-card__price-pill {
  width: 100%;
  min-width: 0;
}

.hgg-wc-product-card__price-pill .price,
ul.products > li.product .price,
.woocommerce ul.products > li.product .price,
.woocommerce-page ul.products > li.product .price {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: center;
  gap: 4px .42em;
  width: 100%;
  min-width: 0;
  margin: 0;
  color: var(--hgg-wc-loop-price-color, var(--hgg-wc-price-color, var(--hgg-text, #111827)));
  font-size: var(--hgg-wc-loop-price-size, var(--hgg-wc-loop-price-size-default));
  font-weight: var(--hgg-wc-loop-price-weight, 800);
  line-height: 1.05;
  text-align: center;
}

.hgg-wc-product-card__price-pill .price del,
.hgg-wc-product-card__price-pill .price ins,
ul.products > li.product .price del,
ul.products > li.product .price ins,
.woocommerce ul.products > li.product .price del,
.woocommerce ul.products > li.product .price ins,
.woocommerce-page ul.products > li.product .price del,
.woocommerce-page ul.products > li.product .price ins {
  display: inline-flex;
  align-items: baseline;
  width: auto;
  max-width: 100%;
  margin: 0;
  line-height: 1.05;
  white-space: nowrap;
}

ul.products > li.product .price del,
.woocommerce ul.products > li.product .price del,
.woocommerce-page ul.products > li.product .price del {
  opacity: .55;
}

ul.products > li.product .price ins,
.woocommerce ul.products > li.product .price ins,
.woocommerce-page ul.products > li.product .price ins {
  color: inherit;
  font-weight: inherit;
  text-decoration: none;
}

ul.products > li.product .price .woocommerce-Price-amount,
ul.products > li.product .price .woocommerce-Price-currencySymbol,
ul.products > li.product .price bdi,
.woocommerce ul.products > li.product .price .woocommerce-Price-amount,
.woocommerce ul.products > li.product .price .woocommerce-Price-currencySymbol,
.woocommerce ul.products > li.product .price bdi,
.woocommerce-page ul.products > li.product .price .woocommerce-Price-amount,
.woocommerce-page ul.products > li.product .price .woocommerce-Price-currencySymbol,
.woocommerce-page ul.products > li.product .price bdi {
  white-space: nowrap;
}

ul.products > li.product .price .woocommerce-price-suffix,
.woocommerce ul.products > li.product .price .woocommerce-price-suffix,
.woocommerce-page ul.products > li.product .price .woocommerce-price-suffix {
  flex: 0 0 100%;
  width: 100%;
  margin: 2px 0 0;
  color: var(--hgg-wc-loop-price-note-color, var(--hgg-text-muted, #596174));
  font-size: var(--hgg-wc-loop-price-note-size, 12px);
  font-weight: var(--hgg-wc-loop-price-note-weight, 600);
  line-height: 1.2;
  text-align: center;
}

.hgg-wc-product-card__button-wrap {
  display: flex;
  justify-content: var(--hgg-wc-loop-button-justify, center);
  width: 100%;
  min-width: 0;
}

ul.products > li.product.hgg-wc-product-card .button,
.woocommerce ul.products > li.product.hgg-wc-product-card .button,
.woocommerce-page ul.products > li.product.hgg-wc-product-card .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--hgg-wc-loop-button-width, 150px);
  max-width: 100%;
  min-height: var(--hgg-wc-loop-button-min-height, 44px);
  margin: 0;
  padding: var(--hgg-button-padding-y, .7rem) var(--hgg-button-padding-x, 1rem);
  border: 0;
  border-radius: var(--hgg-wc-button-radius, var(--hgg-button-radius, 12px));
  background: var(--hgg-wc-button-bg, var(--hgg-button-bg, #007721));
  color: var(--hgg-wc-button-text, var(--hgg-button-text, #fff));
  font-size: var(--hgg-wc-loop-button-font-size, 13px);
  font-weight: 800;
  line-height: 1.15;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
}

ul.products > li.product.hgg-wc-product-card .button:hover,
ul.products > li.product.hgg-wc-product-card .button:focus-visible,
.woocommerce ul.products > li.product.hgg-wc-product-card .button:hover,
.woocommerce ul.products > li.product.hgg-wc-product-card .button:focus-visible,
.woocommerce-page ul.products > li.product.hgg-wc-product-card .button:hover,
.woocommerce-page ul.products > li.product.hgg-wc-product-card .button:focus-visible {
  background: var(--hgg-wc-button-hover-bg, var(--hgg-button-hover-bg, #045F12));
  color: var(--hgg-wc-button-hover-text, var(--hgg-button-hover-text, #fff));
}

.hgg-loop-badge,
ul.products > li.product .onsale,
.woocommerce ul.products > li.product .onsale,
.woocommerce-page ul.products > li.product .onsale {
  position: absolute;
  top: var(--hgg-wc-loop-badge-offset-y, 12px);
  left: var(--hgg-wc-loop-badge-offset-x, 12px);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 0;
  padding: var(--hgg-wc-loop-badge-padding-y, 6px) var(--hgg-wc-loop-badge-padding-x, 12px);
  border-radius: var(--hgg-wc-loop-badge-radius, 6px);
  background: var(--hgg-wc-sale-badge-bg, var(--hgg-primary, #007721));
  color: var(--hgg-wc-sale-badge-text, #fff);
  font-size: var(--hgg-wc-loop-badge-font-size, 12px);
  font-weight: var(--hgg-wc-loop-badge-font-weight, 600);
  line-height: 1;
  box-shadow: var(--hgg-wc-loop-badge-shadow, 0 10px 24px rgba(17, 34, 68, .16));
}

.hgg-loop-badge--new {
  background: var(--hgg-wc-new-badge-bg, #62e434);
  color: var(--hgg-wc-new-badge-text, #07130a);
}

.hgg-loop-badge--sale,
ul.products > li.product .onsale,
.woocommerce ul.products > li.product .onsale,
.woocommerce-page ul.products > li.product .onsale {
  background: var(--hgg-wc-sale-loop-badge-bg, #ff3535);
  color: var(--hgg-wc-sale-loop-badge-text, #fff);
}

.woocommerce-result-count {
  color: var(--hgg-text-muted, #4b5575);
}

.woocommerce-ordering select {
  min-height: 44px;
}

@media (min-width: 768px) and (max-width: 1024px) {
  ul.products,
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(var(--hgg-wc-loop-columns-tablet, var(--hgg-wc-columns-tablet, 2)), minmax(0, 1fr));
    gap: var(--hgg-wc-loop-gap-tablet, var(--hgg-wc-gap-tablet, 24px));
  }

  .related.products ul.products,
  .upsells.products ul.products,
  .cross-sells ul.products,
  .single-product .related.products ul.products,
  .single-product .upsells.products ul.products,
  .woocommerce-cart .cross-sells ul.products {
    grid-template-columns: repeat(var(--hgg-wc-related-cols-tablet, var(--hgg-wc-loop-columns-tablet, var(--hgg-wc-columns-tablet, 2))), minmax(0, 1fr));
  }

  ul.products > li.product.hgg-wc-product-card,
  .woocommerce ul.products > li.product.hgg-wc-product-card,
  .woocommerce-page ul.products > li.product.hgg-wc-product-card {
    padding: var(--hgg-wc-loop-card-padding-box-tablet, var(--hgg-wc-loop-card-padding-box, 10px 10px 22px 10px));
  }
}

@media (max-width: 767px) {
  ul.products,
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(var(--hgg-wc-loop-columns-mobile, var(--hgg-wc-columns-mobile, 2)), minmax(0, 1fr));
    gap: var(--hgg-wc-loop-gap-mobile, var(--hgg-wc-gap-mobile, 20px));
  }

  .related.products ul.products,
  .upsells.products ul.products,
  .cross-sells ul.products,
  .single-product .related.products ul.products,
  .single-product .upsells.products ul.products,
  .woocommerce-cart .cross-sells ul.products {
    grid-template-columns: repeat(var(--hgg-wc-related-cols-mobile, var(--hgg-wc-loop-columns-mobile, var(--hgg-wc-columns-mobile, 2))), minmax(0, 1fr));
  }

  ul.products > li.product.hgg-wc-product-card,
  .woocommerce ul.products > li.product.hgg-wc-product-card,
  .woocommerce-page ul.products > li.product.hgg-wc-product-card {
    padding: var(--hgg-wc-loop-card-padding-box-mobile, 8px 8px 20px 8px);
  }

  .hgg-wc-product-card__media {
    margin-bottom: 13px;
  }

  .hgg-wc-product-card__title,
  ul.products > li.product .woocommerce-loop-product__title,
  .woocommerce ul.products > li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products > li.product .woocommerce-loop-product__title {
    font-size: var(--hgg-wc-loop-title-size-mobile, clamp(.92rem, 4.2vw, 1.04rem));
    line-height: 1.12;
  }

  .hgg-wc-product-card__excerpt,
  .woocommerce-loop-product__description {
    font-size: var(--hgg-wc-loop-description-size-mobile, 12px);
    line-height: 1.35;
  }

  .hgg-wc-product-card__actions {
    gap: 13px;
    padding-top: 17px;
  }

  .hgg-wc-product-card__price-pill .price,
  ul.products > li.product .price,
  .woocommerce ul.products > li.product .price,
  .woocommerce-page ul.products > li.product .price {
    gap: 3px .35em;
    font-size: var(--hgg-wc-loop-price-size-mobile, var(--hgg-wc-loop-price-size-mobile-default));
  }

  ul.products > li.product .price .woocommerce-price-suffix,
  .woocommerce ul.products > li.product .price .woocommerce-price-suffix,
  .woocommerce-page ul.products > li.product .price .woocommerce-price-suffix {
    font-size: 11px;
  }

  ul.products > li.product.hgg-wc-product-card .button,
  .woocommerce ul.products > li.product.hgg-wc-product-card .button,
  .woocommerce-page ul.products > li.product.hgg-wc-product-card .button {
    min-height: var(--hgg-wc-loop-button-min-height-mobile, 40px);
    padding: 8px 10px;
    font-size: var(--hgg-wc-loop-button-font-size-mobile, 10.5px);
    white-space: normal;
    width: min(100%, var(--hgg-wc-loop-button-width-mobile, var(--hgg-wc-loop-button-width, 150px)));
  }

  body.woocommerce .woocommerce-result-count,
  body.woocommerce-page .woocommerce-result-count {
    float: none;
    width: 100%;
    margin: 0 0 12px;
    text-align: center;
  }

  body.single-product .related.products > h2,
  body.single-product .upsells.products > h2 {
    text-align: center;
    font-size: clamp(1.45rem, 7vw, 2rem);
    line-height: 1.1;
  }
}


/* Huuguu v81.31.5 — accessibility contrast fixes for loop cards. */
body .hgg-loop-badge--sale {
  background: var(--hgg-loop-sale-badge-bg, #b91c1c);
  color: var(--hgg-loop-sale-badge-text, #ffffff);
}

body .hgg-loop-badge--new {
  background: var(--hgg-loop-new-badge-bg, #43d82f);
  color: var(--hgg-loop-new-badge-text, #071407);
}

body .hgg-wc-product-card .price del,
body .hgg-product-card .price del,
body.woocommerce ul.products li.product .price del,
body.woocommerce-page ul.products li.product .price del {
  color: var(--hgg-wc-price-del-color, #4b5563);
  opacity: 1;
  text-decoration-thickness: 2px;
}

body .hgg-wc-product-card .price ins,
body .hgg-product-card .price ins,
body.woocommerce ul.products li.product .price ins,
body.woocommerce-page ul.products li.product .price ins {
  color: var(--hgg-wc-price-sale-color, var(--hgg-text, #0f172a));
  text-decoration: none;
}
