/**
 * Variant CSS: team--portrait-grid
 * Layer 2 — Path B team role (2026-05-28).
 * Dense 4-up portrait grid (portrait + name + role, no bio).
 * Every selector scoped to .universal-team--portrait-grid (no global leak).
 */

body.aibt-universal .universal-team--portrait-grid {
	background: var(--background);
	color: var(--text-primary);
	text-align: center;
}

body.aibt-universal .universal-team--portrait-grid .has-text-align-center {
	margin-inline: auto !important;
}

body.aibt-universal .universal-team--portrait-grid .universal-team__intro {
	margin-bottom: var(--space-xl);
	margin-inline: auto;
	text-align: center;
}
body.aibt-universal .universal-team--portrait-grid .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--portrait-grid .universal-team__headline {
	font-family: var(--font-display) !important;
	color: var(--text-primary) !important;
	margin: 0 auto var(--space-md) auto !important;
}
body.aibt-universal .universal-team--portrait-grid .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;
	max-width: 58ch;
}

body.aibt-universal .universal-team--portrait-grid .universal-team__grid {
	gap: var(--space-lg) var(--space-md) !important;
	flex-wrap: wrap;
}
body.aibt-universal .universal-team--portrait-grid .universal-team__member {
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: var(--space-3xs);
	flex-basis: calc(25% - var(--space-md)) !important;
	flex-grow: 1;
}
body.aibt-universal .universal-team--portrait-grid .universal-team__photo {
	margin: 0 0 var(--space-sm) 0 !important;
	overflow: hidden;
	border-radius: var(--decor-radius);
}
body.aibt-universal .universal-team--portrait-grid .universal-team__photo img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: var(--decor-radius);
	filter: var(--photo-filter, none);
	/* Subtle premium portrait zoom on member hover. */
	transition: transform var(--duration-medium) var(--ease-elegant);
}
body.aibt-universal .universal-team--portrait-grid .universal-team__member:hover .universal-team__photo img {
	transform: scale(1.04);
}
body.aibt-universal .universal-team--portrait-grid .universal-team__name {
	font-family: var(--font-display) !important;
	font-size: var(--text-xl) !important;
	font-weight: 600 !important;
	color: var(--text-primary) !important;
	margin: 0 !important;
	line-height: 1.2 !important;
}
body.aibt-universal .universal-team--portrait-grid .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 !important;
}

@media (max-width: 959px) {
	body.aibt-universal .universal-team--portrait-grid .universal-team__member {
		flex-basis: calc(50% - var(--space-md)) !important;
	}
}
@media (max-width: 600px) {
	body.aibt-universal .universal-team--portrait-grid .universal-team__member {
		flex-basis: 100% !important;
	}
}

/* Cap uppercase tracking on small screens (kicker + role) to avoid cramped wraps. */
@media (max-width: 640px) {
	body.aibt-universal .universal-team--portrait-grid .universal-team__kicker,
	body.aibt-universal .universal-team--portrait-grid .universal-team__role {
		letter-spacing: 0 !important;
	}
}

/* A8/A9 left-shift fix (2026-06-08): centered intro element(s) were max-width-capped by
   WP constrained layout but pinned left by horizontal margin:0. Force margin-inline:auto.
   Section class doubled -> specificity (0,4,1) beats h2.__headline-style rules; harmless on
   already-centered elements (auto margins compute to 0). Only left/right are overridden. */
body.aibt-universal .universal-team--portrait-grid.universal-team--portrait-grid .universal-team__kicker { margin-inline: auto !important; }
