/* =========================================================================
 * UMI Salon — Shop promo-blokken (Acties & Promo)
 * On-brand kaarten op de shop-/categoriepagina. Rustig, premium, editorial.
 * Crème/ink met sage-accent. Afgeronde kaarten, hairline-randen.
 * Responsive: 3 → 1 kolom op mobiel. Touch targets >= 44px.
 * ====================================================================== */

.umi-promo-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	margin: 0 0 32px;
	width: 100%;
	box-sizing: border-box;
}

/* Pas het kolomaantal aan het werkelijke aantal blokken aan, zodat 1 of 2
   blokken niet smal links blijven hangen maar nette breedtes krijgen. */
.umi-promo-grid--1 {
	grid-template-columns: minmax(0, 1fr);
}
.umi-promo-grid--2 {
	grid-template-columns: repeat(2, 1fr);
}

/* Wanneer de blokken NA de eerste rij producten verschijnen, geven we wat
   ademruimte boven het blok zodat het los staat van de productenrij. */
.woocommerce-page ul.products + .umi-promo-grid,
.shop-main ul.products + .umi-promo-grid {
	margin-top: 8px;
}

/* ---- Kaart ---- */
.umi-promo-block {
	display: flex;
	flex-direction: column;
	background: var(--card-soft, #F0E8DA);
	border: 1px solid var(--line-soft, #EBE2D0);
	border-radius: var(--r-lg, 28px);
	overflow: hidden;
	box-sizing: border-box;
	transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}

.umi-promo-block:hover {
	border-color: var(--sage, #B8C7B4);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px -16px rgba(26, 24, 20, .25);
}

/* ---- Media ---- */
.umi-promo-block__media {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--bg-soft, #ECE4D6);
}

.umi-promo-block__media img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* ---- Body ---- */
.umi-promo-block__body {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 22px 22px 24px;
	flex: 1 1 auto;
}

/* Blokken zonder afbeelding krijgen iets meer lucht boven. */
.umi-promo-block:not(.has-image) .umi-promo-block__body {
	padding-top: 26px;
}

.umi-promo-block__title {
	margin: 0;
	font-family: inherit;
	font-size: 1.18rem;
	line-height: 1.25;
	font-weight: 600;
	color: var(--ink, #1A1814);
	letter-spacing: -.01em;
}

.umi-promo-block__text {
	margin: 0;
	color: var(--ink-soft, #6B6259);
	font-size: .94rem;
	line-height: 1.6;
}

.umi-promo-block__text p {
	margin: 0 0 .5em;
}
.umi-promo-block__text p:last-child {
	margin-bottom: 0;
}

/* ---- Knop (sage-accent) ---- */
.umi-promo-block__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	align-self: flex-start;
	margin-top: auto;
	min-height: 44px;
	padding: 11px 22px;
	border-radius: 999px;
	background: var(--success, #4A6B47);
	color: #fff;
	font-size: .9rem;
	font-weight: 600;
	line-height: 1.1;
	text-decoration: none;
	border: 1px solid transparent;
	transition: background .18s ease, color .18s ease, border-color .18s ease;
}

.umi-promo-block__btn:hover,
.umi-promo-block__btn:focus-visible {
	background: var(--sage-dark, #9CAE96);
	color: var(--ink, #1A1814);
	border-color: var(--sage-dark, #9CAE96);
}

.umi-promo-block__btn:focus-visible {
	outline: 2px solid var(--ink, #1A1814);
	outline-offset: 2px;
}

/* =========================================================================
 * Responsive
 * ====================================================================== */

/* Tablet: max 2 kolommen voor de 3-blok variant. */
@media (max-width: 900px) {
	.umi-promo-grid,
	.umi-promo-grid--2,
	.umi-promo-grid--3 {
		grid-template-columns: repeat(2, 1fr);
		gap: 14px;
	}
	.umi-promo-grid--1 {
		grid-template-columns: minmax(0, 1fr);
	}
}

/* Mobiel (<= 600px, incl. 390px): altijd 1 kolom, geen overflow. */
@media (max-width: 600px) {
	.umi-promo-grid,
	.umi-promo-grid--1,
	.umi-promo-grid--2,
	.umi-promo-grid--3 {
		grid-template-columns: minmax(0, 1fr);
		gap: 14px;
		margin-bottom: 24px;
	}

	.umi-promo-block__body {
		padding: 18px 18px 20px;
	}

	.umi-promo-block__title {
		font-size: 1.1rem;
	}

	.umi-promo-block__btn {
		align-self: stretch; /* volledige breedte = makkelijker te tikken */
	}
}
