/**
 * Variant CSS: team--scalable-name-strip-tiles
 * Layer 2 — Path B team role (2026-06-10), Element Count 5+.
 *
 * Scalable grid of full-bleed 4:5 portrait tiles where each member's name + role
 * sit on a dark scrim strip overlaying the BOTTOM of their own photo (cinematic /
 * "poster" feel, not separate cards under the images). 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); CSS turns the columns wrapper
 * into a real grid (auto-fill, minmax) so ANY N reflows 4→3→2→1. WP core pins
 * .wp-block-columns to flex/nowrap ≥782px → we override display:grid. The strip is
 * absolutely anchored to each member tile and text uses --on-dark over a gradient
 * scrim (KI-020-safe: never a bg token as fg; the strip's own dark gradient
 * guarantees contrast regardless of the photo behind it). Tokens only; rgba used
 * only for the photo-legibility scrim.
 */

body.aibt-universal .universal-team--scalable-name-strip-tiles {
	background: var(--background);
	color: var(--text-primary);
}

/* === Intro ================================================================= */
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__intro {
	margin-bottom: var(--space-xl);
}
body.aibt-universal .universal-team--scalable-name-strip-tiles .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--scalable-name-strip-tiles .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--scalable-name-strip-tiles .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;
}

/* === Auto-fill tile grid — reflows for any member count ==================== */
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__grid {
	display: grid !important; /* override WP-core flex/nowrap on .wp-block-columns */
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 230px), 1fr));
	gap: var(--space-sm);
	align-items: stretch;
}
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__member {
	margin: 0 !important; /* neutralise WP-core column margins */
	position: relative;
	display: block;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--background-card);
	box-shadow: var(--decor-shadow-elevated, 0 14px 40px rgba(0, 0, 0, 0.12));
	transition: transform var(--duration-fast) var(--ease-standard);
}
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__member:hover,
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__member:focus-within {
	transform: translateY(-3px);
}

/* === Full-bleed portrait — fills the whole tile =========================== */
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__photo {
	margin: 0 !important;
	display: block;
	width: 100%;
}
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__photo img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	filter: var(--photo-filter, none);
	transition: transform var(--duration-medium) var(--ease-expressive);
}
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__member:hover .universal-team__photo img {
	transform: scale(1.05);
}

/* === Name strip — scrim overlay on the photo bottom ======================== */
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__strip {
	position: absolute;
	inset: auto 0 0 0; /* pin to the bottom edge of the tile */
	padding: var(--space-7) var(--space-md) var(--space-md);
	background: linear-gradient(
		to top,
		rgba(15, 18, 22, 0.92) 0%,
		rgba(15, 18, 22, 0.72) 45%,
		rgba(15, 18, 22, 0) 100%
	);
	pointer-events: none; /* strip is decorative; never blocks the focusable tile */
}
body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__name {
	font-family: var(--font-display) !important;
	font-size: var(--text-lg) !important;
	font-weight: 600 !important;
	line-height: 1.2 !important;
	color: var(--on-dark, #FFFFFF) !important;
	margin: 0 0 var(--space-3xs) 0 !important;
}
body.aibt-universal .universal-team--scalable-name-strip-tiles .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(--on-dark, #FFFFFF) !important;
	opacity: 0.88;
	margin: 0 !important;
}

/* === Responsive ============================================================ */
@media (max-width: 959px) {
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__grid {
		grid-template-columns: repeat(auto-fill, minmax(min(100%, 190px), 1fr));
	}
}

/* Mobile (≤640): two columns; ease the kicker tracking so it never crowds. */
@media (max-width: 640px) {
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__grid {
		grid-template-columns: repeat(2, 1fr);
	}
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__strip {
		padding: var(--space-6) var(--space-sm) var(--space-sm);
	}
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__name {
		font-size: var(--text-base) !important;
	}
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__kicker {
		letter-spacing: var(--tracking-wider) !important;
	}
}

/* Respect reduced-motion — neutralise portrait zoom + lift. */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__photo img,
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__member {
		transition: none;
	}
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__member:hover {
		transform: none;
	}
	body.aibt-universal .universal-team--scalable-name-strip-tiles .universal-team__member:hover .universal-team__photo img {
		transform: none;
	}
}
