:root {
	--ink: #27211c;
	--muted: #6f6257;
	--cream: #fffaf1;
	--paper: #ffffff;
	--cocoa: #68412f;
	--copper: #b7603d;
	--sage: #6d826c;
	--gold: #d8a23a;
	--line: #eadfd2;
	--shadow: 0 18px 45px rgba(39, 33, 28, 0.12);
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	background: var(--cream);
	color: var(--ink);
	font-family: Inter, system-ui, sans-serif;
	font-size: 16px;
	line-height: 1.65;
}

img {
	display: block;
	height: auto;
	max-width: 100%;
}

a {
	color: inherit;
	text-decoration-color: rgba(183, 96, 61, 0.45);
	text-underline-offset: 0.18em;
}

a:hover {
	color: var(--copper);
}

h1,
h2,
h3 {
	font-family: Fraunces, Georgia, serif;
	line-height: 1.05;
	margin: 0 0 0.45em;
}

h1 {
	font-size: clamp(2.75rem, 7vw, 5.9rem);
	max-width: 11ch;
}

h2 {
	font-size: clamp(2rem, 4vw, 3.5rem);
}

h3 {
	font-size: 1.35rem;
}

p {
	margin: 0 0 1rem;
}

.screen-reader-text,
.skip-link {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal;
}

.skip-link:focus {
	background: var(--paper);
	box-shadow: var(--shadow);
	clip: auto;
	clip-path: none;
	height: auto;
	left: 1rem;
	padding: 0.75rem 1rem;
	top: 1rem;
	width: auto;
	z-index: 1000;
}

.site-header {
	background: rgba(255, 250, 241, 0.93);
	border-bottom: 1px solid var(--line);
	position: sticky;
	top: 0;
	z-index: 50;
}

.site-header__inner {
	align-items: center;
	display: flex;
	gap: 2rem;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1180px;
	padding: 1rem 1.5rem;
}

.site-brand {
	font-family: Fraunces, Georgia, serif;
	font-size: 1.35rem;
	font-weight: 700;
	text-decoration: none;
}

.custom-logo,
.placeholder-logo {
	max-height: 58px;
	width: auto;
}

.primary-nav ul,
.footer-menu {
	align-items: center;
	display: flex;
	gap: 1.25rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.primary-nav a {
	font-size: 0.92rem;
	font-weight: 700;
	text-decoration: none;
	text-transform: uppercase;
}

.nav-toggle {
	background: transparent;
	border: 0;
	display: none;
	height: 44px;
	padding: 0;
	width: 44px;
}

.nav-toggle span:not(.screen-reader-text) {
	background: var(--ink);
	display: block;
	height: 2px;
	margin: 7px auto;
	width: 24px;
}

.hero {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1.05fr);
	min-height: calc(100vh - 83px);
}

.hero__content {
	align-self: center;
	padding: clamp(3rem, 7vw, 7rem) clamp(1.5rem, 5vw, 5rem);
}

.hero__content > p:not(.eyebrow) {
	color: var(--muted);
	font-size: clamp(1.05rem, 2vw, 1.28rem);
	max-width: 37rem;
}

.hero__image {
	background-position: center;
	background-size: cover;
	min-height: 520px;
}

.eyebrow {
	color: var(--copper);
	font-size: 0.79rem;
	font-weight: 800;
	letter-spacing: 0;
	margin-bottom: 1rem;
	text-transform: uppercase;
}

.button-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem;
	margin-top: 1.8rem;
}

.button {
	align-items: center;
	border: 2px solid var(--cocoa);
	border-radius: 999px;
	display: inline-flex;
	font-weight: 800;
	justify-content: center;
	min-height: 48px;
	padding: 0.75rem 1.2rem;
	text-decoration: none;
}

.button--primary {
	background: var(--cocoa);
	color: var(--paper);
}

.button--primary:hover {
	background: var(--copper);
	border-color: var(--copper);
	color: var(--paper);
}

.button--secondary {
	background: transparent;
	color: var(--cocoa);
}

.info-strip {
	background: var(--ink);
	color: var(--paper);
	display: grid;
	gap: 1px;
	grid-template-columns: repeat(3, 1fr);
}

.info-strip > div {
	background: #342a23;
	padding: 2rem clamp(1.5rem, 4vw, 4rem);
}

.info-strip span {
	color: var(--gold);
	display: block;
	font-size: 0.78rem;
	font-weight: 800;
	margin-bottom: 0.45rem;
	text-transform: uppercase;
}

.info-strip p {
	margin: 0;
}

.split-section {
	align-items: center;
	display: grid;
	gap: clamp(2rem, 6vw, 5rem);
	grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1fr);
	margin: 0 auto;
	max-width: 1180px;
	padding: clamp(4rem, 8vw, 7rem) 1.5rem;
}

.split-section__media img {
	aspect-ratio: 4 / 5;
	border-radius: 8px;
	box-shadow: var(--shadow);
	object-fit: cover;
	width: 100%;
}

.split-section__content {
	max-width: 640px;
}

.rich-text {
	color: var(--muted);
	font-size: 1.06rem;
}

.content-band {
	margin: 0 auto;
	max-width: 1180px;
	padding: clamp(4rem, 8vw, 6.5rem) 1.5rem;
}

.content-band--soft {
	background: #f4eadb;
	max-width: none;
	padding-left: max(1.5rem, calc((100vw - 1180px) / 2));
	padding-right: max(1.5rem, calc((100vw - 1180px) / 2));
}

.section-heading {
	align-items: end;
	display: flex;
	gap: 1.5rem;
	justify-content: space-between;
	margin-bottom: 2rem;
}

.section-heading h2 {
	margin-bottom: 0;
}

.section-heading a {
	font-weight: 800;
}

.card-grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card-grid--menu {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.menu-card,
.event-card,
.post-preview {
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 8px;
	box-shadow: 0 10px 24px rgba(39, 33, 28, 0.06);
	overflow: hidden;
}

.menu-card {
	display: grid;
	grid-template-columns: 180px minmax(0, 1fr);
	min-height: 180px;
}

.menu-card__image img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.menu-card__body,
.event-card,
.post-preview {
	padding: 1.35rem;
}

.menu-card__title {
	align-items: start;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
}

.menu-card__title h3 {
	font-size: 1.28rem;
	margin-bottom: 0.35rem;
}

.menu-card__title span {
	color: var(--copper);
	font-weight: 900;
	white-space: nowrap;
}

.menu-card p,
.event-card p,
.post-preview p {
	color: var(--muted);
}

.menu-card small {
	color: var(--sage);
	font-weight: 800;
	text-transform: uppercase;
}

.event-card time {
	color: var(--copper);
	display: block;
	font-size: 0.86rem;
	font-weight: 900;
	margin-bottom: 0.8rem;
	text-transform: uppercase;
}

.event-card__meta {
	color: var(--muted);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.9rem;
	gap: 0.7rem;
	margin-bottom: 1rem;
}

.page-hero {
	background: var(--ink);
	color: var(--paper);
	padding: clamp(4rem, 9vw, 8rem) max(1.5rem, calc((100vw - 1180px) / 2));
}

.page-hero h1 {
	max-width: 13ch;
}

.page-hero p:not(.eyebrow) {
	color: #dacfc1;
	max-width: 42rem;
}

.entry-content,
.single-entry {
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 8px;
	box-shadow: 0 10px 24px rgba(39, 33, 28, 0.06);
	padding: clamp(1.4rem, 4vw, 3rem);
}

.entry-content > *:first-child,
.single-entry > *:first-child {
	margin-top: 0;
}

.single-entry {
	margin: 0 auto;
	max-width: 860px;
}

.single-entry__image {
	margin: calc(clamp(1.4rem, 4vw, 3rem) * -1) calc(clamp(1.4rem, 4vw, 3rem) * -1) 2rem;
}

.single-entry__image img {
	aspect-ratio: 16 / 9;
	border-radius: 8px 8px 0 0;
	object-fit: cover;
	width: 100%;
}

.single-entry__meta,
.term-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 0.7rem;
	margin-bottom: 1.5rem;
}

.single-entry__meta span,
.term-filter a {
	background: #f4eadb;
	border-radius: 999px;
	color: var(--cocoa);
	font-weight: 800;
	padding: 0.45rem 0.8rem;
	text-decoration: none;
}

.post-list {
	display: grid;
	gap: 1rem;
}

.navigation.pagination {
	margin-top: 2rem;
}

.map-section iframe {
	border: 0;
	display: block;
	height: 420px;
	width: 100%;
}

.site-footer {
	background: #201a16;
	color: var(--paper);
}

.site-footer__inner {
	display: grid;
	gap: 2rem;
	grid-template-columns: 1.2fr 1fr 1fr;
	margin: 0 auto;
	max-width: 1180px;
	padding: 3rem 1.5rem;
}

.site-footer p {
	color: #d8cdc0;
}

.site-footer a {
	color: var(--paper);
}

.footer-brand,
.site-footer strong {
	display: block;
	margin-bottom: 0.65rem;
}

.footer-menu {
	align-items: flex-start;
	flex-direction: column;
	gap: 0.4rem;
}

.site-footer__credit {
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	font-size: 0.9rem;
	margin: 0;
	padding: 1rem 1.5rem;
	text-align: center;
}

@media (max-width: 860px) {
	.nav-toggle {
		display: block;
	}

	.primary-nav {
		background: var(--cream);
		border-bottom: 1px solid var(--line);
		display: none;
		left: 0;
		padding: 1rem 1.5rem 1.5rem;
		position: absolute;
		right: 0;
		top: 100%;
	}

	.primary-nav.is-open {
		display: block;
	}

	.primary-nav ul {
		align-items: flex-start;
		flex-direction: column;
	}

	.hero,
	.split-section,
	.info-strip,
	.site-footer__inner {
		grid-template-columns: 1fr;
	}

	.hero {
		min-height: 0;
	}

	.hero__image {
		min-height: 360px;
		order: -1;
	}

	.card-grid,
	.card-grid--menu {
		grid-template-columns: 1fr;
	}

	.section-heading {
		align-items: flex-start;
		flex-direction: column;
	}
}

@media (max-width: 560px) {
	h1 {
		font-size: 2.55rem;
	}

	.menu-card {
		grid-template-columns: 1fr;
	}

	.menu-card__image img {
		aspect-ratio: 4 / 3;
	}

	.button {
		width: 100%;
	}
}
