/* =====================================================================
   Ferienwohnung Zum Glockenturm — 2026 redesign
   Warm & cozy editorial. Buildless, hand-written, mobile-first.
   Palette: refined warm heritage (amber + cream + charcoal).
   Fonts: Fraunces (display) + Hanken Grotesk (body) via Google Fonts.
   ===================================================================== */

/* ----------------------------- Tokens ----------------------------- */
:root {
	/* colour */
	--cream:       #faf5ec;
	--cream-2:     #f3ead9;
	--cream-3:     #ece0cb;
	--card:        #fffdf8;
	--ink:         #a38a79;
	--ink-soft:    #4a4138;
	--muted:       #786b59;
	--amber:       #a9791c;
	--amber-deep:  #835e14;
	--amber-soft:  #f6e9cc;
	--forest:      #4a5b3c;
	--line:        rgba(42, 36, 32, .12);
	--line-strong: rgba(42, 36, 32, .22);
	--white:       #ffffff;

	/* type */
	--font-display: "Fraunces", Georgia, "Times New Roman", serif;
	--font-body:    "Hanken Grotesk", "Segoe UI", system-ui, sans-serif;

	/* spacing scale */
	--sp-1: .5rem;
	--sp-2: 1rem;
	--sp-3: 1.5rem;
	--sp-4: 2rem;
	--sp-5: 3rem;
	--sp-6: 4.5rem;
	--sp-7: 6.5rem;

	/* radius + shadow */
	--r-sm: 8px;
	--r:    16px;
	--r-lg: 24px;
	--shadow-sm: 0 2px 10px rgba(42, 36, 32, .06);
	--shadow:    0 14px 40px -16px rgba(42, 36, 32, .28);
	--shadow-lg: 0 30px 70px -28px rgba(42, 36, 32, .42);

	--container: 1160px;
	--header-h: 76px;
}

/* ----------------------------- Reset ------------------------------ */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
	margin: 0;
	font-family: var(--font-body);
	font-size: clamp(1rem, .96rem + .2vw, 1.075rem);
	line-height: 1.7;
	color: var(--ink-soft);
	background: var(--cream);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}

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

a { color: var(--amber-deep); text-decoration: none; transition: color .25s ease; }
a:hover { color: var(--ink); }

h1, h2, h3, h4 {
	font-family: var(--font-display);
	font-weight: 540;
	color: var(--ink);
	line-height: 1.12;
	margin: 0 0 .6em;
	letter-spacing: -.01em;
	font-optical-sizing: auto;
}

p { margin: 0 0 1.1em; }
p:last-child { margin-bottom: 0; }

ul { margin: 0; padding: 0; }

hr { border: 0; height: 1px; background: var(--line); margin: var(--sp-5) 0; }

:focus-visible {
	outline: 3px solid var(--amber);
	outline-offset: 3px;
	border-radius: 4px;
}

.skip-link {
	position: absolute; left: 12px; top: -60px;
	background: var(--ink); color: var(--cream);
	padding: 10px 18px; border-radius: var(--r-sm); z-index: 200;
	transition: top .2s ease;
}
.skip-link:focus { top: 12px; color: var(--cream); }

/* --------------------------- Layout ------------------------------- */
.container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 5vw, 3rem);
}
.container--narrow { max-width: 820px; }

.section { padding-block: clamp(3.25rem, 7vw, var(--sp-7)); }
.section--tint { background: var(--cream-2); }
.section--ink  { background: var(--ink); color: #d9cdb8; }
.section--ink h1, .section--ink h2, .section--ink h3 { color: var(--cream); }

.eyebrow {
	display: inline-block;
	font-family: var(--font-body);
	font-weight: 700;
	font-size: .76rem;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--amber);
	margin-bottom: var(--sp-2);
}
.eyebrow::before {
	content: ""; display: inline-block;
	width: 26px; height: 2px; margin-right: .7em;
	background: var(--amber); vertical-align: middle;
}

.section-title { font-size: clamp(1.9rem, 1.3rem + 2.6vw, 3rem); }
.lead { font-size: clamp(1.1rem, 1.02rem + .4vw, 1.3rem); color: var(--ink-soft); }
.text-center { text-align: center; }
.measure { max-width: 64ch; }
.measure.text-center { margin-inline: auto; }

/* --------------------------- Buttons ------------------------------ */
.btn {
	display: inline-flex; align-items: center; gap: .55em;
	font-family: var(--font-body); font-weight: 600;
	font-size: 1rem; line-height: 1;
	padding: .95em 1.6em;
	border-radius: 999px;
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: transform .2s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn--primary { background: var(--amber); color: #fff; box-shadow: var(--shadow-sm); }
.btn--primary:hover { background: var(--amber-deep); color: #fff; box-shadow: var(--shadow); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn--ghost:hover { border-color: var(--ink); color: var(--ink); background: rgba(255,255,255,.4); }
.btn--light { background: rgba(255,255,255,.92); color: var(--ink); }
.btn--light:hover { background: #fff; color: var(--ink); }
.btn--lg { font-size: 1.05rem; padding: 1.05em 1.9em; }

.arrow-link {
	display: inline-flex; align-items: center; gap: .4em;
	font-weight: 600; color: var(--amber-deep);
}
.arrow-link span { transition: transform .25s ease; }
.arrow-link:hover span { transform: translateX(4px); }

/* --------------------------- Header ------------------------------- */
.site-header {
	position: sticky; top: 0; z-index: 100;
	background: rgba(250, 245, 236, .82);
	backdrop-filter: saturate(140%) blur(12px);
	-webkit-backdrop-filter: saturate(140%) blur(12px);
	border-bottom: 1px solid transparent;
	transition: border-color .3s ease, box-shadow .3s ease, background .3s ease;
}
.site-header.is-stuck {
	border-bottom-color: var(--line);
	box-shadow: var(--shadow-sm);
}
.site-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: var(--sp-2);
	min-height: var(--header-h);
}
.brand {
	display: inline-flex; flex-direction: column; line-height: 1;
	font-family: var(--font-display); color: var(--ink);
}
.brand:hover { color: var(--ink); }
.brand strong { font-size: 1.32rem; font-weight: 600; letter-spacing: -.01em; }
.brand small {
	font-family: var(--font-body); font-weight: 600;
	font-size: .68rem; letter-spacing: .2em; text-transform: uppercase;
	color: var(--amber); margin-top: .35em;
}

.nav { display: flex; align-items: center; gap: clamp(.4rem, 1.4vw, 1.1rem); }
.nav__links { display: flex; align-items: center; gap: clamp(.2rem, 1vw, .7rem); list-style: none; }
.nav__links a {
	display: inline-block; position: relative;
	font-weight: 500; font-size: .96rem; color: var(--ink-soft);
	padding: .5em .2em;
}
.nav__links a::after {
	content: ""; position: absolute; left: .2em; right: .2em; bottom: .2em;
	height: 2px; background: var(--amber);
	transform: scaleX(0); transform-origin: left; transition: transform .25s ease;
}
.nav__links a:hover { color: var(--ink); }
.nav__links a:hover::after,
.nav__links a[aria-current="page"]::after { transform: scaleX(1); }
.nav__links a[aria-current="page"] { color: var(--ink); }

.nav__cta { margin-left: .4rem; }

/* hamburger */
.nav-toggle {
	display: none;
	width: 46px; height: 46px;
	border: 1px solid var(--line-strong); border-radius: 12px;
	background: rgba(255,255,255,.5); cursor: pointer;
	padding: 0; position: relative;
}
.nav-toggle span,
.nav-toggle span::before,
.nav-toggle span::after {
	content: ""; position: absolute; left: 50%; top: 50%;
	width: 20px; height: 2px; background: var(--ink); border-radius: 2px;
	transform: translate(-50%, -50%); transition: transform .3s ease, opacity .2s ease;
}
.nav-toggle span::before { top: -6px; }
.nav-toggle span::after  { top: 6px; }

/* --------------------------- Hero --------------------------------- */
.hero {
	position: relative;
	min-height: min(86vh, 760px);
	display: flex; align-items: flex-end;
	color: #fff;
	background: var(--ink) center/cover no-repeat;
	background-image:
		linear-gradient(180deg, rgba(20,16,12,.18) 0%, rgba(20,16,12,.12) 35%, rgba(20,16,12,.78) 100%),
		var(--hero-img);
	isolation: isolate;
}
.hero__inner { padding-block: clamp(2.5rem, 7vw, 5rem); max-width: 720px; }
.hero .eyebrow { color: #f4d98c; }
.hero .eyebrow::before { background: #f4d98c; }
.hero h1 {
	color: #fff;
	font-size: clamp(2.6rem, 1.6rem + 4.6vw, 5rem);
	font-weight: 500;
	text-wrap: balance;
}
.hero p { color: rgba(255,255,255,.92); font-size: clamp(1.1rem, 1rem + .6vw, 1.45rem); max-width: 36ch; }
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-3); }

/* compact page banner for subpages */
.page-hero {
	position: relative; color: #fff;
	background: var(--ink) center/cover no-repeat;
	background-image:
		linear-gradient(180deg, rgba(20,16,12,.45), rgba(20,16,12,.62)),
		var(--hero-img);
	padding-block: clamp(3rem, 7vw, 6rem);
}
.page-hero h1 { color: #fff; font-size: clamp(2.1rem, 1.4rem + 3vw, 3.6rem); }
.page-hero p { color: rgba(255,255,255,.9); max-width: 56ch; margin-bottom: 0; }
.page-hero .eyebrow { color: #f4d98c; }
.page-hero .eyebrow::before { background: #f4d98c; }

/* breadcrumb-ish back chip on tinted page intros */
.page-intro { background: var(--cream-2); }

/* --------------------------- Cards -------------------------------- */
.grid { display: grid; gap: clamp(1.25rem, 3vw, 2rem); }
.grid--3 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr)); }
.grid--2 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr)); }

.card {
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: clamp(1.5rem, 3vw, 2.1rem);
	box-shadow: var(--shadow-sm);
	transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--line-strong); }
.card__icon {
	width: 52px; height: 52px; border-radius: 14px;
	display: grid; place-items: center; margin-bottom: var(--sp-2);
	background: var(--amber-soft); color: var(--amber-deep);
	font-size: 1.5rem;
}
.card h3 { font-size: 1.4rem; }
.card p { color: var(--muted); }
.card .arrow-link { margin-top: var(--sp-1); }

/* attraction card (image + body) */
.attraction {
	display: flex; flex-direction: column;
	background: var(--card); border: 1px solid var(--line);
	border-radius: var(--r-lg); overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform .3s ease, box-shadow .3s ease;
}
.attraction:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.attraction__media { aspect-ratio: 3 / 2; overflow: hidden; }
.attraction__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.attraction:hover .attraction__media img { transform: scale(1.06); }
.attraction__body { padding: clamp(1.3rem, 2.5vw, 1.7rem); display: flex; flex-direction: column; gap: .8rem; flex: 1; }
.attraction__body h3 { font-size: 1.3rem; margin: 0; }
.attraction__body p { color: var(--muted); margin: 0; font-size: .98rem; }
.attraction__body .arrow-link { margin-top: auto; padding-top: .4rem; }

/* --------------------- Room / split sections ---------------------- */
.split {
	display: grid; gap: clamp(1.75rem, 4vw, 3.5rem);
	align-items: center;
	grid-template-columns: 1fr;
}
.split__media { position: relative; }
.split__media img {
	width: 100%; border-radius: var(--r-lg);
	box-shadow: var(--shadow); aspect-ratio: 4 / 3; object-fit: cover;
}
.split__media::after {
	content: ""; position: absolute; inset: 0;
	border-radius: var(--r-lg);
	box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
	pointer-events: none;
}
.split__body h2 { font-size: clamp(1.6rem, 1.2rem + 1.6vw, 2.3rem); }
.split__tag {
	font-family: var(--font-body); font-size: .8rem; font-weight: 700;
	letter-spacing: .12em; text-transform: uppercase; color: var(--amber);
}

/* feature / equipment list with check bullets */
.features { list-style: none; display: grid; gap: .55rem; margin-top: var(--sp-2); }
.features li {
	position: relative; padding-left: 2rem; color: var(--ink-soft);
}
.features li::before {
	content: ""; position: absolute; left: 0; top: .45em;
	width: 1.15rem; height: 1.15rem; border-radius: 50%;
	background: var(--amber-soft);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23835e14' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
	background-size: .7rem; background-position: center; background-repeat: no-repeat;
}
.features--2 { grid-template-columns: 1fr; }

/* generic prose block */
.prose p { color: var(--ink-soft); }
.prose h2 { margin-top: var(--sp-4); }
.prose > :first-child { margin-top: 0; }

/* --------------------------- Stats -------------------------------- */
.stats {
	display: grid; gap: var(--sp-3);
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	margin-top: var(--sp-4);
}
.stat { text-align: center; padding: var(--sp-2); }
.stat strong {
	display: block; font-family: var(--font-display);
	font-size: clamp(2rem, 1.5rem + 2vw, 2.8rem); color: var(--amber-deep); line-height: 1;
}
.stat span { font-size: .9rem; color: var(--muted); letter-spacing: .04em; }

/* --------------------------- Pricing ------------------------------ */
.price-card {
	background: var(--card); border: 1px solid var(--line);
	border-radius: var(--r-lg); box-shadow: var(--shadow);
	overflow: hidden;
}
.price-card__head {
	background: var(--ink); color: var(--cream);
	padding: clamp(1.5rem, 4vw, 2.25rem); text-align: center;
}
.price-card__head .amount {
	font-family: var(--font-display); font-size: clamp(2.6rem, 2rem + 3vw, 3.8rem);
	color: #fff; line-height: 1;
}
.price-card__head .amount sup { font-size: .42em; vertical-align: super; }
.price-card__head .per { color: rgba(255,255,255,.7); font-size: .95rem; }
.price-card__body { padding: clamp(1.5rem, 4vw, 2.25rem); }
.price-list { list-style: none; display: grid; gap: .85rem; }
.price-list li {
	display: flex; gap: .8rem; align-items: flex-start;
	padding-bottom: .85rem; border-bottom: 1px solid var(--line); color: var(--ink-soft);
}
.price-list li:last-child { border-bottom: 0; padding-bottom: 0; }
.price-list li::before { content: "•"; color: var(--amber); font-weight: 700; }

.info-table { width: 100%; border-collapse: collapse; }
.info-table th, .info-table td {
	text-align: left; padding: .9rem 1rem;
	border-bottom: 1px solid var(--line); font-size: .98rem;
}
.info-table thead th {
	font-family: var(--font-body); font-weight: 700; font-size: .78rem;
	text-transform: uppercase; letter-spacing: .08em; color: var(--muted);
	background: var(--cream-2);
}
.info-table tbody td { color: var(--ink-soft); }

/* --------------------------- Contact ------------------------------ */
.contact-grid { display: grid; gap: clamp(1.75rem, 4vw, 3rem); grid-template-columns: 1fr; }
.contact-form-wrap {
	background: var(--card); border: 1px solid var(--line);
	border-radius: var(--r-lg); padding: clamp(1.5rem, 3vw, 2rem); box-shadow: var(--shadow-sm);
}
.contact-form-wrap form { width: 100%; }
.address-block { display: grid; gap: var(--sp-3); }
.address-card {
	display: flex; gap: var(--sp-2); align-items: flex-start;
	padding: var(--sp-2) 0; border-bottom: 1px solid var(--line);
}
.address-card:last-child { border-bottom: 0; }
.address-card .ic {
	flex: none; width: 44px; height: 44px; border-radius: 12px;
	background: var(--amber-soft); color: var(--amber-deep);
	display: grid; place-items: center; font-size: 1.2rem;
}
.address-card h4 { margin: 0 0 .2em; font-size: 1.05rem; }
.address-card p { margin: 0; color: var(--muted); font-size: .98rem; }
.address-card a { color: var(--amber-deep); }

.map-frame {
	border-radius: var(--r-lg); overflow: hidden;
	border: 1px solid var(--line); box-shadow: var(--shadow-sm);
	margin-top: var(--sp-3);
}
.map-frame iframe { display: block; width: 100%; height: clamp(280px, 45vw, 440px); border: 0; }

/* ------------------------- Gallery -------------------------------- */
.gallery-grid {
	columns: 1; column-gap: clamp(.9rem, 2vw, 1.25rem);
}
.gallery-item {
	display: block; width: 100%; margin-bottom: clamp(.9rem, 2vw, 1.25rem);
	break-inside: avoid; position: relative;
	border-radius: var(--r); overflow: hidden;
	border: 1px solid var(--line); box-shadow: var(--shadow-sm);
	cursor: zoom-in; background: var(--cream-3);
}
.gallery-item img { width: 100%; transition: transform .6s ease; }
.gallery-item:hover img { transform: scale(1.05); }
.gallery-item figcaption {
	position: absolute; left: 0; right: 0; bottom: 0;
	padding: 1.4rem 1rem .9rem; color: #fff;
	font-family: var(--font-display); font-size: 1.05rem;
	background: linear-gradient(to top, rgba(20,16,12,.78), transparent);
	opacity: 0; transform: translateY(8px); transition: opacity .3s ease, transform .3s ease;
}
.gallery-item:hover figcaption,
.gallery-item:focus-visible figcaption { opacity: 1; transform: translateY(0); }

/* lightbox */
.lightbox {
	position: fixed; inset: 0; z-index: 300;
	display: none; align-items: center; justify-content: center;
	background: rgba(18, 14, 10, .92);
	padding: clamp(1rem, 4vw, 3rem);
}
.lightbox.is-open { display: flex; animation: lb-fade .25s ease; }
@keyframes lb-fade { from { opacity: 0; } to { opacity: 1; } }
.lightbox__img {
	max-width: min(1100px, 92vw); max-height: 82vh;
	border-radius: var(--r); box-shadow: var(--shadow-lg);
}
.lightbox__cap {
	position: absolute; bottom: clamp(1rem, 4vw, 2.2rem); left: 0; right: 0;
	text-align: center; color: #f2e7d3; font-family: var(--font-display); font-size: 1.1rem;
}
.lightbox__btn {
	position: absolute; background: rgba(255,255,255,.12); color: #fff;
	border: 1px solid rgba(255,255,255,.25); cursor: pointer;
	width: 52px; height: 52px; border-radius: 50%;
	display: grid; place-items: center; font-size: 1.4rem; line-height: 1;
	transition: background .2s ease, transform .2s ease;
}
.lightbox__btn:hover { background: rgba(255,255,255,.24); transform: scale(1.06); }
.lightbox__close { top: clamp(1rem, 4vw, 2rem); right: clamp(1rem, 4vw, 2rem); }
.lightbox__prev { left: clamp(.5rem, 3vw, 2rem); top: 50%; transform: translateY(-50%); }
.lightbox__next { right: clamp(.5rem, 3vw, 2rem); top: 50%; transform: translateY(-50%); }
.lightbox__prev:hover, .lightbox__next:hover { transform: translateY(-50%) scale(1.06); }

/* ------------------- Reviews / guestbook wrap --------------------- */
.embed-card {
	background: var(--card); border: 1px solid var(--line);
	border-radius: var(--r-lg); padding: clamp(1.25rem, 3vw, 2rem);
	box-shadow: var(--shadow-sm);
}
.guestbook-frame { width: 100%; border: 0; min-height: 600px; }
.review-cta {
	display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-2);
	margin-top: var(--sp-3);
}

/* --------------------------- Footer ------------------------------- */
.site-footer {
	background: var(--ink); color: #c9bda8;
	padding-block: clamp(3rem, 6vw, var(--sp-6));
}
.site-footer a { color: #e7d9be; }
.site-footer a:hover { color: #fff; }
.footer-grid {
	display: grid; gap: var(--sp-4);
	grid-template-columns: 1fr;
}
.footer-brand strong {
	font-family: var(--font-display); font-size: 1.6rem; color: var(--cream);
	display: block; margin-bottom: .4rem;
}
.footer-brand p { color: #9c917f; font-size: .95rem; max-width: 34ch; }
.footer-col h4 {
	color: var(--cream); font-family: var(--font-body); font-weight: 700;
	font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; margin-bottom: var(--sp-2);
}
.footer-col ul { list-style: none; display: grid; gap: .5rem; }
.footer-col li a { font-size: .98rem; }
.footer-bottom {
	margin-top: var(--sp-4); padding-top: var(--sp-3);
	border-top: 1px solid rgba(255,255,255,.12);
	display: flex; flex-wrap: wrap; gap: .6rem var(--sp-3);
	justify-content: space-between; font-size: .88rem; color: #8d8472;
}

/* ------------------------- Back to top ---------------------------- */
.to-top {
	position: fixed; right: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem);
	width: 50px; height: 50px; border-radius: 50%;
	background: var(--amber); color: #fff; border: 0; cursor: pointer;
	display: grid; place-items: center; font-size: 1.3rem;
	box-shadow: var(--shadow); z-index: 90;
	opacity: 0; visibility: hidden; transform: translateY(12px);
	transition: opacity .3s ease, transform .3s ease, background .25s ease, visibility .3s;
}
.to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.to-top:hover { background: var(--amber-deep); }

/* ------------------------- Reveal on scroll ----------------------- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-in { opacity: 1; transform: none; }

/* =========================== Responsive ========================== */
@media (min-width: 720px) {
	.split { grid-template-columns: 1fr 1fr; }
	.split--reverse .split__media { order: 2; }
	.features--2 { grid-template-columns: 1fr 1fr; }
	.contact-grid { grid-template-columns: 1.05fr .95fr; align-items: start; }
	.gallery-grid { columns: 2; }
	.footer-grid { grid-template-columns: 1.6fr 1fr 1fr; gap: var(--sp-5); }
	.pricing-layout { display: grid; grid-template-columns: 360px 1fr; gap: clamp(1.75rem, 4vw, 3rem); align-items: start; }
}

@media (min-width: 1080px) {
	.gallery-grid { columns: 3; }
}

/* ----- Mobile nav: collapse to overlay below 940px ----- */
@media (max-width: 939px) {
	.nav-toggle { display: inline-grid; place-items: center; }
	.nav {
		position: fixed; inset: 0 0 0 auto;
		width: min(360px, 86vw);
		background: var(--cream);
		flex-direction: column; align-items: stretch; justify-content: flex-start;
		gap: 0; padding: calc(var(--header-h) + 1rem) clamp(1.5rem, 6vw, 2.5rem) 2rem;
		box-shadow: var(--shadow-lg);
		transform: translateX(100%);
		transition: transform .35s cubic-bezier(.4,0,.2,1);
		overflow-y: auto;
	}
	.nav.is-open { transform: translateX(0); }
	.nav__links { flex-direction: column; align-items: stretch; gap: 0; width: 100%; }
	.nav__links li { border-bottom: 1px solid var(--line); }
	.nav__links a { padding: .95em .1em; font-size: 1.08rem; }
	.nav__links a::after { display: none; }
	.nav__links a[aria-current="page"] { color: var(--amber-deep); }
	.nav__cta { margin: var(--sp-3) 0 0; }
	.nav__cta .btn { width: 100%; justify-content: center; }

	.nav-toggle { z-index: 110; }
	.nav-toggle.is-active span { background: transparent; }
	.nav-toggle.is-active span::before { top: 0; transform: rotate(45deg); }
	.nav-toggle.is-active span::after  { top: 0; transform: rotate(-45deg); }

	.nav-backdrop {
		position: fixed; inset: 0; z-index: 95;
		background: rgba(20,16,12,.45); opacity: 0; visibility: hidden;
		transition: opacity .3s ease, visibility .3s;
	}
	.nav-backdrop.is-open { opacity: 1; visibility: visible; }
	body.nav-open { overflow: hidden; }
}

@media (min-width: 940px) {
	.nav-backdrop { display: none; }
}

/* ----------------------- Reduced motion --------------------------- */
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after {
		animation-duration: .001ms !important;
		transition-duration: .001ms !important;
	}
	.reveal { opacity: 1; transform: none; }
}
