/* Shared product loop card (used on shop + any product grid) */

/* WooCommerce core adds clearfix pseudo-elements to ul.products; in a grid they
   become grid items and shift every card. Kill them. */
.woocommerce ul.products::before, .woocommerce ul.products::after,
ul.products::before, ul.products::after { content: none !important; display: none !important; }

.woocommerce ul.products, ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin: 0 0 40px;
  padding: 0;
  list-style: none;
}
.woocommerce ul.products li.product, ul.products li.product {
  width: auto !important; margin: 0 !important; float: none !important;
  display: flex; flex-direction: column;
  background: #fff; border: 1px solid rgba(36,22,18,.08); border-radius: 8px; overflow: hidden;
  text-align: left;
}
.woocommerce ul.products li.product a img { margin: 0; border-radius: 0; }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--chroma-font-head); font-weight: 800; font-size: 22px;
  color: var(--chroma-ink); padding: 16px 16px 0;
}
.woocommerce ul.products li.product .price {
  font-family: var(--chroma-font-body); color: var(--chroma-red); font-weight: 700;
  padding: 8px 16px 0; margin-bottom: 14px; /* fixed gap so price never jams the button */
}
.woocommerce ul.products li.product .button {
  margin: auto 16px 16px; align-self: flex-start;
  font-family: var(--chroma-font-body); font-size: 15px;
  background: var(--chroma-red); color: #fff; border: 0; padding: 11px 18px; border-radius: 3px;
}
.woocommerce ul.products li.product .button:hover { background: var(--chroma-red-dark); }

@media (max-width: 900px) { .woocommerce ul.products, ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .woocommerce ul.products, ul.products { grid-template-columns: 1fr; } }
