/**
 * Variant CSS: team--scalable-masonry-portraits
 * Layer 2 — Path B team role (2026-06-10), Element Count 5+.
 *
 * Scalable masonry wall of portraits (CSS multi-columns) with deliberately VARIED
 * heights (alternating 3:4 / 1:1 / 4:5 per :nth-child) and name + role under each
 * photo. Each member is one self-contained block that never splits across columns
 * (break-inside: avoid) → an irregular, editorial "face wall" with a natural
 * rhythm. 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 `column-count` so portraits flow top-to-bottom then wrap, and
 * the count steps 4→3→2→1 by breakpoint for ANY N. WP core flex on .wp-block-columns
 * is overridden with display:block + columns. Tokens only; caption text is
 * --text-primary / --text-secondary (never a bg token as fg, KI-020).
 */

body.aibt-universal .universal-team--scalable-masonry-portraits {
	background: var(--background);
	color: var(--text-primary);
}

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

/* === Masonry columns — flows + wraps for any member count ================== */
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__grid {
	display: block !important; /* override WP-core flex on .wp-block-columns */
	column-count: 4;
	column-gap: var(--space-md);
}
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__member {
	margin: 0 0 var(--space-md) 0 !important; /* vertical rhythm; column-gap = horizontal */
	display: block; /* inline-block/flex would break column flow */
	break-inside: avoid; /* keep photo + caption together in one column */
	-webkit-column-break-inside: avoid;
	background: var(--background-card);
	border: var(--decor-border-width, 1px) solid var(--divider-primary);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition:
		border-color var(--duration-fast) var(--ease-standard),
		box-shadow var(--duration-fast) var(--ease-standard);
}
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__member:hover,
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__member:focus-within {
	border-color: var(--accent);
	box-shadow: var(--decor-shadow-elevated, 0 16px 44px rgba(0, 0, 0, 0.12));
}

/* === Portrait — varied aspect per position for the masonry rhythm ========== */
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__photo {
	margin: 0 !important;
	display: block;
	width: 100%;
}
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__photo img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 5; /* default height */
	object-fit: cover;
	filter: var(--photo-filter, none);
	transition: transform var(--duration-medium) var(--ease-expressive);
}
/* Alternate heights so the columns stagger (works for any N via nth-child cycle). */
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__member:nth-child(3n + 1) .universal-team__photo img {
	aspect-ratio: 3 / 4;
}
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__member:nth-child(3n + 2) .universal-team__photo img {
	aspect-ratio: 1;
}
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__member:nth-child(3n + 3) .universal-team__photo img {
	aspect-ratio: 4 / 5;
}
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__member:hover .universal-team__photo img {
	transform: scale(1.04);
}

/* === Caption (name + role under each portrait) ============================= */
body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__caption {
	padding: var(--space-sm) var(--space-md) var(--space-md);
}
body.aibt-universal .universal-team--scalable-masonry-portraits .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--scalable-masonry-portraits .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 — step the column count down ============================== */
@media (max-width: 959px) {
	body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__grid {
		column-count: 3;
	}
}
@media (max-width: 781px) {
	body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__grid {
		column-count: 2;
	}
}
@media (max-width: 480px) {
	body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__grid {
		column-count: 1;
	}
	body.aibt-universal .universal-team--scalable-masonry-portraits .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--scalable-masonry-portraits .universal-team__photo img {
		transition: none;
	}
	body.aibt-universal .universal-team--scalable-masonry-portraits .universal-team__member:hover .universal-team__photo img {
		transform: none;
	}
}
