/*
 * Services page — detailed service journey.
 */

.services-page {
	background: var(--color-white);
}

/* Hero */
.services-hero {
	padding-block: clamp(1.15rem, 2.2vw, 2rem) clamp(1.75rem, 3.2vw, 2.5rem);
	background:
		radial-gradient(900px 420px at 80% -10%, rgba(232, 185, 187, 0.22), transparent 60%),
		radial-gradient(700px 360px at 8% 10%, rgba(196, 215, 155, 0.16), transparent 58%),
		var(--color-white);
	text-align: center;
}

.services-hero__eyebrow {
	display: inline-block;
	margin-bottom: var(--sp-4);
}

.services-hero__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(2.15rem, 4.45vw, 3.9rem);
	line-height: 1.06;
	letter-spacing: -0.04em;
	color: var(--color-charcoal);
	margin: 0 auto var(--sp-4);
	max-width: 24ch;
	text-wrap: balance;
}

.services-hero__lede {
	font-size: 1.05rem;
	line-height: 1.65;
	color: var(--text-secondary);
	margin: 0 auto;
	max-width: 66ch;
}

/* Proof strip */
.services-proof {
	background: var(--color-white);
	padding-block: 0 clamp(3rem, 5vw, 4.5rem);
}

.services-proof__list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--sp-3);
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: var(--sp-3);
	box-shadow: 0 24px 60px -44px rgba(43, 43, 47, 0.35);
}

.services-proof__item {
	display: grid;
	gap: 0.35rem;
	padding: var(--sp-4);
	border-radius: var(--radius-md);
	background: rgba(196, 215, 155, 0.13);
}

.services-proof__item span {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.11em;
	text-transform: uppercase;
	color: var(--color-green-dark);
}

.services-proof__item strong {
	font-family: var(--font-heading);
	font-size: 0.98rem;
	line-height: 1.35;
	color: var(--color-charcoal);
}

/* Intro */
.services-intro {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--bg-soft);
}

.services-intro__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 420px;
	gap: var(--sp-7);
	align-items: center;
}

.services-intro__title,
.services-next__title,
.services-section-head__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.15rem);
	line-height: 1.12;
	letter-spacing: -0.03em;
	color: var(--color-charcoal);
	margin: var(--sp-3) 0 var(--sp-4);
}

.services-intro__title,
.services-next__title {
	max-width: 13ch;
}

.services-intro__body,
.services-next__body,
.services-section-head__body {
	font-size: 1.025rem;
	line-height: 1.7;
	color: var(--text-secondary);
	margin: 0;
	max-width: 62ch;
}

.services-intro__card {
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: clamp(1.5rem, 3vw, 2rem);
	box-shadow: 0 24px 55px -42px rgba(43, 43, 47, 0.32);
}

.services-intro__card h3 {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.3rem;
	line-height: 1.25;
	color: var(--color-charcoal);
	margin: 0 0 var(--sp-4);
}

.services-intro__card ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--sp-3);
}

.services-intro__card li {
	position: relative;
	padding-left: 1.9rem;
	font-weight: 500;
	line-height: 1.55;
	color: var(--color-charcoal);
}

.services-intro__card li::before {
	content: "\2713";
	position: absolute;
	left: 0;
	top: 0.05rem;
	display: grid;
	place-items: center;
	width: 21px;
	height: 21px;
	border-radius: 50%;
	background: rgba(196, 215, 155, 0.55);
	color: var(--color-green-dark);
	font-size: 0.75rem;
	font-weight: 700;
}

/* Detail section */
.services-detail {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--bg-soft);
}

.services-detail__grid {
	display: grid;
	gap: var(--sp-6);
}

/* Service blocks */
.service-block {
	position: relative;
	overflow: hidden;
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: clamp(1.75rem, 3vw, 2.75rem);
	box-shadow: 0 24px 50px -34px rgba(43, 43, 47, 0.22);
	display: grid;
	gap: var(--sp-6);
}

.service-block::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 5px;
	background: var(--color-green-dark);
}

.service-block:nth-child(2)::before {
	background: #b5686b;
}

.service-block:nth-child(3)::before {
	background: var(--color-sage);
}

.service-block__head {
	display: grid;
	grid-template-columns: auto auto 1fr;
	align-items: center;
	gap: var(--sp-3) var(--sp-4);
}

.service-block__num {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 0.8125rem;
	letter-spacing: 0.14em;
	color: var(--color-green-dark);
}

.service-block:nth-child(2) .service-block__num {
	color: #b5686b;
}

.service-block__icon {
	display: grid;
	place-items: center;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: rgba(79, 126, 74, 0.12);
	color: var(--color-green-dark);
	font-family: var(--font-heading);
	font-size: 1.35rem;
	font-weight: 700;
	line-height: 1;
}

.service-block:nth-child(2) .service-block__icon {
	background: rgba(232, 185, 187, 0.5);
	color: #b5686b;
}

.service-block:nth-child(3) .service-block__icon {
	background: rgba(196, 215, 155, 0.55);
	color: var(--color-green-dark);
}

.service-block__kicker {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-green-dark);
	margin: 0 0 0.35rem;
}

.service-block:nth-child(2) .service-block__kicker {
	color: #b5686b;
}

.service-block__title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(1.4rem, 2vw, 1.85rem);
	line-height: 1.22;
	letter-spacing: -0.02em;
	color: var(--color-charcoal);
	margin: 0;
}

.service-block__body {
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: var(--sp-7);
	align-items: start;
}

.service-block__lede {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-secondary);
	margin: 0;
}

.service-block__note {
	margin: var(--sp-4) 0 0;
	padding: var(--sp-4);
	border-radius: var(--radius-md);
	background: rgba(196, 215, 155, 0.14);
	color: var(--color-charcoal);
	font-size: 0.95rem;
	line-height: 1.6;
	font-weight: 500;
}

.service-block__panel {
	background: rgba(250, 248, 245, 0.76);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-md);
	padding: var(--sp-5);
}

.service-block__panel h3 {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.05rem;
	color: var(--color-charcoal);
	margin: 0 0 var(--sp-4);
}

.service-block__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--sp-3);
}

.service-block__list li {
	position: relative;
	padding-left: 2rem;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--color-charcoal);
	font-weight: 500;
}

.service-block__list li::before {
	content: "\2713";
	position: absolute;
	left: 0;
	top: 0.05rem;
	display: grid;
	place-items: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: rgba(196, 215, 155, 0.55);
	color: var(--color-green-dark);
	font-size: 0.8rem;
	font-weight: 700;
}

/* Shared section heading */
.services-section-head {
	text-align: center;
	max-width: 720px;
	margin: 0 auto var(--sp-7);
}

.services-section-head__title {
	margin-inline: auto;
}

.services-section-head__body {
	margin-inline: auto;
}

/* Expectations */
.services-expect {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--color-white);
}

.services-expect__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--sp-4);
}

.expect-card {
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: var(--sp-5);
	box-shadow: 0 20px 45px -36px rgba(43, 43, 47, 0.25);
}

.expect-card h3 {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.15rem;
	line-height: 1.25;
	color: var(--color-charcoal);
	margin: 0 0 var(--sp-3);
}

.expect-card p {
	font-size: 0.95rem;
	line-height: 1.65;
	color: var(--text-secondary);
	margin: 0;
}

/* Next steps */
.services-next {
	padding-block: clamp(3rem, 6vw, 5rem);
	background: var(--bg-soft);
}

.services-next__grid {
	display: grid;
	grid-template-columns: 0.85fr 1.15fr;
	gap: var(--sp-7);
	align-items: start;
}

.services-next__steps {
	list-style: none;
	counter-reset: service-step;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--sp-4);
}

.services-next__steps li {
	counter-increment: service-step;
	position: relative;
	background: var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: var(--sp-5) var(--sp-5) var(--sp-5) 4.5rem;
	box-shadow: 0 20px 45px -38px rgba(43, 43, 47, 0.25);
}

.services-next__steps li::before {
	content: counter(service-step, decimal-leading-zero);
	position: absolute;
	left: var(--sp-5);
	top: var(--sp-5);
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 0.85rem;
	letter-spacing: 0.12em;
	color: var(--color-green-dark);
}

.services-next__steps strong {
	display: block;
	font-family: var(--font-heading);
	font-size: 1.05rem;
	line-height: 1.25;
	color: var(--color-charcoal);
	margin-bottom: 0.35rem;
}

.services-next__steps span {
	display: block;
	font-size: 0.95rem;
	line-height: 1.65;
	color: var(--text-secondary);
}

/* Final decision section */
.services-final {
	padding-block: clamp(3.5rem, 7vw, 6rem);
	background:
		radial-gradient(720px 360px at 20% 20%, rgba(196, 215, 155, 0.18), transparent 62%),
		radial-gradient(720px 360px at 85% 45%, rgba(232, 185, 187, 0.22), transparent 62%),
		var(--color-white);
}

.services-final__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
	gap: var(--sp-6);
	align-items: stretch;
}

.services-final__card,
.services-final__cta {
	min-height: 100%;
}

.services-compliance__card {
	display: grid;
	gap: var(--sp-5);
	background:
		linear-gradient(135deg, rgba(196, 215, 155, 0.2), rgba(232, 185, 187, 0.2)),
		var(--color-white);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: clamp(1.75rem, 4vw, 3rem);
	box-shadow: 0 24px 55px -40px rgba(43, 43, 47, 0.28);
	position: relative;
	overflow: hidden;
}

.services-compliance__card::after {
	content: "";
	position: absolute;
	right: -70px;
	bottom: -70px;
	width: 180px;
	height: 180px;
	border-radius: 999px;
	background: rgba(196, 215, 155, 0.22);
	pointer-events: none;
}

.services-compliance__card h2 {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: clamp(1.7rem, 3vw, 2.45rem);
	line-height: 1.16;
	letter-spacing: -0.03em;
	color: var(--color-charcoal);
	margin: var(--sp-3) 0 0;
	max-width: 14ch;
}

.services-compliance__card p {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-secondary);
	margin: 0;
	max-width: 58ch;
}

.services-final__cta {
	margin: 0;
	align-self: stretch;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/* Motion */
.services-page [data-reveal] {
	opacity: 0;
	transform: translateY(28px);
	transition:
		opacity 700ms var(--ease-out),
		transform 700ms var(--ease-out);
	will-change: opacity, transform;
}

.services-page [data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0);
}

.services-page .services-hero__eyebrow,
.services-page .services-hero__title,
.services-page .services-hero__lede {
	opacity: 0;
	animation: servicesFadeUp 850ms var(--ease-out) forwards;
}

.services-page .services-hero__title {
	animation-delay: 120ms;
}

.services-page .services-hero__lede {
	animation-delay: 240ms;
}

.service-block,
.expect-card,
.services-next__steps li,
.services-proof__item,
.services-intro__card,
.services-compliance__card,
.services-final__cta {
	transition:
		transform 280ms var(--ease-out),
		box-shadow 280ms var(--ease-out),
		border-color 280ms var(--ease-out);
}

.service-block:hover,
.expect-card:hover,
.services-next__steps li:hover,
.services-proof__item:hover,
.services-intro__card:hover,
.services-compliance__card:hover,
.services-final__cta:hover {
	transform: translateY(-4px);
	box-shadow: 0 28px 60px -38px rgba(43, 43, 47, 0.35);
	border-color: rgba(79, 126, 74, 0.22);
}

.service-block__icon,
.services-intro__card li::before,
.service-block__list li::before {
	transition:
		transform 260ms var(--ease-out),
		background-color 260ms var(--ease-out);
}

.service-block:hover .service-block__icon {
	transform: scale(1.06) rotate(-2deg);
}

@keyframes servicesFadeUp {
	from {
		opacity: 0;
		transform: translateY(24px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Tablet */
@media (max-width: 1024px) {
	.services-proof__list,
	.services-expect__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.services-intro__grid,
	.services-next__grid,
	.services-final__grid {
		grid-template-columns: 1fr;
	}

	.services-intro__title,
	.services-next__title {
		max-width: 18ch;
	}
}

/* Mobile */
@media (max-width: 640px) {
	.services-hero {
		text-align: left;
	}

	.services-hero__title,
	.services-hero__lede {
		margin-inline: 0;
	}

	.services-proof__list,
	.services-expect__grid {
		grid-template-columns: 1fr;
	}

	.service-block__head {
		grid-template-columns: auto 1fr;
	}

	.service-block__num {
		grid-column: 1 / -1;
	}

	.service-block__body {
		grid-template-columns: 1fr;
		gap: var(--sp-5);
	}

	.service-block__title {
		font-size: 1.35rem;
	}

	.services-next__steps li {
		padding-left: var(--sp-5);
		padding-top: 3.5rem;
	}

	.services-final__grid {
		grid-template-columns: 1fr;
	}

	.services-final__cta {
		min-width: 0;
	}
}

/* Motion accessibility */
@media (prefers-reduced-motion: reduce) {
	.services-page [data-reveal],
	.services-page .services-hero__eyebrow,
	.services-page .services-hero__title,
	.services-page .services-hero__lede,
	.service-block,
	.expect-card,
	.services-next__steps li,
	.services-proof__item,
	.services-intro__card,
	.services-compliance__card,
	.services-final__cta,
	.service-block__icon {
		opacity: 1;
		transform: none;
		animation: none;
		transition: none;
	}
}

/* === Service photos — added 2026-06-05 === */
.services-hero__cover {
	margin-top: clamp(1.5rem, 3vw, 2.5rem);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 30px 60px -34px rgba(43, 52, 40, 0.45);
}
.services-hero__cover img {
	display: block;
	width: 100%;
	height: clamp(220px, 30vw, 360px);
	object-fit: cover;
	object-position: center 68%;
}
.service-block__media {
	margin: 0 0 var(--sp-5);
	border-radius: var(--radius-md);
	overflow: hidden;
}
.service-block__media img {
	display: block;
	width: 100%;
	aspect-ratio: 3 / 2;
	object-fit: cover;
}
#placement .service-block__media img { object-position: center 26%; }
#documentation .service-block__media img { object-position: center 32%; }
#after-placement .service-block__media img { object-position: center 9%; }
.services-intro__media {
	margin: 0 0 var(--sp-4);
	border-radius: var(--radius-md);
	overflow: hidden;
}
.services-intro__media img {
	display: block;
	width: 100%;
	height: clamp(160px, 20vw, 200px);
	object-fit: cover;
	object-position: center 28%;
}
