/*
 related-fix.css
 Purpose: stable 3-col related cards desktop, 2-col tablet, 1-col mobile
 Images use 4:3 aspect-ratio; titles clamped to 2 lines
 Scope: body.single-product .related
*/

body.single-product .related ul.products,
body.single-product .related .products {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  overflow-x: visible;
  box-sizing: border-box;
}

/* card sizing via flex-basis so it won't force horizontal overflow */
body.single-product .related ul.products li.product,
body.single-product .related .products li.product {
  float: none;
  width: auto;
  min-width: 0;
  flex: 0 0 calc(33.333% - 18.666px); /* 3 columns desktop */
  max-width: 380px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  margin: 0;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
}

/* Image: reserve 4:3 area to prevent CLS */
body.single-product .related ul.products li.product a img,
body.single-product .related .products li.product a img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  border-radius: 12px 12px 0 0;
}

/* Inner content area */
body.single-product .related ul.products li.product .woocommerce-loop-product__title,
body.single-product .related .products li.product .woocommerce-loop-product__title {
  margin: 12px 16px 0;
  font-size: 16px;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: #1f2937;
  text-align: center;
}

/* Price / rating / CTA zone */
body.single-product .related ul.products li.product .price,
body.single-product .related .products li.product .price {
  margin: 10px 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  min-height: 2.4em;
}

/* CTA area pinned near bottom so cards align */
body.single-product .related ul.products li.product .add_to_cart_button,
body.single-product .related .products li.product .add_to_cart_button,
body.single-product .related ul.products li.product .gt-wa-archive,
body.single-product .related .products li.product .gt-wa-archive {
  margin: 10px 16px 18px;
  align-self: stretch;
}

/* ensure chat/cta wrap stays near bottom for consistent height */
body.single-product .related ul.products li.product > .woocommerce-loop-product__title + .price + .loop-button-wrapper,
body.single-product .related .products li.product > .woocommerce-loop-product__title + .price + .loop-button-wrapper {
  margin-top: auto;
}

/* Tablet -> 2 columns */
@media (max-width: 980px) {
  body.single-product .related ul.products li.product,
  body.single-product .related .products li.product {
    flex: 0 0 calc(50% - 14px);
    max-width: 420px;
  }
}

/* Mobile -> 1 column full-width */
@media (max-width: 560px) {
  body.single-product .related ul.products,
  body.single-product .related .products {
    gap: 12px;
    padding: 0 12px;
  }
  body.single-product .related ul.products li.product,
  body.single-product .related .products li.product {
    flex: 0 0 100%;
    max-width: 720px;
  }

  /* slightly smaller image height on mobile (but aspect-ratio keeps stability) */
  body.single-product .related ul.products li.product a img,
  body.single-product .related .products li.product a img {
    aspect-ratio: 4 / 3;
  }
}
