/**
 * Variant CSS: team--quad-numbered-roster
 * Layer 2 — Path B team role (count-4 expansion 2026-06-10).
 *
 * Dedicated layout for EXACTLY four people: a vertical "roster" of four rows,
 * each = a big ordinal + a circular photo + name / role / short bio aligned on
 * one line, with a hairline rule between rows. The table-of-contents rhythm
 * sets this apart from the carded grid, the calm 2×2, the centered headshot
 * row, the zigzag bio rows, and the lead + trio split. Text is --ink
 * (polarity-aware); ordinal + role lean on --accent. Photos swapped by the
 * photo system. Every selector scoped to the variant.
 */

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

/* === Intro ================================================================= */
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__intro {
	margin-bottom: clamp(2rem, 4vw, 3rem);
}
body.aibt-universal .universal-team--quad-numbered-roster .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-2) 0 !important;
}
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__headline {
	font-family: var(--font-display) !important;
	color: var(--ink) !important;
	margin: 0 0 var(--space-3) 0 !important;
}
body.aibt-universal .universal-team--quad-numbered-roster .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;
}

/* === Roster ================================================================ */
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__roster {
	display: flex;
	flex-direction: column;
}

/* === Row =================================================================== */
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__row {
	gap: clamp(1.1rem, 2.6vw, 2rem) !important;
	align-items: center;
	padding-block: calc(clamp(1.1rem, 2.4vw, 1.7rem) * var(--density, 1));
}

/* Big decorative ordinal. */
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__ordinal {
	flex: 0 0 auto;
	width: 2.4ch;
	font-family: var(--font-display) !important;
	font-size: clamp(1.6rem, 3.4vw, 2.6rem) !important;
	font-weight: 600 !important;
	line-height: 1 !important;
	letter-spacing: -0.02em !important;
	font-variant-numeric: tabular-nums;
	color: var(--accent) !important;
	opacity: 0.55;
	margin: 0 !important;
	text-align: center;
}

/* Circular photo. */
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__photo {
	flex: 0 0 auto;
	width: clamp(64px, 9vw, 92px);
	margin: 0 !important;
	border-radius: var(--radius-pill);
	overflow: hidden;
}
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__photo img {
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: var(--radius-pill);
	filter: var(--photo-filter, none);
}

/* === Text body ============================================================= */
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__body {
	flex: 1 1 auto;
	min-width: 0;
}
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__name {
	font-family: var(--font-display) !important;
	font-size: clamp(1.2rem, 2.4vw, 1.55rem) !important;
	font-weight: 600 !important;
	line-height: 1.18 !important;
	letter-spacing: -0.01em !important;
	color: var(--ink) !important;
	margin: 0 0 0.15rem 0 !important;
}
body.aibt-universal .universal-team--quad-numbered-roster .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-2) 0 !important;
}
body.aibt-universal .universal-team--quad-numbered-roster .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: 60ch;
}

/* === Hairline rule ========================================================= */
body.aibt-universal .universal-team--quad-numbered-roster .universal-team__rule {
	border: 0 !important;
	border-top: 1px solid var(--divider-primary) !important;
	background: transparent !important;
	margin: 0 !important;
	opacity: 0.7;
}

/* === Focus-visible (keyboard) ============================================== */
body.aibt-universal .universal-team--quad-numbered-roster .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-numbered-roster .universal-team__kicker,
	body.aibt-universal .universal-team--quad-numbered-roster .universal-team__role {
		letter-spacing: 0 !important;
	}
}

/* Mobile (≤640): ordinal + photo on a top line, body wraps below full-width. */
@media (max-width: 640px) {
	body.aibt-universal .universal-team--quad-numbered-roster .universal-team__row {
		flex-wrap: wrap !important;
		gap: 0.75rem 1rem !important;
	}
	body.aibt-universal .universal-team--quad-numbered-roster .universal-team__body {
		flex: 1 1 100%;
	}
}
