/**
 * Variant CSS: testimonials--scalable-avatar-top-cards
 * Layer 2 — Path B testimonials role (2026-06-11).
 * "Faces first" grid: 6 cards, each with a circular avatar centered at the TOP,
 * then stars, quote, author + role. Scales/trims to the client's review count —
 * the loader chunks the cards into wp:columns rows of 3, so the grid is styled to
 * keep every chunk a clean 3-col row (2 col ≤900px, 1 col ≤600px).
 * Every selector scoped to .universal-testimonials--scalable-avatar-top-cards (no global leak).
 */

body.aibt-universal .universal-testimonials--scalable-avatar-top-cards {
	background: var(--background);
	color: var(--text-primary);
}

body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__intro {
	margin-bottom: var(--space-xl);
	text-align: center;
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__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;
	/* A8/A9: centered kicker in an alignfull constrained section keeps horizontal auto margins. */
	margin: 0 auto var(--space-sm) auto !important;
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__headline {
	font-family: var(--font-display) !important;
	color: var(--text-primary) !important;
	/* A8/A9: centered headline keeps horizontal auto margins. */
	margin: 0 auto !important;
}

/* Grid: each rendered chunk is a wp:columns row. Force 3 equal columns that wrap,
   so the trimmer's rows-of-3 read as a single even grid. */
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__grid {
	gap: var(--space-lg) !important;
	flex-wrap: wrap !important;
	align-items: stretch !important;
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__grid + .universal-testimonials__grid {
	margin-top: var(--space-lg);
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__card {
	flex: 1 1 calc((100% - 2 * var(--space-lg)) / 3) !important;
	min-width: 0 !important;
	background: var(--background-card, var(--background-alt)) !important;
	border: 1px solid var(--divider-primary);
	border-radius: var(--decor-radius);
	padding: var(--space-lg) var(--space-md) var(--space-md) !important;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	box-shadow: var(--decor-shadow-soft, none);
	transition: border-color var(--duration-fast) ease, transform var(--duration-fast) ease;
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__card:hover {
	border-color: var(--accent);
	transform: translateY(-3px);
}

/* Signature: round avatar centered at the top of the card. */
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__avatar {
	margin: 0 auto var(--space-md) auto !important;
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__avatar img {
	width: clamp(4rem, 6vw, 4.5rem) !important;
	height: clamp(4rem, 6vw, 4.5rem) !important;
	border-radius: 50% !important;
	object-fit: cover !important;
	display: block;
	margin-inline: auto !important;
	border: 2px solid var(--divider-primary);
}

body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__stars {
	color: var(--accent) !important;
	font-size: var(--text-base) !important;
	letter-spacing: 0.15em !important;
	margin: 0 auto var(--space-sm) auto !important;
	line-height: 1 !important;
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__quote {
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	line-height: var(--leading-relaxed) !important;
	color: var(--text-primary) !important;
	margin: 0 auto var(--space-md) auto !important;
	flex-grow: 1;
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__name {
	font-family: var(--font-display) !important;
	font-size: var(--text-base) !important;
	font-weight: 600 !important;
	color: var(--text-primary) !important;
	margin: 0 auto !important;
	line-height: 1.3 !important;
}
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__authorrole {
	font-family: var(--font-body) !important;
	font-size: var(--text-sm) !important;
	/* --text-secondary (not --text-muted): role is meaningful attribution text and must
	   clear AA 4.5:1 as normal-size body on the card background across all themes. */
	color: var(--text-secondary) !important;
	margin: var(--space-xxs, 0.25rem) auto 0 auto !important;
	line-height: 1.3 !important;
}

/* ≤900px → 2 columns. */
@media (max-width: 900px) {
	body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__card {
		flex-basis: calc((100% - var(--space-lg)) / 2) !important;
	}
}

/* ≤600px → 1 column. */
@media (max-width: 600px) {
	body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__card {
		flex-basis: 100% !important;
	}
	/* A5: cap uppercase kicker tracking on small screens to avoid line-break artifacts. */
	body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__kicker {
		letter-spacing: 0 !important;
	}
}

/* Respect reduced-motion: drop the card lift/transition for users who opt out. */
@media (prefers-reduced-motion: reduce) {
	body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__card {
		transition: none;
	}
	body.aibt-universal .universal-testimonials--scalable-avatar-top-cards .universal-testimonials__card:hover {
		transform: none;
	}
}

/* Keyboard focus: visible accent ring on any focusable link inside a card. */
body.aibt-universal .universal-testimonials--scalable-avatar-top-cards a:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 2px;
}
