/* ==========================================================================
   Przystań u Miksera — main.css
   Dedykowany styl strony. Paleta oparta o nocny, ciepły ton z projektu:
   głęboki brąz/granat jako bazowe tło, kremowe sekcje, akcent bursztyn.
   ========================================================================== */

/* ----- 1. Design tokens (custom properties) ------------------------------ */
:root {
	/* Kolory */
	--c-ink:        #1a120b;   /* główny ciemny, prawie czarny z brązem */
	--c-ink-soft:   #2a1e14;
	--c-ink-haze:   #3a2a1d;
	--c-cream:      #f6f0e7;   /* tło sekcji jasnych */
	--c-cream-deep: #ece3d3;
	--c-paper:      #faf6ef;
	--c-amber:      #c8923f;   /* akcent bursztynowy, CTA */
	--c-amber-soft: #e3b36a;
	--c-amber-deep: #a47223;
	--c-muted:      #8a7a66;
	--c-line:       rgba(26,18,11,.12);
	--c-line-light: rgba(246,240,231,.14);
	--c-shadow:     rgba(26,18,11,.18);

	/* Typografia */
	--f-serif: "Cormorant Garamond", "Times New Roman", Georgia, serif;
	--f-sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

	--fs-xs:   0.75rem;
	--fs-sm:   0.875rem;
	--fs-base: 1rem;
	--fs-md:   1.125rem;
	--fs-lg:   1.375rem;
	--fs-xl:   clamp(1.75rem, 3vw, 2.5rem);
	--fs-2xl:  clamp(2.25rem, 4.5vw, 3.75rem);
	--fs-3xl:  clamp(2.75rem, 6.5vw, 5.25rem);
	--fs-hero: clamp(3rem, 9vw, 7.5rem);

	/* Odstępy */
	--sp-1:  .25rem;
	--sp-2:  .5rem;
	--sp-3:  .75rem;
	--sp-4:  1rem;
	--sp-5:  1.5rem;
	--sp-6:  2rem;
	--sp-7:  3rem;
	--sp-8:  4rem;
	--sp-9:  6rem;
	--sp-10: 8rem;

	/* Layout */
	--container:        1240px;
	--container-narrow: 760px;
	--radius-sm:  8px;
	--radius-md:  16px;
	--radius-lg:  28px;
	--radius-xl:  40px;
	--radius-pill: 999px;

	/* Easing / timings */
	--ease: cubic-bezier(.22, .61, .36, 1);
	--ease-emphasized: cubic-bezier(.2, .9, .3, 1.1);

	/* Header height (używane do scroll-padding kotwic) */
	--header-h: 84px;
}

/* ----- 2. Reset (lekki) -------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: var(--header-h); }
body { margin: 0; }
img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration: none; }
ul, ol { padding: 0; margin: 0; list-style: none; }
blockquote { margin: 0; }
figure { margin: 0; }

/* Screen reader only */
.screen-reader-text {
	position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.skip-link:focus {
	left: 1rem; top: 1rem; z-index: 100; width: auto; height: auto; clip: auto;
	padding: .75rem 1rem; background: var(--c-ink); color: var(--c-cream); border-radius: var(--radius-sm);
}

/* ----- 3. Base typography ------------------------------------------------ */
body {
	font-family: var(--f-sans);
	font-size: var(--fs-base);
	line-height: 1.6;
	color: var(--c-ink);
	background: var(--c-paper);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
	font-family: var(--f-serif);
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -.01em;
	margin: 0 0 var(--sp-4);
	color: var(--c-ink);
}

p { margin: 0 0 1em; }

.kicker {
	display: inline-block;
	font-family: var(--f-sans);
	font-size: var(--fs-xs);
	font-weight: 500;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--c-amber-deep);
	margin: 0 0 var(--sp-4);
	position: relative;
	padding-left: 2.5rem;
}
.kicker::before {
	content: "";
	position: absolute;
	left: 0; top: 50%;
	width: 2rem; height: 1px;
	background: var(--c-amber-deep);
	transform: translateY(-50%);
}

.section__heading {
	font-size: var(--fs-2xl);
	margin: 0 0 var(--sp-5);
}
.section__heading--light { color: var(--c-cream); }
.section__lead {
	font-size: var(--fs-md);
	color: var(--c-ink-soft);
	max-width: 52ch;
}
.section__lead p { margin: 0 0 1em; }
.section__lead p:last-child { margin-bottom: 0; }

.muted { color: var(--c-muted); font-size: var(--fs-sm); }
.text-center { text-align: center; }

/* ----- 4. Layout utilities ---------------------------------------------- */
.container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 var(--sp-5);
}
.container--narrow { max-width: var(--container-narrow); }

.section {
	padding: var(--sp-10) 0;
	position: relative;
}
.section__header { margin: 0 0 var(--sp-7); }
.section__header--center { text-align: center; max-width: 640px; margin-left: auto; margin-right: auto; }
.section__header--center .kicker { padding-left: 0; }
.section__header--center .kicker::before { content: none; }

/* ----- 5. Buttons ------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	padding: .95rem 1.7rem;
	font-family: var(--f-sans);
	font-size: var(--fs-sm);
	font-weight: 500;
	letter-spacing: .05em;
	text-transform: uppercase;
	border-radius: var(--radius-pill);
	transition: background .35s var(--ease), color .35s var(--ease), transform .35s var(--ease), box-shadow .35s var(--ease);
	will-change: transform;
	cursor: pointer;
	line-height: 1;
}
.btn svg { width: 1em; height: 1em; }
.btn:hover  { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
	background: var(--c-amber);
	color: #fff;
	box-shadow: 0 6px 22px -10px rgba(200, 146, 63, .6);
}
.btn--primary:hover { background: var(--c-amber-deep); box-shadow: 0 12px 28px -10px rgba(200, 146, 63, .65); }

.btn--outline {
	background: transparent;
	color: var(--c-ink);
	border: 1.5px solid var(--c-ink);
}
.btn--outline:hover { background: var(--c-ink); color: var(--c-cream); }

.btn--ghost {
	background: rgba(246, 240, 231, .08);
	color: var(--c-cream);
	border: 1px solid rgba(246, 240, 231, .28);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.btn--ghost:hover { background: rgba(246, 240, 231, .18); }

/* ----- 6. Header -------------------------------------------------------- */
.site-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 50;
	padding: 1.2rem 0;
	transition: background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
	color: var(--c-cream);
	/* Szanuj notch / safe area na iOS. Bez transformów — na Chrome Mobile
	   transform: translateZ(0) na fixed elemencie powoduje, że ląduje on
	   poza viewportem przy zwijaniu/rozwijaniu URL bara. */
	padding-top: calc(1.2rem + env(safe-area-inset-top, 0px));
}
/* Subtelny gradient pod headerem gdy nie jest jeszcze "przyklejony" —
   sprawia, że treść sekcji nie uderza wizualnie w dolną krawędź headera. */
.site-header::after {
	content: "";
	position: absolute;
	left: 0; right: 0; top: 100%;
	height: 40px;
	pointer-events: none;
	background: linear-gradient(180deg, rgba(0, 0, 0, .35), rgba(0, 0, 0, 0));
	opacity: 0;
	transition: opacity .4s var(--ease);
}
.site-header.is-scrolled::after { opacity: 1; }
.site-header.is-scrolled {
	/* Pełny, nieprzezroczysty kolor — inaczej tekst sekcji (np. "Opinie",
	   "Kontakt") przeziera przez półprzezroczysty header podczas scrollu. */
	background: var(--c-ink);
	box-shadow: 0 10px 30px -18px rgba(0, 0, 0, .6);
	padding: .75rem 0;
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-6);
}
.site-header__logo {
	display: inline-flex;
	align-items: center;
	height: 48px;
	color: currentColor;
}
.site-header__logo img,
.site-header__logo svg {
	height: 48px;
	width: auto;
	max-width: 180px;
}

/* Nav */
.site-nav { position: relative; }
.site-nav__menu {
	display: flex;
	align-items: center;
	gap: var(--sp-6);
	font-size: var(--fs-sm);
	font-weight: 500;
	letter-spacing: .02em;
}
.site-nav__menu a {
	position: relative;
	padding: .4rem 0;
	transition: color .3s var(--ease);
}
.site-nav__menu a::after {
	content: "";
	position: absolute;
	left: 0; bottom: 0;
	width: 100%; height: 1px;
	background: currentColor;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform .35s var(--ease);
}
.site-nav__menu a:hover::after { transform: scaleX(1); }

.site-nav__toggle {
	display: none;
	flex-direction: column;
	gap: 6px;
	width: 40px;
	height: 40px;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 2;
}
.site-nav__toggle-bar {
	display: block;
	width: 22px;
	height: 1.5px;
	background: currentColor;
	transition: transform .35s var(--ease), opacity .3s var(--ease);
}
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bar:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bar:nth-child(2) { opacity: 0; }
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bar:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }
.site-nav__toggle-close {
	position: absolute;
	inset: 0;
	opacity: 0;
	pointer-events: none;
	transition: opacity .3s var(--ease);
}
.site-nav__toggle-close::before,
.site-nav__toggle-close::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 24px;
	height: 1.5px;
	background: currentColor;
	transform-origin: center;
}
.site-nav__toggle-close::before { transform: translate(-50%, -50%) rotate(45deg); }
.site-nav__toggle-close::after { transform: translate(-50%, -50%) rotate(-45deg); }
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-bar {
	opacity: 0;
}
.site-nav__toggle[aria-expanded="true"] .site-nav__toggle-close {
	opacity: 1;
}

/* Mobile: header zawsze solid (bez pół-przezroczystej fazy na hero) —
   gwarantuje czytelność logo i hamburgera w każdym punkcie scrolla.

   POSITION: STICKY zamiast FIXED — Chrome iOS ma znany bug z position:fixed
   gdy URL bar się rozwija/zwija; element potrafi "wypaść" poza viewport.
   Sticky jest w tym zakresie stabilniejsze (Safari iOS i Chrome Android
   też działają z sticky bez problemów). */
@media (max-width: 820px) {
	.site-header {
		position: sticky;
		top: 0;
		background: var(--c-ink);
		box-shadow: 0 6px 18px -14px rgba(0, 0, 0, .6);
		padding: .75rem 0;
		padding-top: calc(.75rem + env(safe-area-inset-top, 0px));
	}
	.site-header::after { content: none; }
	.site-header__logo img,
	.site-header__logo svg { height: 40px; }

	/* Sticky header zajmuje wysokość w layoutcie, więc hero lekko skracamy
	   żeby pierwszy ekran = header + hero = 100vh (bez zbędnego scrollu). */
	.hero {
		min-height: calc(100svh - 64px);
		min-height: calc(100dvh - 64px);
	}
}

@media (max-width: 820px) {
	.site-nav__toggle {
		display: flex;
		/* Fixed + wysoki z-index — button ma być zawsze nad overlayem menu,
		   także po jego otwarciu (żeby X był klikalny jako close). */
		position: fixed;
		top: calc(.75rem + env(safe-area-inset-top, 0px));
		right: 1.25rem;
		z-index: 110;
		background: transparent;
		border-radius: 50%;
		transition: background .3s var(--ease);
	}
	.site-nav__toggle[aria-expanded="true"] {
		background: rgba(246, 240, 231, .08);
	}
	.site-nav__menu {
		position: fixed;
		inset: 0;
		z-index: 100;
		background: rgba(26, 18, 11, .97);
		backdrop-filter: blur(14px);
		-webkit-backdrop-filter: blur(14px);
		flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: var(--sp-6);
		font-size: var(--fs-lg);
		font-family: var(--f-serif);
		transform: translateY(-100%);
		pointer-events: none;
		transition: transform .5s var(--ease);
		color: var(--c-cream);
	}
	.site-nav__menu.is-open {
		transform: translateY(0);
		pointer-events: auto;
	}
}

/* ----- 7. Hero ---------------------------------------------------------- */
.hero {
	position: relative;
	min-height: 100svh;
	min-height: 100dvh;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	color: var(--c-cream);
	overflow: hidden;
	padding: var(--sp-10) 0 var(--sp-9);
}
.hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.hero__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.1);
	transition: transform 1.6s var(--ease);
	will-change: transform;
}
.hero.is-ready .hero__image { transform: scale(1); }
.hero__gradient {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(26,18,11,.55) 0%, rgba(26,18,11,.15) 25%, rgba(26,18,11,.25) 55%, rgba(26,18,11,.9) 100%);
}
.hero__content {
	position: relative;
	z-index: 1;
	max-width: 1100px;
	padding-bottom: var(--sp-8);
}

.hero__heading {
	font-family: var(--f-serif);
	font-weight: 500;
	font-size: var(--fs-hero);
	line-height: .95;
	letter-spacing: -.02em;
	margin: 0 0 var(--sp-5);
	color: var(--c-cream);
	overflow: hidden;
}
.hero__word {
	display: inline-block;
	margin-right: .15em;
	transform: translateY(120%);
	opacity: 0;
	will-change: transform, opacity;
}
.hero__word:last-child::after {
	content: ".";
	color: var(--c-amber);
}
.hero.is-ready .hero__word {
	animation: heroWordIn 1s var(--ease-emphasized) forwards;
	animation-delay: calc(var(--i, 0) * 0.14s + 0.3s);
}
@keyframes heroWordIn {
	0%   { transform: translateY(120%); opacity: 0; }
	100% { transform: translateY(0);    opacity: 1; }
}

.hero__sub {
	font-family: var(--f-sans);
	font-size: var(--fs-md);
	font-weight: 300;
	max-width: 48ch;
	margin: 0 0 var(--sp-6);
	color: rgba(246, 240, 231, .88);
	opacity: 0;
	transform: translateY(20px);
	transition: opacity .8s var(--ease) .9s, transform .8s var(--ease) .9s;
}
.hero.is-ready .hero__sub { opacity: 1; transform: translateY(0); }

.hero__cta {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity .8s var(--ease) 1.1s, transform .8s var(--ease) 1.1s, background .35s var(--ease), color .35s var(--ease);
}
.hero.is-ready .hero__cta { opacity: 1; transform: translateY(0); }

.hero__scroll {
	position: absolute;
	bottom: 1.5rem; left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .6rem;
	font-size: var(--fs-xs);
	letter-spacing: .25em;
	text-transform: uppercase;
	color: rgba(246, 240, 231, .7);
	opacity: 0;
	transition: opacity 1s var(--ease) 1.4s, color .3s var(--ease);
	z-index: 1;
}
.hero.is-ready .hero__scroll { opacity: 1; }
.hero__scroll:hover { color: var(--c-cream); }
.hero__scroll-line {
	width: 1px; height: 48px;
	background: linear-gradient(180deg, transparent, var(--c-amber-soft));
	animation: scrollBob 2.4s var(--ease) infinite;
}
@keyframes scrollBob {
	0%, 100% { transform: translateY(0) scaleY(1);    }
	50%      { transform: translateY(10px) scaleY(.6); }
}

/* ----- 8. About --------------------------------------------------------- */
.section--about { background: var(--c-cream); }
.about {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
	gap: var(--sp-8);
	align-items: center;
}
.about__text { position: relative; }
.about__media {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-lg);
	box-shadow: 0 30px 80px -40px var(--c-shadow);
	aspect-ratio: 4/3;
}
.about__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transform: scale(1.1);
	transition: transform 1.4s var(--ease);
	will-change: transform;
}
.about__media.is-visible img { transform: scale(1); }

@media (max-width: 880px) {
	.about { grid-template-columns: 1fr; }
	.about__media { aspect-ratio: 4/3; }
}

.features {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	margin-top: var(--sp-6);
}
.feature {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	padding: .55rem 1rem;
	background: rgba(26, 18, 11, .05);
	border: 1px solid var(--c-line);
	border-radius: var(--radius-pill);
	font-size: var(--fs-sm);
	color: var(--c-ink-soft);
	transition: background .3s var(--ease), transform .3s var(--ease);
}
.feature:hover { background: rgba(26, 18, 11, .09); transform: translateY(-2px); }
.feature__icon {
	display: inline-flex;
	width: 1.1rem; height: 1.1rem;
	color: var(--c-amber-deep);
}
.feature__icon svg { width: 100%; height: 100%; }

/* ----- 9. Menu teaser --------------------------------------------------- */
.section--menu {
	background: var(--c-ink);
	color: var(--c-cream);
	overflow: hidden;
}
.section--menu .kicker { color: var(--c-amber-soft); }
.section--menu .kicker::before { background: var(--c-amber-soft); }
.section--menu .section__heading { color: var(--c-cream); }
.section--menu .section__lead { color: rgba(246, 240, 231, .78); }
.section--menu .btn--outline {
	color: var(--c-cream);
	border-color: rgba(246, 240, 231, .4);
}
.section--menu .btn--outline:hover {
	background: var(--c-cream);
	color: var(--c-ink);
	border-color: var(--c-cream);
}

.menu-teaser {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: var(--sp-8);
	align-items: center;
}
.menu-teaser__media {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 1/1;
	box-shadow: 0 40px 100px -50px rgba(0,0,0,.8);
}
.menu-teaser__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transform: scale(1.1);
	transition: transform 1.4s var(--ease);
}
.menu-teaser__media.is-visible img { transform: scale(1); }

@media (max-width: 880px) {
	.menu-teaser { grid-template-columns: 1fr; }
}

/* ----- 10. Gallery ------------------------------------------------------ */
.section--gallery { background: var(--c-cream-deep); }
.gallery {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--sp-3);
}
.gallery__item {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-md);
	aspect-ratio: 3/4;
	opacity: 0;
	transform: translateY(30px);
	transition: opacity .9s var(--ease), transform .9s var(--ease);
	transition-delay: calc(var(--i, 0) * 0.08s);
}
.gallery__item.is-visible { opacity: 1; transform: translateY(0); }
.gallery__item img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .8s var(--ease);
}
.gallery__item:hover img { transform: scale(1.05); }
.gallery__item::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 40%, rgba(26, 18, 11, .55));
	opacity: 0;
	transition: opacity .35s var(--ease);
	pointer-events: none;
}
.gallery__item:hover::after { opacity: 1; }

.gallery__item--ph {
	background:
		linear-gradient(135deg, var(--c-ink) 0%, var(--c-ink-haze) 60%, var(--c-amber-deep) 140%);
	opacity: .7;
}

@media (max-width: 880px) { .gallery { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .gallery { grid-template-columns: 1fr; } }

/* Lightbox */
.lightbox {
	position: fixed;
	inset: 0;
	background: rgba(10, 6, 2, .94);
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--sp-5);
	opacity: 0;
	transition: opacity .4s var(--ease);
}
.lightbox.is-open { opacity: 1; }
.lightbox[hidden] { display: none; }
.lightbox__image {
	max-width: 90vw;
	max-height: 85vh;
	object-fit: contain;
	border-radius: var(--radius-md);
}
.lightbox__close, .lightbox__nav {
	position: absolute;
	color: var(--c-cream);
	font-size: 2rem;
	line-height: 1;
	width: 48px; height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	transition: background .3s var(--ease);
}
.lightbox__close { top: 1rem; right: 1rem; }
.lightbox__close:hover, .lightbox__nav:hover { background: rgba(246, 240, 231, .15); }
.lightbox__nav { top: 50%; transform: translateY(-50%); }
.lightbox__nav--prev { left: 1rem; }
.lightbox__nav--next { right: 1rem; }

/* ----- 11. Reviews ------------------------------------------------------ */
.section--reviews {
	background: var(--c-cream);
	overflow: hidden;
}
.reviews {
	position: relative;
	max-width: 860px;
	margin: 0 auto;
}
.reviews__track {
	position: relative;
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: 100%;
	overflow: hidden;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
}
.review {
	scroll-snap-align: start;
	padding: var(--sp-8) var(--sp-5);
	text-align: center;
	opacity: 1;
}
.review__marks {
	font-family: var(--f-serif);
	font-size: 6rem;
	line-height: 1;
	color: var(--c-amber);
	margin: 0 0 -.4em;
}
.review__quote {
	font-family: var(--f-serif);
	font-style: italic;
	font-size: var(--fs-xl);
	line-height: 1.35;
	color: var(--c-ink);
	margin: var(--sp-4) 0 var(--sp-6);
}
.review__quote p { margin: 0 0 .7em; }
.review__quote p:last-child { margin: 0; }
.review__foot {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--sp-2);
}
.review__author { margin: 0; font-size: var(--fs-md); }
.review__loc { color: var(--c-muted); font-weight: 400; }
.review__src {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	font-size: var(--fs-sm);
	color: var(--c-muted);
	padding: .3rem .75rem;
	border-radius: var(--radius-pill);
	border: 1px solid var(--c-line);
	transition: background .3s var(--ease), color .3s var(--ease);
}
a.review__src:hover { background: var(--c-ink); color: var(--c-cream); border-color: var(--c-ink); }
.review__src svg { width: 1em; height: 1em; fill: currentColor; }

.stars { display: inline-flex; gap: 2px; margin: 0 0 var(--sp-3); }
.stars__item { width: 18px; height: 18px; fill: rgba(26, 18, 11, .15); }
.stars__item--on { fill: var(--c-amber); }

.reviews__controls {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-5);
	margin-top: var(--sp-4);
}
.reviews__btn {
	width: 44px; height: 44px;
	border-radius: 50%;
	border: 1px solid var(--c-line);
	color: var(--c-ink);
	font-size: 1.4rem;
	line-height: 0;
	transition: background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.reviews__btn:hover { background: var(--c-ink); color: var(--c-cream); border-color: var(--c-ink); }

.reviews__dots {
	display: flex;
	gap: var(--sp-2);
}
.reviews__dot {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--c-line);
	transition: background .3s var(--ease), transform .3s var(--ease);
	cursor: pointer;
}
.reviews__dot.is-active { background: var(--c-amber); transform: scale(1.3); }

.reviews-empty { text-align: center; padding: var(--sp-6) 0; }

/* ----- 12. Contact ------------------------------------------------------ */
.section--contact {
	background: var(--c-ink);
	color: var(--c-cream);
	padding: 0;
	position: relative;
	overflow: hidden;
}
.contact {
	position: relative;
	min-height: 620px;
	display: flex;
	align-items: center;
}
.contact__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.contact__media img {
	width: 100%; height: 100%;
	object-fit: cover;
}
.contact__gradient {
	position: absolute;
	inset: 0;
	background: linear-gradient(100deg,
		rgba(26,18,11,.88) 0%,
		rgba(26,18,11,.55) 50%,
		rgba(26,18,11,.85) 100%);
}
.contact__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr minmax(300px, 420px);
	gap: var(--sp-8);
	align-items: center;
	padding-top: var(--sp-9);
	padding-bottom: var(--sp-9);
}
.contact__text { max-width: 520px; }
.contact__text .section__heading { font-size: var(--fs-3xl); }
.contact__sub {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin: 0 0 var(--sp-5);
	font-size: var(--fs-md);
	color: rgba(246, 240, 231, .78);
}
.contact__sub svg { width: 1.2em; height: 1.2em; color: var(--c-amber-soft); }

.contact__card {
	background: rgba(26, 18, 11, .72);
	border: 1px solid rgba(246, 240, 231, .14);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border-radius: var(--radius-lg);
	padding: var(--sp-7) var(--sp-6);
	box-shadow: 0 40px 80px -40px rgba(0, 0, 0, .7);
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
}
.contact__block-title {
	font-family: var(--f-sans);
	font-size: var(--fs-xs);
	font-weight: 500;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--c-amber-soft);
	margin: 0 0 var(--sp-3);
}
.contact__hours { font-size: var(--fs-sm); }
.contact__hours li {
	display: flex;
	justify-content: space-between;
	padding: .3rem 0;
	border-bottom: 1px solid var(--c-line-light);
}
.contact__hours li:last-child { border-bottom: 0; }
.contact__day  { color: rgba(246, 240, 231, .9); }
.contact__time { color: rgba(246, 240, 231, .6); }
.contact__phone {
	display: block;
	font-family: var(--f-serif);
	font-size: var(--fs-xl);
	line-height: 1.2;
	color: var(--c-cream);
	margin: 0 0 .3rem;
}
.contact__phone:hover { color: var(--c-amber-soft); }
.contact__email {
	display: block;
	font-size: var(--fs-sm);
	color: rgba(246, 240, 231, .6);
}
.contact__email:hover { color: var(--c-cream); }

@media (max-width: 880px) {
	.contact { min-height: auto; padding: 0; }
	.contact__inner { grid-template-columns: 1fr; padding-top: var(--sp-8); padding-bottom: var(--sp-8); }
	.contact__card { max-width: 440px; }
}

/* ----- 13. Footer ------------------------------------------------------- */
.site-footer {
	background: #120c07;
	color: rgba(246, 240, 231, .7);
	padding: var(--sp-7) 0 var(--sp-5);
	font-size: var(--fs-sm);
}
.site-footer__inner {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: var(--sp-6);
	align-items: start;
}
.site-footer__brand img,
.site-footer__brand svg {
	height: 48px;
	width: auto;
	max-width: 200px;
}
.site-footer__contact { display: flex; flex-direction: column; gap: .3rem; }
.site-footer__address { margin: 0; }
.site-footer__link {
	color: rgba(246, 240, 231, .85);
	transition: color .3s var(--ease);
}
.site-footer__link:hover { color: var(--c-amber-soft); }
.site-footer__social {
	display: flex;
	gap: var(--sp-3);
	justify-self: end;
}
.site-footer__social a {
	width: 40px; height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: rgba(246, 240, 231, .06);
	transition: background .3s var(--ease), transform .3s var(--ease);
	color: var(--c-cream);
}
.site-footer__social a svg { width: 18px; height: 18px; fill: currentColor; }
.site-footer__social a:hover { background: var(--c-amber); transform: translateY(-2px); }

.site-footer__copy {
	grid-column: 1 / -1;
	padding-top: var(--sp-5);
	margin-top: var(--sp-5);
	border-top: 1px solid rgba(246, 240, 231, .1);
	font-size: var(--fs-xs);
	color: rgba(246, 240, 231, .5);
	text-align: center;
}

@media (max-width: 720px) {
	.site-footer__inner { grid-template-columns: 1fr; text-align: center; }
	.site-footer__contact { align-items: center; }
	.site-footer__social { justify-self: center; }
}

/* ----- 14. Reveal animations (scroll) ----------------------------------- */
[data-reveal] {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 1s var(--ease), transform 1s var(--ease);
}
[data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0);
}
[data-reveal-stagger] > * {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity .7s var(--ease), transform .7s var(--ease);
}
[data-reveal-stagger].is-visible > * {
	opacity: 1;
	transform: translateY(0);
}
[data-reveal-stagger].is-visible > *:nth-child(1) { transition-delay: .05s; }
[data-reveal-stagger].is-visible > *:nth-child(2) { transition-delay: .12s; }
[data-reveal-stagger].is-visible > *:nth-child(3) { transition-delay: .19s; }
[data-reveal-stagger].is-visible > *:nth-child(4) { transition-delay: .26s; }
[data-reveal-stagger].is-visible > *:nth-child(5) { transition-delay: .33s; }
[data-reveal-stagger].is-visible > *:nth-child(6) { transition-delay: .40s; }

/* ----- 15. Reduced motion ----------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
		scroll-behavior: auto !important;
	}
	.hero__word, .hero__sub, .hero__cta, .hero__scroll { opacity: 1 !important; transform: none !important; }
	[data-reveal], [data-reveal-stagger] > * { opacity: 1 !important; transform: none !important; }
}

/* ----- 16. Post / page (fallback) --------------------------------------- */
.section--plain { padding: calc(var(--header-h) + var(--sp-8)) 0 var(--sp-9); background: var(--c-cream); }
.section--404   { padding: calc(var(--header-h) + var(--sp-10)) 0 var(--sp-10); background: var(--c-cream); }
.post__title   { font-size: var(--fs-2xl); }
.post__content p, .post__content ul, .post__content ol { margin-bottom: 1em; }
.post__content a { color: var(--c-amber-deep); border-bottom: 1px solid var(--c-amber-soft); }
