/* ==========================================================================
   Service Page
   ========================================================================== */
/* Hero */

.service-hero {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	min-height: 400px;
	padding: clamp(80px, 12vw, 120px) 0;
	background: #d9d9d9;
}

.service-hero__inner {
	display: flex;
	justify-content: center;
}

.service-hero__title {
	margin: 0;
	font-size: clamp(36px, 5vw + 0.5rem, 60px);
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: -0.01em;
	color: var(--color-text);
	text-align: center;
}

/* Intro */

.service-intro {
	padding: clamp(80px, 12vw, 160px) 0;
}

.service-intro__row {
	display: grid;
	grid-template-columns: minmax(280px, 500px) 1fr;
	gap: clamp(32px, 5vw, 60px);
	align-items: center;
}

.service-intro__media {
	aspect-ratio: 1;
	border-radius: var(--radius-lg);
	overflow: hidden;
}

.service-intro__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.service-intro__content {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.service-intro__title {
	margin: 0;
	font-size: clamp(24px, 2.5vw + 0.75rem, 32px);
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: -0.01em;
}

.service-intro__desc {
	font-size: clamp(16px, 1vw + 0.75rem, 20px);
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: -0.01em;
	color: var(--color-text-secondary);
}

.service-intro__desc p + p {
	margin-top: 0.5em;
}

/* Partners */

.service-partners {
	padding: clamp(80px, 12vw, 160px) 0;
}

.service-partners__heading {
	margin: 0 0 clamp(40px, 6vw, 60px);
	font-size: clamp(32px, 4vw + 0.5rem, 48px);
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: -0.01em;
	text-align: center;
}

.service-partners__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.partner-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
	padding: 48px 20px;
	background: #f4f4f4;
	text-align: center;
}

.partner-card__icon {
	width: 90px;
	height: 90px;
	flex-shrink: 0;
}

.media-placeholder--icon {
	width: 100%;
	height: 100%;
	border-radius: var(--radius-lg);
}

.partner-card__title {
	margin: 0;
	font-size: clamp(20px, 2vw + 0.5rem, 24px);
	font-weight: 600;
	line-height: 1.6;
	letter-spacing: -0.01em;
}

.partner-card__desc {
	font-size: clamp(15px, 1vw + 0.5rem, 18px);
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: -0.01em;
	color: var(--color-text-secondary);
}

.partner-card__desc p + p {
	margin-top: 0.25em;
}

/* Features */

.service-features {
	padding: clamp(80px, 12vw, 160px) 0;
	background: #e9e9e9;
}

.service-features__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: clamp(28px, 4vw, 42px);
	max-width: 863px;
	margin: 0 auto;
	text-align: center;
}

.service-features__heading {
	margin: 0;
	font-size: clamp(32px, 4vw + 0.5rem, 48px);
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: -0.01em;
}

.service-features__desc {
	font-size: clamp(16px, 1vw + 0.75rem, 20px);
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: -0.01em;
	color: var(--color-text);
}

.service-features__desc p + p {
	margin-top: 0.5em;
}

@media (max-width: 1024px) {
	.service-intro__row {
		grid-template-columns: 1fr;
	}

	.service-intro__media {
		max-width: 500px;
		margin: 0 auto;
		width: 100%;
	}

	.service-partners__grid {
		grid-template-columns: 1fr;
		max-width: 480px;
		margin: 0 auto;
	}
}

@media (max-width: 768px) {
	.service-hero {
		min-height: 280px;
		padding: 64px 0 48px;
	}

	.service-intro,
	.service-partners,
	.service-features {
		padding: 64px 0;
	}

	.partner-card {
		padding: 40px 20px;
	}
}

@media (max-width: 480px) {
	.service-hero__title {
		font-size: 32px;
	}

	.service-intro__title {
		font-size: 22px;
	}

	.service-partners__heading,
	.service-features__heading {
		font-size: 28px;
	}

	.partner-card__title {
		font-size: 20px;
	}

	.service-intro__desc,
	.service-features__desc,
	.partner-card__desc {
		font-size: 15px;
	}
}
