:root{
  --green:#2F4A35;
  --moss:#6F8061;
  --stone:#77736A;
  --cream:#F4EBDD;
  --cream-2:#FBF7EE;
  --wood:#8A5F3F;
  --terracotta:#B06F4F;
  --charcoal:#2A2925;
  --line:rgba(47,74,53,.18);
  --shadow:0 24px 70px rgba(47,42,34,.14);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--cream-2);
  color:var(--charcoal);
  font-family:"Manrope",system-ui,sans-serif;
  line-height:1.5;
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.08;
  background-image:radial-gradient(var(--stone) .6px, transparent .6px);
  background-size:12px 12px;
}
img{max-width:100%;display:block;object-fit:cover}
a{color:inherit;text-decoration:none}
.section-pad{padding:96px clamp(20px,5vw,72px)}
.nav{
  position:sticky;
  top:0;
  z-index:20;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:18px clamp(20px,5vw,72px);
  background:rgba(251,247,238,.86);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--green)}
.brand-mark{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--green);color:var(--cream);
  font-family:"Cormorant Garamond",Georgia,serif;font-weight:800;
}
.nav nav{display:flex;gap:28px;color:rgba(42,41,37,.72);font-size:14px}
.nav nav a:hover{color:var(--green)}
.nav-cta{padding:12px 18px;border-radius:999px;background:var(--green);color:var(--cream);font-weight:800;font-size:13px;letter-spacing:.04em;text-transform:uppercase}
.hero{
  display:grid;
  grid-template-columns:minmax(0, .92fr) minmax(360px,1.08fr);
  gap:56px;
  align-items:center;
  min-height:calc(100dvh - 80px);
}
.eyebrow{
  margin:0 0 14px;
  color:var(--moss);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:11px;
  font-weight:700;
}
h1,h2{font-family:"Cormorant Garamond",Georgia,serif;line-height:.92;letter-spacing:-.018em;margin:0;color:var(--green);font-weight:700}
h1{font-size:clamp(58px,8.4vw,122px);text-wrap:balance}
h2{font-size:clamp(40px,5.2vw,78px);text-wrap:balance}
.lead{font-size:19px;color:rgba(42,41,37,.72);max-width:620px;font-weight:500;margin:28px 0 0}
.actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.button{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:15px 22px;font-weight:800;letter-spacing:.035em;text-transform:uppercase;transition:transform .25s ease, background .25s ease}
.button:active{transform:scale(.98) translateY(1px)}
.primary{background:var(--green);color:var(--cream)}
.primary:hover{background:#263d2c}
.secondary{background:rgba(47,74,53,.08);color:var(--green);border:1px solid var(--line)}
.large{padding:18px 28px;white-space:nowrap}
.hero-media{position:relative}
.hero-media img{height:min(74vh,720px);width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}
.hero-card{
  position:absolute;left:28px;bottom:28px;right:28px;
  padding:20px 22px;border-radius:22px;
  background:rgba(244,235,221,.86);
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.48);
  display:flex;justify-content:space-between;gap:18px;align-items:center;
}
.hero-card span{color:rgba(42,41,37,.68)}
.highlights{
  margin:0 clamp(20px,5vw,72px);
  padding:18px;
  border:1px solid var(--line);
  border-radius:999px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  background:var(--cream);
}
.highlights span{padding:9px 14px;border-radius:999px;background:rgba(47,74,53,.07);color:var(--green);font-size:14px;font-weight:700}
.story{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:end;border-bottom:1px solid var(--line)}
.story p:last-child{font-size:21px;color:rgba(42,41,37,.72);max-width:760px;font-weight:500;margin:0}
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.reverse{background:var(--cream)}
.split img{height:620px;width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}
.split-copy p:not(.eyebrow){font-size:18px;color:rgba(42,41,37,.72);max-width:590px}
.ticks{list-style:none;padding:0;margin:28px 0 0;display:grid;gap:12px}
.ticks li{padding:14px 16px;border-left:3px solid var(--terracotta);background:rgba(176,111,79,.08);border-radius:12px}
.section-head{max-width:860px;margin-bottom:42px}.section-head.compact{max-width:720px}
.gallery-grid{display:grid;grid-template-columns:1.25fr .85fr .85fr;grid-auto-rows:320px;gap:18px}
figure{margin:0;position:relative;overflow:hidden;border-radius:24px;background:var(--cream);box-shadow:0 16px 48px rgba(47,42,34,.10)}
figure.large{grid-row:span 2}
figure img{width:100%;height:100%}
figcaption{position:absolute;left:16px;bottom:16px;background:rgba(251,247,238,.88);padding:10px 13px;border-radius:999px;color:var(--green);font-weight:700;font-size:13px}
.river{background:linear-gradient(135deg,rgba(47,74,53,.96),rgba(111,128,97,.9)),url('assets/4433a8c8-841c-4224-a8cb-669ea52f34e6.jpg') center/cover;color:var(--cream)}
.river-panel{max-width:820px}.river h2,.river .eyebrow{color:var(--cream)}.river p:last-child{font-size:20px;color:rgba(244,235,221,.82)}
.amenity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.amenity-grid div{padding:26px;border:1px solid var(--line);border-radius:22px;background:var(--cream)}
.amenity-grid strong{display:block;color:var(--green);font-size:19px;margin-bottom:8px;letter-spacing:-.01em}.amenity-grid span{color:rgba(42,41,37,.68)}
.faq{background:var(--cream)}
details{border-top:1px solid var(--line);padding:22px 0;max-width:960px}details:last-child{border-bottom:1px solid var(--line)}
summary{cursor:pointer;font-weight:700;color:var(--green);font-size:20px;letter-spacing:-.01em}details p{color:rgba(42,41,37,.7);max-width:760px}
.booking{display:flex;justify-content:space-between;align-items:center;gap:32px;background:var(--green);color:var(--cream)}
.booking h2,.booking .eyebrow{color:var(--cream)}.booking p:last-child{max-width:640px;color:rgba(244,235,221,.78);font-size:18px}.booking .primary{background:var(--cream);color:var(--green)}
@media (max-width: 900px){
  .nav nav{display:none}.nav-cta{display:none}.section-pad{padding:64px 20px}.hero,.story,.split{grid-template-columns:1fr;gap:34px}.hero{min-height:auto}.hero-media img,.split img{height:460px}.gallery-grid{grid-template-columns:1fr;grid-auto-rows:280px}figure.large{grid-row:span 1}.amenity-grid{grid-template-columns:1fr}.booking{display:block}.booking .button{margin-top:24px}.highlights{border-radius:24px}.hero-card{position:static;margin-top:14px;display:block}
}
.links-body{
  min-height:100dvh;
  background:
    radial-gradient(circle at 15% 0%, rgba(176,111,79,.18), transparent 34%),
    linear-gradient(145deg, var(--cream-2), var(--cream));
}
.links-page{
  min-height:100dvh;
  display:grid;
  place-items:center;
  padding:28px 18px;
}
.links-card{
  width:min(100%, 540px);
  padding:18px 18px 24px;
  border:1px solid var(--line);
  border-radius:34px;
  background:rgba(251,247,238,.88);
  box-shadow:var(--shadow);
}
.links-hero-img img{
  width:100%;
  height:250px;
  border-radius:24px;
  box-shadow:0 18px 42px rgba(47,42,34,.12);
}
.brand-lockup{
  text-align:center;
  padding:24px 14px 18px;
}
.brand-lockup .brand-mark{
  margin:0 auto 18px;
}
.brand-lockup h1{
  font-size:clamp(40px, 11vw, 62px);
}
.brand-lockup p:not(.eyebrow){
  margin:14px auto 0;
  color:rgba(42,41,37,.72);
  max-width:410px;
}
.link-list{
  display:grid;
  gap:12px;
}
.link-pill{
  display:block;
  padding:17px 18px;
  border-radius:20px;
  background:var(--cream);
  border:1px solid var(--line);
  transition:transform .2s ease, border-color .2s ease, background .2s ease;
}
.link-pill:hover{
  transform:translateY(-2px);
  border-color:rgba(47,74,53,.38);
}
.link-pill strong{
  display:block;
  color:var(--green);
  font-size:17px;
}
.link-pill span{
  display:block;
  margin-top:3px;
  color:rgba(42,41,37,.62);
  font-size:14px;
}
.primary-link{
  background:var(--green);
  border-color:var(--green);
}
.primary-link strong,.primary-link span{color:var(--cream)}
.primary-link span{opacity:.78}
.links-foot{
  margin:18px 0 0;
  text-align:center;
  color:var(--moss);
  font-weight:700;
}
@media (max-width:520px){
  .links-card{border-radius:28px;padding:14px 14px 20px}
  .links-hero-img img{height:210px}
}
.nav-logo{
  width:46px;
  height:46px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid rgba(47,74,53,.2);
}
.actual-logo{
  width:118px;
  height:118px;
  border-radius:50%;
  object-fit:cover;
  margin:0 auto 18px;
  display:block;
  border:1px solid rgba(47,74,53,.18);
  box-shadow:0 14px 34px rgba(47,42,34,.12);
}
.links-hero-scroll{
  display:flex;
  gap:12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding-bottom:10px;
  scrollbar-color:rgba(47,74,53,.35) transparent;
}
.links-hero-scroll img{
  flex:0 0 86%;
  width:86%;
  height:250px;
  border-radius:24px;
  scroll-snap-align:center;
  box-shadow:0 18px 42px rgba(47,42,34,.12);
}
.links-hero-scroll img:first-child{margin-left:0}
.links-hero-scroll:after{
  content:"";
  flex:0 0 2px;
}
@media (max-width:520px){
  .links-hero-scroll img{height:210px;flex-basis:88%;width:88%}
  .actual-logo{width:104px;height:104px}
}
/* Gallery alignment refinement */
.gallery-grid{
  align-items:stretch;
}
.gallery-grid figure{
  display:grid;
  grid-template-rows:1fr auto;
  overflow:hidden;
  background:var(--cream);
}
.gallery-grid figure img{
  grid-row:1;
  width:100%;
  height:100%;
  min-height:0;
}
.gallery-grid figure figcaption{
  position:static;
  grid-row:2;
  display:flex;
  align-items:center;
  min-height:54px;
  padding:14px 18px;
  border-radius:0;
  background:var(--cream);
  border-top:1px solid var(--line);
  color:var(--green);
  font-weight:800;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.gallery-grid figure.large img{
  height:586px;
}
@media (max-width:900px){
  .gallery-grid figure.large img,
  .gallery-grid figure img{height:226px}
  .gallery-grid{grid-auto-rows:auto}
}
/* Editorial hero refinement */
.hero-editorial{
  position:relative;
  overflow:hidden;
  grid-template-columns:minmax(0,.9fr) minmax(420px,1.1fr);
}
.hero-editorial:before{
  content:"";
  position:absolute;
  width:520px;
  height:520px;
  border-radius:50%;
  right:-160px;
  top:72px;
  background:rgba(111,128,97,.16);
  z-index:-1;
}
.hero-logo{
  width:138px;
  height:138px;
  border-radius:50%;
  object-fit:cover;
  margin-bottom:28px;
  border:1px solid rgba(47,74,53,.18);
  box-shadow:0 18px 44px rgba(47,42,34,.12);
}
.hero-collage{
  position:relative;
  min-height:720px;
}
.hero-main-photo{
  position:absolute;
  inset:34px 0 64px 82px;
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.hero-main-photo img{
  width:100%;
  height:100%;
}
.hero-main-photo figcaption{
  position:absolute;
  left:20px;
  bottom:20px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.52);
  background:rgba(244,235,221,.88);
  backdrop-filter:blur(12px);
}
.hero-float{
  position:absolute;
  border-radius:24px;
  border:8px solid var(--cream-2);
  box-shadow:0 20px 54px rgba(47,42,34,.18);
}
.hero-float-one{
  width:310px;
  height:235px;
  left:0;
  top:0;
}
.hero-float-two{
  width:250px;
  height:180px;
  right:18px;
  bottom:0;
}
.hero-collage .hero-card{
  left:auto;
  right:38px;
  bottom:104px;
  width:min(360px,70%);
}
@media (max-width:900px){
  .hero-editorial{grid-template-columns:1fr}
  .hero-logo{width:112px;height:112px;margin-bottom:20px}
  .hero-collage{min-height:auto;display:grid;gap:14px}
  .hero-main-photo,.hero-float,.hero-collage .hero-card{position:static;width:100%;height:auto;inset:auto}
  .hero-main-photo{height:420px}
  .hero-main-photo img{height:100%}
  .hero-float{display:none}
  .hero-main-photo figcaption{position:absolute}
}
/* Impeccable pass: typography, hero, narrative gallery */
h1,h2{font-family:"Marcellus", Georgia, serif;font-weight:400;letter-spacing:-.026em;line-height:.94}
h1{font-size:clamp(52px,7.6vw,108px)}
h2{font-size:clamp(36px,4.8vw,68px)}
.hero-retreat{
  min-height:calc(100dvh - 80px);
  display:grid;
  grid-template-columns:minmax(0,1.12fr) minmax(380px,.88fr);
  gap:0;
  padding:clamp(18px,2vw,28px) clamp(20px,5vw,72px) 72px;
  align-items:stretch;
}
.hero-image-panel{
  min-height:720px;
  border-radius:36px 0 0 36px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.hero-image-panel img{width:100%;height:100%;object-fit:cover}
.hero-copy-panel{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:clamp(32px,5vw,72px);
  background:var(--cream);
  border:1px solid var(--line);
  border-left:0;
  border-radius:0 36px 36px 0;
  box-shadow:0 24px 70px rgba(47,42,34,.10);
}
.hero-copy-panel .lead{font-size:20px;max-width:560px}
.hero-copy-panel .hero-logo{width:116px;height:116px;margin-bottom:34px}
.gallery .section-head h2{max-width:720px}
.gallery-grid figure figcaption{
  font-family:"Marcellus", Georgia, serif;
  text-transform:none;
  letter-spacing:-.01em;
  font-size:22px;
  font-weight:400;
  min-height:64px;
}
.river{background:linear-gradient(90deg,rgba(47,74,53,.98),rgba(47,74,53,.74),rgba(47,74,53,.42)),url('assets/4433a8c8-841c-4224-a8cb-669ea52f34e6.jpg') center/cover}
@media (max-width:900px){
  h1{font-size:clamp(46px,14vw,70px)}
  h2{font-size:clamp(34px,10vw,52px)}
  .hero-retreat{display:flex;flex-direction:column;padding:14px 14px 52px;min-height:auto}
  .hero-image-panel{min-height:360px;border-radius:28px 28px 0 0;box-shadow:none}
  .hero-copy-panel{border-left:1px solid var(--line);border-top:0;border-radius:0 0 28px 28px;padding:28px 22px 30px;box-shadow:0 18px 46px rgba(47,42,34,.10)}
  .hero-copy-panel .hero-logo{width:92px;height:92px;margin-bottom:22px}
  .hero-copy-panel .lead{font-size:17px}
  .actions .button{width:100%}
  .gallery-grid figure figcaption{font-size:20px;min-height:58px}
}
@media (max-width:520px){
  .nav{padding:12px 14px}.brand span:last-child{font-size:13px}.nav-logo{width:38px;height:38px}
  .highlights{margin:0 14px;padding:12px;justify-content:flex-start;border-radius:20px}.highlights span{font-size:12px;padding:8px 10px}
  .section-pad{padding:54px 16px}
  .split img{height:310px}.hero-image-panel{min-height:300px}
}
.side-scroll{
  display:flex;
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 4px 18px;
}
.side-scroll img{
  flex:0 0 min(86%, 620px);
  height:620px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  scroll-snap-align:start;
}
.feature-scroll{
  min-width:0;
}
@media (max-width:900px){
  .side-scroll{margin-inline:-16px;padding-inline:16px;gap:12px}
  .side-scroll img{flex-basis:88%;height:360px;border-radius:24px}
}
@media (max-width:520px){
  .side-scroll img{height:310px;flex-basis:88%}
}
/* Mobile hero overlay refinement */
@media (max-width:900px){
  .hero-retreat{
    position:relative;
    display:block;
    min-height:calc(100dvh - 68px);
    padding:14px;
    overflow:hidden;
  }
  .hero-image-panel{
    position:absolute;
    inset:14px;
    min-height:0;
    height:auto;
    border-radius:30px;
    box-shadow:var(--shadow);
  }
  .hero-image-panel:after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, rgba(24,39,28,.10) 0%, rgba(24,39,28,.18) 34%, rgba(24,39,28,.78) 100%);
    pointer-events:none;
  }
  .hero-copy-panel{
    position:relative;
    z-index:1;
    min-height:calc(100dvh - 96px);
    justify-content:flex-end;
    padding:28px 22px 30px;
    background:transparent;
    border:0;
    box-shadow:none;
    color:var(--cream);
  }
  .hero-copy-panel h1,
  .hero-copy-panel .eyebrow{
    color:var(--cream);
    text-shadow:0 2px 22px rgba(0,0,0,.26);
  }
  .hero-copy-panel .lead{
    color:rgba(244,235,221,.88);
    text-shadow:0 2px 18px rgba(0,0,0,.24);
  }
  .hero-copy-panel .hero-logo{
    width:84px;
    height:84px;
    margin-bottom:auto;
    background:var(--cream);
    border:4px solid rgba(244,235,221,.72);
    box-shadow:0 14px 34px rgba(0,0,0,.22);
  }
  .hero-copy-panel .actions{
    margin-top:24px;
  }
  .hero-copy-panel .button.primary{
    background:var(--cream);
    color:var(--green);
  }
  .hero-copy-panel .button.secondary{
    background:rgba(244,235,221,.16);
    color:var(--cream);
    border-color:rgba(244,235,221,.42);
    backdrop-filter:blur(10px);
  }
}
@media (max-width:520px){
  .hero-retreat{min-height:calc(100dvh - 64px);padding:10px}
  .hero-image-panel{inset:10px;border-radius:26px}
  .hero-copy-panel{min-height:calc(100dvh - 84px);padding:22px 18px 24px}
  .hero-copy-panel h1{font-size:clamp(42px,13vw,62px)}
  .hero-copy-panel .lead{font-size:16px;line-height:1.55}
}
/* Mobile hero readability pass */
@media (max-width:900px){
  .hero-image-panel:after{
    background:
      linear-gradient(180deg, rgba(12,22,15,.42) 0%, rgba(12,22,15,.50) 34%, rgba(12,22,15,.88) 100%),
      radial-gradient(circle at 24% 20%, rgba(12,22,15,.18), transparent 34%);
  }
  .hero-copy-panel h1{
    color:#fbf4e8;
    text-shadow:0 3px 30px rgba(0,0,0,.58), 0 1px 2px rgba(0,0,0,.36);
  }
  .hero-copy-panel .eyebrow{
    color:#fbf4e8;
    text-shadow:0 2px 16px rgba(0,0,0,.58);
    font-weight:900;
  }
  .hero-copy-panel .lead{
    color:rgba(251,244,232,.96);
    text-shadow:0 2px 18px rgba(0,0,0,.62), 0 1px 2px rgba(0,0,0,.38);
    font-weight:600;
  }
  .hero-copy-panel .button.primary{
    box-shadow:0 12px 34px rgba(0,0,0,.22);
  }
  .hero-copy-panel .button.secondary{
    background:rgba(18,35,24,.44);
    border-color:rgba(251,244,232,.56);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 12px 34px rgba(0,0,0,.18);
  }
}
/* Mobile gallery + amenities refinement */
@media (max-width:900px){
  .gallery-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:18px;
  }
  .gallery-grid figure,
  .gallery-grid figure.large{
    grid-row:auto;
    border-radius:26px;
  }
  .gallery-grid figure img,
  .gallery-grid figure.large img{
    width:100%;
    height:260px;
    object-fit:cover;
  }
  .gallery-grid figure figcaption{
    min-height:62px;
    padding:16px 18px;
  }
  .amenity-grid{
    display:flex;
    overflow-x:auto;
    gap:14px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    margin-inline:-16px;
    padding:4px 16px 18px;
  }
  .amenity-grid div{
    flex:0 0 78%;
    min-height:166px;
    scroll-snap-align:start;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
  }
}
@media (max-width:520px){
  .gallery-grid figure img,
  .gallery-grid figure.large img{
    height:238px;
  }
  .amenity-grid div{
    flex-basis:82%;
    min-height:154px;
  }
}
.whatsapp-link{
  background:rgba(47,74,53,.10);
  border:2px solid rgba(47,74,53,.34);
}
.whatsapp-link strong{
  font-weight:900;
  color:var(--green);
}
.whatsapp-link span{
  font-weight:600;
  color:rgba(42,41,37,.72);
}
/* Make reservation CTA the primary action on links page */
.link-list .primary-link{
  background:var(--cream);
  border:1px solid var(--line);
}
.link-list .primary-link strong{color:var(--green)}
.link-list .primary-link span{color:rgba(42,41,37,.62);opacity:1}
.whatsapp-link{
  background:var(--green);
  border-color:var(--green);
  box-shadow:0 18px 42px rgba(47,74,53,.22);
}
.whatsapp-link strong,
.whatsapp-link span{
  color:var(--cream);
}
.whatsapp-link span{opacity:.82}
/* Links CTA color hierarchy */
.link-list .primary-link{
  background:var(--moss);
  border-color:var(--moss);
  box-shadow:0 14px 34px rgba(111,128,97,.18);
}
.link-list .primary-link strong,
.link-list .primary-link span{
  color:var(--cream);
}
.link-list .primary-link span{opacity:.84}
.whatsapp-link{
  background:var(--green);
  border-color:var(--green);
  box-shadow:0 18px 42px rgba(47,74,53,.24);
}
.links-gallery-wrap{
  margin-top:18px;
}
.links-gallery-wrap .links-hero-scroll img{
  height:190px;
  flex-basis:78%;
}
@media (max-width:520px){
  .links-gallery-wrap .links-hero-scroll img{
    height:172px;
    flex-basis:82%;
  }
}
.ig-handle{
  display:inline-flex;
  margin-top:14px;
  color:var(--moss);
  font-weight:800;
  letter-spacing:.02em;
}
.inline-link{
  color:var(--cream);
  font-weight:800;
  text-decoration:underline;
  text-underline-offset:4px;
}
/* Brand-icon amenities */
.amenity-grid{
  align-items:stretch;
}
.amenity-card{
  position:relative;
  overflow:hidden;
  min-height:230px;
}
.amenity-icon{
  width:44px;
  height:44px;
  border-radius:999px;
  display:grid;
  place-items:center;
  margin-bottom:30px;
  border:1px solid rgba(47,74,53,.24);
  color:var(--green);
  background:rgba(111,128,97,.10);
  font-family:"Marcellus", Georgia, serif;
  font-size:24px;
  line-height:1;
}
.amenity-card.tall{
  min-height:300px;
  background:linear-gradient(180deg, rgba(111,128,97,.14), var(--cream));
}
.amenity-card.wide{
  grid-column:span 2;
  background:rgba(176,111,79,.08);
}
.amenity-card.quiet{
  background:rgba(119,115,106,.10);
}
.amenity-card.image-card{
  color:var(--cream);
  background:var(--green);
  border-color:rgba(47,74,53,.28);
}
.amenity-card.image-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.28;
}
.amenity-card.image-card:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(47,74,53,.34),rgba(47,74,53,.86));
}
.amenity-card.image-card .amenity-icon,
.amenity-card.image-card strong,
.amenity-card.image-card span:not(.amenity-icon){
  position:relative;
  z-index:1;
  color:var(--cream);
}
.amenity-card.image-card .amenity-icon{
  border-color:rgba(244,235,221,.36);
  background:rgba(244,235,221,.14);
}
@media (max-width:900px){
  .amenity-grid .amenity-card,
  .amenity-grid .amenity-card.tall,
  .amenity-grid .amenity-card.wide{
    flex:0 0 78%;
    min-height:210px;
    grid-column:auto;
  }
  .amenity-icon{margin-bottom:22px}
}
@media (max-width:520px){
  .amenity-grid .amenity-card,
  .amenity-grid .amenity-card.tall,
  .amenity-grid .amenity-card.wide{
    flex-basis:82%;
    min-height:190px;
  }
}
/* Mobile gallery becomes horizontal image carousel with overlay labels */
@media (max-width:900px){
  .gallery-grid{
    display:flex;
    overflow-x:auto;
    gap:16px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    margin-inline:-16px;
    padding:4px 16px 22px;
  }
  .gallery-grid figure,
  .gallery-grid figure.large{
    flex:0 0 82%;
    height:360px;
    grid-row:auto;
    border-radius:28px;
    scroll-snap-align:start;
    display:block;
    position:relative;
    background:var(--green);
    box-shadow:0 18px 46px rgba(47,42,34,.14);
  }
  .gallery-grid figure:after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,rgba(10,20,13,0) 42%, rgba(10,20,13,.58) 100%);
    pointer-events:none;
  }
  .gallery-grid figure img,
  .gallery-grid figure.large img{
    width:100%;
    height:100%;
    object-fit:cover;
  }
  .gallery-grid figure figcaption{
    position:absolute;
    left:18px;
    bottom:18px;
    z-index:1;
    min-height:auto;
    padding:8px 14px;
    border:1px solid rgba(244,235,221,.42);
    border-radius:999px;
    background:rgba(244,235,221,.18);
    backdrop-filter:blur(10px);
    color:var(--cream);
    font-size:22px;
    line-height:1;
  }
}
@media (max-width:520px){
  .gallery-grid figure,
  .gallery-grid figure.large{
    flex-basis:84%;
    height:330px;
  }
}
/* Remove mobile gallery backing/borders: images fill cards */
@media (max-width:900px){
  .gallery-grid figure,
  .gallery-grid figure.large{
    padding:0;
    background:transparent;
    border:0;
  }
  .gallery-grid figure img,
  .gallery-grid figure.large img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:inherit;
  }
}
/* Nature proof directly below intro story */
.story-with-nature{
  grid-template-columns:1.05fr .95fr;
  row-gap:44px;
}
.nature-strip{
  grid-column:1 / -1;
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 2px 18px;
}
.nature-strip img{
  flex:0 0 min(72%, 760px);
  height:430px;
  border-radius:28px;
  object-fit:cover;
  scroll-snap-align:start;
  box-shadow:0 18px 46px rgba(47,42,34,.12);
}
.nature-strip img:nth-child(2){flex-basis:min(54%, 560px)}
.nature-strip img:nth-child(3){flex-basis:min(62%, 640px)}
@media (max-width:900px){
  .story-with-nature{display:grid;grid-template-columns:1fr;row-gap:30px}
  .nature-strip{margin-inline:-16px;padding-inline:16px;gap:14px}
  .nature-strip img,
  .nature-strip img:nth-child(2),
  .nature-strip img:nth-child(3){
    flex-basis:84%;
    height:310px;
    border-radius:26px;
  }
}
@media (max-width:520px){
  .nature-strip img,
  .nature-strip img:nth-child(2),
  .nature-strip img:nth-child(3){
    height:285px;
    flex-basis:86%;
  }
}
.mini-image-strip{
  display:flex;
  gap:12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  margin-top:28px;
  padding-bottom:12px;
}
.mini-image-strip img{
  flex:0 0 46%;
  height:180px;
  border-radius:20px;
  object-fit:cover;
  scroll-snap-align:start;
  box-shadow:0 12px 30px rgba(47,42,34,.10);
}
@media (max-width:900px){
  .mini-image-strip{margin-inline:-16px;padding-inline:16px;gap:12px}
  .mini-image-strip img{flex-basis:68%;height:190px;border-radius:22px}
}
@media (max-width:520px){
  .mini-image-strip img{flex-basis:74%;height:175px}
}
/* Mobile: keep Living & Dining heading before its images */
@media (max-width:900px){
  .split{
    display:flex;
    flex-direction:column;
  }
  .split > .split-copy{
    order:1;
  }
  .split > .feature-scroll,
  .split > img{
    order:2;
  }
  .split.reverse > .split-copy{
    order:1;
  }
  .split.reverse > .feature-scroll,
  .split.reverse > img{
    order:2;
  }
}
/* Lightweight image lightbox */
.is-zoomable{
  cursor:zoom-in;
}
.lightbox-lock{
  overflow:hidden;
}
.lightbox{
  position:fixed;
  inset:0;
  z-index:100;
  display:grid;
  place-items:center;
  padding:clamp(18px,4vw,46px);
  background:rgba(16,26,18,.86);
  backdrop-filter:blur(14px);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease;
}
.lightbox.is-open{
  opacity:1;
  pointer-events:auto;
}
.lightbox-image{
  max-width:min(100%, 1180px);
  max-height:82dvh;
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:24px;
  box-shadow:0 30px 90px rgba(0,0,0,.38);
  cursor:zoom-out;
}
.lightbox-close{
  position:fixed;
  top:18px;
  right:18px;
  width:46px;
  height:46px;
  border:1px solid rgba(244,235,221,.34);
  border-radius:999px;
  background:rgba(244,235,221,.14);
  color:var(--cream);
  font-size:30px;
  line-height:1;
  cursor:pointer;
  backdrop-filter:blur(10px);
}
.lightbox-caption{
  margin:14px 0 0;
  max-width:min(90vw, 760px);
  color:rgba(244,235,221,.84);
  text-align:center;
  font-size:14px;
}
@media (max-width:520px){
  .lightbox{padding:14px}
  .lightbox-image{max-height:78dvh;border-radius:18px}
  .lightbox-close{top:12px;right:12px;width:42px;height:42px}
}
.lightbox-nav{
  position:fixed;
  top:50%;
  transform:translateY(-50%);
  width:52px;
  height:52px;
  border:1px solid rgba(244,235,221,.34);
  border-radius:999px;
  background:rgba(244,235,221,.14);
  color:var(--cream);
  font-size:44px;
  line-height:.8;
  cursor:pointer;
  backdrop-filter:blur(10px);
}
.lightbox-prev{left:18px}
.lightbox-next{right:18px}
.lightbox-nav[hidden]{display:none}
@media (max-width:520px){
  .lightbox-nav{
    top:auto;
    bottom:56px;
    transform:none;
    width:46px;
    height:46px;
    font-size:38px;
  }
  .lightbox-prev{left:18px}
  .lightbox-next{right:18px}
}
