/**
 * Variant CSS: team--numbered-roster-cards
 * Layer 2 — Path B team role (2026-06-10).
 *
 * Count-adaptive roster: each member is a card with a large editorial index
 * number above a circular avatar, then name / role / bio. The loader clones or
 * trims .universal-team__member to the brief's headcount (4–12), so the grid
 * MUST reflow at any N — handled with flex-wrap + a fixed-ish flex-basis that
 * yields 3-up on desktop, 2-up on tablet, 1-up on mobile regardless of count.
 */

body.aibt-universal .universal-team--numbered-roster-cards {
	background: var(--background);
	color: var(--text-primary);
	text-align: center;
}

body.aibt-universal .universal-team.universal-team--numbered-roster-cards .has-text-align-center {
	margin-inline: auto !important;
}

/* === Intro ================================================================= */
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__intro {
	margin: 0 auto var(--space-xl) auto;
}
body.aibt-universal .universal-team--numbered-roster-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 auto var(--space-sm) auto !important;
}
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__headline {
	font-family: var(--font-display) !important;
	color: var(--text-primary) !important;
	margin: 0 auto var(--space-sm) auto !important;
}
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__deck {
	font-family: var(--font-body) !important;
	font-size: var(--text-lg) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--text-secondary) !important;
	margin: 0 auto !important;
}

/* === Roster grid — wraps to any member count =============================== */
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__grid {
	flex-wrap: wrap;
	gap: var(--space-lg);
	align-items: stretch;
}
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__member {
	/* 3-up baseline: each card claims ~1/3 minus the gap, wrapping after 3. */
	flex: 1 1 calc((100% - 2 * var(--space-lg)) / 3);
	min-width: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: var(--space-lg) var(--space-md) var(--space-md);
	background: var(--background-card);
	border: var(--decor-border-width, 1px) solid var(--line);
	border-radius: var(--decor-radius);
	/* Lift on hover — restrained editorial elevation. */
	transition:
		transform var(--duration-fast) var(--ease-default),
		box-shadow var(--duration-fast) var(--ease-default),
		border-color var(--duration-fast) var(--ease-default);
}
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__member:hover {
	transform: translateY(-4px);
	box-shadow: var(--decor-shadow-elevated);
	border-color: var(--divider-accent);
}

/* === Large editorial index number ========================================= */
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__index {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: 700;
	line-height: 1;
	letter-spacing: var(--tracking-normal);
	color: var(--accent);
	opacity: 0.55;
	margin-bottom: var(--space-sm);
	font-variant-numeric: tabular-nums;
}

/* === Circular portrait ===================================================== */
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__photo {
	margin: 0 0 var(--space-sm) 0;
	width: 116px;
	height: 116px;
	border-radius: var(--radius-pill, 999px);
	overflow: hidden;
	box-shadow: 0 0 0 var(--space-3xs) var(--accent-fade);
}
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__photo img {
	width: 100%;
	height: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	border-radius: var(--radius-pill, 999px);
	filter: var(--photo-filter, none);
	transition: transform var(--duration-medium) var(--ease-elegant);
}
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__member:hover .universal-team__photo img {
	transform: scale(1.05);
}

/* === Text ================================================================== */
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__name {
	font-family: var(--font-display) !important;
	font-size: var(--text-xl) !important;
	color: var(--text-primary) !important;
	margin: 0 0 var(--space-3xs) 0 !important;
}
body.aibt-universal .universal-team--numbered-roster-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;
	color: var(--accent) !important;
	margin: 0 0 var(--space-2xs) 0 !important;
}
body.aibt-universal .universal-team--numbered-roster-cards .universal-team__bio {
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--text-secondary) !important;
	margin: 0 !important;
}

/* === Responsive ============================================================ */
/* Tablet (641–959): 2-up. */
@media (max-width: 959px) {
	body.aibt-universal .universal-team--numbered-roster-cards .universal-team__member {
		flex-basis: calc((100% - var(--space-lg)) / 2);
	}
}

/* Mobile (≤640): single column. */
@media (max-width: 640px) {
	body.aibt-universal .universal-team--numbered-roster-cards .universal-team__member {
		flex-basis: 100%;
	}
	body.aibt-universal .universal-team--numbered-roster-cards .universal-team__kicker {
		letter-spacing: var(--tracking-wider) !important;
	}
}
