/**
 * SSRP LP — Speakers block.
 *
 * Circular headshot grid with an optional headliner card shown larger above
 * the main grid.
 */

.ssrp-lp-section--speakers .ssrp-lp-section-header {
	max-width: 48rem;
	margin-inline: auto;
	margin-bottom: 1.25rem;
	align-items: center;
	text-align: center;
}

.ssrp-lp-section--speakers .ssrp-lp-subhead {
	margin-inline: auto;
}

/* --------------------------------------------------------------------------
   Headliner card — wider layout, image on one side, meta on the other.
   -------------------------------------------------------------------------- */
.ssrp-lp-speakers__headliner-wrap {
	margin: 2.5rem auto 2rem;
	max-width: 44rem;
}

.ssrp-lp-speakers__card--headliner {
	display: grid;
	grid-template-columns: 10rem minmax(0, 1fr);
	gap: 1.5rem;
	align-items: center;
	padding: 1.5rem;
	background: var(--ssrp-lp-surface);
	border: 1px solid var(--ssrp-lp-border);
	border-radius: var(--ssrp-lp-radius-lg);
	box-shadow: 0 12px 32px -20px rgb(3 7 18 / 0.15);
	text-align: left;
}

.ssrp-lp-speakers__card--headliner .ssrp-lp-speakers__photo {
	width: 10rem;
	height: 10rem;
	border-radius: 999px;
	overflow: hidden;
	background: var(--ssrp-lp-surface-muted);
}

.ssrp-lp-speakers__card--headliner .ssrp-lp-speakers__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ssrp-lp-speakers__card--headliner .ssrp-lp-speakers__name {
	font-size: 1.375rem;
	margin-bottom: 0.25rem;
}

@media (max-width: 640px) {
	.ssrp-lp-speakers__card--headliner {
		grid-template-columns: 1fr;
		text-align: center;
		justify-items: center;
	}
}

/* --------------------------------------------------------------------------
   Grid — circular headshots, 3–5 per row depending on viewport.
   -------------------------------------------------------------------------- */
.ssrp-lp-speakers__grid {
	margin: 2rem auto 0;
	max-width: 52rem;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
	gap: 2rem 1.5rem;
	justify-content: center;
}

.ssrp-lp-speakers__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.75rem;
	text-align: center;
}

.ssrp-lp-speakers__photo {
	width: 7rem;
	height: 7rem;
	border-radius: 999px;
	overflow: hidden;
	background: var(--ssrp-lp-surface);
	border: 1px solid var(--ssrp-lp-border);
	display: flex;
	align-items: center;
	justify-content: center;
}

.ssrp-lp-speakers__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ssrp-lp-speakers__placeholder {
	font-size: 2rem;
	font-weight: 700;
	color: var(--ssrp-lp-ink-muted);
}

.ssrp-lp-speakers__meta {
	display: flex;
	flex-direction: column;
	gap: 0.125rem;
	min-width: 0;
}

.ssrp-lp-speakers__name {
	margin: 0;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--ssrp-lp-ink);
}

.ssrp-lp-speakers__name a {
	color: inherit;
	text-decoration: none;
}

.ssrp-lp-speakers__name a:hover,
.ssrp-lp-speakers__name a:focus {
	color: var(--ssrp-lp-brand);
	text-decoration: underline;
}

.ssrp-lp-speakers__credentials {
	margin: 0;
	font-size: 0.875rem;
	color: var(--ssrp-lp-brand);
	font-weight: 600;
}

.ssrp-lp-speakers__company {
	margin: 0;
	font-size: 0.875rem;
	color: var(--ssrp-lp-ink-muted);
}

.ssrp-lp-speakers__footer {
	margin: 2rem auto 0;
	text-align: center;
	color: var(--ssrp-lp-ink-muted);
	font-size: 0.9375rem;
	max-width: 42rem;
}

.ssrp-lp-speakers__ctas {
	margin: 2rem auto 0;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
}

/* --------------------------------------------------------------------------
   Ink variant.
   -------------------------------------------------------------------------- */
.ssrp-lp-section--ink .ssrp-lp-speakers__card--headliner {
	background: rgba(255, 255, 255, 0.04);
	border-color: rgba(255, 255, 255, 0.1);
	box-shadow: none;
}

.ssrp-lp-section--ink .ssrp-lp-speakers__name {
	color: #fff;
}

.ssrp-lp-section--ink .ssrp-lp-speakers__company,
.ssrp-lp-section--ink .ssrp-lp-speakers__footer {
	color: rgba(255, 255, 255, 0.7);
}

.ssrp-lp-section--ink .ssrp-lp-speakers__photo {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.1);
}
