:root {
  --ink: #211a16;
  --muted: #6f625a;
  --paper: #f7f1e9;
  --paper-2: #fffaf3;
  --stone: #d8c9b7;
  --clay: #9a5739;
  --clay-dark: #713d28;
  --black: #111111;
  --white: #ffffff;
  --line: rgba(33, 26, 22, 0.16);
  --radius: 24px;
  --shadow: 0 20px 60px rgba(33, 26, 22, 0.16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.5;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
p { color: var(--muted); font-size: 1.04rem; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  padding: 1rem clamp(1rem, 4vw, 3rem);
  background: rgba(247, 241, 233, 0.88);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
.brand { display: inline-flex; align-items: center; gap: .75rem; font-weight: 700; letter-spacing: .02em; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 999px; color: var(--paper); background: var(--ink); font-size: .85rem; letter-spacing: .08em; }
.main-nav { display: flex; align-items: center; gap: 1.2rem; color: var(--muted); font-size: .94rem; }
.main-nav a:hover { color: var(--ink); }
.nav-toggle { display: none; border: 0; background: transparent; font: inherit; color: var(--ink); }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: .9rem 1.25rem;
  border-radius: 999px;
  border: 1px solid var(--ink);
  background: var(--ink);
  color: var(--paper-2);
  font-weight: 700;
  cursor: pointer;
}
.button:hover { transform: translateY(-1px); }
.button-small { min-height: 38px; padding: .5rem 1rem; font-size: .9rem; }
.button-ghost { background: rgba(255,255,255,.72); color: var(--ink); border-color: rgba(255,255,255,.72); }
.button-outline { background: transparent; color: var(--ink); }
.text-link { color: var(--clay-dark); font-weight: 800; text-decoration: underline; text-underline-offset: 5px; }

.hero {
  min-height: calc(100vh - 76px);
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(340px, .9fr);
  align-items: stretch;
  background: var(--paper-2);
}
.hero-media {
  min-height: 620px;
  background-image: linear-gradient(90deg, rgba(0,0,0,.05), rgba(0,0,0,0)), url('../assets/images/featured/hero.jpg');
  background-size: cover;
  background-position: center;
}
.hero-content {
  align-self: center;
  padding: clamp(2rem, 6vw, 5rem);
}
.eyebrow { text-transform: uppercase; letter-spacing: .16em; font-size: .78rem; font-weight: 800; color: var(--clay); margin: 0 0 1rem; }
h1, h2, h3 { line-height: 1.03; margin: 0; letter-spacing: -.04em; }
h1 { font-size: clamp(3rem, 6vw, 6.9rem); max-width: 11ch; }
h2 { font-size: clamp(2.2rem, 4vw, 4.7rem); }
h3 { font-size: 1.55rem; }
.hero-content p:not(.eyebrow) { max-width: 54ch; margin: 1.5rem 0 0; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .85rem; margin-top: 2rem; }

.quick-facts {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--ink);
  color: var(--paper-2);
}
.quick-facts article { padding: 1.5rem clamp(1rem, 3vw, 2rem); border-right: 1px solid rgba(255,255,255,.18); }
.quick-facts strong { display: block; font-size: 1.25rem; }
.quick-facts span { color: rgba(255,255,255,.68); }

.section { padding: clamp(4rem, 8vw, 7rem) clamp(1rem, 4vw, 4rem); }
.split { display: grid; grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr); gap: clamp(2rem, 6vw, 6rem); align-items: start; }
.copy-block { max-width: 760px; }
.section-heading { max-width: 880px; margin-bottom: 2rem; }
.section-heading.narrow { max-width: 820px; margin-inline: auto; text-align: center; }

.card-grid { display: grid; gap: 1.2rem; }
.card-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.stay-card { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.stay-card img { width: 100%; height: 280px; object-fit: cover; }
.stay-card div { padding: 1.5rem; }
.stay-card ul { list-style: none; padding: 0; margin: 1rem 0 1.2rem; display: grid; gap: .35rem; color: var(--muted); }
.stay-card li::before { content: "- "; color: var(--clay); font-weight: 900; }
.feature-card { background: #efe1d0; }

.dark-band { background: var(--ink); color: var(--paper-2); }
.dark-band .eyebrow { color: #dfb58f; }
.dark-band h2 { max-width: 760px; }
.band-content { max-width: 1180px; margin: auto; }
.booking-modes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 2rem; }
.booking-modes div { border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius); padding: 1.4rem; background: rgba(255,255,255,.05); }
.booking-modes span { color: #dfb58f; font-weight: 800; }
.booking-modes strong { display: block; font-size: 1.25rem; margin-top: .5rem; }
.booking-modes p { color: rgba(255,255,255,.65); margin-bottom: 0; }

.image-split { align-items: center; }
.image-split img { border-radius: var(--radius); box-shadow: var(--shadow); aspect-ratio: 4 / 3; object-fit: cover; width: 100%; }
.reverse { grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr); }
.amenities-list { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: 1.4rem; }
.amenities-list span { border: 1px solid var(--line); border-radius: 999px; padding: .55rem .9rem; background: var(--paper-2); color: var(--ink); font-weight: 700; }

.destination { background: #efe7dc; }
.destination-grid { max-width: 1160px; margin: 2.2rem auto 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.destination-grid article { border: 1px solid var(--line); border-radius: var(--radius); padding: 1.5rem; background: rgba(255,255,255,.45); }

.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .75rem; }
.gallery-grid button { border: 0; padding: 0; background: transparent; cursor: zoom-in; }
.gallery-grid img { width: 100%; height: 250px; object-fit: cover; border-radius: 16px; }
#showMorePhotos { margin-top: 1.2rem; }

.booking { display: grid; grid-template-columns: minmax(0, .85fr) minmax(320px, 1.15fr); gap: clamp(2rem, 6vw, 6rem); background: var(--paper-2); }
.booking-form { display: grid; gap: 1rem; padding: 1.4rem; border: 1px solid var(--line); border-radius: var(--radius); background: var(--paper); box-shadow: var(--shadow); }
.booking-form label { display: grid; gap: .4rem; font-weight: 800; }
.booking-form input, .booking-form select, .booking-form textarea {
  width: 100%; border: 1px solid var(--line); border-radius: 14px; padding: .9rem 1rem; font: inherit; color: var(--ink); background: var(--paper-2);
}
.form-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.form-note { margin: 0; font-size: .9rem; }
code { background: rgba(0,0,0,.08); padding: .1rem .3rem; border-radius: 5px; }

.site-footer { display: flex; justify-content: space-between; gap: 2rem; padding: 2rem clamp(1rem, 4vw, 4rem); background: var(--ink); color: var(--paper-2); }
.site-footer p { margin: .25rem 0 0; color: rgba(255,255,255,.62); }
.footer-links { display: grid; gap: .5rem; text-align: right; }
.footer-links a { color: rgba(255,255,255,.82); }

.lightbox { position: fixed; inset: 0; z-index: 100; background: rgba(0,0,0,.86); display: none; place-items: center; padding: 2rem; }
.lightbox[aria-hidden="false"] { display: grid; }
.lightbox img { max-height: 86vh; width: auto; border-radius: 12px; box-shadow: 0 20px 80px rgba(0,0,0,.4); }
.lightbox-close { position: absolute; top: 1rem; right: 1rem; width: 44px; height: 44px; border-radius: 999px; border: 0; font-size: 2rem; background: var(--paper-2); cursor: pointer; }

@media (max-width: 980px) {
  .nav-toggle { display: inline-flex; }
  .main-nav { position: absolute; top: 100%; left: 0; right: 0; display: none; flex-direction: column; align-items: flex-start; padding: 1rem; background: var(--paper); border-bottom: 1px solid var(--line); }
  .main-nav.open { display: flex; }
  .hero, .split, .reverse, .booking { grid-template-columns: 1fr; }
  .hero-media { min-height: 460px; order: -1; }
  h1 { max-width: 12ch; }
  .quick-facts, .card-grid.three, .booking-modes, .destination-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 640px) {
  .hero-media { min-height: 360px; }
  .quick-facts, .card-grid.three, .booking-modes, .destination-grid, .gallery-grid, .form-row { grid-template-columns: 1fr; }
  .gallery-grid img { height: 280px; }
  .site-footer { display: grid; }
  .footer-links { text-align: left; }
  .hero-actions .button { width: 100%; }
}
