/**
 * Variant CSS: team--headshot-grid-dense
 * Layer 2 — Path B team role (2026-06-10), Element Count 5+.
 *
 * Dense "contact-sheet" headshot grid for a larger team: square 1:1 portraits
 * sit edge-to-edge in a tight grid, each over a thin card surface with a hairline
 * border, and name + role live in a narrow caption bar BELOW the photo (never on
 * it). Reads as a compact directory wall, not airy cards. Authored as
 * wp:columns.universal-team__grid > wp:column.universal-team__member so the loader
 * clones/trims to the brief's exact headcount (5-12) and re-chunks client renders
 * into 3-up rows; CSS forces flex-wrap + a ~3-up flex-basis so the 6-member demo
 * (wraps 3+3) matches the rebuilt client output. WP core pins .wp-block-columns to
 * nowrap ≥782px → `flex-wrap: wrap !important`. Tokens only; caption text uses
 * --text-primary / --text-secondary (never --bg-main as fg, KI-020).
 */

body.aibt-universal .universal-team--headshot-grid-dense {
	background: var(--background);
	color: var(--text-primary);
}

/* === Intro ================================================================= */
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__intro {
	margin-bottom: var(--space-xl);
}
body.aibt-universal .universal-team--headshot-grid-dense .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--headshot-grid-dense .universal-team__headline {
	font-family: var(--font-display) !important;
	color: var(--text-primary) !important;
	margin: 0 0 var(--space-md) 0 !important;
}
body.aibt-universal .universal-team--headshot-grid-dense .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 !important;
}

/* === Dense grid — wraps to any member count (3-up baseline) ================ */
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__grid {
	flex-wrap: wrap !important; /* override WP-core nowrap on .wp-block-columns */
	gap: var(--space-md);
	align-items: stretch;
}
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__member {
	/* 3-up: each tile claims ~1/3 minus the gap; demo (6) wraps 3+3, matching
	   the loader's rebuilt 3-column client rows. */
	flex: 1 1 calc((100% - 2 * var(--space-md)) / 3) !important;
	min-width: 0;
	display: flex;
	flex-direction: column;
	background: var(--background-card);
	border: var(--decor-border-width, 1px) solid var(--line);
	border-radius: var(--decor-radius);
	overflow: hidden;
	transition:
		border-color var(--duration-fast) var(--ease-default),
		box-shadow var(--duration-fast) var(--ease-default);
}
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__member:hover,
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__member:focus-within {
	border-color: var(--divider-accent);
	box-shadow: var(--decor-shadow-elevated);
}

/* === Square headshot — fills the tile width, edge-to-edge ================== */
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__photo {
	margin: 0 !important;
	display: block;
	width: 100%;
}
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__photo img {
	display: block;
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	filter: var(--photo-filter, none);
	transition: transform var(--duration-medium) var(--ease-elegant);
}
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__member:hover .universal-team__photo img {
	transform: scale(1.04);
}

/* === Caption bar below the photo (thin, hairline-separated) ================ */
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__caption {
	padding: var(--space-sm) var(--space-md) var(--space-md);
	border-top: var(--decor-border-width, 1px) solid var(--line);
}
body.aibt-universal .universal-team--headshot-grid-dense .universal-team__name {
	font-family: var(--font-display) !important;
	font-size: var(--text-lg) !important;
	font-weight: 600 !important;
	line-height: 1.25 !important;
	color: var(--text-primary) !important;
	margin: 0 0 var(--space-3xs) 0 !important;
}
body.aibt-universal .universal-team--headshot-grid-dense .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 !important;
}

/* === Responsive ============================================================ */
/* Tablet (641–959): 2-up. */
@media (max-width: 959px) {
	body.aibt-universal .universal-team--headshot-grid-dense .universal-team__member {
		flex-basis: calc((100% - var(--space-md)) / 2) !important;
	}
}

/* Mobile (≤640): single column; ease the kicker tracking so it never crowds. */
@media (max-width: 640px) {
	body.aibt-universal .universal-team--headshot-grid-dense .universal-team__member {
		flex-basis: 100% !important;
	}
	body.aibt-universal .universal-team--headshot-grid-dense .universal-team__kicker {
		letter-spacing: var(--tracking-wider) !important;
	}
}

/* Respect reduced-motion — neutralise the portrait zoom. */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-team--headshot-grid-dense .universal-team__photo img {
		transition: none;
	}
	body.aibt-universal .universal-team--headshot-grid-dense .universal-team__member:hover .universal-team__photo img {
		transform: none;
	}
}
