/* SOS Home Shell (premium hero homepage-only)
 * Scope: body.sos-home-elevation
 * Purpose: canonical base layer for the premium hero homepage (front-page.php),
 *          decoupled from legacy preview CSS (home-rebuild.css).
 */

body.sos-home-elevation {
	--sos-bg: #08152d;
	--sos-panel: #102348;
	--sos-panel-soft: rgba(16, 35, 72, 0.72);
	--sos-accent: #49e9b9;
	--sos-accent-dark: #122b33;
	--sos-text: #f7fbff;
	--sos-text-soft: rgba(247, 251, 255, 0.9);
	--sos-border: rgba(255, 255, 255, 0.12);
	--sos-shadow: 0 16px 40px rgba(0, 0, 0, 0.22);
	--sos-font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

	margin: 0;
	background:
		radial-gradient(circle at top right, rgba(73, 233, 185, 0.28), transparent 28rem),
		linear-gradient(180deg, #0d1c3d 0%, #08152d 100%);
	color: var(--sos-text);
	font-family: var(--sos-font-sans);
	line-height: 1.5;
}

body.sos-home-elevation * {
	box-sizing: border-box;
}

body.sos-home-elevation a {
	color: inherit;
	text-decoration: none;
}

body.sos-home-elevation a:focus-visible,
body.sos-home-elevation summary:focus-visible {
	outline: 3px solid var(--sos-accent);
	outline-offset: 4px;
}

body.sos-home-elevation .sos-home-preview-shell {
	min-height: 100vh;
}

body.sos-home-elevation .sos-lite-header {
	position: sticky;
	top: 0;
	z-index: 20;
	backdrop-filter: blur(12px);
	background: rgba(8, 21, 45, 0.92);
	border-bottom: 1px solid var(--sos-border);
}

body.sos-home-elevation .sos-lite-header__inner,
body.sos-home-elevation .sos-home-hero__inner {
	width: min(100% - 2rem, 72rem);
	margin: 0 auto;
}

body.sos-home-elevation .sos-lite-header__inner {
	min-height: 4.75rem;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 1rem;
}

body.sos-home-elevation .sos-lite-brand {
	display: inline-flex;
	align-items: center;
}

body.sos-home-elevation .sos-lite-brand__wordmark {
	display: block;
	width: clamp(11.75rem, 31vw, 15rem);
	height: clamp(1.85rem, 5vw, 2.45rem);
	object-fit: cover;
	object-position: center 72%;
	filter: drop-shadow(0 2px 10px rgba(0, 0, 0, 0.22));
}

body.sos-home-elevation .sos-home-hero__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 4.125rem;
	min-width: 12.5rem;
	padding: 1.1rem 1.75rem;
	border-radius: 1.1rem;
	border: 1px solid rgba(73, 233, 185, 0.35);
	background: linear-gradient(135deg, #0f6e61 0%, #08463e 100%);
	color: rgba(247, 251, 255, 0.98);
	font-weight: 800;
	font-size: clamp(1rem, 2.2vw, 1.1rem);
	line-height: 1.1;
	letter-spacing: -0.015em;
	box-shadow: 0 14px 30px rgba(8, 70, 62, 0.28);
	text-align: center;
	text-decoration: none;
}

body.sos-home-elevation .sos-home-hero__cta--secondary {
	border: 1px solid var(--sos-border);
	background: rgba(255, 255, 255, 0.05);
	color: rgba(247, 251, 255, 0.96);
	box-shadow: none;
}

body.sos-home-elevation .sos-home-hero__cta:focus-visible {
	outline: 3px solid rgba(247, 251, 255, 0.95);
	outline-offset: 3px;
	box-shadow:
		0 0 0 3px rgba(73, 233, 185, 0.42),
		0 14px 30px rgba(8, 70, 62, 0.3);
}

body.sos-home-elevation .sos-home-elevation-help-why__gap {
	height: clamp(2.25rem, 4vw, 3rem);
}

body.sos-home-elevation .sos-home-reviews-proof {
	width: 100%;
	padding: 0.75rem 0 4.5rem;
	color: #102348;
	--sos-proof-bg: #ffffff;
	--sos-proof-bg-soft: #f5fbff;
	--sos-proof-border: rgba(16, 35, 72, 0.08);
	--sos-proof-shadow: 0 18px 45px rgba(18, 35, 72, 0.12);
	--sos-proof-text: #102348;
	--sos-proof-text-soft: rgba(16, 35, 72, 0.72);
	--sos-proof-accent: #49e9b9;
	--sos-proof-accent-dark: #102348;
}

body.sos-home-elevation .sos-home-reviews-proof__inner {
	width: min(100% - 1.5rem, 66rem);
	margin: 0 auto;
	padding: 0;
}

body.sos-home-elevation .sos-home-reviews-proof__panel {
	padding: 1.5rem;
	border: 1px solid var(--sos-proof-border);
	border-radius: 1.75rem;
	background: linear-gradient(180deg, var(--sos-proof-bg) 0%, var(--sos-proof-bg-soft) 100%);
	box-shadow: var(--sos-proof-shadow);
}

body.sos-home-elevation .sos-home-reviews-proof__eyebrow,
body.sos-home-elevation .sos-home-reviews-proof__featured-label {
	margin: 0;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--sos-proof-accent-dark);
}

body.sos-home-elevation .sos-home-reviews-proof__topline {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
}

body.sos-home-elevation .sos-home-reviews-proof__summary-row {
	margin-top: 1.25rem;
	display: grid;
	grid-template-columns: 1.2fr 0.8fr;
	gap: 1.5rem;
	align-items: start;
}

body.sos-home-elevation .sos-home-reviews-proof__title {
	margin: 0;
	font-size: clamp(1.7rem, 3vw, 2.2rem);
	line-height: 1.08;
	letter-spacing: -0.02em;
	color: var(--sos-proof-text);
}

body.sos-home-elevation .sos-home-reviews-proof__count {
	margin: 0.85rem 0 0;
	display: inline-flex;
	align-items: baseline;
	gap: 0.45rem;
	padding: 0.48rem 0.72rem;
	border-radius: 999px;
	background: rgba(16, 35, 72, 0.08);
	color: var(--sos-proof-text);
}

body.sos-home-elevation .sos-home-reviews-proof__count-value {
	font-size: 1rem;
	font-weight: 820;
	letter-spacing: -0.01em;
}

body.sos-home-elevation .sos-home-reviews-proof__count-label {
	font-size: 0.9rem;
	font-weight: 640;
	color: rgba(16, 35, 72, 0.72);
}

body.sos-home-elevation .sos-home-reviews-proof__trust {
	padding: 1.25rem;
	border-radius: 1.4rem;
	border: 1px solid rgba(16, 35, 72, 0.1);
	background: rgba(73, 233, 185, 0.08);
	display: grid;
	gap: 0.35rem;
	justify-items: start;
}

body.sos-home-elevation .sos-home-reviews-proof__rating {
	margin: 0;
	font-size: 2.2rem;
	font-weight: 800;
	letter-spacing: -0.03em;
	color: var(--sos-proof-text);
}

body.sos-home-elevation .sos-home-reviews-proof__rating-scale {
	font-size: 1.1rem;
	font-weight: 700;
	color: rgba(16, 35, 72, 0.7);
}

body.sos-home-elevation .sos-home-reviews-proof__stars {
	margin: 0;
	color: #f5b301;
	letter-spacing: 0.08em;
}

body.sos-home-elevation .sos-home-reviews-proof__actions {
	margin-top: 0.45rem;
}

body.sos-home-elevation .sos-home-reviews-proof__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.8rem;
	padding: 0.65rem 1rem;
	border-radius: 999px;
	background: rgba(16, 35, 72, 0.1);
	color: var(--sos-proof-text);
	font-weight: 800;
	letter-spacing: -0.01em;
	transition: transform 160ms ease, opacity 160ms ease;
}

body.sos-home-elevation .sos-home-reviews-proof__cta:hover {
	transform: translateY(-1px);
}

body.sos-home-elevation .sos-home-reviews-proof__cta:focus-visible {
	outline: 2px solid rgba(73, 233, 185, 0.7);
	outline-offset: 3px;
}

body.sos-home-elevation .sos-home-reviews-proof__content {
	margin-top: 1.5rem;
	display: grid;
	gap: 1rem;
}

body.sos-home-elevation .sos-home-reviews-proof__featured,
body.sos-home-elevation .sos-home-reviews-proof__card {
	padding: 1.25rem;
	border-radius: 1.4rem;
	border: 1px solid rgba(16, 35, 72, 0.08);
	background: rgba(255, 255, 255, 0.85);
}

body.sos-home-elevation .sos-home-reviews-proof__quote {
	margin: 0.75rem 0 0;
	color: var(--sos-proof-text);
}

body.sos-home-elevation .sos-home-reviews-proof__quote p {
	margin: 0;
	color: rgba(16, 35, 72, 0.86);
	line-height: 1.65;
}

body.sos-home-elevation .sos-home-reviews-proof__meta {
	margin-top: 0.9rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem 0.65rem;
	align-items: baseline;
}

body.sos-home-elevation .sos-home-reviews-proof__author {
	font-style: normal;
	font-weight: 800;
	color: var(--sos-proof-text);
}

body.sos-home-elevation .sos-home-reviews-proof__context {
	color: rgba(16, 35, 72, 0.7);
	font-weight: 650;
}

@media (max-width: 64rem) {
	body.sos-home-elevation .sos-home-reviews-proof__summary-row {
		grid-template-columns: 1fr;
	}
}
