/**
 * Variant CSS: team--quad-numeral-side-cards
 * Layer 2 — Path B team role (2026-06-10).
 *
 * Dedicated layout for EXACTLY four people: a 2×2 grid of cards, each card split
 * into a left numeral rail (oversized editorial ordinal 01–04, accent-tinted, low
 * weight in the visual stack) and a content column (4:5 portrait + name + role +
 * short bio). The dominant typographic side ordinal gives a magazine / table-of-
 * contents feel — distinct from quad-numbered-roster (small number badge) and from
 * quad-portrait-2x2 (no numeral). Card internal grid is `auto minmax(0,1fr)` so the
 * numeral lives in its own rail and never pushes content off-edge. Text stays --ink
 * (polarity-aware); role + numeral lean on --accent. Portraits are swapped by the
 * photo system. Every selector scoped to the variant.
 */

body.aibt-universal .universal-team--quad-numeral-side-cards {
	padding-block: calc(clamp(3rem, 7vw, 5rem) * var(--density, 1));
}

/* === Intro ================================================================= */
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__intro {
	margin-bottom: clamp(2rem, 4vw, 3rem);
}
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__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 0 var(--space-sm) 0 !important;
}
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__headline {
	font-family: var(--font-display) !important;
	color: var(--ink) !important;
	margin: 0 0 var(--space-sm) 0 !important;
}
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__deck {
	font-family: var(--font-body) !important;
	font-size: var(--text-lg) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--ink) !important;
	opacity: 0.76;
	max-width: 56ch;
	margin: 0 !important;
}

/* === 2×2 grid ============================================================== */
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__grid {
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	gap: clamp(1.6rem, 3.5vw, 2.8rem) !important;
	align-items: start;
}

/* === Member card =========================================================== */
/* `auto minmax(0,1fr)`: numeral rail keeps its intrinsic width; content takes the
   rest and can shrink to 0 — the oversized numeral can never push content off-edge. */
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__member {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	column-gap: clamp(0.75rem, 1.6vw, 1.25rem);
	align-items: start;
	min-width: 0;
}

/* === Side numeral rail (decorative, not bound) ============================= */
/* Accent-tint via color-mix so it reads as decoration, never invisible, never
   overpowering. Never a bg-token as foreground (KI-020). */
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__numeral {
	font-family: var(--font-display) !important;
	font-size: clamp(3.25rem, 7vw, 5.25rem) !important;
	font-weight: 700 !important;
	line-height: 0.82 !important;
	letter-spacing: -0.04em !important;
	color: color-mix(in srgb, var(--accent) 38%, transparent) !important;
	margin: 0 !important;
	padding: 0 !important;
	align-self: start;
	/* Anchor the numeral to the top of the portrait column (no extra leading gap). */
	margin-top: -0.08em !important;
	-webkit-user-select: none;
	user-select: none;
	pointer-events: none;
}

/* === Content column (portrait + text) ====================================== */
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__content {
	min-width: 0;
}
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__photo {
	margin: 0 0 var(--space-md) 0 !important;
	border-radius: var(--decor-radius);
	overflow: hidden;
}
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__photo img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	border-radius: var(--decor-radius);
	filter: var(--photo-filter, none);
	/* Restrained premium portrait zoom on card hover. */
	transition: transform var(--duration-medium) var(--ease-elegant);
}
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__member:hover .universal-team__photo img {
	transform: scale(1.04);
}

/* === Text ================================================================== */
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__name {
	font-family: var(--font-display) !important;
	font-size: clamp(1.25rem, 2.4vw, 1.6rem) !important;
	font-weight: 600 !important;
	line-height: 1.18 !important;
	letter-spacing: -0.01em !important;
	color: var(--ink) !important;
	margin: 0 0 0.2rem 0 !important;
}
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__role {
	font-family: var(--font-body) !important;
	font-size: var(--text-sm) !important;
	font-weight: 600 !important;
	letter-spacing: var(--tracking-wide) !important;
	text-transform: uppercase !important;
	color: var(--accent) !important;
	margin: 0 0 var(--space-xs) 0 !important;
}
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__bio {
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--ink) !important;
	opacity: 0.78;
	margin: 0 !important;
	max-width: 42ch;
}

/* === Focus-visible (keyboard) ============================================== */
body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__photo img:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
}

/* === Responsive ============================================================ */
/* Cap wide uppercase tracking on small screens (A5). */
@media (max-width: 640px) {
	body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__kicker,
	body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__role {
		letter-spacing: 0 !important;
	}
}

/* Mobile (≤640): single column; numeral rail shrinks but stays in its own column. */
@media (max-width: 640px) {
	body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__grid {
		grid-template-columns: 1fr !important;
		gap: 2rem !important;
	}
	body.aibt-universal .universal-team--quad-numeral-side-cards .universal-team__numeral {
		font-size: clamp(2.5rem, 12vw, 3.5rem) !important;
	}
}
