:root {
	--color-primary: #1a3c40;
	--color-secondary: #f0e6da;
	--color-accent: #c17f4a;
	--color-highlight: #957fa8;
	--color-text: #252822;
	--color-muted: #5a5852;
	--color-line: rgba(37, 40, 34, 0.14);
	--font-head: "Outfit", system-ui, sans-serif;
	--font-body: "Source Serif 4", Georgia, serif;
	--radius-sm: 0.5rem;
	--radius-md: 0.85rem;
	--radius-lg: 1.1rem;
	--shadow-sm: 0 0.15rem 0.45rem rgba(26, 60, 64, 0.14);
	--shadow-md: 0 0.35rem 1rem rgba(26, 60, 64, 0.2);
	--space-xs: 0.35rem;
	--space-sm: 0.55rem;
	--space-md: 0.9rem;
	--space-lg: 1.35rem;
	--space-xl: 2rem;
	--space-2xl: clamp(2.2rem, 4vw, 3.5rem);
	--max-w: 72rem;
	--transition-fast: 0.2s ease;
	--transition-mid: 0.35s ease;
	--header-offset: 0.35rem;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

body {
	margin: 0;
	font-family: var(--font-body);
	font-size: clamp(0.9rem, 0.85rem + 0.35vw, 1rem);
	line-height: 1.55;
	color: var(--color-text);
	background: var(--color-secondary);
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--color-primary);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
	transition: color var(--transition-fast), background-color var(--transition-fast);
}

a:hover,
a:focus-visible {
	color: var(--color-accent);
}

.wrap {
	width: min(100% - var(--space-lg) * 2, var(--max-w));
	margin-inline: auto;
}

.site-header {
	position: relative;
	z-index: 40;
	padding: var(--space-sm) var(--space-md) 0;
}

.header-shell {
	width: min(100% - var(--space-lg), var(--max-w));
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	padding: var(--space-sm) var(--space-md);
	background: rgba(240, 230, 218, 0.9);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	backdrop-filter: blur(10px);
}

.logo {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	text-decoration: none;
	color: var(--color-text);
	font-family: var(--font-head);
	font-weight: 600;
	font-size: clamp(0.78rem, 0.65rem + 0.55vw, 0.95rem);
	letter-spacing: -0.02em;
	max-width: 100%;
}

.logo:hover,
.logo:focus-visible {
	color: var(--color-primary);
}

.logo-mark {
	width: 1.65rem;
	height: 1.65rem;
	border-radius: var(--radius-sm);
	background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
	flex-shrink: 0;
	box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.35);
}

.logo-text {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.nav-menu .nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs) var(--space-md);
	align-items: center;
	justify-content: center;
}

.nav-link {
	font-family: var(--font-head);
	font-size: clamp(0.72rem, 0.68rem + 0.2vw, 0.82rem);
	font-weight: 500;
	text-decoration: none;
	color: var(--color-muted);
	padding: var(--space-xs) var(--space-sm);
	border-radius: var(--radius-sm);
}

.nav-link:hover,
.nav-link:focus-visible {
	color: var(--color-primary);
	background: rgba(193, 127, 74, 0.16);
}

.menu-toggle {
	order: 3;
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 0.28rem;
	padding: var(--space-sm);
	background: var(--color-primary);
	border: none;
	border-radius: var(--radius-sm);
	cursor: pointer;
	z-index: 61;
	transition: transform var(--transition-fast), opacity var(--transition-fast);
}

.menu-toggle-bar {
	width: 1.25rem;
	height: 2px;
	background: var(--color-secondary);
	border-radius: 1px;
}

.mobile-menu {
	position: fixed;
	top: 0;
	right: 0;
	width: min(100%, 20rem);
	height: 100vh;
	background: linear-gradient(165deg, var(--color-primary), #0f2a2e);
	color: var(--color-secondary);
	padding: var(--space-xl) var(--space-lg);
	transform: translateY(-100%);
	transition: transform var(--transition-mid);
	z-index: 60;
	box-shadow: var(--shadow-md);
	overflow-y: auto;
}

.mobile-menu.active {
	transform: translateY(0);
}

.mobile-menu .mobile-list {
	list-style: none;
	margin: var(--space-xl) 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.mobile-link {
	font-family: var(--font-head);
	font-size: 0.95rem;
	font-weight: 500;
	color: var(--color-secondary);
	text-decoration: none;
	display: block;
	padding: var(--space-sm) 0;
	border-bottom: 1px solid rgba(240, 230, 218, 0.18);
}

.mobile-link:hover,
.mobile-link:focus-visible {
	color: var(--color-highlight);
}

.menu-close {
	position: absolute;
	top: var(--space-md);
	right: var(--space-md);
	background: rgba(240, 230, 218, 0.12);
	border: 1px solid rgba(240, 230, 218, 0.38);
	color: var(--color-secondary);
	width: 2.25rem;
	height: 2.25rem;
	border-radius: var(--radius-sm);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
}

.menu-close:hover,
.menu-close:focus-visible {
	background: rgba(149, 127, 168, 0.38);
	color: var(--color-secondary);
}

@media (max-width: 860px) {
	.nav-menu {
		display: none;
	}

	.menu-toggle {
		display: flex;
	}

	body.menu-open .menu-toggle {
		display: none;
	}
}

body.menu-open {
	overflow: hidden;
}

.hero {
	position: relative;
	min-height: clamp(22rem, 65vh, 38rem);
	display: grid;
	grid-template-columns: 1fr;
	align-items: center;
	padding: var(--space-2xl) var(--space-lg);
	overflow: hidden;
	background-color: var(--color-primary);
	background-image: url("../img/hero-bg.jpg");
	background-size: cover;
	background-position: center;
	isolation: isolate;
}

.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(120deg, rgba(26, 60, 64, 0.84), rgba(240, 230, 218, 0.48));
	z-index: 0;
}

.hero-glow {
	position: absolute;
	width: 18rem;
	height: 18rem;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(149, 127, 168, 0.42), transparent 65%);
	top: 10%;
	right: 8%;
	z-index: 1;
	filter: blur(4px);
	animation: pulse-glow 6s ease-in-out infinite alternate;
}

@media (prefers-reduced-motion: reduce) {
	.hero-glow {
		animation: none;
	}
}

@keyframes pulse-glow {
	0% {
		opacity: 0.45;
		transform: scale(0.95);
	}
	100% {
		opacity: 0.85;
		transform: scale(1.05);
	}
}

.hero-content {
	position: relative;
	z-index: 2;
	width: min(100%, 38rem);
}

.hero-kicker {
	font-family: var(--font-head);
	font-size: clamp(0.68rem, 0.62rem + 0.25vw, 0.78rem);
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-secondary);
	margin: 0 0 var(--space-sm);
	display: flex;
	align-items: center;
	gap: var(--space-sm);
}

.hero-title {
	font-family: var(--font-head);
	font-size: clamp(1.35rem, 1rem + 2vw, 2.15rem);
	font-weight: 700;
	line-height: 1.15;
	color: var(--color-secondary);
	margin: 0 0 var(--space-md);
	letter-spacing: -0.03em;
}

.hero-lead {
	font-size: clamp(0.88rem, 0.82rem + 0.3vw, 1.02rem);
	color: rgba(240, 230, 218, 0.93);
	margin: 0 0 var(--space-lg);
	max-width: 32rem;
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.hero-figure {
	position: absolute;
	right: clamp(4%, 8vw, 12%);
	bottom: 8%;
	z-index: 2;
	width: clamp(7rem, 18vw, 11rem);
	height: clamp(10rem, 22vw, 14rem);
	pointer-events: none;
}

.figure-orb {
	position: absolute;
	border-radius: 50%;
	background: rgba(240, 230, 218, 0.24);
}

.figure-orb-a {
	width: 3.2rem;
	height: 3.2rem;
	top: 0;
	right: 1rem;
	animation: float-a 5s ease-in-out infinite;
}

.figure-orb-b {
	width: 2rem;
	height: 2rem;
	bottom: 3.5rem;
	left: 0;
	animation: float-b 4.2s ease-in-out infinite;
}

@keyframes float-a {
	0%,
	100% {
		transform: translate(0, 0);
	}
	50% {
		transform: translate(-0.35rem, 0.45rem);
	}
}

@keyframes float-b {
	0%,
	100% {
		transform: translate(0, 0);
	}
	50% {
		transform: translate(0.4rem, -0.25rem);
	}
}

.figure-cup {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 4.2rem;
	height: 3.4rem;
	background: linear-gradient(180deg, rgba(240, 230, 218, 0.88), rgba(240, 230, 218, 0.48));
	border-radius: 0 0 var(--radius-md) var(--radius-md);
	box-shadow: 0 0.25rem 0.6rem rgba(45, 45, 45, 0.25);
}

.figure-cup::before {
	content: "";
	position: absolute;
	right: -0.65rem;
	top: 0.65rem;
	width: 1rem;
	height: 1.4rem;
	border: 0.28rem solid rgba(240, 230, 218, 0.78);
	border-left: none;
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.figure-steam {
	position: absolute;
	width: 0.35rem;
	height: 1.6rem;
	background: linear-gradient(180deg, rgba(240, 230, 218, 0.72), transparent);
	border-radius: 999px;
	bottom: 3.2rem;
	opacity: 0;
	animation: steam 2.8s ease-in-out infinite;
}

.figure-steam-a {
	left: calc(50% - 0.9rem);
	animation-delay: 0s;
}

.figure-steam-b {
	left: calc(50% + 0.45rem);
	animation-delay: 0.6s;
}

@keyframes steam {
	0% {
		opacity: 0;
		transform: translateY(0.4rem) scaleY(0.6);
	}
	40% {
		opacity: 0.85;
	}
	100% {
		opacity: 0;
		transform: translateY(-1.8rem) scaleY(1.1);
	}
}

@media (prefers-reduced-motion: reduce) {
	.figure-orb-a,
	.figure-orb-b,
	.figure-steam {
		animation: none;
	}
	.figure-steam {
		opacity: 0.35;
	}
}

@media (max-width: 720px) {
	.hero-figure {
		display: none;
	}
}

.btn {
	font-family: var(--font-head);
	font-size: clamp(0.72rem, 0.68rem + 0.2vw, 0.82rem);
	font-weight: 600;
	padding: var(--space-sm) var(--space-md);
	border-radius: var(--radius-md);
	border: none;
	cursor: pointer;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-xs);
	transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
	margin-top: var(--space-sm);
	text-decoration: none;
}

.btn-primary {
	background: var(--color-accent);
	color: var(--color-text);
	box-shadow: var(--shadow-sm);
}

.btn-primary:hover,
.btn-primary:focus-visible {
	background: #9e6232;
	color: #1b120c;
}

.btn-ghost {
	background: transparent;
	color: var(--color-primary);
	border: 1px solid rgba(26, 60, 64, 0.38);
}

.btn-ghost:hover,
.btn-ghost:focus-visible {
	color: var(--color-accent);
	border-color: var(--color-accent);
	background: rgba(193, 127, 74, 0.14);
}

.hero .btn-ghost {
	color: var(--color-secondary);
	border: 1px solid rgba(240, 230, 218, 0.58);
}

.hero .btn-ghost:hover,
.hero .btn-ghost:focus-visible {
	color: var(--color-highlight);
	border-color: var(--color-highlight);
	background: rgba(240, 230, 218, 0.1);
}

.section {
	padding: var(--space-2xl) var(--space-md);
}

.section-alt {
	background: rgba(255, 255, 255, 0.45);
}

.section-title {
	font-family: var(--font-head);
	font-size: clamp(0.95rem, 0.82rem + 0.55vw, 1.25rem);
	font-weight: 650;
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-md);
	color: var(--color-primary);
	line-height: 1.25;
}

.section-intro {
	margin: 0 0 var(--space-lg);
	color: var(--color-muted);
	max-width: 44rem;
}

.grid-3 {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr));
	gap: var(--space-md);
}

.grid-2 {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
	gap: var(--space-md);
}

.card {
	background: #fff;
	padding: var(--space-md);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-line);
	box-shadow: var(--shadow-sm);
}

.card-quiet {
	background: rgba(240, 230, 218, 0.72);
}

.card-title {
	font-family: var(--font-head);
	font-size: clamp(0.82rem, 0.75rem + 0.3vw, 0.95rem);
	font-weight: 600;
	margin: 0 0 var(--space-sm);
	color: var(--color-text);
}

.card-text {
	margin: 0;
	font-size: 0.92rem;
	color: var(--color-muted);
}

.split {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
	gap: var(--space-xl);
	align-items: center;
}

.split-reverse .split-media {
	order: -1;
}

@media (min-width: 768px) {
	.split-reverse .split-media {
		order: 2;
	}

	.split-reverse .split-text {
		order: 1;
	}
}

.rounded-img {
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	border: 1px solid var(--color-line);
}

.tag-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.tag {
	font-family: var(--font-head);
	font-size: 0.72rem;
	font-weight: 600;
	padding: var(--space-xs) var(--space-sm);
	border-radius: 999px;
	background: rgba(26, 60, 64, 0.1);
	color: var(--color-primary);
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
}

.step-list {
	margin: 0;
	padding: 0;
	list-style: none;
	counter-reset: step;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.step-list li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--space-md);
	align-items: start;
	padding: var(--space-md);
	background: #fff;
	border-radius: var(--radius-md);
	border: 1px solid var(--color-line);
}

.step-label {
	font-family: var(--font-head);
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-accent);
}

.cta-panel {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-lg);
	background: linear-gradient(120deg, rgba(193, 127, 74, 0.2), rgba(149, 127, 168, 0.18));
	padding: var(--space-xl);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-line);
}

.cta-text {
	margin: var(--space-sm) 0 0;
	max-width: 36rem;
	color: var(--color-muted);
}

.cta-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.disclaimer {
	background: #fff;
	padding: var(--space-lg);
	border-radius: var(--radius-lg);
	border: 1px dashed rgba(26, 60, 64, 0.38);
	font-size: 0.88rem;
	color: var(--color-muted);
}

.disclaimer p {
	margin: 0 0 var(--space-md);
}

.disclaimer p:last-child {
	margin-bottom: 0;
}

.site-footer {
	background: var(--color-primary);
	color: var(--color-secondary);
	padding: var(--space-xl) var(--space-md) var(--space-lg);
	margin-top: var(--space-xl);
}

.site-footer a {
	color: var(--color-secondary);
}

.site-footer a:hover,
.site-footer a:focus-visible {
	color: var(--color-highlight);
}

.footer-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr));
	gap: var(--space-xl);
	align-items: start;
}

.footer-heading {
	font-family: var(--font-head);
	font-size: clamp(0.78rem, 0.72rem + 0.2vw, 0.88rem);
	font-weight: 650;
	margin: 0 0 var(--space-sm);
	color: var(--color-secondary);
}

.footer-links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	font-size: 0.85rem;
}

.footer-note {
	font-size: 0.85rem;
	opacity: 0.9;
	margin: var(--space-sm) 0 0;
}

.footer-address,
.footer-phone,
.footer-email {
	font-size: 0.85rem;
	margin: 0 0 var(--space-xs);
	opacity: 0.92;
}

.footer-bottom {
	text-align: center;
	font-size: 0.75rem;
	margin: var(--space-xl) 0 0;
	opacity: 0.75;
}

.logo-footer {
	color: var(--color-secondary);
}

.logo-footer .logo-mark {
	box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.25);
}

.privacy-popup,
.cookie-banner {
	position: fixed;
	inset: 0;
	background: rgba(45, 45, 45, 0.45);
	z-index: 100;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: var(--space-md);
}

.privacy-popup[hidden],
.cookie-banner[hidden] {
	display: none;
}

.privacy-popup-inner,
.cookie-banner-inner {
	background: #fff;
	max-width: 32rem;
	width: 100%;
	padding: var(--space-lg);
	border-radius: var(--radius-lg) var(--radius-lg) 0 0;
	box-shadow: var(--shadow-md);
	margin-bottom: env(safe-area-inset-bottom, 0);
}

@media (min-width: 600px) {
	.privacy-popup,
	.cookie-banner {
		align-items: center;
		padding: var(--space-lg);
	}

	.privacy-popup-inner,
	.cookie-banner-inner {
		border-radius: var(--radius-lg);
		margin-bottom: 0;
	}
}

.privacy-popup-title,
.cookie-banner-title {
	font-family: var(--font-head);
	font-size: clamp(0.9rem, 0.82rem + 0.35vw, 1.05rem);
	margin: 0 0 var(--space-sm);
	color: var(--color-primary);
}

.privacy-popup-text,
.cookie-banner-text {
	margin: 0 0 var(--space-md);
	font-size: 0.88rem;
	color: var(--color-muted);
}

.privacy-popup-actions,
.cookie-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.cookie-tools {
	margin-bottom: var(--space-md);
	border: 1px solid var(--color-line);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.cookie-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--space-sm) var(--space-md);
	border-bottom: 1px solid var(--color-line);
	font-family: var(--font-head);
	font-size: 0.82rem;
}

.cookie-apply {
	width: 100%;
	margin-top: 0;
	border-radius: 0 0 var(--radius-md) var(--radius-md);
	border-top: 1px solid var(--color-line);
}

.cookie-label {
	color: var(--color-text);
}

.page-header {
	padding: var(--space-xl) var(--space-md) var(--space-md);
	background: linear-gradient(180deg, rgba(26, 60, 64, 0.09), transparent);
}

.page-title {
	font-family: var(--font-head);
	font-size: clamp(1rem, 0.85rem + 0.65vw, 1.35rem);
	font-weight: 700;
	margin: 0;
	color: var(--color-primary);
	letter-spacing: -0.02em;
}

.page-lead {
	margin: var(--space-sm) 0 0;
	max-width: 40rem;
	color: var(--color-muted);
	font-size: 0.92rem;
}

.subhero-img {
	margin-top: var(--space-lg);
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--color-line);
	box-shadow: var(--shadow-sm);
}

.legal-page {
	padding-bottom: var(--space-2xl);
}

.legal-wrap {
	width: min(100% - var(--space-lg) * 2, 50rem);
	margin-inline: auto;
	padding: var(--space-lg) 0;
}

.legal-wrap h1 {
	font-family: var(--font-head);
	font-size: clamp(1rem, 0.85rem + 0.65vw, 1.35rem);
	font-weight: 700;
	margin: 0 0 var(--space-md);
	color: var(--color-primary);
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.legal-wrap h2 {
	font-family: var(--font-head);
	font-size: clamp(0.88rem, 0.78rem + 0.4vw, 1.05rem);
	font-weight: 650;
	margin: var(--space-xl) 0 var(--space-sm);
	color: var(--color-primary);
}

.legal-wrap h3 {
	font-family: var(--font-head);
	font-size: clamp(0.82rem, 0.75rem + 0.25vw, 0.92rem);
	font-weight: 600;
	margin: var(--space-lg) 0 var(--space-sm);
	color: var(--color-text);
}

.legal-wrap p,
.legal-wrap li {
	font-size: 0.9rem;
	color: var(--color-muted);
}

.legal-wrap ul {
	padding-left: 1.1rem;
}

.legal-wrap .home-button {
	display: inline-flex;
	margin-top: var(--space-md);
	font-family: var(--font-head);
	font-weight: 600;
	font-size: 0.82rem;
	padding: var(--space-sm) var(--space-md);
	border-radius: var(--radius-md);
	background: var(--color-accent);
	color: var(--color-text);
	text-decoration: none;
}

.legal-wrap .home-button:hover,
.legal-wrap .home-button:focus-visible {
	color: #1b120c;
	background: #9e6232;
}

.legal-last-update {
	font-family: var(--font-head);
	font-size: clamp(0.78rem, 0.72rem + 0.2vw, 0.85rem);
	font-weight: 600;
	color: var(--color-primary);
	margin: 0 0 var(--space-sm);
}

.legal-last-update .legal-date {
	font-weight: 500;
	color: var(--color-muted);
}

.legal-meta {
	background: rgba(26, 60, 64, 0.07);
	padding: var(--space-md);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-line);
	font-size: 0.85rem;
	margin: var(--space-lg) 0;
}

.table-scroll {
	overflow: auto;
	margin: var(--space-md) 0;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-md);
	background: #fff;
}

.legal-wrap table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.82rem;
	min-width: 18rem;
}

.legal-wrap th,
.legal-wrap td {
	padding: var(--space-sm) var(--space-md);
	text-align: left;
	border-bottom: 1px solid var(--color-line);
}

.legal-wrap th {
	font-family: var(--font-head);
	font-weight: 600;
	color: var(--color-primary);
	background: rgba(240, 230, 218, 0.72);
}

.contact-layout {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
	gap: var(--space-xl);
	align-items: start;
	padding: var(--space-xl) var(--space-md);
}

.contact-card {
	background: #fff;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: var(--space-lg);
	box-shadow: var(--shadow-sm);
	position: relative;
	overflow: hidden;
}

.contact-card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 0.28rem;
	background: linear-gradient(90deg, var(--color-primary), var(--color-accent), var(--color-highlight));
}

.contact-card-muted {
	background: rgba(26, 60, 64, 0.07);
}

.contact-card h2 {
	font-family: var(--font-head);
	font-size: clamp(0.88rem, 0.78rem + 0.35vw, 1rem);
	margin: 0 0 var(--space-md);
	color: var(--color-primary);
}

.contact-note {
	font-size: 0.88rem;
	color: var(--color-muted);
	margin: 0 0 var(--space-md);
}

.contact-lines {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	font-size: 0.88rem;
}

.map-wrap {
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--color-line);
	box-shadow: var(--shadow-sm);
	background: #fff;
}

.map-wrap iframe {
	display: block;
	width: 100%;
	height: 22rem;
	min-height: 21.875rem;
	border: 0;
}

.form-group {
	margin-bottom: var(--space-md);
}

.form-group label {
	display: block;
	font-family: var(--font-head);
	font-size: 0.78rem;
	font-weight: 600;
	margin-bottom: var(--space-xs);
	color: var(--color-text);
}

.form-group input,
.form-group textarea {
	width: 100%;
	padding: var(--space-sm) var(--space-md);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-line);
	font-family: var(--font-body);
	font-size: 0.9rem;
	background: #fff;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-group textarea {
	min-height: 8rem;
	resize: vertical;
}

.form-group input:focus-visible,
.form-group textarea:focus-visible {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(26, 60, 64, 0.22);
}

.field-error {
	font-family: var(--font-head);
	font-size: 0.72rem;
	color: #8b2942;
	margin-top: var(--space-xs);
	min-height: 1rem;
}

.checkbox-row {
	display: flex;
	align-items: flex-start;
	gap: var(--space-sm);
	font-size: 0.82rem;
	color: var(--color-muted);
}

.checkbox-row input {
	width: auto;
	margin-top: 0.2rem;
}

body.layout-footer-bottom {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

body.layout-footer-bottom .site-header {
	flex-shrink: 0;
}

body.layout-footer-bottom main.page-center {
	flex: 1;
	min-height: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

body.layout-footer-bottom .site-footer {
	flex-shrink: 0;
	margin-top: auto;
}

.page-center {
	min-height: 55vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-2xl) var(--space-md);
}

.page-center-inner {
	text-align: center;
	max-width: 36rem;
}

.page-center-inner h1,
.page-center-inner h2 {
	font-family: var(--font-head);
	font-size: clamp(1rem, 0.85rem + 0.55vw, 1.35rem);
	color: var(--color-primary);
	margin: 0 0 var(--space-md);
}

.page-center-inner p {
	max-width: none;
	margin: 0 0 var(--space-md);
	color: var(--color-muted);
}

.page-center-inner.page-center-wide {
	max-width: min(100% - var(--space-lg), 44rem);
	width: 100%;
}

.page-center-inner p:last-of-type {
	margin-bottom: 0;
}

.recipe-list-plain {
	list-style: disc;
	padding-left: 1.25rem;
	margin: var(--space-md) 0 0;
}

.recipe-list-plain li {
	margin-bottom: var(--space-xs);
}

.pull-quote {
	font-size: 0.95rem;
	font-style: italic;
	color: var(--color-primary);
	border-left: 3px solid var(--color-accent);
	padding-left: var(--space-md);
	margin: var(--space-lg) 0;
}
