/**
 * SSRP LP — CTA Banner block.
 *
 * Figma "Questions? Schedule a call" pattern — a single horizontal card with
 * an optional rounded image on the left, copy in the middle, and the CTA on
 * the right. Outer section stays plain; the card itself is the visual unit.
 *
 * Three variants:
 *   muted  → white card on page bg (Figma default).
 *   ink    → dark card.
 *   brand  → brand gradient card.
 */

.ssrp-lp-section--cta-banner {
	padding-block: clamp(1.25rem, 3vw, 2rem);
}

.ssrp-lp-cta-banner__layout {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: clamp(1rem, 3vw, 2rem);
	align-items: center;
	padding: clamp(1.25rem, 2.5vw, 1.75rem);
	background: var(--ssrp-lp-surface);
	border: 1px solid var(--ssrp-lp-border);
	border-radius: var(--ssrp-lp-radius);
}

/* Without image, collapse to copy + actions. */
.ssrp-lp-cta-banner:not(.ssrp-lp-cta-banner--with-image) .ssrp-lp-cta-banner__layout {
	grid-template-columns: 1fr auto;
}

.ssrp-lp-cta-banner__copy {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	min-width: 0;
}

/* Primary CTA + optional small circular icon link. */
.ssrp-lp-cta-banner__actions {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	justify-self: end;
}

.ssrp-lp-cta-banner__icon-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	border-radius: 999px;
	background: var(--ssrp-lp-ink);
	color: var(--ssrp-lp-surface);
	text-decoration: none;
	transition: transform 150ms ease-out, background-color var(--ssrp-lp-transition);
}
.ssrp-lp-cta-banner__icon-link:hover,
.ssrp-lp-cta-banner__icon-link:focus-visible {
	transform: translateY(-1px);
	background: #000;
	color: var(--ssrp-lp-surface);
}
.ssrp-lp-cta-banner__icon-link svg {
	width: 1rem;
	height: 1rem;
	display: block;
}

.ssrp-lp-cta-banner__cta {
	padding: 0.875rem 1.5rem;
}

.ssrp-lp-cta-banner__header {
	margin: 0;
}

.ssrp-lp-cta-banner__header .ssrp-lp-heading {
	font-size: clamp(1.125rem, 1.8vw, 1.375rem);
	line-height: 1.25;
	margin: 0;
}

.ssrp-lp-cta-banner__header .ssrp-lp-subhead {
	font-size: 0.9375rem;
	line-height: 1.4;
	margin: 0.25rem 0 0;
	max-width: 60ch;
}

.ssrp-lp-cta-banner__cta {
	align-self: center;
	justify-self: end;
}

/* Rounded media block (Figma shows a team headshot). */
.ssrp-lp-cta-banner__media {
	position: relative;
	border-radius: var(--ssrp-lp-radius-sm);
	overflow: hidden;
	width: clamp(5rem, 10vw, 7rem);
	aspect-ratio: 1 / 1;
	background: var(--ssrp-lp-border-soft);
	flex-shrink: 0;
}

.ssrp-lp-cta-banner__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

@media (max-width: 720px) {
	.ssrp-lp-cta-banner__layout,
	.ssrp-lp-cta-banner:not(.ssrp-lp-cta-banner--with-image) .ssrp-lp-cta-banner__layout {
		grid-template-columns: 1fr;
		text-align: center;
		justify-items: center;
		gap: 1rem;
	}
	.ssrp-lp-cta-banner__media {
		width: 6rem;
	}
	.ssrp-lp-cta-banner__actions {
		justify-self: stretch;
		justify-content: center;
		width: 100%;
	}
	.ssrp-lp-cta-banner__cta {
		flex: 1 1 auto;
	}
}

/* --------------------------------------------------------------------------
   Variant: ink (dark card).
   -------------------------------------------------------------------------- */
.ssrp-lp-cta-banner--ink .ssrp-lp-cta-banner__layout {
	background: var(--ssrp-lp-ink);
	border-color: var(--ssrp-lp-ink);
	color: var(--ssrp-lp-surface);
}
.ssrp-lp-cta-banner--ink .ssrp-lp-eyebrow { color: var(--ssrp-lp-surface); }
.ssrp-lp-cta-banner--ink .ssrp-lp-heading { color: var(--ssrp-lp-surface); }
.ssrp-lp-cta-banner--ink .ssrp-lp-subhead { color: rgb(255 255 255 / 0.75); }

/* --------------------------------------------------------------------------
   Variant: brand.
   -------------------------------------------------------------------------- */
.ssrp-lp-cta-banner--brand .ssrp-lp-cta-banner__layout {
	background: linear-gradient(135deg, var(--ssrp-lp-brand) 0%, var(--ssrp-lp-brand-dark) 100%);
	border-color: transparent;
	color: var(--ssrp-lp-surface);
}
.ssrp-lp-cta-banner--brand .ssrp-lp-eyebrow { color: rgb(255 255 255 / 0.9); }
.ssrp-lp-cta-banner--brand .ssrp-lp-heading { color: var(--ssrp-lp-surface); }
.ssrp-lp-cta-banner--brand .ssrp-lp-subhead { color: rgb(255 255 255 / 0.9); }
.ssrp-lp-cta-banner--brand .ssrp-lp-btn {
	background: var(--ssrp-lp-surface);
	color: var(--ssrp-lp-ink);
	border-color: var(--ssrp-lp-surface);
}
