/* Service detail — hero section + trust strip.
   Hero variants: Maps SEO uses .svc-hero-trust column; Ads + GEO use .svc-phone mockup. */

/* ---------- 1 · HERO ---------- */

.svc-hero {
	background: var(--ms-surface);
	padding: 48px var(--ms-pad-x) 80px;
	border-bottom: 1px solid var(--ms-line);
}

.svc-hero-crumb-wrap { padding-bottom: 36px; }

.svc-hero-grid {
	display: grid;
	grid-template-columns: 1fr 380px;
	gap: 64px;
	align-items: start;
}

.svc-hero-grid--wide-r { grid-template-columns: 1fr 440px; }
.svc-hero-grid--xwide-r { grid-template-columns: 1fr 460px; }

.svc-hero-title {
	font-size: 84px;
	line-height: 0.95;
	letter-spacing: -3px;
	font-weight: 800;
	max-width: 900px;
	margin: 0;
}

.svc-hero-sub {
	margin-top: 28px;
	font-size: 20px;
	line-height: 1.5;
	max-width: 640px;
	color: var(--ms-ink);
	opacity: 0.85;
}

.svc-hero-actions {
	margin-top: 36px;
	display: flex;
	gap: 18px;
	flex-wrap: wrap;
	align-items: center;
}

.svc-btn-primary {
	padding: 18px 26px;
	background: var(--ms-accent);
	color: var(--ms-surface);
	font-size: 16px;
	font-weight: 700;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	letter-spacing: 0.2px;
	border: 0;
}

.svc-btn-primary--lg {
	padding: 20px 30px;
	font-size: 17px;
	gap: 12px;
}

.svc-btn-primary--md {
	padding: 16px 22px;
	font-size: 15px;
	gap: 10px;
}

.svc-btn-tel {
	font-size: 16px;
	color: var(--ms-ink);
	text-decoration: none;
	font-weight: 700;
	border-bottom: 2px solid var(--ms-ink);
	padding-bottom: 2px;
}

/* Hero trust badge column (Maps SEO) */

.svc-hero-trust {
	border: 1px solid var(--ms-line);
	background: var(--ms-bg);
	padding: 28px;
}

.svc-hero-trust-row {
	display: flex;
	align-items: center;
	gap: 18px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--ms-line);
}

.svc-hero-trust-label {
	font-size: 11px;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--ms-muted);
	font-weight: 700;
}

.svc-hero-trust-h {
	font-size: 18px;
	font-weight: 500;
	letter-spacing: -0.3px;
	margin-top: 4px;
	line-height: 1.2;
}

.svc-hero-trust-body {
	margin-top: 20px;
	font-size: 13px;
	color: var(--ms-muted);
	line-height: 1.5;
}

/* Hero phone mockup (Ads + GEO) */

.svc-phone-wrap { display: flex; justify-content: center; position: relative; }

.svc-phone {
	position: relative;
	width: 300px;
	height: 600px;
	background: var(--ms-ink);
	border-radius: 36px;
	padding: 14px;
	box-shadow: 0 30px 60px rgba(20, 17, 14, 0.20), 0 12px 24px rgba(20, 17, 14, 0.10);
}

.svc-phone--lg { width: 320px; height: 640px; padding: 14px; border-radius: 38px; }

.svc-phone-notch {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	top: 18px;
	width: 90px;
	height: 18px;
	background: var(--ms-ink);
	border-radius: 10px;
	z-index: 2;
}

.svc-phone-notch--lg { width: 96px; }

.svc-phone-screen {
	width: 100%;
	height: 100%;
	background: #FFFFFF;
	border-radius: 24px;
	overflow: hidden;
	position: relative;
}

.svc-phone-screen--lg { border-radius: 26px; display: flex; flex-direction: column; }

.svc-phone-status {
	display: flex;
	justify-content: space-between;
	padding: 10px 22px 0;
	font-size: 11px;
	font-weight: 700;
	color: var(--ms-ink);
}

.svc-phone-status-icons { display: inline-flex; gap: 4px; align-items: center; }

/* Floating "Cited #1" badge (GEO) */

.svc-phone-badge {
	position: absolute;
	top: 38px;
	right: -30px;
	padding: 8px 12px;
	background: var(--ms-accent);
	color: #FFF;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	box-shadow: 0 8px 24px rgba(176, 84, 42, 0.35);
	transform: rotate(4deg);
}

/* Hero engine row (GEO) */

.svc-engines-row {
	margin-top: 32px;
	display: flex;
	align-items: center;
	gap: 28px;
	flex-wrap: wrap;
	padding: 18px 22px;
	background: var(--ms-bg);
	border: 1px solid var(--ms-line);
	max-width: 600px;
}

.svc-engines-label {
	font-family: var(--ms-font-mono);
	font-size: 11px;
	letter-spacing: 1.5px;
	color: var(--ms-muted);
	text-transform: uppercase;
	font-weight: 700;
}

.svc-engine-tag {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--ms-ink);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: -0.2px;
}

/* ---------- TRUST STRIP (4 stats) ---------- */

.svc-trust-strip {
	margin-top: 64px;
	padding-top: 32px;
	border-top: 1px solid var(--ms-line);
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
}

.svc-trust-label {
	font-family: var(--ms-font-mono);
	font-size: 11px;
	letter-spacing: 2px;
	color: var(--ms-muted);
	text-transform: uppercase;
	font-weight: 600;
	margin-bottom: 8px;
}

.svc-trust-num {
	font-size: 48px;
	font-weight: 800;
	letter-spacing: -1.5px;
	line-height: 1;
	color: var(--ms-accent);
}

.svc-trust-cap {
	margin-top: 8px;
	font-size: 13px;
	color: var(--ms-muted);
}

.svc-trust-partner {
	display: flex;
	align-items: center;
	gap: 12px;
}

.svc-trust-partner-h {
	font-size: 18px;
	font-weight: 800;
	letter-spacing: -0.4px;
	line-height: 1.1;
}

/* ---------- 5-STAR RATING UNDER CTAs ---------- */

.svc-rating {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-top: 16px;
	padding: 8px 14px;
	background: var(--ms-bg);
	border: 1px solid var(--ms-line);
	border-radius: 999px;
}

.svc-rating-stars {
	color: #F4B400;
	font-size: 16px;
	letter-spacing: 2px;
	line-height: 1;
}

.svc-rating-text {
	font-family: var(--ms-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ms-muted);
}

.svc-rating--final {
	margin-top: 24px;
}
