:root{
  --bg:#ffffff;
  --text:#1f2937;
  --muted:#6b7280;
  --accent:#2F6B4F;
  --border:#e5e7eb;
  --maxw:1100px;
  --airbnb:#FF5A5F;
  --booking:#003580;
  --space-s: 12px;
}

/* Base */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,Arial,sans-serif;line-height:1.55}
img{max-width:100%;height:auto;display:block;border-radius:14px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:40px 20px}
.hd{font-family:"Playfair Display",Georgia,serif;font-size:clamp(28px,4vw,42px);line-height:1.15;letter-spacing:-.2px;margin:0 0 16px}

/* Make section headings smaller in subsections */
.gallery .hd,
.about .hd,
.reviews .hd,
.location .hd,
.book .hd{
  font-size:clamp(20px, 3vw, 32px);
  line-height:1.2;
  margin-bottom:12px;
}

/* Sub-headers to match section heading style */
.about h3,
.reviews h3,
.location h3,
.book h3{
  font-family:"Playfair Display",Georgia,serif;
  font-weight:700;
  font-size:clamp(20px,3vw,32px);
  line-height:1.2;
  letter-spacing:-0.2px;
  margin:18px 0 8px;
}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:40;transition:background .2s, box-shadow .2s}
.site-header .nav{display:flex;align-items:center;justify-content:space-between;padding:14px 20px}
.site-header .brand{font-family:"Playfair Display",Georgia,serif;font-weight:700;color:var(--text);font-size:32px;letter-spacing:-.3px;position:relative}

/* Subtle brand badge over hero (no stroke, softer everything) */
.site-header:not(.scrolled) .brand{
  padding:2px 8px;
  border-radius:10px;
  background:rgba(255,255,255,.18);
  -webkit-backdrop-filter:saturate(120%) blur(6px);
  backdrop-filter:saturate(120%) blur(6px);
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.site-header.scrolled .brand{
  background:transparent;
  box-shadow:none;
  padding:0;
}


.site-header .menu a{margin-left:18px;color:var(--text);opacity:.9}
.site-header.scrolled{background:rgba(255,255,255,.85);backdrop-filter:saturate(130%) blur(10px);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.site-header.scrolled .menu a{opacity:.8}

/* Header reveal */
body:not(.ready) .site-header .brand,
body:not(.ready) .site-header .menu a{opacity:0;transform:translateY(-6px)}
body.ready .site-header .brand,
body.ready .site-header .menu a{opacity:1;transform:none;transition:opacity .75s ease, transform .5s ease}
body.ready .site-header .menu a:nth-child(1){transition-delay:.05s}
body.ready .site-header .menu a:nth-child(2){transition-delay:.10s}
body.ready .site-header .menu a:nth-child(3){transition-delay:.15s}
body.ready .site-header .menu a:nth-child(4){transition-delay:.20s}

/* Desktop vs mobile nav */
.menu.desktop{display:flex}
.menu.mobile{display:none;position:absolute;right:20px;top:60px;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;box-shadow:0 12px 30px rgba(0,0,0,.12);padding:8px;z-index:70}
.menu.mobile a{display:block;padding:10px 14px;color:var(--text);opacity:.9}
.menu.mobile a + a{border-top:1px solid rgba(0,0,0,.06)}

/* Burger */
.burger{display:none;position:relative;width:36px;height:28px;border:0;background:transparent;cursor:pointer}
.burger span{position:absolute;left:0;right:0;height:2px;background:var(--text);border-radius:2px;transition:transform .2s, opacity .2s}
.burger span:nth-child(1){top:4px}
.burger span:nth-child(2){top:13px}
.burger span:nth-child(3){bottom:4px}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

@media (max-width: 860px){
  .menu.desktop{display:none}
  .burger{display:block}
  .menu.mobile{display:block}
  .site-header .nav{position:relative}
  #mobile-menu[hidden]{display:none !important}
}

.sub{color:var(--muted);margin:8px 0 20px}

/* Hero */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:flex-end;
  color:#fff;
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.35), rgba(0,0,0,.10) 40%, rgba(0,0,0,0) 70%);
  z-index:0;
}
.hero__spacer{height:12vh}

/* Hero overlay CTA (hidden; we use intro CTA instead) */
.hero .hero__cta.overlay{position:absolute;left:50%;bottom:12vh;transform:translateX(-50%);display:flex;gap:12px;z-index:1}
@media (max-width: 640px){.hero .hero__cta.overlay{bottom:8vh;flex-wrap:wrap;justify-content:center}}
.hero .hero__cta.overlay .btn{backdrop-filter:saturate(120%) blur(2px);box-shadow:0 10px 30px rgba(0,0,0,.22)}
.hero .hero__cta.overlay{display:none !important}

/* Desktop: smooth fixed hero background without JS */
@media (min-width: 1024px){
  .hero{ background-attachment: fixed; }
}


/* Floating CTA on desktop (unused on mobile) */
@media (min-width: 992px){
  .float-cta{position:fixed;right:20px;bottom:24px;z-index:60;box-shadow:0 10px 30px rgba(0,0,0,.18)}
}
.float-cta{padding:10px 16px;border:1px solid rgba(255,255,255,.6)}

/* Section spacing tweaks */
.wrap > *:last-child{margin-bottom:0}
.intro .intro-inner{text-align:center}
.intro .cta-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:8px}
.intro.wrap{padding-bottom:var(--space-s)}
.facts.wrap{padding-top:var(--space-s)}
.about.wrap{padding-bottom:var(--space-s)}
.reviews{padding:var(--space-s) 0}
.reviews .wrap{padding-top:var(--space-s)}
.location.wrap{padding-top:var(--space-s);padding-bottom:var(--space-s)}
.book.wrap{padding-top:var(--space-s);padding-bottom:var(--space-s)}

/* Buttons */
.btn{display:inline-block;padding:12px 20px;border-radius:999px;border:1px solid transparent;font-weight:700;letter-spacing:.2px;box-shadow:0 10px 30px rgba(0,0,0,.12);transition:transform .12s ease}
.btn:active{transform:translateY(1px)}
.btn-airbnb{background:var(--airbnb);color:#fff}
.btn-airbnb:hover{filter:brightness(0.95)}
.btn-booking{background:var(--booking);color:#fff}
.btn-booking:hover{filter:brightness(1.05)}

/* Facts */
.facts .facts-list{display:flex;flex-wrap:wrap;gap:10px 14px;padding:0;margin:0;list-style:none;color:var(--muted);justify-content:center}
.facts .facts-list li{padding:8px 12px;border:1px solid rgba(0,0,0,.08);border-radius:999px;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.04)}

/* Gallery */
.gallery .grid figure{margin:0} /* reset user-agent margin */
.gallery{background:#fafafa;border-top:none;border-bottom:none}
.gallery .wrap{padding-top:16px;padding-bottom:12px}
.gallery .grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
@media (max-width: 1200px){.gallery .grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}}
@media (max-width: 900px){.gallery .grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:4px}}
@media (max-width: 560px){.gallery .grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:2px}}

.gallery .grid figure{
  aspect-ratio:4/3;
  overflow:hidden;
  position:relative;
  display:block;
  border-radius:8px;
  background:#fff;
}
.gallery .grid figure::after{
  content:"";
  position:absolute;
  inset:0;
  border:1px solid rgba(0,0,0,.06);
  border-radius:8px;
  pointer-events:none;
}
.gallery .grid figure img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:0 !important;
  transform:translateZ(0);
  will-change:transform;
}

/* Reviews */
.reviews{padding:32px 0}
.reviews .reviews-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.reviews blockquote{margin:0;padding:16px 18px;border:1px solid rgba(0,0,0,.06);border-radius:12px;background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.06)}
.reviews cite{display:block;margin-top:8px;color:var(--muted);font-style:normal}
@media (max-width: 1000px){.reviews .reviews-row{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 560px){.reviews .reviews-row{grid-template-columns:1fr}}

/* Location map */
.map-embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;border:1px solid var(--border)}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* CTA row */
.cta-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* Footer */
.footer{border-top:1px solid rgba(0,0,0,.06);margin-top:var(--space-s)}
.footer .footer-inner{display:flex;justify-content:space-between;align-items:center;gap:20px;color:var(--muted);flex-wrap:wrap}

/* Scroll to top */
#toTop{position:fixed;right:16px;bottom:86px;z-index:60;width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--text);box-shadow:0 6px 20px rgba(0,0,0,.12);opacity:0;pointer-events:none;transition:opacity .2s, transform .2s}
#toTop.show{opacity:1;pointer-events:auto;transform:translateY(0)}
#toTop:hover{transform:translateY(-2px)}

/* Mobile adjustments */
@media (max-width: 767px){
  .hero{background-attachment:scroll;background-position:center center !important}
}

/* Mobile spacing for the (now removed) bottom CTA — harmless if unused */
@media (max-width: 991px){
  .float-cta{display:inline-block;margin:0 16px 16px 16px}
}

/* Footer contact (non-italic) + emphasis */
.footer address,
.footer-contact{font-style:normal;color:var(--muted)}
.footer-contact a{color:var(--accent);text-decoration:none;font-weight:600;text-underline-offset:2px}
.footer-contact a:hover{text-decoration:underline}

/* Gallery: "Show more" reveal */
#gallery-grid.is-collapsed figure:nth-child(n+10){ display:none; }
.gallery-toggle-wrap{ margin-top: 14px; display:flex; justify-content:center; }
.btn-more{
  background:#f3f4f6;
  color:#111827;
  border:1px solid var(--border);
  padding:10px 14px;
  border-radius:12px;
  cursor:pointer;
}
.btn-more:hover{ filter:brightness(0.98); }

/* PhotoSwipe tweaks */
.pswp__bg{ background: rgba(0,0,0,0.7) !important; } /* see page through only around outside */
.pswp img{ max-width: none !important; height: auto !important; } /* let PSWP control sizing */
.pswp__img{ border-radius: 0 !important; } /* no rounding on lightbox image */

/* Optional: better click affordance on thumbs */
.gallery .grid a{ cursor: zoom-in; }