/**
 * Coffee Trade — Product cards
 * ----------------------------------------------------------------------------
 * Calm, uniform, premium cards for shop / category / related / cross-sell loops.
 * Scoped to `.woocommerce ul.products li.product` so it matches Astra's loop
 * output without touching grid column maths (column count/spacing stays in
 * Astra Customizer > WooCommerce).
 *
 * Card content order (title/price/cart) is the configurable `shop-product-
 * structure` Astra option — we style spacing/emphasis, we do NOT reorder.
 */

.woocommerce ul.products li.product {
	position: relative; /* anchor for category badge + sale flash */
	display: flex;
	flex-direction: column;
	background: var(--ctc-cream);
	border: var(--ctc-border-width) solid var(--ctc-line);
	border-radius: var(--ctc-radius-lg);
	padding: var(--ctc-space-3);
	box-shadow: var(--ctc-shadow-sm);
	transition: box-shadow var(--ctc-transition),
		transform var(--ctc-transition),
		border-color var(--ctc-transition);
}

.woocommerce ul.products li.product:hover {
	box-shadow: var(--ctc-shadow);
	border-color: var(--ctc-taupe);
	transform: translateY(-2px);
}

/* --- Image: fixed format on a calm stone backdrop ------------------------- */
.woocommerce ul.products li.product .astra-shop-thumbnail-wrap {
	display: block;
	position: relative;
	aspect-ratio: var(--ctc-card-ratio);
	background: var(--ctc-stone);
	border-radius: var(--ctc-radius);
	overflow: hidden;
	margin-bottom: var(--ctc-space-4);
}

.woocommerce ul.products li.product .astra-shop-thumbnail-wrap img {
	width: 100%;
	height: 100%;
	object-fit: contain; /* show whole machine, no awkward crop */
	padding: var(--ctc-space-4);
	margin: 0;
	transition: transform var(--ctc-transition-slow);
}

.woocommerce ul.products li.product:hover .astra-shop-thumbnail-wrap img {
	transform: scale(1.03);
}

/* Fallback when Astra's thumbnail wrap is absent: keep images tidy. */
.woocommerce ul.products li.product > a img {
	border-radius: var(--ctc-radius);
}

/* --- Category badge (top-left) ------------------------------------------- */
.woocommerce ul.products li.product .ctc-card-badge {
	position: absolute;
	top: var(--ctc-space-3);
	left: var(--ctc-space-3);
	z-index: 2;
	background: var(--ctc-badge-bg);
	color: var(--ctc-badge-fg);
	font-size: var(--ctc-badge-font-size);
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 0.3rem 0.55rem;
	border-radius: var(--ctc-radius-sm);
}

/* --- Sale flash (top-right, out of the badge's way) ----------------------- */
.woocommerce ul.products li.product .onsale {
	position: absolute;
	top: var(--ctc-space-3);
	right: var(--ctc-space-3);
	left: auto;
	margin: 0;
	min-height: 0;
	min-width: 0;
	line-height: 1;
	padding: 0.3rem 0.6rem;
	background: var(--ctc-espresso);
	color: var(--ctc-cream);
	border-radius: var(--ctc-radius-pill);
	font-size: var(--ctc-badge-font-size);
	font-weight: 600;
}

/* --- Title: short, calm, readable ---------------------------------------- */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .ast-woo-product-title,
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3 {
	color: var(--ctc-text);
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.35;
	letter-spacing: 0;
	margin: 0 0 var(--ctc-space-2);
	padding: 0;
}

/* --- Price: clear premium, no "price war" -------------------------------- */
.woocommerce ul.products li.product .price {
	color: var(--ctc-text);
	font-size: 1.05rem;
	font-weight: 600;
	margin: 0 0 var(--ctc-space-3);
}

.woocommerce ul.products li.product .price del {
	color: var(--ctc-text-muted);
	font-weight: 400;
	opacity: 1;
}

.woocommerce ul.products li.product .price ins {
	text-decoration: none;
	color: var(--ctc-walnut);
}

/* --- Actions pinned to the bottom for uniform card heights ---------------- */
.woocommerce ul.products li.product .button {
	width: 100%;
	margin-top: auto; /* push the primary action to the card foot */
}

.woocommerce ul.products li.product .ctc-card-advisory {
	width: 100%;
	margin-top: var(--ctc-space-2);
}

/* When an advisory CTA is present, the primary button shouldn't also stretch
   with auto-margin twice; keep spacing tidy. */
.woocommerce ul.products li.product .button + .ctc-card-advisory {
	margin-top: var(--ctc-space-2);
}

/* --- Rating stars: quieter, on-brand ------------------------------------- */
.woocommerce ul.products li.product .star-rating {
	margin: 0 0 var(--ctc-space-2);
	color: var(--ctc-bronze);
	font-size: 0.85em;
}
