/**
 * Variant CSS: offer--grid-compact-auto
 * Layer 2 — a DENSE auto-fit grid for a long service list. Element Count: 3+
 * (the rebuild clones the tile to N). The columns container is forced to CSS grid
 * with auto-fit minmax so 4 / 8 / 12 tiles all balance into 2–4 tidy columns
 * instead of a cramped flex row.
 * Scope: body.aibt-universal .universal-offer--grid-compact-auto
 */

body.aibt-universal .universal-offer--grid-compact-auto {
	padding-block: calc(clamp(var(--space-xl), 8vw, var(--space-3xl)) * var(--density, 1));
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__intro {
	max-width: 42rem;
	margin: 0 auto clamp(var(--space-lg), 4vw, var(--space-2xl));
	text-align: center;
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__kicker {
	font-family: var(--font-body);
	font-size: var(--text-sm);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--accent);
	margin: 0 0 var(--space-sm);
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__headline {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.5rem);
	line-height: 1.06;
	letter-spacing: -0.03em;
	color: var(--ink);
	margin: 0;
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__headline em {
	font-style: italic;
	color: var(--accent);
}

/* Force the rebuilt wp:columns into a self-balancing grid regardless of N. */
body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__cards {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
	gap: clamp(var(--space-xs), 1.5vw, var(--space-md));
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__card {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	padding: clamp(var(--space-md), 2vw, var(--space-lg));
	background: var(--background-card);
	border: 1px solid var(--divider-primary);
	border-radius: var(--decor-radius);
	margin: 0 !important;
	transition: border-color var(--duration-fast) var(--ease-default), transform var(--duration-fast) var(--ease-default);
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__card:hover {
	border-color: var(--accent);
	transform: translateY(-2px);
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__icon {
	display: inline-flex;
	width: 2.25rem;
	height: 2.25rem;
	align-items: center;
	justify-content: center;
	color: var(--accent);
	margin-bottom: var(--space-2xs, 0.25rem);
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__icon svg { width: 1.35rem; height: 1.35rem; }

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__card-title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.18rem;
	line-height: 1.18;
	letter-spacing: -0.01em;
	color: var(--ink);
	margin: 0;
}

body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__card-desc {
	font-family: var(--font-body);
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--ink-soft, var(--ink));
	margin: 0;
}

/* Reduced motion — hold the card lift still for users who prefer no motion. */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__card {
		transition: none;
	}
	body.aibt-universal .universal-offer--grid-compact-auto .universal-offer__card:hover {
		transform: none;
	}
}
