/**
 * Variant CSS: process--cards-grid
 * Layer 2 — Path B process role (2026-05-29).
 * Steps as a card grid (number badge + title + desc), 3-up wrapping to 2x2.
 * Every selector scoped to .universal-process--cards-grid (no global leak).
 */

body.aibt-universal .universal-process--cards-grid {
	background: var(--background);
	color: var(--text-primary);
}

/* Restore WP constrained-layout centering for centered intro elements. */
body.aibt-universal .universal-process.universal-process--cards-grid .has-text-align-center {
	margin-inline: auto !important;
}

body.aibt-universal .universal-process--cards-grid .universal-process__intro {
	margin-bottom: var(--space-2xl);
	text-align: center;
}
body.aibt-universal .universal-process--cards-grid .universal-process__kicker {
	font-family: var(--font-body) !important;
	font-size: var(--text-xs) !important;
	font-weight: 600 !important;
	letter-spacing: var(--tracking-widest) !important;
	text-transform: uppercase !important;
	color: var(--accent) !important;
	margin: 0 auto var(--space-sm) auto !important;
}
body.aibt-universal .universal-process--cards-grid .universal-process__headline {
	font-family: var(--font-display) !important;
	color: var(--text-primary) !important;
	margin: 0 auto !important;
}
body.aibt-universal .universal-process--cards-grid .universal-process__headline em {
	color: var(--accent) !important;
	font-style: italic;
}

/* Grid — wrap so 4 steps fall into a 2x2 / 3-col rhythm. */
body.aibt-universal .universal-process--cards-grid .universal-process__steps {
	gap: var(--space-lg) !important;
	flex-wrap: wrap;
	align-items: stretch !important;
}

/* Each step is a card. */
body.aibt-universal .universal-process--cards-grid .universal-process__step {
	flex-basis: calc(33.333% - var(--space-lg)) !important;
	flex-grow: 1;
	background: var(--background-card, var(--background-alt)) !important;
	border: 1px solid var(--divider-primary);
	border-radius: var(--decor-radius);
	padding: var(--space-lg) var(--space-md) !important;
	box-shadow: var(--decor-shadow, none);
	transition: border-color var(--duration-fast) ease, transform var(--duration-fast) ease;
}
body.aibt-universal .universal-process--cards-grid .universal-process__step:hover {
	border-color: var(--accent);
	transform: translateY(-3px);
}

/* Number badge — circular accent chip. */
body.aibt-universal .universal-process--cards-grid .universal-process__num {
	font-family: var(--font-display) !important;
	font-weight: 700 !important;
	font-size: var(--text-base) !important;
	line-height: 1 !important;
	letter-spacing: 0 !important;
	color: var(--cta-text-primary, var(--text-on-dark, #FFFFFF)) !important;
	background: var(--accent) !important;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	border-radius: 50%;
	margin: 0 0 var(--space-md) 0 !important;
}

body.aibt-universal .universal-process--cards-grid h3.universal-process__step-title,
body.aibt-universal .universal-process--cards-grid .universal-process__step-title {
	font-family: var(--font-display) !important;
	font-weight: 600 !important;
	font-size: var(--text-xl) !important;
	line-height: 1.2 !important;
	letter-spacing: -0.015em !important;
	color: var(--text-primary) !important;
	margin: 0 0 var(--space-xs) 0 !important;
}

body.aibt-universal .universal-process--cards-grid .universal-process__step-desc {
	font-family: var(--font-body) !important;
	font-size: var(--text-sm) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--text-secondary) !important;
	margin: 0 !important;
}

@media (max-width: 959px) {
	body.aibt-universal .universal-process--cards-grid .universal-process__step {
		flex-basis: calc(50% - var(--space-lg)) !important;
	}
}

@media (max-width: 781px) {
	body.aibt-universal .universal-process--cards-grid .universal-process__steps {
		flex-direction: column !important;
	}
	body.aibt-universal .universal-process--cards-grid .universal-process__step {
		flex-basis: 100% !important;
	}
}

/* Drop the wide kicker tracking on narrow phones so the uppercase label never
   strains or wraps in the constrained intro column. */
@media (max-width: 640px) {
	body.aibt-universal .universal-process--cards-grid .universal-process__kicker {
		letter-spacing: 0 !important;
	}
}

/* Respect reduced-motion: drop the card lift + transition, keep the (non-motion)
   border-color hover affordance. */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-process--cards-grid .universal-process__step {
		transition: none !important;
	}
	body.aibt-universal .universal-process--cards-grid .universal-process__step:hover {
		transform: none !important;
	}
}
