/* WooCommerce shop archive + product card. */

.woo-archive__head {
  text-align: center;
  margin-bottom: var(--sp-7);
}
.woo-archive__head .page-title,
.woo-archive__head h1 {
  font-family: var(--ff-display);
  font-size: var(--fs-h1);
  letter-spacing: var(--ls-display);
  color: var(--c-navy);
  margin: 0 0 var(--sp-3);
}
.woo-archive__intro { color: var(--c-field-gray); margin: 0 auto; }

/* Notices (cart updated, login error, etc.) */
.woocommerce-notices-wrapper:empty { display: none; }
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  font-family: var(--ff-ui);
  font-size: var(--fs-small);
  border: 1px solid var(--c-rule);
  background: var(--c-cream-soft);
  border-left: 3px solid var(--c-bronze);
  padding: var(--sp-3) var(--sp-4);
  margin: 0 0 var(--sp-5);
  list-style: none;
}
.woocommerce-error { border-left-color: var(--c-red); background: #FAE2E4; }

/* The product grid (Woo's default ul) */
ul.products {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--sp-6);
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
}
ul.products > li { list-style: none; }
@media (min-width: 600px) { ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 960px) { ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (min-width: 1200px) {
  ul.products.columns-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* Card */
.woo-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  list-style: none;
}
.woo-card__view { margin-top: auto; align-self: flex-start; }
.woo-card__media {
  display: block;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--c-cream-soft);
  border-radius: var(--radius-sm);
}
.woo-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 400ms ease;
}
.woo-card:hover .woo-card__media img { transform: scale(1.02); }

.woo-card__body {
  padding: var(--sp-4) var(--sp-1) 0;
}
.woo-card__title-link { text-decoration: none; }
.woo-card__title {
  font-family: var(--ff-headline);
  font-size: var(--fs-h4);
  font-weight: 700;
  color: var(--c-navy);
  margin: 0 0 var(--sp-2);
  line-height: 1.3;
}
.woo-card:hover .woo-card__title { color: var(--c-red); }
.woo-card__excerpt {
  font-size: var(--fs-small);
  color: var(--c-field-gray);
  margin: 0 0 var(--sp-3);
}

.woo-card__price {
  font-family: var(--ff-ui);
  font-weight: 600;
  color: var(--c-charcoal);
  margin-bottom: var(--sp-3);
}
.woo-card__price del { color: var(--c-field-gray); font-weight: 400; margin-right: var(--sp-2); }
.woo-card__price ins { text-decoration: none; color: var(--c-red); }
.woo-card__view { align-self: flex-start; }

/* Pagination — reuse our pagination component but override the Woo wrapper */
nav.woocommerce-pagination { margin-top: var(--sp-7); display: flex; justify-content: center; }
.woocommerce-pagination ul.page-numbers {
  list-style: none; padding: 0; margin: 0;
  display: flex; gap: var(--sp-2); flex-wrap: wrap;
}
.woocommerce-pagination li { display: inline-flex; }

/* Result count + ordering — restrained */
.woocommerce-result-count,
.woocommerce-ordering {
  font-family: var(--ff-ui);
  font-size: var(--fs-small);
  color: var(--c-field-gray);
  margin-bottom: var(--sp-5);
}
.woocommerce-ordering select {
  font-family: var(--ff-ui);
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--c-rule);
  padding-left: 0;
  padding-right: 24px;
  cursor: pointer;
}

/* Breadcrumbs */
.woocommerce-breadcrumb {
  font-family: var(--ff-ui);
  font-size: var(--fs-caption);
  letter-spacing: var(--ls-ui);
  text-transform: uppercase;
  color: var(--c-field-gray);
  margin: 0 0 var(--sp-5);
}
.woocommerce-breadcrumb a { color: var(--c-field-gray); text-decoration: none; }
.woocommerce-breadcrumb a:hover { color: var(--c-navy); }
.woocommerce-breadcrumb .sep { margin: 0 var(--sp-2); }
