.site-wrap {
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 20px;
}

.site-header {
	background: #fcfbf7;
	border-bottom: 1px solid #e8e2d3;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 18px 20px;
	gap: 20px;
}

.site-branding__eyebrow,
.hero__eyebrow {
	margin: 0 0 8px;
	font-size: 13px;
	font-weight: bold;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #4f6d5a;
}

.site-title {
	margin: 0;
	font-size: 28px;
	line-height: 1.2;
}

.site-title a {
	color: #183a37;
}

.site-nav__menu,
.site-footer__menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-nav__menu li {
	display: inline-block;
	margin-left: 18px;
}

.site-main {
	display: block;
}

.hero {
	background: linear-gradient(180deg, #183a37 0%, #264f4a 100%);
	color: #fcfbf7;
	padding: 72px 0;
}

.hero__inner {
	max-width: 860px;
}

.hero__title {
	margin: 0 0 20px;
	font-size: 48px;
	line-height: 1.15;
}

.hero__text {
	max-width: 720px;
	margin: 0 0 28px;
	font-size: 20px;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.button {
	display: inline-block;
	padding: 13px 18px;
	border: 1px solid #183a37;
	background: #fcfbf7;
	color: #183a37;
	font-weight: bold;
}

.button--secondary {
	background: transparent;
	border-color: #fcfbf7;
	color: #fcfbf7;
}

.section {
	padding: 56px 0;
}

.section--soft {
	background: #f3eee2;
}

.card-grid {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -12px;
}

.card-grid .card {
	box-sizing: border-box;
	width: 33.3333%;
	padding: 0 12px;
	margin-bottom: 24px;
}

.card {
	border: 1px solid #e8e2d3;
	background: #fffdf8;
	padding: 24px;
}

.content-wrap,
.archive-header,
.content-list {
	padding-top: 40px;
	padding-bottom: 20px;
}

.entry-title,
.archive-header h1 {
	margin-top: 0;
	font-size: 40px;
	line-height: 1.2;
}

.content-card {
	padding: 24px 0;
	border-bottom: 1px solid #e8e2d3;
}

.content-card__title {
	margin: 0 0 10px;
	font-size: 28px;
}

.site-footer {
	border-top: 1px solid #e8e2d3;
	background: #fcfbf7;
}

.site-footer__inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 24px;
	padding-top: 36px;
	padding-bottom: 36px;
}

.site-footer__block {
	flex: 1 1 280px;
}

@media (max-width: 900px) {
	.site-header__inner {
		display: block;
	}

	.site-nav {
		margin-top: 16px;
	}

	.site-nav__menu li {
		display: block;
		margin: 0 0 10px;
	}

	.hero {
		padding: 56px 0;
	}

	.hero__title {
		font-size: 34px;
	}

	.hero__text {
		font-size: 18px;
	}

	.card-grid .card {
		width: 100%;
	}
}
