/* Maui Beachside Bungalows — demo by Cavmir */
:root{
  --ink:#0b2b30;
  --teal:#0e6973;
  --teal-deep:#0b3c43;
  --lagoon:#0f8a96;
  --coral:#ff7a59;
  --coral-deep:#e8603f;
  --sand:#f7f2e9;
  --sand-deep:#efe6d6;
  --white:#ffffff;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--sand);line-height:1.65;font-weight:400;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}

h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.08}
h2{font-size:clamp(2rem,4.2vw,3.2rem);letter-spacing:-.01em}
.kicker{font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--coral-deep);font-weight:600;margin-bottom:14px}
.section-head{margin-bottom:56px}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:14px 34px;transition:background .35s,box-shadow .35s;color:#fff}
#nav.solid{background:rgba(11,43,48,.92);backdrop-filter:blur(12px);box-shadow:0 2px 24px rgba(0,0,0,.18)}
.nav-brand{display:flex;align-items:center;gap:12px}
.brand-badge{width:42px;height:42px;border:1.5px solid rgba(255,255,255,.85);border-radius:50%;display:flex;align-items:center;justify-content:center}
.brand-badge svg{width:24px;height:24px}
.brand-words{display:flex;flex-direction:column;line-height:1.2}
.brand-words strong{font-family:var(--serif);font-weight:500;font-size:1.02rem;letter-spacing:.02em}
.brand-words em{font-style:normal;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;opacity:.75}
.nav-links{display:flex;align-items:center;gap:30px;font-size:.86rem;font-weight:500;letter-spacing:.04em}
.nav-links a{opacity:.92;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.nav-cta{background:var(--coral);padding:10px 22px;border-radius:100px;font-weight:600}
.nav-cta:hover{background:var(--coral-deep)}
#nav-burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
#nav-burger span{display:block;width:24px;height:2px;background:#fff}

/* HERO */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero-img{position:absolute;inset:-6%;background-size:cover;background-position:center 35%;animation:kenburns 18s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,30,36,.42) 0%,rgba(8,30,36,.18) 45%,rgba(8,30,36,.62) 100%)}
.hero-inner{position:relative;max-width:880px;padding:96px 28px 0}
.hero-kicker{font-size:.8rem;letter-spacing:.42em;text-transform:uppercase;margin-bottom:22px;opacity:.95}
.hero h1{font-size:clamp(3.4rem,9.5vw,7.2rem);font-weight:300;letter-spacing:.01em;text-shadow:0 4px 40px rgba(0,0,0,.35)}
.hero-sub{max-width:620px;margin:26px auto 36px;font-size:1.08rem;font-weight:300;opacity:.96}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-proof{margin-top:46px;display:flex;gap:18px;justify-content:center;align-items:center;flex-wrap:wrap;font-size:.86rem;opacity:.95}
.hero-proof i{width:1px;height:16px;background:rgba(255,255,255,.4)}
.hero-proof strong{font-weight:600}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%)}
.hero-scroll span{display:block;width:1px;height:48px;background:rgba(255,255,255,.6);animation:drip 2s infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* BUTTONS */
.btn{display:inline-block;padding:15px 34px;border-radius:100px;font-weight:600;font-size:.92rem;letter-spacing:.03em;transition:transform .2s,background .2s,box-shadow .2s;cursor:pointer;border:0;font-family:var(--sans)}
.btn:hover{transform:translateY(-2px)}
.btn-coral{background:var(--coral);color:#fff;box-shadow:0 10px 30px rgba(232,96,63,.35)}
.btn-coral:hover{background:var(--coral-deep)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.7);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-ghost2{border:1.5px solid var(--teal);color:var(--teal);background:none}
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{background:var(--teal-deep)}
.btn-wide{width:100%}

/* INTRO */
.intro{padding:110px 0 90px;text-align:center}
.intro .wrap{max-width:820px}
.intro p:last-child{margin-top:24px;font-size:1.05rem;color:#3c5257}

/* BUNGALOWS */
.bungalows{padding:30px 0 40px}
.bungalows .section-head{text-align:center}
.b-card{display:grid;grid-template-columns:1.15fr 1fr;min-height:560px;margin-bottom:90px;align-items:center;gap:0}
.b-card.flip .b-media{order:2}
.b-card.flip .b-body{order:1}
.b-media{position:relative;height:100%;min-height:520px;display:flex;flex-direction:column;gap:10px;padding:0}
.b-main{flex:1;background-size:cover;background-position:center;border-radius:0;min-height:380px}
.b-card:not(.flip) .b-main,.b-card:not(.flip) .b-strip{margin-left:0}
.b-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;height:130px}
.b-strip div{background-size:cover;background-position:center}
.b-body{padding:50px 64px}
.b-rating{font-size:.82rem;font-weight:600;letter-spacing:.08em;color:var(--coral-deep);text-transform:uppercase;margin-bottom:14px}
.b-body h3{font-size:clamp(1.7rem,2.8vw,2.4rem);margin-bottom:8px}
.b-tag{font-size:.85rem;letter-spacing:.06em;color:#5b7176;text-transform:uppercase;margin-bottom:18px}
.b-body>p:not(.b-tag){color:#33494e}
.b-feats{list-style:none;margin:22px 0 30px;display:grid;grid-template-columns:1fr 1fr;gap:9px 18px}
.b-feats li{font-size:.9rem;color:#33494e;padding-left:22px;position:relative}
.b-feats li::before{content:'';position:absolute;left:0;top:9px;width:10px;height:2px;background:var(--coral)}
.b-ctas{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.b-link{font-size:.88rem;font-weight:600;color:var(--teal);border-bottom:1px solid transparent;transition:border .2s}
.b-link:hover{border-bottom-color:var(--teal)}

/* PARALLAX BANDS */
.band{position:relative;min-height:64vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.band-short{min-height:46vh}
.band-bg{position:absolute;left:0;right:0;top:-18%;bottom:-18%;background-size:cover;background-position:center;will-change:transform}
.band-shade{position:absolute;inset:0;background:rgba(9,38,44,.45)}
.band-shade.light{background:rgba(9,38,44,.12)}
.band-inner{position:relative;max-width:760px;padding:80px 28px}
.band-inner p{font-family:var(--serif);font-size:clamp(1.5rem,3.2vw,2.4rem);line-height:1.3;font-weight:300}
.band-inner span{display:block;margin-top:22px;font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;opacity:.9}

/* DIRECT */
.direct{padding:120px 0;background:var(--teal-deep);color:#fff}
.direct .kicker{color:var(--coral)}
.direct-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px}
.d-num{font-family:var(--serif);font-size:1rem;color:var(--coral);letter-spacing:.1em}
.d-item h4{font-family:var(--serif);font-weight:500;font-size:1.3rem;margin:14px 0 10px}
.d-item p{font-size:.92rem;font-weight:300;opacity:.85}

/* REVIEWS */
.reviews{padding:120px 0}
.reviews .section-head{text-align:center}
.r-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}
.r-grid blockquote{background:#fff;padding:38px 34px;border-radius:2px;box-shadow:0 18px 50px rgba(11,43,48,.07);font-size:.98rem;color:#2d4348;position:relative}
.r-grid blockquote::before{content:'\201C';font-family:var(--serif);font-size:4rem;color:var(--coral);position:absolute;top:6px;left:24px;opacity:.25;line-height:1}
.r-grid cite{display:block;margin-top:20px;font-style:normal;font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--teal)}
.r-note{text-align:center;margin-top:44px;font-size:.84rem;color:#6c8186}

/* HOSTS */
.hosts{padding:40px 0 120px}
.hosts-grid{display:grid;grid-template-columns:380px 1fr;gap:80px;align-items:center}
.hosts-photo{position:relative}
.hosts-img{border-radius:50%;overflow:hidden;aspect-ratio:1;box-shadow:0 30px 80px rgba(11,43,48,.22)}
.hosts-img img{width:100%;height:100%;object-fit:cover}
.hosts-badge{position:absolute;bottom:14px;right:6px;background:var(--coral);color:#fff;border-radius:50%;width:110px;height:110px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;line-height:1.4;box-shadow:0 12px 30px rgba(232,96,63,.4)}
.hosts-body p{color:#33494e;max-width:560px}
.hosts-stats{display:flex;gap:54px;margin-top:38px}
.hosts-stats strong{display:block;font-family:var(--serif);font-size:2.1rem;font-weight:400;color:var(--teal)}
.hosts-stats span{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:#6c8186}

/* BOOK */
.book{padding:120px 0;background:linear-gradient(180deg,var(--sand) 0%,var(--sand-deep) 100%)}
.book-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}
.book-intro>p{color:#33494e;margin-bottom:26px}
.book-points{list-style:none}
.book-points li{padding:10px 0 10px 30px;position:relative;font-size:.94rem;color:#33494e;border-bottom:1px solid rgba(11,43,48,.08)}
.book-points li::before{content:'\2713';position:absolute;left:2px;color:var(--coral-deep);font-weight:700}
.book-form{background:#fff;padding:44px;border-radius:4px;box-shadow:0 30px 90px rgba(11,43,48,.12)}
.book-form label{display:block;font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#5b7176;margin-bottom:18px}
.book-form input,.book-form select,.book-form textarea{display:block;width:100%;margin-top:7px;padding:13px 14px;border:1.5px solid #dcd4c4;border-radius:3px;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:#fdfcf9;transition:border .2s}
.book-form input:focus,.book-form select:focus,.book-form textarea:focus{outline:none;border-color:var(--teal)}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.f-note{font-size:.8rem;color:#6c8186;margin-top:16px;text-align:center;letter-spacing:0;text-transform:none;font-weight:400}
.book-done{background:#fff;padding:52px 44px;border-radius:4px;box-shadow:0 30px 90px rgba(11,43,48,.12);text-align:center}
.book-done h3{font-size:1.8rem;margin-bottom:16px}
.book-done p{color:#33494e}
.done-ctas{display:flex;gap:14px;justify-content:center;margin-top:28px;flex-wrap:wrap}

/* FOOTER */
footer{background:var(--ink);color:#cfdcdd;padding:80px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:60px;padding-bottom:60px}
.foot-brand{font-family:var(--serif);font-size:1.5rem;color:#fff;margin-bottom:12px}
.foot-tag{font-size:.9rem;font-weight:300;opacity:.8}
.foot-links{display:flex;flex-direction:column;gap:12px;font-size:.9rem}
.foot-links a:hover{color:#fff}
.foot-legal{font-size:.8rem;opacity:.65;line-height:2}
.foot-base{border-top:1px solid rgba(255,255,255,.1);padding:26px 34px;display:flex;justify-content:space-between;font-size:.8rem;opacity:.7;flex-wrap:wrap;gap:10px}
.foot-base a{text-decoration:underline}

/* REVEAL */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* RESPONSIVE */
@media (max-width:1020px){
  .b-card{grid-template-columns:1fr;min-height:0}
  .b-card.flip .b-media{order:0}
  .b-card.flip .b-body{order:1}
  .b-media{min-height:0}
  .b-main{min-height:320px}
  .b-body{padding:38px 8px 10px}
  .direct-grid{grid-template-columns:1fr 1fr;gap:36px}
  .r-grid{grid-template-columns:1fr 1fr}
  .hosts-grid{grid-template-columns:1fr;gap:46px;text-align:center}
  .hosts-photo{max-width:300px;margin:0 auto}
  .hosts-stats{justify-content:center}
  .book-grid{grid-template-columns:1fr;gap:50px}
  .foot-grid{grid-template-columns:1fr;gap:36px}
}
@media (max-width:760px){
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(11,43,48,.97);padding:26px 34px;gap:20px}
  #nav-burger{display:flex}
  #nav{background:rgba(11,43,48,.92)}
  .band-bg{top:0;bottom:0;transform:none !important}
  .r-grid{grid-template-columns:1fr}
  .direct-grid{grid-template-columns:1fr}
  .f-row{grid-template-columns:1fr}
  .b-strip{height:90px}
  .hero-proof{gap:10px;font-size:.78rem}
  .book-form{padding:30px 22px}
}
