.km-code-pages {
	background: linear-gradient(180deg, #f6f2ea 0%, #ffffff 36%, #f3efe8 100%);
	color: #171512;
	min-height: 60vh;
}

.km-code-page {
	padding: 48px 20px;
}

.km-code-page__inner {
	margin: 0 auto;
	max-width: 1120px;
}

.km-code-page__eyebrow {
	color: #8c2419;
	font-family: "Open Sans", sans-serif;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	margin: 0 0 18px;
	text-transform: uppercase;
}

.km-code-page__title {
	color: #171512;
	font-family: Georgia, serif;
	font-size: clamp(2.2rem, 4vw, 4.4rem);
	line-height: 1.06;
	margin: 0 0 20px;
	max-width: 12ch;
}

.km-code-page__lead {
	font-family: "Open Sans", sans-serif;
	font-size: 1.05rem;
	line-height: 1.8;
	margin: 0;
	max-width: 62ch;
}

.km-code-page__grid {
	display: grid;
	gap: 20px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.km-code-card {
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid rgba(23, 21, 18, 0.09);
	border-radius: 20px;
	box-shadow: 0 18px 50px rgba(34, 25, 18, 0.06);
	padding: 28px;
}

.km-code-card h2 {
	font-family: Georgia, serif;
	font-size: 1.35rem;
	margin: 0 0 12px;
}

.km-code-card p {
	font-family: "Open Sans", sans-serif;
	line-height: 1.7;
	margin: 0;
}

.km-code-page--newsletter {
	background:
		radial-gradient(circle at top right, rgba(140, 36, 25, 0.14), transparent 34%),
		linear-gradient(180deg, #f8f1e6 0%, #ffffff 100%);
}

@media (max-width: 880px) {
	.km-code-page__grid {
		grid-template-columns: 1fr;
	}
}
