:root {
  --paper: oklch(0.972 0.013 82);
  --paper-2: oklch(0.948 0.018 78);
  --paper-3: oklch(0.912 0.024 74);
  --ink: oklch(0.262 0.018 54);
  --ink-2: oklch(0.432 0.02 52);
  --ink-3: oklch(0.572 0.018 52);
  --clay: oklch(0.602 0.134 42);
  --clay-deep: oklch(0.498 0.122 40);
  --night: oklch(0.252 0.022 52);
  --line: oklch(0.262 0.018 54 / 0.14);
  --line-soft: oklch(0.262 0.018 54 / 0.08);

  --maxw: 1240px;
  --gutter: clamp(1.25rem, 5vw, 4.5rem);
  --serif: "Young Serif", Georgia, serif;
  --sans: "Hanken Grotesk", system-ui, sans-serif;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

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

body {
  font-family: var(--sans);
  background: var(--paper);
  color: var(--ink);
  font-size: clamp(1rem, 0.96rem + 0.22vw, 1.16rem);
  line-height: 1.65;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

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

a {
  color: inherit;
  text-decoration: none;
}

.wrap {
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.kicker {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--clay-deep);
}

h1, h2, h3 {
  font-family: var(--serif);
  font-weight: 400;
  line-height: 1.02;
  letter-spacing: -0.01em;
}

.reveal {
  opacity: 0;
  transform: translateY(26px);
}

.reveal.in {
  opacity: 1;
  transform: none;
  transition: opacity 1s var(--ease), transform 1.1s var(--ease);
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal, .reveal.in { opacity: 1; transform: none; transition: none; }
}

/* Header */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: clamp(1rem, 2.2vw, 1.6rem) var(--gutter);
  color: var(--paper);
  transition: background 0.5s var(--ease), color 0.5s var(--ease), box-shadow 0.5s var(--ease), padding 0.5s var(--ease);
}

.site-header.scrolled {
  background: color-mix(in oklch, var(--paper) 86%, transparent);
  backdrop-filter: blur(14px) saturate(1.3);
  color: var(--ink);
  box-shadow: 0 1px 0 var(--line-soft);
  padding-block: clamp(0.7rem, 1.4vw, 1rem);
}

.brand {
  font-family: var(--serif);
  font-size: clamp(1.25rem, 1.1rem + 0.7vw, 1.7rem);
  letter-spacing: -0.01em;
}

.header-right {
  display: flex;
  align-items: center;
  gap: clamp(0.8rem, 2vw, 1.6rem);
}

.nav-contact {
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  padding-bottom: 2px;
  border-bottom: 1.5px solid color-mix(in oklch, currentColor 45%, transparent);
  transition: border-color 0.3s var(--ease), opacity 0.3s var(--ease);
}

.nav-contact:hover { border-bottom-color: var(--clay); opacity: 0.95; }
.site-header.scrolled .nav-contact:hover { border-bottom-color: var(--clay-deep); }

.lang-toggle {
  display: inline-flex;
  align-items: center;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  border: 1px solid currentColor;
  border-radius: 999px;
  overflow: hidden;
  opacity: 0.92;
}

.lang-toggle button {
  font: inherit;
  background: transparent;
  color: inherit;
  border: 0;
  cursor: pointer;
  padding: 0.32rem 0.7rem;
  transition: background 0.3s var(--ease), color 0.3s var(--ease);
}

.lang-toggle button[aria-pressed="true"] {
  background: var(--clay);
  color: var(--paper);
}

/* Hero */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  color: var(--paper);
  overflow: hidden;
}

.hero-media {
  position: absolute;
  inset: 0;
}

.hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.08);
  animation: heroZoom 14s var(--ease) forwards;
}

@keyframes heroZoom {
  to { transform: scale(1); }
}

.hero-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, oklch(0.2 0.02 50 / 0.82) 0%, oklch(0.2 0.02 50 / 0.2) 42%, oklch(0.2 0.02 50 / 0.15) 100%),
    linear-gradient(to right, oklch(0.2 0.02 50 / 0.35), transparent 60%);
}

.hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-bottom: clamp(2.5rem, 6vh, 5rem);
  padding-top: 7rem;
}

.hero .kicker {
  color: oklch(0.86 0.06 60);
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.hero .kicker::before {
  content: "";
  width: 2.4rem;
  height: 1px;
  background: currentColor;
  display: inline-block;
}

.hero h1 {
  font-size: clamp(3.6rem, 13vw, 11rem);
  margin: 0.18em 0 0.12em -0.02em;
  text-shadow: 0 2px 30px oklch(0.2 0.02 50 / 0.4);
}

.hero-tag {
  font-size: clamp(1.05rem, 0.95rem + 0.7vw, 1.55rem);
  max-width: 30ch;
  line-height: 1.45;
  color: oklch(0.95 0.01 80);
}

.hero-facts {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  margin-top: clamp(2rem, 5vh, 3.2rem);
  padding-top: 1.6rem;
  border-top: 1px solid oklch(0.95 0.01 80 / 0.28);
}

.hero-facts div {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.hero-facts b {
  font-family: var(--serif);
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  font-weight: 400;
  line-height: 1;
}

.hero-facts small {
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.82;
}

.scroll-cue {
  position: absolute;
  bottom: 1.5rem;
  right: var(--gutter);
  z-index: 2;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  opacity: 0.7;
}

/* Section scaffolding */
section.block {
  padding-block: clamp(4.5rem, 11vh, 9rem);
}

.section-head {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.section-head h2 {
  font-size: clamp(1.95rem, 1.4rem + 2.6vw, 3.4rem);
  max-width: 18ch;
}

/* About */
.about {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: start;
}

.about-copy p {
  max-width: 60ch;
  margin-bottom: 1.1rem;
  color: var(--ink-2);
}

.about-copy p:first-child {
  font-size: clamp(1.2rem, 1.05rem + 0.7vw, 1.55rem);
  line-height: 1.5;
  color: var(--ink);
}

.features {
  border-top: 1px solid var(--line);
}

.features li {
  list-style: none;
  display: flex;
  align-items: baseline;
  gap: 1rem;
  padding: 0.95rem 0;
  border-bottom: 1px solid var(--line);
  font-size: 1.02rem;
}

.features li::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--clay);
  flex: none;
  transform: translateY(-2px);
}

/* Facts strip */
.facts-strip {
  background: var(--paper-2);
  border-block: 1px solid var(--line-soft);
}

.facts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.facts-grid div {
  padding: clamp(2rem, 4vw, 3rem) clamp(1rem, 2vw, 2rem);
  border-right: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.facts-grid div:last-child { border-right: 0; }

.facts-grid b {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2.1rem, 1.4rem + 2.6vw, 3.4rem);
  line-height: 0.95;
}

.facts-grid b em {
  font-style: normal;
  font-size: 0.42em;
  color: var(--ink-3);
  font-family: var(--sans);
  font-weight: 500;
  letter-spacing: 0.02em;
}

.facts-grid small {
  font-size: 0.76rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-3);
}

/* Gallery */
.gallery {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(0.6rem, 1.2vw, 1rem);
  grid-auto-flow: dense;
}

.gallery figure {
  position: relative;
  overflow: hidden;
  background: var(--paper-3);
  grid-column: span 2;
  aspect-ratio: 3 / 2;
  cursor: zoom-in;
}

.gallery figure:nth-child(7n + 1) { grid-column: span 4; aspect-ratio: 16 / 9; }
.gallery figure:nth-child(7n + 4) { grid-column: span 3; aspect-ratio: 4 / 3; }
.gallery figure:nth-child(7n + 5) { grid-column: span 3; aspect-ratio: 4 / 3; }

.gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease), filter 0.6s var(--ease);
}

.gallery figure:hover img {
  transform: scale(1.05);
}

.gallery figure::after {
  content: "";
  position: absolute;
  inset: 0;
  background: oklch(0.6 0.13 42 / 0);
  transition: background 0.5s var(--ease);
}

.gallery figure:hover::after {
  background: oklch(0.6 0.13 42 / 0.12);
}

/* Film */
.film {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 340px), 1fr));
  gap: clamp(0.8rem, 1.6vw, 1.4rem);
  justify-content: center;
}

.film-item {
  position: relative;
  overflow: hidden;
  background: var(--night);
  cursor: pointer;
  max-height: 82vh;
}

.film-item video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.film-item .play {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: oklch(0.2 0.02 50 / 0.18);
  transition: background 0.4s var(--ease), opacity 0.4s var(--ease);
}

.film-item .play span {
  width: clamp(3.6rem, 6vw, 5rem);
  height: clamp(3.6rem, 6vw, 5rem);
  border-radius: 999px;
  background: var(--clay);
  color: var(--paper);
  display: grid;
  place-items: center;
  padding-left: 0.25em;
  font-size: 1.4rem;
  box-shadow: 0 12px 40px oklch(0.2 0.02 50 / 0.45);
  transition: transform 0.4s var(--ease), background 0.4s var(--ease);
}

.film-item:hover .play span { transform: scale(1.08); background: var(--clay-deep); }
.film-item.playing .play { opacity: 0; pointer-events: none; }

/* Location */
.location {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.location-copy p {
  max-width: 52ch;
  color: var(--ink-2);
  margin-bottom: 1rem;
}

.location-media {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--paper-3);
}

.location-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Contact */
.contact {
  background: var(--night);
  color: var(--paper);
}

.contact .wrap {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
  padding-block: clamp(4.5rem, 11vh, 8.5rem);
}

.contact h2 {
  font-size: clamp(2.2rem, 1.5rem + 3.4vw, 4.2rem);
}

.contact .lead {
  margin-top: 1.4rem;
  max-width: 40ch;
  color: oklch(0.85 0.02 70);
}

.contact-actions {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.05rem 1.5rem;
  border: 1px solid oklch(0.85 0.02 70 / 0.25);
  border-radius: 4px;
  font-weight: 600;
  font-size: 1.02rem;
  transition: background 0.4s var(--ease), color 0.4s var(--ease), border-color 0.4s var(--ease), transform 0.4s var(--ease);
}

.btn .arrow { transition: transform 0.4s var(--ease); }
.btn:hover .arrow { transform: translateX(5px); }

.btn-primary {
  background: var(--clay);
  border-color: var(--clay);
  color: var(--paper);
}

.btn-primary:hover { background: var(--clay-deep); border-color: var(--clay-deep); }

.btn:hover { transform: translateY(-2px); }

.btn small {
  display: block;
  font-weight: 400;
  font-size: 0.78rem;
  opacity: 0.7;
  letter-spacing: 0.02em;
}

/* Footer */
.site-footer {
  background: var(--night);
  color: oklch(0.7 0.02 70);
  font-size: 0.85rem;
  border-top: 1px solid oklch(0.85 0.02 70 / 0.12);
}

.site-footer .wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: space-between;
  padding-block: 2.2rem;
}

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

/* Lightbox */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: oklch(0.18 0.015 50 / 0.96);
  display: grid;
  place-items: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.45s var(--ease);
}

.lightbox.open { opacity: 1; pointer-events: auto; }

.lightbox img {
  max-width: 92vw;
  max-height: 86vh;
  object-fit: contain;
  box-shadow: 0 30px 80px oklch(0 0 0 / 0.5);
}

.lightbox-close,
.lightbox-nav button {
  position: absolute;
  background: oklch(0.95 0.01 80 / 0.1);
  color: var(--paper);
  border: 0;
  width: 3rem;
  height: 3rem;
  border-radius: 999px;
  font-size: 1.4rem;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background 0.3s var(--ease);
}

.lightbox-close { top: 1.4rem; right: 1.4rem; }
.lightbox-nav .prev { left: 1.4rem; top: 50%; transform: translateY(-50%); }
.lightbox-nav .next { right: 1.4rem; top: 50%; transform: translateY(-50%); }

.lightbox-close:hover,
.lightbox-nav button:hover { background: oklch(0.95 0.01 80 / 0.22); }

.lightbox-count {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  color: oklch(0.85 0.02 70);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
}

/* Responsive */
@media (max-width: 880px) {
  .about,
  .location,
  .contact .wrap { grid-template-columns: 1fr; }

  .gallery { grid-template-columns: repeat(2, 1fr); }
  .gallery figure,
  .gallery figure:nth-child(7n + 1),
  .gallery figure:nth-child(7n + 4),
  .gallery figure:nth-child(7n + 5) { grid-column: span 1; aspect-ratio: 3 / 2; }
  .gallery figure:nth-child(7n + 1) { grid-column: span 2; aspect-ratio: 16 / 10; }

  .scroll-cue { display: none; }
  .facts-grid div:nth-child(even) { border-right: 0; }
}

@media (max-width: 560px) {
  .price-chip { display: none; }
  .hero-facts { gap: 1.4rem 2rem; }
}
