:root{--cream:#fff7e8;--sand:#f4dfbf;--ink:#18251f;--muted:#667068;--olive:#556b39;--aqua:#74d6d3;--lemon:#ffd84d;--coral:#ff6b65;--pink:#e94387;--white:#fff;--radius:28px;--shadow:0 24px 70px rgba(64,44,27,.16)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;overflow-x:hidden;background:radial-gradient(circle at 8% 4%,#fff2b9 0 11rem,transparent 12rem),linear-gradient(180deg,var(--cream),#fffaf1 52%,#f8ead5);color:var(--ink);font-family:Inter,system-ui,sans-serif}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:0 auto;padding:14px clamp(18px,4vw,48px);background:rgba(255,247,232,.78);backdrop-filter:blur(18px);border-bottom:1px solid rgba(24,37,31,.08)}.brand{display:flex;align-items:center;gap:.75rem;font-weight:900;line-height:.95}.brand small{font-weight:700;color:var(--muted)}.brand-mark{display:grid;place-items:center;width:46px;height:46px;border-radius:16px;background:var(--ink);color:var(--lemon);box-shadow:7px 7px 0 var(--lemon)}.main-nav{display:flex;align-items:center;gap:.45rem}.main-nav a{padding:.75rem .9rem;border-radius:999px;font-weight:800;font-size:.92rem}.main-nav a:hover,.nav-cta{background:var(--white);box-shadow:0 10px 24px rgba(0,0,0,.08)}.nav-toggle{display:none}.section-pad{padding:clamp(3rem,7vw,6rem) clamp(18px,4vw,48px)}.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,1fr);gap:clamp(2rem,5vw,5rem);align-items:center;max-width:1360px;margin:auto;min-height:calc(100vh - 80px)}.eyebrow{margin:0 0 1rem;text-transform:uppercase;letter-spacing:.16em;color:var(--olive);font-weight:900;font-size:.76rem}.hero h1,.intro h2,.split-feature h2,.section-heading h2,.surroundings h2{font-family:'Playfair Display',serif;font-size:clamp(2.6rem,7vw,6.7rem);line-height:.88;margin:0 0 1.25rem;letter-spacing:-.055em}.intro h2,.split-feature h2,.section-heading h2,.surroundings h2{font-size:clamp(2.2rem,4.8vw,4.6rem)}.lead,.intro p,.split-feature p{font-size:clamp(1.05rem,2vw,1.32rem);line-height:1.7;color:#4c564e;max-width:67ch}.button{display:inline-flex;align-items:center;justify-content:center;padding:1rem 1.25rem;border-radius:999px;font-weight:900;margin:.4rem .5rem .4rem 0}.primary,.submit{background:linear-gradient(135deg,var(--coral),var(--pink));color:white;box-shadow:0 18px 35px rgba(233,67,135,.28)}.ghost{background:var(--white);border:1px solid rgba(24,37,31,.1)}.hero-collage{position:relative;min-height:650px}.photo{position:absolute;object-fit:cover;border:10px solid #fff;border-radius:36px;box-shadow:var(--shadow)}.p-main{inset:8% 10% auto auto;width:72%;height:62%;transform:rotate(2deg)}.p-pool{left:0;bottom:5%;width:48%;height:34%;transform:rotate(-5deg)}.p-lemon{right:0;bottom:0;width:38%;height:42%;transform:rotate(5deg)}.sun-note{position:absolute;left:8%;top:9%;display:grid;place-items:center;width:142px;height:142px;border-radius:50%;background:var(--lemon);font-weight:950;text-align:center;box-shadow:12px 12px 0 var(--aqua);transform:rotate(-8deg)}.quick-facts{max-width:1180px;margin:-1rem auto 2rem;padding:0 clamp(18px,4vw,48px);display:grid;grid-template-columns:repeat(5,1fr);gap:.8rem}.quick-facts div{background:#fff;border:1px solid rgba(24,37,31,.08);border-radius:22px;padding:1.25rem;box-shadow:0 10px 30px rgba(64,44,27,.08)}.quick-facts strong{display:block;font-size:2rem}.quick-facts span{color:var(--muted);font-weight:800}.content-shell{max-width:1440px;margin:auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(450px,500px);gap:2rem;align-items:start}.intro{padding-top:2rem}.story-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:1rem}.story-card{position:relative;min-height:360px;border-radius:var(--radius);overflow:hidden;background:#ddd}.story-card.big{grid-row:span 2;min-height:740px}.story-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}.story-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.68))}.story-card div{position:absolute;z-index:1;left:1.5rem;right:1.5rem;bottom:1.5rem;color:#fff}.story-card span{font-weight:900;color:var(--lemon)}.story-card h3{font-size:clamp(1.4rem,3vw,2.7rem);line-height:1;margin:.35rem 0 0}.split-feature{display:grid;grid-template-columns:.85fr 1fr;gap:2rem;align-items:center}.stacked-photos{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stacked-photos img,.mosaic img,.room-card img{height:100%;width:100%;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}.stacked-photos img:first-child{margin-top:3rem}.mosaic{display:grid;grid-template-columns:1.2fr .9fr .9fr;gap:1rem}.mosaic figure{margin:0;position:relative;height:390px}.mosaic figcaption{position:absolute;left:1rem;bottom:1rem;background:#fff;border-radius:999px;padding:.7rem 1rem;font-weight:900}.rooms,.amenity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.room-card{background:#fff;border-radius:var(--radius);padding:1rem;box-shadow:0 14px 38px rgba(64,44,27,.09)}.room-card img{height:260px}.room-card h3{font-size:1.55rem;margin:1rem 0 .3rem}.room-card p{color:var(--muted);line-height:1.6}.amenity-grid{grid-template-columns:repeat(2,1fr)}.amenity-grid div{padding:1.2rem;background:linear-gradient(135deg,#fff,#fff6df);border:1px solid rgba(24,37,31,.08);border-radius:22px;font-weight:900}.surroundings{background:var(--ink);color:#fff;border-radius:40px;margin:3rem clamp(18px,4vw,48px)}.surroundings .eyebrow{color:var(--aqua)}.timeline{display:grid;gap:.75rem}.timeline div{display:flex;justify-content:space-between;gap:1rem;padding:1rem;border-bottom:1px solid rgba(255,255,255,.14)}.timeline b{font-size:1.5rem;color:var(--lemon)}.booking-wrap{position:sticky;top:96px;padding:2rem 18px 4rem;width:100%;max-width:500px}.booking-card{background:#fff;border:1px solid rgba(24,37,31,.11);border-radius:32px;padding:1.75rem;box-shadow:0 26px 80px rgba(64,44,27,.20)}.card-kicker{margin:0;color:var(--pink);font-weight:950;text-transform:uppercase;font-size:.75rem;letter-spacing:.13em}.booking-card h2{font-size:2rem;margin:.35rem 0}.booking-card p{color:var(--muted);line-height:1.55}.field-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1rem}.booking-card label{display:grid;gap:.45rem;margin:.75rem 0;font-weight:800}.booking-card input,.booking-card select{width:100%;border:1px solid #e3d8ca;border-radius:16px;padding:.95rem .85rem;background:#fffaf3;font:inherit;color:var(--ink);min-width:0}.submit{width:100%;border:0;border-radius:18px;padding:1rem;margin:.7rem 0;font:inherit;font-weight:950;cursor:pointer}.booking-card small{display:block;color:var(--muted);text-align:center}.booking-card ul{padding-left:1.1rem;color:#4c564e;line-height:1.8}footer{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;padding:clamp(3.5rem,7vw,5.5rem) clamp(18px,4vw,48px);background:#17251f;border-top:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.74);font-size:clamp(1rem,1.6vw,1.18rem)}.footer-copy{display:grid;gap:.65rem}.footer-copy address{font-style:normal;color:#fff;font-weight:800;font-size:clamp(1.18rem,2vw,1.55rem);line-height:1.35}.footer-copy address a{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:.22em;white-space:normal}.footer-phone{margin:.15rem 0 0;color:#fff;font-weight:800;font-size:clamp(1.08rem,1.8vw,1.38rem);line-height:1.35}.footer-phone span{color:rgba(255,255,255,.72);font-weight:700}.footer-phone a{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:.22em;white-space:normal}footer strong{color:#fff;font-size:clamp(1.28rem,2.2vw,1.85rem)}footer a{font-weight:800;white-space:nowrap}@media (max-width:1180px){.content-shell{grid-template-columns:minmax(0,1fr) minmax(420px,460px)}.booking-card{padding:1.45rem}.field-row{gap:.75rem}}@media (max-width:980px){.nav-toggle{display:block;border:0;background:var(--ink);color:#fff;border-radius:14px;padding:.7rem .9rem}.main-nav{position:absolute;top:100%;left:1rem;right:1rem;display:none;flex-direction:column;background:#fff;padding:1rem;border-radius:22px;box-shadow:var(--shadow)}.main-nav.open{display:flex}.hero,.content-shell,.split-feature{grid-template-columns:1fr}.hero{min-height:auto}.hero-collage{min-height:520px}.quick-facts{grid-template-columns:repeat(2,1fr)}.content-shell{display:flex;flex-direction:column}.booking-wrap{position:static;order:-1;width:100%;max-width:none;padding:1rem 18px}.story-grid,.rooms,.mosaic,.amenity-grid{grid-template-columns:1fr}.story-card.big{min-height:460px}.story-card{min-height:330px}.mosaic figure{height:320px}}@media (max-width:560px){.section-pad{padding:3rem 18px}.hero h1{font-size:3.05rem}.hero-collage{min-height:430px}.p-main{width:82%;height:55%;right:0}.p-pool{width:58%;height:30%}.p-lemon{width:48%;height:34%}.sun-note{width:104px;height:104px;font-size:.82rem}.quick-facts{grid-template-columns:1fr 1fr}.quick-facts div{padding:1rem}.field-row{grid-template-columns:1fr}.timeline div,footer{flex-direction:column}.surroundings{margin:1rem 18px;border-radius:28px}}

.photo-gallery{max-width:1240px;margin:clamp(2rem,5vw,4rem) auto 0;display:grid;grid-template-columns:minmax(260px,.82fr) minmax(0,1.18fr);gap:clamp(1.4rem,4vw,3rem);align-items:stretch}.gallery-intro{position:relative;overflow:hidden;border-radius:var(--radius);padding:clamp(1.6rem,4vw,3rem);background:linear-gradient(145deg,#fff 0%,#fff8df 58%,#dff7f4 100%);box-shadow:var(--shadow)}.gallery-intro:after{content:"";position:absolute;right:-3.5rem;bottom:-3.5rem;width:10rem;height:10rem;border-radius:50%;background:var(--lemon);opacity:.55}.gallery-intro h2{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,4.6rem);line-height:.9;letter-spacing:-.05em;margin:0 0 1rem}.gallery-intro p:not(.eyebrow){color:var(--muted);font-weight:700;line-height:1.65;max-width:34rem}.gallery-open{position:relative;z-index:1;border:0;cursor:pointer;margin-top:1rem}.gallery-preview{display:grid;grid-template-columns:1.05fr .95fr;grid-template-rows:repeat(2,minmax(190px,1fr));gap:1rem}.gallery-tile{position:relative;overflow:hidden;border:0;border-radius:24px;padding:0;cursor:pointer;background:var(--sand);box-shadow:0 18px 44px rgba(64,44,27,.14);isolation:isolate}.gallery-tile.tall{grid-row:span 2}.gallery-tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.gallery-tile:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 44%,rgba(24,37,31,.72));z-index:1}.gallery-tile span{position:absolute;left:1rem;right:1rem;bottom:1rem;z-index:2;color:white;font-weight:900;text-align:left;text-shadow:0 2px 12px rgba(0,0,0,.35)}.gallery-tile:hover img,.gallery-tile:focus-visible img{transform:scale(1.055)}.gallery-tile:focus-visible,.gallery-open:focus-visible,.lightbox-close:focus-visible,.lightbox-nav:focus-visible,.strip-thumb:focus-visible{outline:3px solid var(--lemon);outline-offset:3px}.gallery-lightbox[hidden]{display:none}.gallery-lightbox{position:fixed;inset:0;z-index:100;display:grid;grid-template-columns:minmax(56px,1fr) minmax(0,1040px) minmax(56px,1fr);grid-template-rows:minmax(0,1fr) auto;gap:1rem;align-items:center;padding:clamp(1rem,3vw,2rem);background:rgba(10,17,14,.9);backdrop-filter:blur(12px)}body.lightbox-open{overflow:hidden}.lightbox-frame{grid-column:2;grid-row:1;align-self:center;margin:0;min-width:0}.lightbox-image{width:100%;max-height:calc(100vh - 190px);object-fit:contain;border-radius:24px;box-shadow:0 26px 80px rgba(0,0,0,.42);background:#111}.lightbox-frame figcaption{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:.85rem;color:#fff;font-weight:900}.lightbox-caption{font-size:clamp(1rem,2vw,1.22rem)}.lightbox-counter{color:#ffe98a}.lightbox-close,.lightbox-nav{border:0;cursor:pointer;color:#fff;background:rgba(255,255,255,.14);box-shadow:0 12px 34px rgba(0,0,0,.2);backdrop-filter:blur(8px)}.lightbox-close{position:absolute;top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);width:48px;height:48px;border-radius:50%;font-size:2rem;line-height:1}.lightbox-nav{width:52px;height:72px;border-radius:999px;font-size:3rem;line-height:.8;justify-self:center}.lightbox-prev{grid-column:1;grid-row:1}.lightbox-next{grid-column:3;grid-row:1}.lightbox-strip{grid-column:1 / -1;grid-row:2;display:flex;gap:.65rem;overflow-x:auto;padding:.25rem .2rem .6rem;scrollbar-color:var(--lemon) rgba(255,255,255,.16)}.strip-thumb{flex:0 0 86px;height:62px;border:2px solid transparent;border-radius:14px;padding:0;overflow:hidden;cursor:pointer;background:transparent;opacity:.66}.strip-thumb img{width:100%;height:100%;object-fit:cover}.strip-thumb.active{border-color:var(--lemon);opacity:1}.strip-thumb:hover{opacity:1}@media (max-width:900px){.photo-gallery{grid-template-columns:1fr}.gallery-preview{grid-template-rows:repeat(2,180px)}.gallery-lightbox{grid-template-columns:1fr 1fr;grid-template-rows:minmax(0,1fr) auto auto}.lightbox-frame{grid-column:1 / -1}.lightbox-prev,.lightbox-next{grid-row:2;width:100%;height:50px;font-size:2.3rem}.lightbox-prev{grid-column:1}.lightbox-next{grid-column:2}.lightbox-strip{grid-row:3}.lightbox-image{max-height:calc(100vh - 230px)}}@media (max-width:620px){.gallery-preview{grid-template-columns:1fr 1fr;grid-template-rows:170px 135px}.gallery-tile{border-radius:18px}.gallery-tile.tall{grid-column:1 / -1;grid-row:auto}.lightbox-frame figcaption{align-items:flex-start;flex-direction:column}.strip-thumb{flex-basis:72px;height:54px}.lightbox-close{width:44px;height:44px}}


/* Centered sticky menu bar logo */
.site-header{position:sticky;top:0;z-index:50;min-height:76px;justify-content:center;padding:10px clamp(18px,4vw,48px);overflow:visible}
.main-nav{position:relative;width:min(1180px,100%);display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:clamp(.75rem,2.2vw,1.6rem)}
.nav-side{display:flex;align-items:center;gap:.45rem;min-width:0}.nav-side-left{justify-content:flex-end}.nav-side-right{justify-content:flex-start}.brand{justify-self:center;position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.16rem;text-align:center;line-height:1;min-width:auto;transform:translateY(14px)}
.brand-logo{width:clamp(104px,10vw,148px);height:clamp(104px,10vw,148px);object-fit:contain;border-radius:0;background:transparent;padding:0;box-shadow:none}.brand-copy{display:flex;flex-direction:column;gap:.08rem;line-height:1.02;letter-spacing:-.02em}.brand-copy strong{font-size:clamp(.82rem,1.2vw,1rem)}.brand-copy small{font-size:.68rem;letter-spacing:.12em;color:var(--muted)}
@media (max-width:980px){.site-header{justify-content:space-between;min-height:70px;padding:10px 18px}.nav-toggle{display:block;position:relative;z-index:3;border:0;background:var(--ink);color:#fff;border-radius:14px;padding:.7rem .9rem}.main-nav{position:absolute;top:100%;left:1rem;right:1rem;width:auto;display:none;grid-template-columns:1fr;justify-items:stretch;gap:.7rem;background:#fff;padding:1rem;border-radius:22px;box-shadow:var(--shadow)}.main-nav.open{display:grid}.nav-side{display:flex;flex-direction:column;align-items:stretch;gap:.35rem}.nav-side-left,.nav-side-right{justify-content:flex-start}.main-nav a{text-align:center}.brand{order:-1;transform:none}.brand-logo{width:92px;height:92px}.brand-copy strong{font-size:.95rem}.brand-copy small{font-size:.66rem}}
@media (max-width:560px){.site-header{padding:9px 14px}.brand-logo{width:82px;height:82px}.nav-toggle{padding:.62rem .78rem}}

/* Header refinement: centered overflowing logo */
.site-header{position:sticky;top:0;z-index:80;min-height:78px;height:78px;display:flex;align-items:center;justify-content:center;padding:0 clamp(18px,4vw,48px);overflow:visible;background:rgba(255,247,232,.86);backdrop-filter:blur(18px)}
.main-nav{position:relative;width:min(1180px,100%);height:78px;display:grid;grid-template-columns:minmax(0,1fr) minmax(150px,220px) minmax(0,1fr);align-items:center;gap:clamp(.75rem,2.2vw,1.6rem)}
.nav-side{display:flex;align-items:center;gap:.45rem;min-width:0}.nav-side-left{justify-content:flex-end;padding-right:clamp(1rem,4vw,4rem)}.nav-side-right{justify-content:flex-start;padding-left:clamp(1rem,4vw,4rem)}
.brand{position:absolute;left:50%;top:50%;z-index:3;display:flex;align-items:center;justify-content:center;min-width:0;transform:translate(-50%,-42%);line-height:1;text-align:center;background:transparent!important;border:0!important;box-shadow:none!important;padding:0!important;border-radius:0!important}
.brand-logo{width:clamp(132px,12vw,178px);height:clamp(132px,12vw,178px);object-fit:contain;border-radius:0;background:transparent!important;padding:0!important;box-shadow:none!important}
.brand-copy{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
@media (max-width:980px){.site-header{height:78px;min-height:78px;justify-content:space-between;padding:0 18px}.main-nav{position:absolute;top:100%;left:1rem;right:1rem;width:auto;height:auto;display:none;grid-template-columns:1fr;justify-items:stretch;gap:.7rem;background:#fff;padding:1rem;border-radius:22px;box-shadow:var(--shadow)}.main-nav.open{display:grid}.brand{position:relative;left:auto;top:auto;transform:none;order:-1}.brand-logo{width:108px;height:108px}.brand-copy{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}.nav-side-left,.nav-side-right{padding:0;justify-content:flex-start}}

/* Header v16: wider white rounded menu bar with integrated circular logo */
.site-header{position:sticky;top:0;z-index:80;height:auto;min-height:0;display:flex;align-items:center;justify-content:center;padding:12px clamp(14px,4vw,48px);overflow:visible;background:rgba(255,247,232,.55);backdrop-filter:blur(18px);border-bottom:0}.main-nav{position:relative;width:min(1080px,100%);height:auto;min-height:82px;display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:clamp(1rem,2.4vw,1.8rem);padding:.6rem clamp(.9rem,2vw,1.3rem);background:#fff;border:1px solid rgba(24,37,31,.08);border-radius:999px;box-shadow:0 18px 48px rgba(64,44,27,.14)}.nav-side{display:flex;align-items:center;gap:.35rem;min-width:0}.nav-side-left{justify-content:flex-end;padding-right:0}.nav-side-right{justify-content:flex-start;padding-left:0}.main-nav a{white-space:nowrap;font-family:'Playfair Display',serif;font-size:clamp(1.05rem,1.25vw,1.22rem);font-weight:800;letter-spacing:-.015em}.brand{position:relative;left:auto;top:auto;z-index:3;justify-self:center;display:flex;align-items:center;justify-content:center;min-width:0;transform:none;line-height:1;background:transparent!important;border:0!important;box-shadow:none!important;padding:.15rem!important;border-radius:999px!important}.brand-logo{width:clamp(82px,8vw,112px);height:clamp(82px,8vw,112px);object-fit:cover;border-radius:50%;background:#fff!important;padding:.28rem!important;box-shadow:0 10px 24px rgba(64,44,27,.16)!important}.brand-copy{display:none!important}.nav-cta{background:var(--ink)!important;color:#fff!important;box-shadow:0 12px 28px rgba(24,37,31,.18)!important}.nav-cta:hover{background:var(--olive)!important}@media (max-width:1080px){.main-nav{grid-template-columns:auto 1fr auto}.nav-side-left a{display:none}.brand{justify-self:start}.brand-logo{width:78px;height:78px}.nav-side-right{justify-content:flex-end}}@media (max-width:980px){.site-header{height:auto;min-height:0;justify-content:space-between;padding:10px 14px}.nav-toggle{display:block;position:relative;z-index:3;border:0;background:var(--ink);color:#fff;border-radius:14px;padding:.7rem .9rem}.main-nav{position:absolute;top:100%;left:1rem;right:1rem;width:auto;height:auto;min-height:0;display:none;grid-template-columns:1fr;justify-items:stretch;gap:.7rem;background:#fff;padding:1rem;border-radius:22px;box-shadow:var(--shadow)}.main-nav.open{display:grid}.nav-side{display:flex;flex-direction:column;align-items:stretch;gap:.35rem}.nav-side-left,.nav-side-right{padding:0;justify-content:flex-start}.nav-side-left a{display:block}.main-nav a{text-align:center}.brand{order:-1;justify-self:center}.brand-logo{width:86px;height:86px}.nav-cta{display:block}}@media (max-width:560px){.site-header{padding:9px 12px}.brand-logo{width:74px;height:74px}.nav-toggle{padding:.62rem .78rem}}

/* v17: broader 1080px content rhythm and roomier Inter navigation */
:root{--content-max:1080px;--page-gutter:clamp(20px,4vw,48px)}
.section-pad{padding-left:var(--page-gutter);padding-right:var(--page-gutter)}
.hero,.quick-facts,.photo-gallery,.content-shell{max-width:var(--content-max);width:100%;margin-left:auto;margin-right:auto}
.hero{grid-template-columns:minmax(0,1.02fr) minmax(360px,.98fr);gap:clamp(2.4rem,5vw,4.5rem)}
.photo-gallery{grid-template-columns:minmax(300px,.9fr) minmax(0,1.1fr);gap:clamp(1.75rem,4vw,3rem)}
.content-shell{grid-template-columns:minmax(0,1fr) minmax(300px,340px);gap:clamp(1.6rem,3vw,2.4rem)}
.story-grid,.rooms,.amenity-grid,.mosaic{gap:clamp(1.1rem,2.2vw,1.6rem)}
.room-card,.amenity-grid div{padding:clamp(1.1rem,2.2vw,1.45rem)}
.quick-facts{padding-left:var(--page-gutter);padding-right:var(--page-gutter);gap:clamp(.9rem,1.7vw,1.25rem)}
.quick-facts div{padding:clamp(1.1rem,2vw,1.45rem)}
.booking-wrap{max-width:340px;padding-left:0;padding-right:0}
footer{padding-left:max(var(--page-gutter),calc((100vw - var(--content-max))/2 + var(--page-gutter)));padding-right:max(var(--page-gutter),calc((100vw - var(--content-max))/2 + var(--page-gutter)))}
.main-nav{width:min(var(--content-max),100%);grid-template-columns:minmax(0,1.35fr) auto minmax(260px,.9fr);gap:clamp(1.2rem,2.6vw,2rem);padding:.65rem clamp(1.2rem,2.6vw,1.8rem)}
.nav-side{gap:clamp(.45rem,1vw,.8rem)}
.main-nav a{font-family:Inter,system-ui,sans-serif;font-size:clamp(.86rem,1vw,.98rem);font-weight:850;letter-spacing:-.01em;padding:.78rem clamp(.72rem,1vw,.95rem)}
.nav-cta{font-family:Inter,system-ui,sans-serif!important;padding:.9rem clamp(1rem,1.4vw,1.25rem)!important}
.brand-logo{width:clamp(76px,7vw,96px);height:clamp(76px,7vw,96px)}
@media (max-width:1080px){.main-nav{grid-template-columns:auto 1fr auto}.booking-wrap{max-width:none;padding-left:18px;padding-right:18px}}
@media (max-width:980px){.hero,.photo-gallery,.content-shell{max-width:var(--content-max)}.hero{grid-template-columns:1fr}.photo-gallery{grid-template-columns:1fr}.content-shell{display:flex}.main-nav{top:calc(100% + .35rem);border-radius:24px}.main-nav a{font-size:.98rem}.nav-cta{padding:.9rem 1rem!important}}
@media (max-width:560px){:root{--page-gutter:18px}.section-pad{padding-left:var(--page-gutter);padding-right:var(--page-gutter)}}

/* v18: wider page rhythm, calmer hero headline, larger hero collage */
:root{--content-max:1280px;--page-gutter:clamp(22px,4vw,56px)}
.main-nav{width:min(1080px,100%)}
.hero,.quick-facts,.photo-gallery,.content-shell{max-width:var(--content-max)}
.hero{grid-template-columns:minmax(0,.9fr) minmax(500px,1.1fr);gap:clamp(2.5rem,4.5vw,5.5rem)}
.hero h1{font-size:clamp(3.2rem,5.8vw,88px);line-height:.9;max-width:9.8em}
.hero-collage{min-height:clamp(660px,54vw,760px);margin-right:clamp(-18px,-1vw,-10px);padding-bottom:3.4rem}
.hero-collage .photo{border-width:10px}
.hero-collage .p-main{inset:5% 5% auto auto;width:78%;height:65%}
.hero-collage .p-pool{left:0;bottom:9%;width:52%;height:35%}
.hero-collage .p-lemon{right:0;bottom:5%;width:42%;height:43%}
.hero-collage .sun-note{left:5%;top:7%;width:clamp(132px,10vw,156px);height:clamp(132px,10vw,156px)}
.hero-gallery-link{position:absolute;right:clamp(1rem,3vw,2rem);bottom:.25rem;z-index:4;display:inline-flex;align-items:center;gap:.45rem;border:0;background:rgba(255,255,255,.92);color:var(--ink);font:850 clamp(.95rem,1.15vw,1.08rem)/1 Inter,system-ui,sans-serif;padding:.82rem 1.05rem;border-radius:999px;box-shadow:0 14px 34px rgba(64,44,27,.16);cursor:pointer;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:4px}.hero-gallery-link:after{content:"→";font-size:1.1em}.hero-gallery-link:hover{background:#fff;transform:translateY(-1px)}.hero-gallery-link:focus-visible{outline:3px solid var(--lemon);outline-offset:4px}
.photo-gallery{grid-template-columns:minmax(340px,.85fr) minmax(0,1.15fr)}
.content-shell{grid-template-columns:minmax(0,1fr) minmax(320px,360px);gap:clamp(2rem,3.5vw,3.2rem)}
.booking-wrap{max-width:360px}
footer{padding-left:max(var(--page-gutter),calc((100vw - var(--content-max))/2 + var(--page-gutter)));padding-right:max(var(--page-gutter),calc((100vw - var(--content-max))/2 + var(--page-gutter)))}
@media (min-width:1281px){.hero{max-width:1360px}.hero h1{font-size:88px}.hero-collage{margin-right:-24px}}
@media (max-width:1180px){.hero{grid-template-columns:minmax(0,.95fr) minmax(430px,1.05fr)}.hero h1{font-size:clamp(3rem,6.2vw,76px)}.hero-collage{min-height:clamp(560px,56vw,680px);margin-right:0}.content-shell{grid-template-columns:minmax(0,1fr) minmax(300px,340px)}}
@media (max-width:980px){.hero{grid-template-columns:1fr}.hero h1{font-size:clamp(2.8rem,10vw,5.4rem);max-width:10em}.hero-collage{min-height:clamp(500px,72vw,660px);padding-bottom:3.6rem}.content-shell{display:flex}.booking-wrap{max-width:none}}
@media (max-width:560px){.hero h1{font-size:clamp(2.45rem,13vw,4rem)}.hero-collage{min-height:460px}.hero-collage .photo{border-width:7px;border-radius:24px}.hero-gallery-link{left:50%;right:auto;transform:translateX(-50%);white-space:nowrap}.hero-gallery-link:hover{transform:translateX(-50%) translateY(-1px)}}

/* v19: gallery moved into content flow with photo-first masonry preview */
.content-shell .photo-gallery{max-width:none;width:100%;margin:0;display:flex;flex-direction:column;gap:clamp(1.1rem,2.4vw,1.6rem);padding-top:clamp(3.4rem,6vw,5rem);padding-bottom:clamp(3.4rem,6vw,5rem)}
.content-shell .photo-gallery .gallery-preview{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-auto-rows:clamp(118px,10vw,172px);gap:clamp(.72rem,1.35vw,1rem);align-items:stretch}
.content-shell .photo-gallery .gallery-tile{min-height:0;border-radius:clamp(18px,2vw,28px);box-shadow:0 16px 38px rgba(64,44,27,.14)}
.content-shell .photo-gallery .gallery-tile.hero-tile{grid-column:span 3;grid-row:span 2}
.content-shell .photo-gallery .gallery-tile.wide{grid-column:span 2}
.content-shell .photo-gallery .gallery-tile.tall{grid-column:span 2;grid-row:span 2}
.content-shell .photo-gallery .gallery-tile span{display:inline-flex;left:.75rem;right:auto;bottom:.75rem;max-width:calc(100% - 1.5rem);padding:.42rem .68rem;border-radius:999px;background:rgba(255,255,255,.9);color:var(--ink);font-size:clamp(.74rem,.86vw,.86rem);line-height:1.05;text-shadow:none;box-shadow:0 8px 22px rgba(24,37,31,.12)}
.content-shell .photo-gallery .gallery-intro{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"kicker button" "title button" "text button";align-items:center;column-gap:clamp(1rem,2.5vw,2rem);padding:clamp(1.1rem,2.4vw,1.5rem);border-radius:24px;background:rgba(255,255,255,.82);box-shadow:0 16px 42px rgba(64,44,27,.1)}
.content-shell .photo-gallery .gallery-intro:after{display:none}
.content-shell .photo-gallery .gallery-intro .eyebrow{grid-area:kicker;margin-bottom:.35rem}
.content-shell .photo-gallery .gallery-intro h2{grid-area:title;font-size:clamp(1.55rem,2.7vw,2.45rem);line-height:1;margin:0 0 .35rem;letter-spacing:-.045em}
.content-shell .photo-gallery .gallery-intro p:not(.eyebrow){grid-area:text;max-width:48rem;margin:0;color:var(--muted);font-size:.96rem;line-height:1.55;font-weight:650}
.content-shell .photo-gallery .gallery-open{grid-area:button;margin:0;white-space:nowrap}
@media (max-width:1180px){.content-shell .photo-gallery .gallery-preview{grid-template-columns:repeat(4,minmax(0,1fr));grid-auto-rows:clamp(112px,16vw,165px)}.content-shell .photo-gallery .gallery-tile.hero-tile{grid-column:span 2}.content-shell .photo-gallery .gallery-tile.tall{grid-column:span 2}}
@media (max-width:760px){.content-shell .photo-gallery .gallery-preview{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:clamp(120px,32vw,178px);gap:.75rem}.content-shell .photo-gallery .gallery-tile.hero-tile,.content-shell .photo-gallery .gallery-tile.wide,.content-shell .photo-gallery .gallery-tile.tall{grid-column:span 2;grid-row:span 1}.content-shell .photo-gallery .gallery-intro{grid-template-columns:1fr;grid-template-areas:"kicker" "title" "text" "button";gap:.6rem}.content-shell .photo-gallery .gallery-open{justify-self:start;margin-top:.3rem}}
/* v20: compact four-photo gallery preview without tile captions */
.content-shell .photo-gallery .gallery-preview{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);grid-template-rows:repeat(3,minmax(118px,1fr));grid-auto-rows:auto;gap:clamp(.72rem,1.35vw,1rem);min-height:clamp(420px,38vw,540px)}
.content-shell .photo-gallery .gallery-tile.hero-tile{grid-column:1;grid-row:1 / span 3}
.content-shell .photo-gallery .gallery-tile{grid-column:2;grid-row:auto;min-height:0}
.content-shell .photo-gallery .gallery-tile:before{display:none}
.content-shell .photo-gallery .gallery-tile span{display:none}
@media (max-width:760px){.content-shell .photo-gallery .gallery-preview{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(2,minmax(126px,34vw));min-height:0}.content-shell .photo-gallery .gallery-tile.hero-tile,.content-shell .photo-gallery .gallery-tile{grid-column:auto;grid-row:auto}}

/* v21: subtle watercolor lemon accents */
.hero,.photo-gallery,.booking-card{position:relative;isolation:isolate}
.hero:before{content:"";position:absolute;z-index:-1;right:clamp(-150px,-9vw,-70px);top:clamp(72px,10vw,140px);width:clamp(230px,28vw,410px);aspect-ratio:1;background:url('assets/decor/lemon-branch-hero.webp') center/contain no-repeat;opacity:.18;transform:rotate(7deg);pointer-events:none;filter:drop-shadow(0 18px 28px rgba(85,107,57,.08))}
.content-shell .photo-gallery:after{content:"";position:absolute;z-index:-1;left:clamp(-86px,-5vw,-38px);bottom:clamp(22px,4vw,56px);width:clamp(150px,18vw,250px);aspect-ratio:1;background:url('assets/decor/lemon-branch-hero.webp') center/contain no-repeat;opacity:.12;transform:rotate(-18deg);pointer-events:none}
.booking-card:after{content:"";position:absolute;right:-30px;top:-28px;width:clamp(86px,9vw,128px);aspect-ratio:1;background:url('assets/decor/lemon-half-accent.webp') center/contain no-repeat;opacity:.24;transform:rotate(10deg);pointer-events:none}
.booking-card>*{position:relative;z-index:1}
@media (max-width:980px){.hero:before{right:-90px;top:120px;width:240px;opacity:.12}.content-shell .photo-gallery:after{display:none}.booking-card:after{right:-22px;top:-22px;width:92px;opacity:.18}}
@media (max-width:560px){.hero:before{display:none}.booking-card:after{right:-16px;top:-18px;width:76px;opacity:.14}}


/* v24: responsive hardening for mobile and tablet */
html,body{max-width:100%;overflow-x:hidden}
button,input,select,textarea{font:inherit;max-width:100%}
body.lightbox-open{overflow:hidden}
.main-nav,.hero,.quick-facts,.content-shell,.content-shell .photo-gallery,footer{min-width:0}
.hero-copy,.hero-collage,.content-shell>article,.booking-wrap,.booking-card,.gallery-intro,.gallery-preview{min-width:0}

@media (max-width:1080px){
  .main-nav{width:100%;grid-template-columns:auto minmax(0,1fr);gap:.8rem;padding:.55rem .7rem;min-height:74px}
  .brand{justify-self:start;grid-column:1}
  .nav-side-left{display:none!important}
  .nav-side-right{grid-column:2;justify-self:end;min-width:0}
  .nav-cta{max-width:100%;white-space:normal;text-align:center;line-height:1.15;padding:.78rem .9rem!important}
  .brand-logo{width:72px;height:72px}
  .hero{grid-template-columns:1fr;min-height:0;padding-top:clamp(2.2rem,5vw,4rem)}
  .hero-collage{margin-right:0;width:100%;max-width:720px;justify-self:center;min-height:clamp(470px,68vw,640px)}
  .content-shell{grid-template-columns:minmax(0,1fr) minmax(280px,320px);padding-left:var(--page-gutter);padding-right:var(--page-gutter)}
  .booking-wrap{width:100%;max-width:320px;padding-left:0;padding-right:0}
}

@media (max-width:980px){
  .site-header{padding:10px 14px}
  .main-nav{left:14px;right:14px;max-width:calc(100vw - 28px);overflow:hidden}
  .main-nav.open{display:grid;grid-template-columns:1fr}
  .main-nav .brand{justify-self:center;grid-column:auto}
  .main-nav .nav-side-left{display:flex!important}
  .main-nav .nav-side{width:100%;align-items:stretch}
  .main-nav a{white-space:normal;text-align:center}
  .content-shell{display:flex;flex-direction:column;padding-left:0;padding-right:0}
  .booking-wrap{order:-1;max-width:none;width:100%;padding:0 var(--page-gutter) clamp(2rem,5vw,3rem)}
  .booking-card{position:relative;top:auto}
  .field-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .split-feature,.rooms,.amenity-grid,.mosaic{grid-template-columns:1fr 1fr}
  .story-grid{grid-template-columns:1fr 1fr}
  .story-card.big{grid-row:auto;grid-column:1 / -1;min-height:420px}
  .story-card{min-height:300px}
  .mosaic figure{height:clamp(240px,38vw,340px)}
  .mosaic figure:first-child{grid-column:1 / -1}
  .quick-facts{grid-template-columns:repeat(5,minmax(0,1fr));gap:.6rem}
  .quick-facts div{padding:.9rem .7rem;min-width:0}
  .quick-facts strong{font-size:clamp(1.35rem,4vw,1.8rem)}
  .quick-facts span{font-size:.82rem;overflow-wrap:anywhere}
}

@media (max-width:760px){
  :root{--page-gutter:18px;--radius:22px}
  .section-pad{padding-top:clamp(2.8rem,10vw,4rem);padding-bottom:clamp(2.8rem,10vw,4rem)}
  .hero h1{font-size:clamp(2.55rem,12vw,4.2rem);line-height:.94}
  .lead{font-size:1.02rem}
  .hero-actions{display:grid;grid-template-columns:1fr;gap:.75rem;max-width:360px}
  .button{justify-content:center;text-align:center;width:100%}
  .hero-collage{min-height:0;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding-bottom:0;max-width:520px}
  .hero-collage .photo{position:relative!important;inset:auto!important;width:100%!important;height:auto!important;aspect-ratio:4/3;border-width:6px;border-radius:20px;transform:none!important}
  .hero-collage .p-main{grid-column:1 / -1;aspect-ratio:16/10}
  .hero-collage .sun-note{left:.75rem;top:.75rem;width:94px;height:94px;font-size:.78rem}
  .hero-gallery-link{position:relative;left:auto;right:auto;bottom:auto;grid-column:1 / -1;justify-content:center;width:100%;transform:none!important;white-space:normal}
  .quick-facts{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:0}
  .quick-facts div:last-child{grid-column:1 / -1}
  .story-grid,.split-feature,.rooms,.amenity-grid,.mosaic,.stacked-photos{grid-template-columns:1fr}
  .story-card,.story-card.big{grid-column:auto;min-height:260px}
  .stacked-photos img:first-child{margin-top:0}
  .content-shell .photo-gallery .gallery-preview{grid-template-columns:1fr 1fr;grid-template-rows:repeat(2,minmax(126px,34vw));min-height:0}
  .content-shell .photo-gallery .gallery-tile.hero-tile,.content-shell .photo-gallery .gallery-tile{grid-column:auto;grid-row:auto}
  .content-shell .photo-gallery .gallery-intro{grid-template-columns:1fr;grid-template-areas:"kicker" "title" "text" "button";gap:.65rem}
  .content-shell .photo-gallery .gallery-open{justify-self:stretch;text-align:center}
  .field-row{grid-template-columns:1fr}
  .booking-card{padding:1.25rem;border-radius:24px;overflow:hidden}
  .booking-card:after{right:-20px;top:-18px;width:76px}
  .lightbox-close{top:.75rem;right:.75rem}
  .gallery-lightbox{padding:.75rem;grid-template-columns:1fr 1fr;grid-template-rows:minmax(0,1fr) auto auto;gap:.65rem}
  .lightbox-frame{grid-column:1 / -1;grid-row:1;align-self:end}
  .lightbox-image{max-height:calc(100dvh - 205px);border-radius:16px}
  .lightbox-prev,.lightbox-next{position:relative;grid-row:2;width:100%;height:48px;font-size:2rem;transform:none;left:auto;right:auto;top:auto}
  .lightbox-strip{grid-column:1 / -1;grid-row:3;max-width:100%;padding:.55rem}
  footer{flex-direction:column;gap:1.25rem;overflow-wrap:anywhere}
}

@media (max-width:430px){
  :root{--page-gutter:16px}
  .site-header{padding:8px 10px}
  .nav-toggle{flex:0 0 auto;padding:.58rem .72rem;border-radius:12px}
  .main-nav{left:10px;right:10px;max-width:calc(100vw - 20px);padding:.85rem;border-radius:20px}
  .brand-logo{width:66px;height:66px}
  .nav-cta{font-size:.82rem;padding:.68rem .72rem!important}
  .hero{padding-top:2rem}
  .hero h1{font-size:clamp(2.38rem,11.8vw,3.05rem)}
  .hero-collage{gap:.6rem}
  .hero-collage .photo{border-width:5px;border-radius:18px}
  .quick-facts{padding-left:16px;padding-right:16px}
  .booking-wrap{padding-left:16px;padding-right:16px}
  .booking-card input,.booking-card select{padding:.85rem .75rem;border-radius:14px}
  .content-shell .photo-gallery .gallery-preview{gap:.6rem;grid-template-rows:repeat(2,minmax(116px,32vw))}
  .mosaic figure{height:240px}
}

@media (max-width:1080px){
  .hero:before,.content-shell .photo-gallery:after{display:none}
  .booking-card{overflow:hidden}
}
/* v25/v26: restore desktop sticky booking request block and keep lemon below menu */
html,body{overflow-x:clip}
@media (min-width:981px){
  .content-shell{align-items:start}
  .booking-wrap{position:sticky!important;top:clamp(148px,12vw,164px)!important;scroll-margin-top:clamp(170px,14vw,190px);align-self:start!important;height:max-content;overflow:visible}
}

/* v28: make footer phone details readable on the dark footer */
.footer-house-number,
.footer-phone{color:#fff;margin:.15rem 0 0;font-weight:850;line-height:1.45;text-shadow:0 1px 12px rgba(0,0,0,.22)}
.footer-house-number span,
.footer-phone span{color:rgba(255,255,255,.9);font-weight:850}
.footer-phone a{display:inline-flex;align-items:center;margin-left:.35rem;padding:.2rem .58rem;border-radius:999px;background:rgba(255,216,77,.16);color:var(--lemon);font-weight:950;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:.22em;box-shadow:inset 0 0 0 1px rgba(255,216,77,.34);white-space:nowrap}
.footer-phone a:hover{background:rgba(255,216,77,.24);color:#fff7d0}
.footer-phone a:focus-visible{outline:3px solid var(--lemon);outline-offset:3px;background:rgba(255,216,77,.26);color:#fff;box-shadow:0 0 0 6px rgba(255,216,77,.18),inset 0 0 0 1px rgba(255,255,255,.45)}
footer>a:focus-visible,
.footer-copy address a:focus-visible{outline:3px solid var(--lemon);outline-offset:4px;border-radius:8px}

.booking-card .calendar-jump {
  margin: 50px 0;
}
.booking-card > p {
  margin-bottom: 50px;
}
.booking-card ul {
  margin-top: 50px;
}


@media (max-width: 760px) {
  .calendar-shell iframe#iframe_huurkalender_23007 {
    min-height: 820px;
    max-height: 920px;
  }
}

/* Keep the embedded Huurkalender stable after date clicks. */
.calendar-section {
  overflow: hidden;
}
.calendar-shell {
  overflow: hidden;
}
.calendar-shell .huurkalender-embed,
.calendar-shell .huurkalender-embed-container_calendar {
  width: 100%;
  max-width: 100%;
  height: 760px !important;
  max-height: 760px !important;
  overflow: hidden !important;
}
.calendar-shell iframe#iframe_huurkalender_23007 {
  display: block;
  width: 100%;
  height: 760px !important;
  min-height: 760px !important;
  max-height: 760px !important;
  overflow: hidden !important;
}
@media (max-width: 760px) {
  .calendar-shell .huurkalender-embed,
  .calendar-shell .huurkalender-embed-container_calendar,
  .calendar-shell iframe#iframe_huurkalender_23007 {
    height: 820px !important;
    min-height: 820px !important;
    max-height: 820px !important;
  }
}
