/* Kuwa Zanzibar — "Coastal Editorial" · sand/ivory + deep sea-blue + soft turquoise
   Fraunces (serif headlines) + Inter · full-bleed editorial hero · mobile-first, weak-net safe */
:root{
  --sand:#f6f0e4; --sand2:#efe6d4; --cream:#fbf7ef; --card:#ffffff;
  --ink:#1e3a40; --ink2:#15292e; --soft:#5f7077; --muted:#92a0a4;
  --sea:#2f9a98; --sea-deep:#1f7a78; --sea-soft:#5fbdb8;
  --terra:#cf6a42; --terra-deep:#b1542f; --saffron:#e0a24a;
  --line:rgba(30,58,64,.12); --line2:rgba(30,58,64,.2);
  --wa:#1daa50; --wa-dark:#168a40; --radius:18px;
  --disp:"Fraunces",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--sand);color:var(--ink);line-height:1.7;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--disp);font-weight:400;line-height:1.08;letter-spacing:-.01em}
h2{font-size:clamp(1.95rem,4.6vw,3.3rem)}
.wrap{max-width:1140px;margin:0 auto;padding:0 1.5rem}
.kick{display:inline-block;font:600 .7rem var(--sans);letter-spacing:.28em;text-transform:uppercase;color:var(--sea-deep);margin-bottom:1rem}
.kick--light{color:#cdeae6}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font:600 .9rem var(--sans);padding:.82rem 1.6rem;border-radius:999px;transition:transform .15s,background .2s,box-shadow .2s,border-color .2s,color .2s;white-space:nowrap;cursor:pointer;border:0}
.btn:active{transform:scale(.97)}
.btn--sea{background:var(--sea);color:#fff;box-shadow:0 8px 22px rgba(31,122,120,.28)}.btn--sea:hover{background:var(--sea-deep);box-shadow:0 10px 30px rgba(31,122,120,.4)}
.btn--cream{background:var(--cream);color:var(--ink)}.btn--cream:hover{background:#fff}
.btn--wa{background:var(--wa);color:#fff}.btn--wa:hover{background:var(--wa-dark)}
.btn--ghost{background:transparent;border:1.5px solid var(--line2);color:var(--ink)}.btn--ghost:hover{border-color:var(--sea);color:var(--sea-deep)}
.btn--ghost-light{background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.5);color:#fff;backdrop-filter:blur(4px)}.btn--ghost-light:hover{background:rgba(255,255,255,.2)}
.btn--block{width:100%}.btn--lg{padding:.98rem 2rem;font-size:1rem}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,box-shadow .3s}
.nav.scrolled{background:rgba(246,240,228,.9);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.nav__in{max-width:1140px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;gap:1.4rem}
.brand{display:flex;flex-direction:column;line-height:.92}
.brand__name{font:400 1.5rem var(--disp);color:#fff;letter-spacing:.02em;transition:color .3s}
.brand__sub{font:600 .58rem var(--sans);letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,255,.85);transition:color .3s}
.nav.scrolled .brand__name{color:var(--ink)}.nav.scrolled .brand__sub{color:var(--sea-deep)}
.nav__links{display:flex;gap:1.7rem;margin-left:auto;font:500 .92rem var(--sans);color:#fff}
.nav.scrolled .nav__links{color:var(--soft)}
.nav__links a{transition:color .2s}.nav__links a:hover{color:var(--sea-soft)}.nav.scrolled .nav__links a:hover{color:var(--sea-deep)}
.nav__act{display:flex;align-items:center;gap:.8rem}
.lang{display:flex;border:1px solid rgba(255,255,255,.5);border-radius:999px;overflow:hidden;background:rgba(255,255,255,.12)}
.nav.scrolled .lang{border-color:var(--line2);background:#fff}
.lang__btn{border:0;background:transparent;font:600 .74rem var(--sans);padding:.4rem .56rem;cursor:pointer;color:rgba(255,255,255,.85)}
.nav.scrolled .lang__btn{color:var(--muted)}
.lang__btn.is-active{background:var(--sea);color:#fff}
.navtog{display:none;background:none;border:0;cursor:pointer;padding:.4rem}.navtog span{display:block;width:22px;height:2px;background:#fff;margin:4.5px 0;transition:background .3s}
.nav.scrolled .navtog span{background:var(--ink)}

/* HERO — full-bleed editorial */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 42%;animation:kenburns 22s ease-in-out infinite alternate;transform-origin:55% 45%}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.14)}}
.hero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(21,41,46,.5) 0%,rgba(21,41,46,.1) 28%,rgba(21,41,46,.12) 55%,rgba(21,41,46,.82) 100%)}
.hero__c{position:relative;z-index:2;max-width:1140px;margin:0 auto;width:100%;padding:0 clamp(1.5rem,5vw,2.2rem) clamp(2.4rem,6vw,3.6rem);color:#fff}
.hero__title{font-size:clamp(2.6rem,6.4vw,5.1rem);color:#fff;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero__title em{font-style:italic;color:var(--saffron)}
.hero__sub{margin:1.2rem 0 1.7rem;max-width:34rem;color:rgba(255,255,255,.92);font-size:clamp(1rem,1.6vw,1.12rem);text-shadow:0 1px 14px rgba(0,0,0,.4)}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap}

/* calc card floating bottom-right over hero */
.rcalc{position:absolute;z-index:3;right:clamp(1.5rem,5vw,2.2rem);bottom:clamp(2.4rem,6vw,3.6rem);width:min(22rem,86vw);
  background:rgba(251,247,239,.92);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.7);border-radius:var(--radius);
  padding:1.15rem 1.25rem;box-shadow:0 24px 60px rgba(15,41,46,.34)}
.rcalc__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}
.rcalc__title{font:400 1.3rem var(--disp);color:var(--ink)}
.rcalc__ai{font:600 .58rem var(--sans);letter-spacing:.12em;text-transform:uppercase;color:var(--sea-deep);border:1px solid var(--line2);border-radius:999px;padding:.25rem .58rem}
.rcalc label{display:block;font:600 .64rem var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.rcalc label span{display:block;margin-bottom:.26rem}
.rcalc select,.rcalc input[type=number]{width:100%;padding:.56rem .68rem;border:1px solid var(--line2);border-radius:11px;font:500 .88rem var(--sans);color:var(--ink);background:#fff}
.rcalc select:focus,.rcalc input:focus{outline:2px solid var(--sea-soft);outline-offset:0}
.rcalc__grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.rcalc__chk{display:flex!important;align-items:center;gap:.5rem;font:500 .76rem var(--sans)!important;letter-spacing:0!important;text-transform:none!important;color:var(--soft)!important;cursor:pointer;margin:.55rem 0 0}
.rcalc__chk input{width:auto;accent-color:var(--sea)}.rcalc__chk span{margin:0!important}
.rcalc__total{display:flex;align-items:baseline;justify-content:space-between;border-top:1px solid var(--line);margin:.85rem 0 .8rem;padding-top:.7rem}
.rcalc__total span{font:600 .66rem var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.rcalc__total strong{font:400 1.85rem var(--disp);color:var(--sea-deep)}
.rcalc__note{font-size:.64rem;color:var(--muted);text-align:center;margin-top:.6rem}

/* sections */
.sec{padding:clamp(3.5rem,8vw,6.2rem) 0}
.sec--intro{background:var(--sand)}
.sec--bento{background:var(--cream)}
.sec--rooms{background:var(--sand)}
.sec--gallery{background:var(--cream)}
.sec--reviews{background:var(--sand2)}
.sec--loc{background:var(--cream)}
.sec--faq{background:var(--sand)}
.sec__head{max-width:46rem;margin:0 auto 2.8rem;text-align:center}
.sec__head p.lead{color:var(--soft);margin-top:.85rem;font-size:1.06rem}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1rem;text-align:center;box-shadow:0 10px 30px rgba(31,122,120,.06)}
.stat strong{display:block;font:400 2.3rem var(--disp);color:var(--sea-deep);line-height:1}
.stat .stat__s{font-size:1.2rem;color:var(--saffron)}
.stat span{font:500 .8rem var(--sans);color:var(--soft);margin-top:.4rem;display:block}

/* bento */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.bento__c{padding:1.6rem 1.5rem;display:flex;flex-direction:column;min-width:0;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 10px 30px rgba(31,122,120,.05)}
.bento--wide{grid-column:span 2}
.bento__c svg{width:30px;height:30px;fill:none;stroke:var(--sea-deep);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;margin-bottom:.95rem}
.bento__c h3{font-size:1.28rem;margin-bottom:.35rem}
.bento__c p{color:var(--soft);font-size:.92rem}

/* DUO-SCROLL */
.duo{display:grid;grid-template-columns:1fr 1fr;align-items:start;background:var(--ink2);color:#fff}
.duo__sticky{position:sticky;top:0;height:100svh;overflow:hidden}
.duo__sticky img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .9s ease}
.duo__sticky img.on{opacity:1}
.duo__sticky::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(21,41,46,.45),transparent 45%)}
.duo__beats{display:flex;flex-direction:column}
.dbeat{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:3rem clamp(1.5rem,5vw,4.5rem)}
.dbeat .kick{color:var(--sea-soft);margin-bottom:.7rem}
.dbeat h2{margin-bottom:.85rem;color:#fff}
.dbeat p{color:rgba(255,255,255,.82);max-width:34rem}
.dbeat ul{list-style:none;margin-top:1.3rem;display:grid;gap:.55rem}
.dbeat li{padding-left:1.5rem;position:relative;font-weight:500;color:rgba(255,255,255,.92)}
.dbeat li::before{content:"";position:absolute;left:0;top:.62em;width:.5rem;height:.5rem;border-radius:50%;background:var(--saffron)}

/* rooms */
.rooms{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem}
.room{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 12px 34px rgba(31,122,120,.07);display:flex;flex-direction:column}
.room img{width:100%;aspect-ratio:16/10;object-fit:cover}
.room__b{padding:1.3rem 1.4rem;display:flex;flex-direction:column;flex:1}
.room__h{display:flex;align-items:baseline;justify-content:space-between;gap:.8rem;flex-wrap:wrap;margin-bottom:.4rem}
.room__h h3{font-size:1.42rem}
.room__cap{font:600 .66rem var(--sans);letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.room__b p{color:var(--soft);font-size:.92rem;flex:1}
.room__f{display:flex;align-items:center;justify-content:space-between;margin-top:1.1rem;gap:.8rem;flex-wrap:wrap}
.room__price{font:400 1.5rem var(--disp);color:var(--terra-deep)}.room__price small{font:600 .66rem var(--sans);color:var(--muted)}
.rooms__more{text-align:center;margin-top:1.8rem;color:var(--soft);font-size:.95rem}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem}
.ph{border-radius:14px;overflow:hidden;background:var(--sand2)}
.ph img{width:100%;height:100%;aspect-ratio:1/1;object-fit:cover;transition:transform .5s ease}
.ph:hover img{transform:scale(1.06)}

/* reviews */
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.rev{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:0 12px 30px rgba(31,122,120,.06)}
.rev__st{color:var(--saffron);letter-spacing:.16em;margin-bottom:.85rem}
.rev blockquote{font:400 1.16rem var(--disp);color:var(--ink);line-height:1.42}
.rev figcaption{margin-top:1.05rem;font:600 .82rem var(--sans);color:var(--muted)}
.ratepill{display:inline-flex;align-items:center;gap:.6rem;background:var(--card);border:1px solid var(--line2);border-radius:999px;padding:.5rem 1.1rem;margin-bottom:1rem}
.ratepill strong{color:var(--sea-deep);font:400 1.1rem var(--disp)}.ratepill span{font:500 .82rem var(--sans);color:var(--soft)}

/* location */
.loc{display:grid;grid-template-columns:1fr 1.05fr;gap:2.6rem;align-items:center}
.loc__media img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius)}
.loc__b h2{margin-bottom:.95rem}.loc__b p{color:var(--soft);margin-bottom:1.6rem;max-width:32rem}
.loc__cta{display:flex;gap:.8rem;flex-wrap:wrap}

/* faq */
.faqwrap{max-width:780px}
.faq{display:grid;gap:.75rem}
.faq__i{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.faq__i summary{list-style:none;cursor:pointer;padding:1.05rem 1.3rem;font:600 1rem var(--sans);color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.faq__i summary::-webkit-details-marker{display:none}
.faq__i summary::after{content:"+";font-weight:400;font-size:1.5rem;line-height:1;color:var(--sea-deep);transition:transform .25s}
.faq__i[open] summary::after{transform:rotate(45deg)}
.faq__i[open] summary{color:var(--sea-deep)}
.faq__a{padding:0 1.3rem 1.15rem}.faq__a p{color:var(--soft);font-size:.95rem;margin:0}

/* cta band */
.cta{text-align:center;padding:clamp(3.6rem,8vw,5.6rem) 1.5rem;background:linear-gradient(135deg,var(--sea-deep),var(--sea));color:#fff;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:-40%;background:radial-gradient(40% 50% at 22% 30%,rgba(255,255,255,.16),transparent 60%),radial-gradient(40% 50% at 80% 70%,rgba(224,162,74,.2),transparent 60%);animation:aurora 16s ease-in-out infinite alternate;pointer-events:none}
.cta>*{position:relative;z-index:1}
.cta h2{color:#fff}.cta p{color:rgba(255,255,255,.9);margin:.75rem 0 1.8rem}
@keyframes aurora{from{transform:translate(-3%,-2%) scale(1)}to{transform:translate(3%,2%) scale(1.08)}}

/* footer */
.footer{background:var(--ink2);color:#a9c1c3;font-size:.9rem}
.footer__in{max-width:1140px;margin:0 auto;padding:3.2rem 1.5rem 2rem;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2rem}
.footer__logo{height:46px;width:auto;background:#fff;border-radius:10px;padding:.5rem .8rem;margin-bottom:.3rem}
.footer h4{color:#fff;font:600 .76rem var(--sans);letter-spacing:.14em;text-transform:uppercase;margin-bottom:.7rem}
.footer a:hover{color:#fff}
.footer__legal{border-top:1px solid rgba(255,255,255,.13);max-width:1140px;margin:0 auto;padding:1.1rem 1.5rem 1.5rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.76rem;color:#789396}
.footer__demo{font-style:italic}

/* fab */
.fab{position:fixed;right:1.1rem;bottom:1.1rem;z-index:60;width:56px;height:56px;border-radius:50%;background:var(--wa);color:#fff;display:none;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(0,0,0,.25)}

/* WOW — progress + reveal + shimmer + card lift */
.prog{position:fixed;top:0;left:0;height:3px;width:0;z-index:70;background:linear-gradient(90deg,var(--sea),var(--saffron));transition:width .1s linear}
.rv{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.hero__title em{background:linear-gradient(100deg,var(--saffron) 30%,#fff 50%,var(--saffron) 70%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 6s linear infinite}
@keyframes shimmer{to{background-position:-220% 0}}
.card{transition:transform .25s ease,box-shadow .25s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(15,41,46,.16)}
.stats.in .stat strong{animation:pop .6s ease both}
.stat:nth-child(2) strong{animation-delay:.08s}.stat:nth-child(3) strong{animation-delay:.16s}.stat:nth-child(4) strong{animation-delay:.24s}
@keyframes pop{0%{transform:scale(.7);opacity:0}60%{transform:scale(1.07)}100%{transform:scale(1);opacity:1}}

/* responsive */
@media(max-width:900px){
  .stats{grid-template-columns:1fr 1fr}
  .revs{grid-template-columns:1fr}
  .loc{grid-template-columns:1fr;gap:1.6rem}
  .duo{grid-template-columns:1fr}
  .duo__sticky{position:relative;top:auto;height:auto;aspect-ratio:4/3}
  .duo__sticky img{position:relative;opacity:1!important}
  .duo__sticky img:not(:first-child){display:none}
  .duo__sticky::after{display:none}
  .dbeat{min-height:auto;padding:2.4rem 1.5rem}
  .bento{grid-template-columns:1fr 1fr}.bento--wide{grid-column:span 2}
  .rooms{grid-template-columns:1fr}
  .rcalc{position:static;width:auto;margin:1.6rem clamp(1.5rem,5vw,2.2rem) 0;backdrop-filter:none;background:var(--cream)}
  .hero{align-items:flex-start}
  .hero__c{padding-top:6.5rem;padding-bottom:1.5rem}
}
@media(max-width:600px){
  .nav__links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:rgba(246,240,228,.98);box-shadow:0 1px 0 var(--line)}
  .nav__links.open{display:flex}.nav__links a{padding:.95rem 1.5rem;border-top:1px solid var(--line);color:var(--ink)}
  .navtog{display:block}.nav__act .btn--sea{display:none}
  .fab{display:flex}
  .footer__in{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr}.bento--wide{grid-column:span 1}
  .gallery{grid-template-columns:1fr 1fr;gap:.6rem}
  .hero__title{font-size:clamp(2.1rem,9vw,3rem)}
  .hero__cta .btn{flex:1}
}
@media(max-width:380px){.stats{grid-template-columns:1fr 1fr}.hero__title{font-size:2rem}}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  .duo__sticky img{transition:none}
  .hero__media img{animation:none;transform:none}
  .hero__title em{animation:none;-webkit-text-fill-color:var(--saffron)}
  .cta::before,.stats.in .stat strong{animation:none}
  html{scroll-behavior:auto}
}
