/* ──────────────────────────────────────────────────────────────────────────
 * bold-pd-bento.css — bold bento stats grid (mixed solid-color cards + image).
 * Echoes move-04 bento: oversized numbers on navy / primary-blue / teal tiles.
 * Contrast notes:
 *   - White number/label on navy #002a4e → > 9:1; on primary #005ea8 → 5.9:1. AA.
 *   - Teal card uses dark ink #00231d on #02e8c2 → > 12:1. AA pass.
 * ────────────────────────────────────────────────────────────────────────── */

.bold-pd .pd-bento-section {
	background: var(--c-bg);
	padding-block: 4rem;
}

.bold-pd .pd-bento__head {
	max-width: 46rem;
	margin-bottom: 2.25rem;
}

.bold-pd .pd-bento__eyebrow {
	display: block;
	margin-bottom: 0.5rem;
	color: var(--c-primary);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.bold-pd .pd-bento__title {
	margin: 0;
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	font-weight: 800;
	line-height: 1.12;
	color: var(--c-text);
}

.bold-pd .pd-bento__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-auto-rows: 13rem;
	gap: 1.25rem;
}

.bold-pd .pd-bento-card {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 1.75rem;
	border-radius: var(--radius);
	overflow: hidden;
}

/* Span helpers */
.bold-pd .pd-bento-card--wide { grid-column: span 2; }
.bold-pd .pd-bento-card--tall { grid-row: span 2; }

/* The tall hero tile carries the headline number — centre it so the extra
 * vertical space reads as deliberate breathing room, not an empty gap. */
.bold-pd .pd-bento-card--tall { justify-content: center; }

/* Colour variants */
.bold-pd .pd-bento-card--navy { background: var(--c-navy); color: var(--c-white); }
.bold-pd .pd-bento-card--primary { background: var(--c-primary); color: var(--c-white); }
.bold-pd .pd-bento-card--teal { background: var(--c-teal); color: var(--c-teal-ink); }

.bold-pd .pd-bento-card__num {
	font-size: clamp(2.75rem, 5vw, 4rem);
	font-weight: 800;
	line-height: 0.95;
	letter-spacing: -0.02em;
}

.bold-pd .pd-bento-card__label {
	margin-top: 0.5rem;
	font-size: 1.0625rem;
	font-weight: 600;
}

.bold-pd .pd-bento-card__note {
	margin-top: 0.4rem;
	font-size: 0.875rem;
	opacity: 0.78;
}

.bold-pd .pd-bento-card__icon {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	width: 2.5rem;
	height: 2.5rem;
	opacity: 0.85;
}

.bold-pd .pd-bento-card--teal .pd-bento-card__icon { color: var(--c-teal-ink); }
.bold-pd .pd-bento-card--navy .pd-bento-card__icon,
.bold-pd .pd-bento-card--primary .pd-bento-card__icon { color: rgb(var(--c-white-rgb) / 0.85); }

/* Image tile */
.bold-pd .pd-bento-card--img {
	padding: 0;
}

.bold-pd .pd-bento-card--img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media (max-width: 60rem) {
	.bold-pd .pd-bento__grid {
		grid-template-columns: repeat(2, 1fr);
		grid-auto-rows: 11rem;
	}
	/* 2-col: hero stays tall (col 1), teal + image stack beside it,
	 * the 100+ card spans the full width underneath. No gaps. */
	.bold-pd .pd-bento-card--wide { grid-column: span 2; }
	.bold-pd .pd-bento-card--tall { grid-row: span 2; }
}

@media (max-width: 38rem) {
	.bold-pd .pd-bento__grid {
		grid-template-columns: 1fr;
	}
	.bold-pd .pd-bento-card--wide { grid-column: auto; }
	.bold-pd .pd-bento-card--tall { grid-row: auto; }
}
