/**
 * Variant CSS: offer--trio-ribbon-header-cards
 * Layer 2 — exactly THREE service cards, each topped by a full-width tinted
 * RIBBON HEADER band carrying the service name; icon, description and price sit
 * in the card body below. The colored header strip is the signature. Element
 * Count: 3 (3-col grid on desktop, single column ≤640px).
 * Scope: body.aibt-universal .universal-offer--trio-ribbon-header-cards
 */

body.aibt-universal .universal-offer--trio-ribbon-header-cards {
	padding-block: calc(clamp(var(--space-xl), 8vw, var(--space-3xl)) * var(--density, 1));
}

/* Intro — centered; A8/A9: horizontal margins auto so centered children
   never left-shift inside the full-width constrained section. */
body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__intro {
	max-width: 44rem;
	margin-inline: auto;
	margin-block: 0 clamp(var(--space-lg), 4vw, var(--space-2xl));
	text-align: center;
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .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 auto var(--space-sm);
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__headline {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: var(--text-4xl);
	line-height: var(--leading-tight);
	letter-spacing: var(--tracking-tight);
	color: var(--text-primary);
	margin: 0 auto;
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__headline em {
	font-style: italic;
	color: var(--accent);
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__deck {
	font-family: var(--font-body);
	font-size: var(--text-lg);
	line-height: var(--leading-relaxed);
	color: var(--text-secondary);
	margin: var(--space-sm) auto 0;
}

/* Card grid — 3 across on desktop, collapses to one column on small screens.
   minmax(0,1fr) keeps long price/title strings from forcing horizontal scroll. */
body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__cards {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(var(--space-sm), 2vw, var(--space-lg));
	align-items: stretch;
}

/* Card — clipped corners so the ribbon header meets the rounded card edge cleanly. */
body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: var(--background);
	border: 1px solid var(--divider-primary, color-mix(in srgb, var(--text-primary) 12%, transparent));
	border-radius: var(--decor-radius);
	box-shadow: var(--decor-shadow-soft);
	transition: transform var(--duration-fast, 180ms) var(--ease-default, ease);
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__card:hover {
	transform: translateY(-3px);
}

/* THE SIGNATURE — full-width tinted ribbon header band across the card top.
   Light accent tint background + accent text → contrast-safe on every theme,
   including light-accent ones (charcoal-mono-luxe / butter / peach) where an
   --on-accent treatment would be unreliable. */
body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__ribbon {
	padding: clamp(var(--space-sm), 2.5vw, var(--space-md)) clamp(var(--space-md), 3vw, var(--space-lg));
	background: color-mix(in srgb, var(--accent) 12%, var(--background));
	border-bottom: 2px solid var(--accent);
	text-align: center;
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__card-title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: var(--text-xl);
	line-height: var(--leading-snug);
	letter-spacing: var(--tracking-tight);
	color: var(--accent);
	margin: 0;
	overflow-wrap: break-word;
}

/* Card body — icon, description, price stacked below the ribbon. */
body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	align-items: center;
	gap: var(--space-sm);
	padding: clamp(var(--space-md), 3vw, var(--space-xl));
	text-align: center;
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__icon {
	display: inline-flex;
	width: 3rem;
	height: 3rem;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: color-mix(in srgb, var(--accent) 10%, var(--background));
	color: var(--accent);
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__icon svg {
	width: 1.6rem;
	height: 1.6rem;
}

body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__card-desc {
	font-family: var(--font-body);
	font-size: var(--text-base);
	line-height: var(--leading-relaxed);
	color: var(--text-secondary);
	margin: 0;
}

/* Price — pinned to the card foot; keep-all + capped size so currency strings
   ("od 200 zł / mies.") never wrap mid-amount or overflow at 375px. */
body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__card-price {
	margin: auto 0 0;
	padding-top: var(--space-xs);
	font-family: var(--font-display);
	font-weight: 600;
	font-size: clamp(var(--text-base), 2vw, var(--text-lg));
	color: var(--text-primary);
	overflow-wrap: normal;
	word-break: keep-all;
}

/* Keyboard focus — visible ring on any focusable inside the section. */
body.aibt-universal .universal-offer--trio-ribbon-header-cards a:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
	border-radius: var(--decor-radius);
}

/* ≤640px — single column stack. */
@media (max-width: 640px) {
	body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__cards {
		grid-template-columns: minmax(0, 1fr);
	}
}

/* Reduced motion — hold the hover lift still. */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__card {
		transition: none;
	}
	body.aibt-universal .universal-offer--trio-ribbon-header-cards .universal-offer__card:hover {
		transform: none;
	}
}
