/* ============================================================================
   Forge Core — Product Cards component
   Single source of truth for product display: [forge_products] grid, homepage
   product section, and every native WooCommerce loop (shop / category /
   archive / search / related). Tokens only (design-system.css).
   ============================================================================ */

/* ── Grid ──────────────────────────────────────────────────────────────────
   .fpc-grid    — shortcode / template grid
   ul.products  — native WooCommerce loop wrapper
   Both share warm-white backdrop + responsive columns. */
.fpc-grid,
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(var(--fpc-cols, var(--forge-grid-cols)), minmax(0, 1fr));
  gap: var(--forge-grid-gap);
  align-items: stretch; /* every card fills its row to equal height */
  margin: 0;
  padding: var(--forge-grid-padding);
  list-style: none;
  background: var(--forge-grid-bg);
  border-radius: var(--forge-card-radius);
}

/* Reset WooCommerce float/percentage widths so grid controls layout */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.fpc-li {
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: none !important;
  list-style: none !important;
  display: flex !important; /* let the card stretch to the row height */
}
.woocommerce ul.products li.product::before { display: none !important; }

/* ── Card ─────────────────────────────────────────────────────────────────── */
.fpc-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%; /* fill the stretched grid cell → equal heights per row */
  background: var(--forge-card-bg);
  border: 1px solid var(--forge-border);
  border-radius: var(--forge-card-radius);
  overflow: hidden;
  text-decoration: none !important;
  box-shadow: var(--forge-card-shadow);
  transition: var(--forge-transition);
}
.fpc-card:hover,
.fpc-card:focus-visible {
  box-shadow: var(--forge-card-shadow-hover);
  transform: translateY(-3px);
}

/* Image — fixed 280px area, full product shown (contain), warm-white backdrop */
.fpc-card__img {
  position: relative;
  width: 100%;
  height: var(--forge-card-img-height);
  flex: 0 0 var(--forge-card-img-height);
  background: var(--forge-card-img-bg);
  padding: var(--forge-card-img-pad);
  overflow: hidden;
}
.fpc-card__img img {
  width: 100%;
  height: 100%;
  object-fit: contain; /* show the whole product, no cropping */
  display: block;
  transition: var(--forge-transition);
}
.fpc-card:hover .fpc-card__img img { transform: scale(1.02); }
.fpc-card__img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

/* MOQ badge — top-left of image, black bg / gold text */
.fpc-card__moq {
  position: absolute;
  top: var(--forge-space-sm);
  left: var(--forge-space-sm);
  z-index: 2;
  background: var(--forge-black);
  color: var(--forge-gold);
  font-family: var(--forge-font-body);
  font-size: var(--forge-badge-size);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.2rem var(--forge-space-sm);
  border-radius: var(--forge-btn-radius);
}

/* Body */
.fpc-card__body {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  padding: var(--forge-card-padding);
}

/* Name — Cormorant Garamond, full name up to 3 lines, clean word wrap */
.fpc-card__name {
  font-family: var(--forge-font-heading) !important;
  font-size: var(--forge-card-title-size);
  font-weight: 600;
  line-height: 1.3;
  color: var(--forge-black) !important;
  margin: 0 0 var(--forge-space-md);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  overflow-wrap: break-word;
  word-break: normal; /* never split mid-word */
}

/* Divider — clean line between name and pricing */
.fpc-card__divider {
  display: block;
  height: 1px;
  background: var(--forge-border);
  margin: 0 0 var(--forge-space-md);
}

/* Footer — pricing left, CTA right, pinned to card bottom */
.fpc-card__foot {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--forge-space-sm);
  margin-top: auto;
}
.fpc-card__price {
  font-family: var(--forge-font-body);
  font-size: var(--forge-size-sm);
  font-weight: 400;
  color: var(--forge-text-light);
}
.fpc-card__from { color: var(--forge-text-light); }
.fpc-card__price strong {
  font-weight: 700;
  font-size: var(--forge-size-md);
  color: var(--forge-black);
}
.fpc-card__unit { color: var(--forge-text-light); font-size: var(--forge-size-xs); }

/* CTA link — reuses buttons.css .forge-cta-link semantics */
.fpc-card__cta {
  font-family: var(--forge-font-body);
  font-size: var(--forge-size-xs);
  font-weight: 600;
  letter-spacing: var(--forge-btn-letter-spacing);
  text-transform: uppercase;
  color: var(--forge-gold);
  text-align: right;
  white-space: nowrap;
  transition: var(--forge-transition);
}
.fpc-card:hover .fpc-card__cta { color: var(--forge-black); }

/* Suppress WooCommerce default loop button on archives (card supplies its own) */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart { display: none !important; }

/* ── Responsive: 3 → 2 → 1 (overrides shortcode --fpc-cols) ─────────────────── */
@media (max-width: 1024px) {
  .fpc-grid,
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .fpc-grid,
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: 1fr; padding: var(--forge-space-lg); }
}

