:root {
  --dark: #11140f;
  --jungle: #1f3324;
  --jungle-2: #2f4933;
  --cream: #f4ead8;
  --sand: #d8c19d;
  --gold: #c99045;
  --rust: #b95f2f;
  --white: #fffaf1;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  color: var(--dark);
  background: var(--cream);
  line-height: 1.65;
}
img { display: block; width: 100%; height: auto; }

.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  padding: 18px clamp(18px, 4vw, 52px);
  color: var(--white);
  background: linear-gradient(to bottom, rgba(0,0,0,.68), rgba(0,0,0,0));
}
.brand {
  color: var(--white);
  text-decoration: none;
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1;
}
.brand span {
  display: block;
  font-family: "Montserrat", sans-serif;
  font-size: .62rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 3px;
}
.nav {
  display: flex;
  gap: 18px;
  font-size: .86rem;
  font-weight: 700;
  align-items: center;
}
.nav a, .nav-cta { color: var(--white); text-decoration: none; }
.nav-cta {
  border: 1px solid rgba(255,255,255,.6);
  padding: 9px 16px;
  border-radius: 999px;
  font-weight: 800;
}

.hero {
  min-height: 100vh;
  position: relative;
  display: grid;
  place-items: center;
  color: var(--white);
  text-align: center;
  padding: 120px 20px 70px;
  background: url("assets/hero.jpg") center/cover no-repeat;
}
.hero-overlay, .final-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, rgba(0,0,0,.16), rgba(0,0,0,.74)),
    radial-gradient(circle at center, rgba(201,144,69,.14), transparent 55%);
}
.hero-content, .final-content { position: relative; max-width: 960px; }
.eyebrow {
  margin: 0 0 14px;
  text-transform: uppercase;
  letter-spacing: .22em;
  font-weight: 800;
  font-size: .76rem;
  color: var(--gold);
}
h1, h2 {
  font-family: "Cormorant Garamond", serif;
  line-height: .95;
  margin: 0 0 22px;
  font-weight: 700;
}
h1 { font-size: clamp(3.2rem, 9vw, 8rem); text-shadow: 0 12px 40px rgba(0,0,0,.68); }
h2 { font-size: clamp(2.4rem, 5.5vw, 5rem); color: var(--jungle); }
.dark h2, .final-cta h2 { color: var(--white); }
.hero-text { font-size: clamp(1.08rem, 2vw, 1.45rem); max-width: 760px; margin: 0 auto 30px; }
.hero-actions { display: flex; justify-content: center; flex-wrap: wrap; gap: 14px; }

.button {
  display: inline-flex;
  min-height: 50px;
  padding: 13px 24px;
  border-radius: 999px;
  text-decoration: none;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  transition: transform .2s ease;
}
.button:hover { transform: translateY(-2px); }
.primary { background: var(--gold); color: #191006; }
.secondary {
  background: rgba(255,255,255,.14);
  color: var(--white);
  border: 1px solid rgba(255,255,255,.55);
  backdrop-filter: blur(8px);
}
.full { width: 100%; }

.section { padding: clamp(70px, 9vw, 130px) 0; }
.container { width: min(1120px, calc(100% - 36px)); margin: 0 auto; }
.narrow { width: min(850px, calc(100% - 36px)); text-align: center; }
.lead { font-size: clamp(1.15rem, 2vw, 1.45rem); color: var(--jungle-2); }

.return-lines {
  display: grid;
  gap: 5px;
  margin: 28px 0;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2rem, 5vw, 4.3rem);
  line-height: 1;
  color: var(--rust);
}

.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 6vw, 76px);
  align-items: center;
}
.reverse > .image-card { order: -1; }
.image-card {
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 24px 70px rgba(0,0,0,.22);
  background: #ddd;
}
.image-card img { aspect-ratio: 4 / 5; object-fit: cover; }
.image-card.tall img { aspect-ratio: 3 / 4; }
.feature-list { padding-left: 20px; font-weight: 600; }

.dark { background: var(--jungle); color: var(--white); }
.quote {
  text-align: center;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2.4rem, 6vw, 6rem);
  line-height: 1;
  color: var(--white);
}
.quote p { margin: 0; }
.warm { background: #eadac1; }

.amenity-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 34px;
}
.amenity-grid div {
  background: var(--white);
  border: 1px solid rgba(31,51,36,.14);
  border-radius: 18px;
  padding: 18px;
  font-weight: 700;
  box-shadow: 0 10px 26px rgba(31,51,36,.07);
}
.photo-grid {
  margin-top: 34px;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.photo-grid img {
  border-radius: 22px;
  height: 340px;
  object-fit: cover;
  box-shadow: 0 14px 38px rgba(0,0,0,.16);
}
.photo-grid img:nth-child(1), .photo-grid img:nth-child(4) { grid-column: span 7; }
.photo-grid img:nth-child(2), .photo-grid img:nth-child(3) { grid-column: span 5; }
.photo-grid img:nth-child(5), .photo-grid img:nth-child(6) { grid-column: span 6; }
.photo-grid img:nth-child(7), .photo-grid img:nth-child(8) { grid-column: span 6; }

.pricing-wrap {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: clamp(28px, 6vw, 70px);
  align-items: center;
}
.price-card {
  padding: 34px;
  border-radius: 30px;
  background: var(--white);
  border: 2px solid rgba(31,51,36,.12);
  box-shadow: 0 22px 62px rgba(31,51,36,.14);
  text-align: center;
}
.price {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(3.6rem, 7vw, 5.7rem);
  line-height: .9;
  color: var(--jungle);
  font-weight: 700;
}
.per { display: block; text-transform: uppercase; font-weight: 800; letter-spacing: .08em; }
.price-card hr { border: 0; height: 1px; background: var(--sand); margin: 24px 0; }
.small-note a { color: var(--rust); font-weight: 800; }

.final-cta {
  min-height: 74vh;
  position: relative;
  display: grid;
  align-items: center;
  text-align: center;
  color: var(--white);
  background: url("assets/lantern-view.jpg") center/cover no-repeat;
  padding: 90px 0;
}
.final-cta h2 { font-size: clamp(3.1rem, 8vw, 7.4rem); }

.footer {
  background: var(--dark);
  color: var(--cream);
  padding: 28px 36px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.footer a { color: var(--gold); font-weight: 800; text-decoration: none; margin-left: 16px; }

@media (max-width: 940px) {
  .nav { display: none; }
  .split, .pricing-wrap { grid-template-columns: 1fr; }
  .reverse > .image-card { order: 0; }
  .amenity-grid { grid-template-columns: repeat(2, 1fr); }
  .photo-grid { grid-template-columns: 1fr; }
  .photo-grid img, .photo-grid img:nth-child(n) { grid-column: auto; height: 330px; }
  .hero { text-align: left; place-items: end start; }
  .hero-actions { justify-content: flex-start; }
}
@media (max-width: 540px) {
  .amenity-grid { grid-template-columns: 1fr; }
  .nav-cta { padding: 8px 12px; font-size: .86rem; }
  h1 { font-size: 3.1rem; }
}

.lang-link {
  color: var(--white);
  text-decoration: none;
  font-weight: 800;
  margin-left: auto;
}

.experience-section .image-card img,
.evening-section .image-card img,
.image-card.wide img {
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.photo-grid.expanded img:nth-child(n) {
  grid-column: span 4;
}

.photo-grid.expanded img:nth-child(1),
.photo-grid.expanded img:nth-child(6),
.photo-grid.expanded img:nth-child(10) {
  grid-column: span 8;
}

@media (max-width: 940px) {
  .photo-grid.expanded img:nth-child(n) {
    grid-column: auto;
  }
  .lang-link {
    margin-left: 0;
  }
}
