/* ============================================================
   Bubble Retreats — Celestial Brand-First
   Built by Impero Solutions
   ============================================================ */

:root{
  --night:#0A0E1A;
  --night-2:#11141F;
  --ink:#070A12;
  --glow:#E8A14B;
  --glow-soft:#F4C77E;
  --twilight:#3A5A82;
  --cream:#F5F1E8;
  --linen:#E7DFCF;
  --linen-dim:#b9b2a3;
  --eucalypt:#9CA98C;
  --navy:#16233F;
  --star:#FDFDFB;

  --maxw:1240px;
  --pad:clamp(1.25rem,5vw,4rem);
  --r:18px;
  --r-lg:26px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --airbnb:#FF385C;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--night);
  color:var(--linen);
  line-height:1.65;
  font-size:clamp(1rem,.95rem + .2vw,1.0625rem);
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
em{font-style:italic}

.skip-link{position:absolute;left:-999px;top:0;background:var(--glow);color:var(--ink);padding:.7rem 1.2rem;z-index:200;border-radius:0 0 10px 0;font-weight:600}
.skip-link:focus{left:0}

:focus-visible{outline:2px solid var(--glow);outline-offset:3px;border-radius:4px}

/* ---------- Typography helpers ---------- */
.h2{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(1.9rem,1.3rem + 2.8vw,3.5rem);
  line-height:1.08;
  letter-spacing:-.01em;
  color:var(--cream);
}
.h2 em{color:var(--glow-soft);font-style:italic}
.h2--light{color:var(--cream)}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:600;
  color:var(--glow);
  margin-bottom:1.1rem;
}
.eyebrow--light{color:var(--glow-soft)}
.lead{font-size:clamp(1.05rem,1rem + .4vw,1.3rem);color:var(--cream);font-weight:300;line-height:1.55}
.lead--light{color:var(--linen)}
.spark{color:var(--glow);display:inline-block}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:.95rem;
  padding:1rem 1.9rem;border-radius:100px;cursor:pointer;border:1px solid transparent;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease),color .35s var(--ease);
  letter-spacing:.01em;white-space:nowrap;
}
.btn--glow{
  background:linear-gradient(135deg,var(--glow),var(--glow-soft));
  color:#2a1c08;
  box-shadow:0 10px 30px -8px rgba(232,161,75,.55);
}
.btn--glow:hover{transform:translateY(-3px);box-shadow:0 18px 44px -10px rgba(232,161,75,.7)}
.btn--ghost{background:rgba(255,255,255,.06);color:var(--cream);border-color:rgba(245,241,232,.32);backdrop-filter:blur(8px)}
.btn--ghost:hover{background:rgba(255,255,255,.14);transform:translateY(-3px);border-color:var(--cream)}
.btn--light{border-color:rgba(245,241,232,.45)}
.btn--sm{padding:.7rem 1.3rem;font-size:.85rem}
.btn--block{width:100%}

/* ---------- Starfield (decorative) ---------- */
.starfield{
  position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.9;
  background-image:
    radial-gradient(1.4px 1.4px at 12% 22%, rgba(255,255,255,.9), transparent),
    radial-gradient(1.2px 1.2px at 28% 60%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.6px 1.6px at 47% 18%, rgba(255,255,255,.85), transparent),
    radial-gradient(1.1px 1.1px at 64% 44%, rgba(255,255,255,.6), transparent),
    radial-gradient(1.5px 1.5px at 79% 28%, rgba(255,255,255,.8), transparent),
    radial-gradient(1.2px 1.2px at 88% 66%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.3px 1.3px at 36% 82%, rgba(255,255,255,.65), transparent),
    radial-gradient(1.1px 1.1px at 71% 78%, rgba(255,255,255,.6), transparent);
  animation:twinkle 6s ease-in-out infinite alternate;
}
@keyframes twinkle{from{opacity:.55}to{opacity:1}}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);padding:.4rem 0}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:.6rem var(--pad);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav__logo img{height:52px;width:auto;transition:height .4s var(--ease);filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}
.nav__links{display:flex;align-items:center;gap:2rem}
.nav__links a{font-size:.9rem;font-weight:400;color:var(--cream);opacity:.92;transition:opacity .25s,color .25s;position:relative}
.nav__links a:not(.nav__cta):hover{opacity:1;color:var(--glow-soft)}
.nav__links a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--glow);transition:width .3s var(--ease)}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__cta{
  background:linear-gradient(135deg,var(--glow),var(--glow-soft));color:#2a1c08;
  padding:.62rem 1.3rem;border-radius:100px;font-weight:600;
  box-shadow:0 8px 24px -10px rgba(232,161,75,.6);transition:transform .3s var(--ease)
}
.nav__cta:hover{transform:translateY(-2px)}
.nav--scrolled{background:rgba(10,14,26,.82);backdrop-filter:blur(16px);box-shadow:0 1px 0 rgba(245,241,232,.08)}
.nav--scrolled .nav__logo img{height:42px}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:120}
.nav__toggle span{width:26px;height:2px;background:var(--cream);border-radius:2px;transition:transform .3s var(--ease),opacity .3s}

/* ============================================================
   HERO
   ============================================================ */
.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 40%}
.hero__overlay{position:absolute;inset:0;z-index:2;
  background:
    radial-gradient(120% 90% at 50% 8%, rgba(10,14,26,.05), rgba(10,14,26,.35) 55%, rgba(10,14,26,.92) 100%),
    linear-gradient(to top, rgba(7,10,18,.96) 0%, rgba(10,14,26,.45) 38%, rgba(10,14,26,.15) 70%);
}
.hero__content{position:relative;z-index:3;max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--pad) clamp(3.5rem,8vh,6rem)}
.hero__eyebrow{text-transform:uppercase;letter-spacing:.28em;font-size:.74rem;font-weight:500;color:var(--linen);margin-bottom:1.4rem;display:flex;align-items:center;gap:.6rem}
.hero__title{
  font-family:var(--serif);font-weight:400;color:var(--star);
  font-size:clamp(2.6rem,1.6rem + 6vw,6rem);line-height:1.02;letter-spacing:-.02em;
  text-shadow:0 4px 40px rgba(0,0,0,.5);
}
.hero__title em{color:var(--glow-soft);font-style:italic}
.hero__sub{max-width:46ch;margin:1.6rem 0 2.2rem;font-size:clamp(1.05rem,1rem + .5vw,1.3rem);color:var(--linen);font-weight:300}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__badges{display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:2.4rem}
.badge{font-size:.85rem;color:var(--linen);display:flex;align-items:center;gap:.4rem}
.badge strong{color:var(--glow-soft);font-weight:600}
.badge:not(:last-child){padding-right:1.4rem;border-right:1px solid rgba(245,241,232,.18)}
.hero__scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:4;width:26px;height:42px;border:1.5px solid rgba(245,241,232,.5);border-radius:14px;display:flex;justify-content:center;padding-top:8px}
.hero__scroll span{width:3px;height:8px;background:var(--glow-soft);border-radius:2px;animation:scroll 1.8s ease-in-out infinite}
@keyframes scroll{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%{opacity:0;transform:translateY(10px)}}

/* ============================================================
   PROOF STRIP
   ============================================================ */
.proof{background:var(--ink);border-top:1px solid rgba(245,241,232,.06);border-bottom:1px solid rgba(245,241,232,.06);overflow:hidden;padding:1rem 0}
.proof__track{display:flex;gap:3rem;white-space:nowrap;width:max-content;animation:marquee 38s linear infinite}
.proof__track span{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--linen-dim);font-weight:400}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   SECTIONS / LAYOUT
   ============================================================ */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(4.5rem,9vw,8rem) var(--pad)}
.section__head{max-width:760px;margin-bottom:clamp(2.5rem,5vw,4rem)}
.section__head .lead{margin-top:1.2rem}

/* Split (image + text) */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--reverse .split__media{order:-1}
.split__body .lead{margin:1.2rem 0}
.split__body p{color:var(--linen);margin-bottom:1rem}
.split__media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:0 40px 80px -30px rgba(0,0,0,.8)}
.split__media img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.2s var(--ease)}
.split__media:hover img{transform:scale(1.04)}
.split__media figcaption{position:absolute;left:0;bottom:0;right:0;padding:1.5rem;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cream);background:linear-gradient(to top,rgba(7,10,18,.85),transparent)}
.split__stats{display:flex;gap:2.4rem;margin-top:2.4rem;flex-wrap:wrap}
.split__stats div{display:flex;flex-direction:column}
.split__stats strong{font-family:var(--serif);font-size:2.4rem;color:var(--glow-soft);line-height:1;font-weight:500}
.split__stats span{font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--linen-dim);margin-top:.4rem}

/* ============================================================
   STARGAZING FEATURE (full bleed)
   ============================================================ */
.starsec{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden}
.starsec__media{position:absolute;inset:0;z-index:0}
.starsec__media img{width:100%;height:100%;object-fit:cover}
.starsec__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(7,10,18,.92) 0%,rgba(7,10,18,.7) 38%,rgba(7,10,18,.25) 75%,transparent 100%)}
.starsec__content{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--pad)}
.starsec__content .lead{max-width:48ch;margin:1.4rem 0 2rem}
.starsec__list{list-style:none;display:flex;flex-direction:column;gap:.9rem;max-width:42ch}
.starsec__list li{display:flex;align-items:center;gap:.8rem;color:var(--cream);font-size:1.02rem}

/* ============================================================
   AMENITIES
   ============================================================ */
.amen__feature{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:clamp(2.5rem,5vw,4rem)}
.amen__feature figure{border-radius:var(--r-lg);overflow:hidden;box-shadow:0 30px 70px -34px rgba(0,0,0,.8)}
.amen__feature img{width:100%;aspect-ratio:16/11;object-fit:cover;transition:transform 1.2s var(--ease)}
.amen__feature figure:hover img{transform:scale(1.05)}
.amen__grid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.amen-card{background:var(--night-2);border:1px solid rgba(245,241,232,.07);border-radius:var(--r);padding:1.8rem 1.5rem;transition:transform .4s var(--ease),border-color .4s,background .4s}
.amen-card:hover{transform:translateY(-6px);border-color:rgba(232,161,75,.4);background:#151926}
.amen-card__ic{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;background:rgba(232,161,75,.12);color:var(--glow);font-size:1.3rem;margin-bottom:1.1rem}
.amen-card__ic svg{width:24px;height:24px}
.amen-card:hover .amen-card__ic{background:rgba(232,161,75,.2)}
.amen-card h3{font-family:var(--serif);font-weight:500;font-size:1.18rem;color:var(--cream);margin-bottom:.5rem;line-height:1.2}
.amen-card p{font-size:.92rem;color:var(--linen-dim);font-weight:300}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:230px;gap:1rem}
.gallery__item{border:0;padding:0;cursor:pointer;border-radius:var(--r);overflow:hidden;position:relative;background:var(--night-2)}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .4s}
.gallery__item:hover img{transform:scale(1.07)}
.gallery__item::after{content:"⤢";position:absolute;top:12px;right:14px;color:#fff;opacity:0;font-size:1.1rem;transition:opacity .3s;text-shadow:0 1px 6px rgba(0,0,0,.6)}
.gallery__item:hover::after{opacity:.9}
.gallery__item--tall{grid-row:span 2}
.gallery__item--wide{grid-column:span 2}

/* ============================================================
   LOCATION
   ============================================================ */
.loc__nearby{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.4rem;margin:1.6rem 0}
.loc__nearby li{position:relative;padding-left:1.5rem;color:var(--cream);font-size:.98rem}
.loc__nearby li::before{content:"✦";position:absolute;left:0;color:var(--glow);font-size:.8rem;top:.15rem}
.loc__note{font-size:.9rem;color:var(--linen-dim);border-top:1px solid rgba(245,241,232,.1);padding-top:1.2rem;margin-top:.5rem}
.loc__note span{display:block;color:var(--glow-soft);margin-top:.2rem}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{text-align:center}
.reviews .section__head{margin-left:auto;margin-right:auto}
.reviews__badge{display:inline-flex;gap:2.5rem;align-items:center;justify-content:center;background:var(--night-2);border:1px solid rgba(245,241,232,.08);border-radius:var(--r-lg);padding:1.6rem 2.6rem;margin-bottom:3rem;flex-wrap:wrap}
.reviews__score strong,.reviews__omg strong{font-family:var(--serif);font-size:2.6rem;color:var(--glow-soft);display:block;line-height:1;font-weight:500}
.reviews__score span{color:var(--glow);letter-spacing:.2em;font-size:.9rem;display:block;margin:.3rem 0}
.reviews__score small,.reviews__omg small{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--linen-dim);display:block;margin-top:.3rem}
.reviews__omg{padding-left:2.5rem;border-left:1px solid rgba(245,241,232,.14)}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;text-align:left}
.review-card{background:linear-gradient(160deg,var(--night-2),#0d1019);border:1px solid rgba(245,241,232,.07);border-radius:var(--r);padding:2rem 1.8rem;position:relative}
.review-card .spark{font-size:1.4rem;margin-bottom:1rem;display:block}
.review-card p{color:var(--cream);font-size:1.02rem;font-weight:300;margin-bottom:1.2rem}
.review-card p em{color:var(--glow-soft);font-style:italic}
.review-card cite{font-style:normal;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--linen-dim)}
.reviews__disclaimer{font-size:.78rem;color:var(--linen-dim);margin-top:1.6rem;font-style:italic}

/* ============================================================
   STAYS
   ============================================================ */
.stays__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.stay-card{background:var(--night-2);border:1px solid rgba(245,241,232,.07);border-radius:var(--r-lg);overflow:hidden;transition:transform .4s var(--ease),border-color .4s}
.stay-card:hover{transform:translateY(-6px);border-color:rgba(232,161,75,.35)}
.stay-card__media{aspect-ratio:16/10;overflow:hidden}
.stay-card__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.stay-card:hover .stay-card__media img{transform:scale(1.06)}
.stay-card__body{padding:1.8rem}
.stay-card__body h3{font-family:var(--serif);font-size:1.7rem;color:var(--cream);font-weight:500;margin-bottom:.6rem}
.stay-card__body p{color:var(--linen-dim);font-size:.96rem;margin-bottom:1.4rem}
.stay-card__actions{display:flex;gap:.7rem;flex-wrap:wrap}

/* ============================================================
   BOOKING
   ============================================================ */
.book{background:
   radial-gradient(80% 120% at 90% 10%, rgba(232,161,75,.14), transparent 60%),
   linear-gradient(180deg,var(--ink),var(--night));
  border-top:1px solid rgba(245,241,232,.06);position:relative;overflow:hidden}
.book__inner{max-width:var(--maxw);margin:0 auto;padding:clamp(4.5rem,9vw,8rem) var(--pad);display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:center}
.book__actions{display:flex;gap:1rem;flex-wrap:wrap;margin:2rem 0}
.book__facts{list-style:none;display:flex;flex-direction:column;gap:.6rem;border-top:1px solid rgba(245,241,232,.12);padding-top:1.4rem}
.book__facts li{font-size:.92rem;color:var(--linen)}
.book__facts strong{color:var(--cream);font-weight:600}
.book__form{background:var(--night-2);border:1px solid rgba(245,241,232,.1);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:0 40px 90px -40px rgba(0,0,0,.9)}
.book__form-title{font-family:var(--serif);font-size:1.4rem;color:var(--cream);font-weight:500;margin-bottom:1.4rem}
.field{margin-bottom:1.1rem}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label,.consent span{font-size:.82rem;color:var(--linen);display:block;margin-bottom:.45rem}
.field input,.field select,.field textarea{
  width:100%;background:var(--ink);border:1px solid rgba(245,241,232,.16);border-radius:12px;
  padding:.85rem 1rem;color:var(--cream);font-family:var(--sans);font-size:16px;transition:border-color .3s,box-shadow .3s
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--glow);box-shadow:0 0 0 3px rgba(232,161,75,.18)}
.field textarea{resize:vertical}
.consent{display:flex;gap:.7rem;align-items:flex-start;margin:1.2rem 0;cursor:pointer}
.consent input{margin-top:.25rem;accent-color:var(--glow);width:18px;height:18px;flex-shrink:0}
.consent span{margin:0;font-size:.82rem;color:var(--linen-dim);line-height:1.5}
.consent a{color:var(--glow-soft);text-decoration:underline}
.book__form-note{font-size:.8rem;color:var(--linen-dim);text-align:center;margin-top:.9rem}

/* ============================================================
   FAQ
   ============================================================ */
.faq__list{max-width:840px}
.faq details{border-bottom:1px solid rgba(245,241,232,.12);padding:.4rem 0}
.faq summary{cursor:pointer;list-style:none;padding:1.3rem 2.5rem 1.3rem 0;position:relative;font-family:var(--serif);font-size:clamp(1.1rem,1rem + .5vw,1.35rem);color:var(--cream);font-weight:500}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:.4rem;top:50%;transform:translateY(-50%);font-size:1.6rem;color:var(--glow);transition:transform .3s var(--ease);font-family:var(--sans);font-weight:300}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq details p{padding:0 2rem 1.4rem 0;color:var(--linen-dim);max-width:70ch}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);border-top:1px solid rgba(245,241,232,.07);padding-top:clamp(3.5rem,6vw,5rem)}
.footer__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:2.5rem}
.footer__brand img{height:64px;width:auto;margin-bottom:1rem;opacity:.95}
.footer__tag{font-family:var(--serif);font-style:italic;color:var(--glow-soft);font-size:1.1rem;margin-bottom:.6rem}
.footer__loc{font-size:.85rem;color:var(--linen-dim)}
.footer__col h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--cream);margin-bottom:1.1rem;font-weight:600;font-family:var(--sans)}
.footer__col a{display:block;font-size:.9rem;color:var(--linen-dim);margin-bottom:.6rem;transition:color .25s}
.footer__col a:hover{color:var(--glow-soft)}
.footer__privacy p{font-size:.85rem;color:var(--linen-dim);line-height:1.6}
.footer__bar{max-width:var(--maxw);margin:clamp(2.5rem,5vw,4rem) auto 0;padding:1.6rem var(--pad);border-top:1px solid rgba(245,241,232,.08);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer__bar p{font-size:.8rem;color:var(--linen-dim)}
.footer__credit a{color:var(--glow-soft)}

/* ============================================================
   FAB (mobile sticky)
   ============================================================ */
.fab{position:fixed;bottom:1.2rem;left:50%;transform:translateX(-50%) translateY(120%);z-index:90;
  background:linear-gradient(135deg,var(--glow),var(--glow-soft));color:#2a1c08;font-weight:600;font-size:.92rem;
  padding:.95rem 1.8rem;border-radius:100px;box-shadow:0 12px 34px -8px rgba(232,161,75,.6);
  transition:transform .45s var(--ease);display:none;white-space:nowrap}
.fab.is-visible{transform:translateX(-50%) translateY(0)}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(5,7,12,.95);display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;pointer-events:none;transition:opacity .35s var(--ease);backdrop-filter:blur(6px)}
.lightbox.is-open{opacity:1;pointer-events:auto}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.7)}
.lightbox__close{position:absolute;top:1.2rem;right:1.6rem;background:none;border:0;color:#fff;font-size:2.6rem;cursor:pointer;line-height:1;opacity:.8;transition:opacity .25s}
.lightbox__close:hover{opacity:1}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
/* staggered cascade inside grids */
.amen__grid .reveal:nth-child(2),.gallery__grid .reveal:nth-child(2){transition-delay:.07s}
.amen__grid .reveal:nth-child(3),.gallery__grid .reveal:nth-child(3){transition-delay:.14s}
.amen__grid .reveal:nth-child(4),.gallery__grid .reveal:nth-child(4){transition-delay:.21s}
.amen__grid .reveal:nth-child(5),.gallery__grid .reveal:nth-child(5){transition-delay:.10s}
.amen__grid .reveal:nth-child(6),.gallery__grid .reveal:nth-child(6){transition-delay:.17s}
.amen__grid .reveal:nth-child(7),.gallery__grid .reveal:nth-child(7){transition-delay:.24s}
.amen__grid .reveal:nth-child(8),.gallery__grid .reveal:nth-child(8){transition-delay:.12s}

/* ============================================================
   CINEMATIC LAYER
   ============================================================ */
/* Intro curtain (CSS-driven; self-dismisses even if JS fails) */
.intro{position:fixed;inset:0;z-index:9999;background:var(--night);display:flex;align-items:center;justify-content:center;pointer-events:none;animation:introOut 1.7s var(--ease) .25s forwards}
.intro__mark{color:var(--glow);font-size:2.6rem;animation:introMark 1.7s var(--ease) .25s forwards;text-shadow:0 0 30px rgba(232,161,75,.7)}
@keyframes introOut{0%,38%{opacity:1}100%{opacity:0;visibility:hidden}}
@keyframes introMark{0%{opacity:0;transform:scale(.6)}30%{opacity:1;transform:scale(1)}60%{opacity:1;transform:scale(1.05)}100%{opacity:0;transform:scale(1.4)}}

/* Ken Burns on hero */
.kenburns{animation:kenburns 28s ease-in-out infinite alternate;transform-origin:60% 45%}
@keyframes kenburns{from{transform:scale(1.03)}to{transform:scale(1.13)}}

/* Hero vignette */
.hero__vignette{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 42%, transparent 38%, rgba(5,7,12,.35) 72%, rgba(5,7,12,.72) 100%)}

/* Hero content cinematic entrance (auto-plays, fill:both = fail-safe visible) */
.hero__content > *{animation:heroIn 1.1s var(--ease) both}
.hero__eyebrow{animation-delay:.45s}
.hero__title{animation-delay:.6s}
.hero__sub{animation-delay:.85s}
.hero__actions{animation-delay:1.05s}
.hero__badges{animation-delay:1.2s}
@keyframes heroIn{from{opacity:0;transform:translateY(28px);filter:blur(7px)}to{opacity:1;transform:none;filter:blur(0)}}

/* Shooting stars (JS spawns .shoot children) */
.shooting{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.shoot{position:absolute;width:140px;height:1.5px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.9));border-radius:2px;opacity:0;transform:rotate(20deg);filter:drop-shadow(0 0 6px rgba(255,255,255,.7));animation:shoot 1.5s ease-out forwards}
@keyframes shoot{0%{opacity:0;transform:translate(0,0) rotate(20deg) scaleX(.2)}12%{opacity:1}100%{opacity:0;transform:translate(-340px,140px) rotate(20deg) scaleX(1)}}

/* Film grain */
/* Static film grain — no mix-blend-mode / no perpetual animation (avoids continuous full-page recompositing) */
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px}

/* Parallax targets */
[data-parallax]{will-change:transform}
.starsec__media img{height:118%;top:-9%;position:absolute;will-change:transform}


/* ============================================================
   EXPERIENCE LAYER v2 (differentiated)
   ============================================================ */

/* Cursor moonlight (enabled via JS on fine pointers only) */
.cursor-glow{position:fixed;top:0;left:0;width:540px;height:540px;border-radius:50%;z-index:55;pointer-events:none;
  transform:translate(-50%,-50%);left:-9999px;opacity:0;transition:opacity .6s ease;mix-blend-mode:screen;
  background:radial-gradient(circle, rgba(150,185,255,.10), rgba(232,161,75,.05) 42%, transparent 68%)}
body.has-cursor-glow .cursor-glow{opacity:1}

/* Hero depth */
.hero__glow{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(42% 52% at 50% 80%, rgba(232,161,75,.22), transparent 72%)}
.starfield--far{opacity:.5;filter:blur(.3px)}
.hero__media,.hero .starfield,.hero__glow{will-change:transform}

/* Hero masked title lines */
.hero__title{animation:none}
.hero__title .line{display:block;overflow:hidden;padding-bottom:.06em}
.hero__title .line>span{display:block;transform:translateY(118%);animation:lineRise 1.15s var(--ease) both}
.hero__title .line:nth-child(1)>span{animation-delay:.5s}
.hero__title .line:nth-child(2)>span{animation-delay:.66s}
@keyframes lineRise{from{transform:translateY(118%)}to{transform:translateY(0)}}

/* Section heading clip-wipe reveal (opacity handled by parent .reveal — fail-safe readable) */
.reveal .h2{clip-path:inset(0 14% 0 0);transition:clip-path 1.1s var(--ease) .06s}
.reveal.is-in .h2{clip-path:inset(0 0 0 0)}

/* ---------- THE NIGHT — cinematic scroll journey ---------- */
.journey{position:relative;height:560vh;background:var(--ink)}
.journey__stage{position:sticky;top:0;height:100vh;overflow:hidden}
.journey__layers{position:absolute;inset:0}
.journey__layer{position:absolute;inset:0;margin:0;opacity:0;transform:scale(1.07);transition:opacity 1.1s var(--ease),transform 1.6s var(--ease)}
.journey__layer.is-active{opacity:1;transform:scale(1)}
.journey__layer img{width:100%;height:100%;object-fit:cover}
.journey__veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(7,10,18,.55),rgba(7,10,18,.12) 38%,rgba(7,10,18,.6))}
.journey__content{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:center;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.journey__eyebrow{text-transform:uppercase;letter-spacing:.3em;font-size:.74rem;color:var(--glow-soft);margin-bottom:1.5rem;display:flex;align-items:center;gap:.6rem}
.journey__caps{position:relative;min-height:2.4em}
.journey__cap{position:absolute;left:0;top:0;margin:0;font-family:var(--serif);font-weight:400;color:var(--star);
  font-size:clamp(2.1rem,1.3rem + 4.6vw,5rem);line-height:1.02;letter-spacing:-.015em;
  opacity:0;transform:translateY(30px);transition:none;text-shadow:0 4px 40px rgba(0,0,0,.55)}
.journey__cap.is-active{opacity:1;transform:none}
.journey__rail{position:absolute;right:var(--pad);top:50%;transform:translateY(-50%);z-index:2;list-style:none;display:flex;flex-direction:column;gap:1.1rem;margin:0;padding:0}
.journey__rail li{display:flex;align-items:center;gap:.7rem;justify-content:flex-end;color:var(--linen-dim);font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;opacity:.45;transition:opacity .4s,color .4s}
.journey__rail li i{width:8px;height:8px;border-radius:50%;border:1px solid currentColor;transition:background .4s,transform .4s}
.journey__rail li.is-active{opacity:1;color:var(--glow-soft)}
.journey__rail li.is-active i{background:var(--glow-soft);transform:scale(1.35)}
.journey__progress{position:absolute;left:0;bottom:0;width:100%;height:2px;background:rgba(245,241,232,.12);z-index:2}
.journey__progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--glow),var(--glow-soft))}

/* ---------- Moon tonight ---------- */
.moon{display:flex;justify-content:center}
.moon__inner{display:grid;grid-template-columns:auto 1fr;gap:clamp(2rem,6vw,5rem);align-items:center;max-width:1000px}
.moon__viz{position:relative;display:grid;place-items:center}
.moon__viz svg{width:clamp(180px,26vw,260px);height:auto;position:relative;z-index:1;filter:drop-shadow(0 0 38px rgba(244,230,200,.25))}
.moon__halo{position:absolute;width:118%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(244,230,200,.18),transparent 60%);animation:halo 6s ease-in-out infinite alternate}
@keyframes halo{from{transform:scale(.92);opacity:.65}to{transform:scale(1.07);opacity:1}}
.moon__stats{list-style:none;display:flex;gap:2rem;flex-wrap:wrap;margin:1.6rem 0 1.4rem;padding:0}
.moon__stats strong{display:block;font-family:var(--serif);font-size:1.45rem;color:var(--glow-soft);line-height:1.05;font-weight:500}
.moon__stats span{font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;color:var(--linen-dim)}
.moon__foot{color:var(--linen-dim);font-size:.95rem;max-width:48ch}

/* ---------- Horizontal gallery ---------- */
.gallery__hint{font-size:.82rem;color:var(--linen-dim);margin-top:1rem;letter-spacing:.04em}
.gallery__hint kbd{display:inline-block;border:1px solid rgba(245,241,232,.25);border-radius:5px;padding:0 .35rem;font-family:var(--sans);font-size:.7rem;color:var(--linen)}
.gallery__rail{display:flex;gap:1.2rem;overflow-x:auto;scroll-snap-type:x mandatory;padding:.5rem var(--pad) 1.6rem;margin:0 calc(-1 * var(--pad));-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab}
.gallery__rail::-webkit-scrollbar{display:none}
.gallery__rail:focus-visible{outline:2px solid var(--glow);outline-offset:-4px}
.gallery__rail.is-dragging{cursor:grabbing;scroll-snap-type:none}
.gallery__card{flex:0 0 auto;width:min(80vw,440px);aspect-ratio:4/3;border:0;padding:0;border-radius:var(--r-lg);overflow:hidden;position:relative;scroll-snap-align:center;cursor:pointer;background:var(--night-2)}
.gallery__card img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);pointer-events:none}
.gallery__card:hover img{transform:scale(1.06)}
.gallery__cap{position:absolute;left:0;right:0;bottom:0;padding:1.7rem 1.3rem .95rem;font-size:.85rem;letter-spacing:.03em;color:var(--cream);text-align:left;
  background:linear-gradient(to top,rgba(7,10,18,.85),transparent);transform:translateY(8px);opacity:.88;transition:transform .4s var(--ease),opacity .4s}
.gallery__card:hover .gallery__cap{transform:none;opacity:1}
.gallery__bar{height:2px;background:rgba(245,241,232,.1);max-width:var(--maxw);margin:0 auto;border-radius:2px;overflow:hidden}
.gallery__bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--glow),var(--glow-soft))}

@media (max-width:780px){
  .journey{height:520vh}
  .journey__rail{right:1rem;gap:.9rem}
  .journey__rail li span{display:none}
  .moon__inner{grid-template-columns:1fr;text-align:center;justify-items:center}
  .moon__stats{justify-content:center}
  .gallery__card{width:82vw}
}

/* ---------- Reviews (real guest quotes) ---------- */
.review-card{display:flex;flex-direction:column}
.review-card__stars{color:var(--glow);letter-spacing:.16em;font-size:.95rem;margin-bottom:1rem}
.review-card p{flex:1}
.review-card__by{display:flex;align-items:center;gap:.85rem;margin-top:1.5rem}
.review-card__ava{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  font-family:var(--serif);font-size:1.1rem;color:#2a1c08;background:linear-gradient(135deg,var(--glow),var(--glow-soft))}
.review-card__by cite{font-style:normal;display:flex;flex-direction:column;color:var(--cream);font-size:.96rem;font-weight:600;letter-spacing:0;text-transform:none}
.review-card__by cite small{color:var(--linen-dim);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;margin-top:.2rem;font-weight:400}
.reviews__cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:2.6rem}

/* ---------- Instagram ---------- */
.insta{text-align:center}
.insta .section__head{margin-left:auto;margin-right:auto}
.insta__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.8rem}
.insta__cell{position:relative;aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:var(--night-2);display:block}
.insta__cell img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .4s}
.insta__cell:hover img{transform:scale(1.08);filter:brightness(.62)}
.insta__ic{position:absolute;inset:0;display:grid;place-items:center;color:#fff;opacity:0;transform:scale(.8);transition:opacity .35s,transform .35s}
.insta__cell:hover .insta__ic{opacity:1;transform:scale(1)}
.insta__cta{margin-top:2.2rem}
@media (max-width:900px){.insta__grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:480px){.insta__grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- Airbnb-identity reviews ---------- */
.eyebrow--airbnb{display:inline-flex;align-items:center;gap:.5rem;color:var(--airbnb)}
.belo{width:18px;height:18px;flex:0 0 auto}
.reviews__fav{display:flex;align-items:center;justify-content:center;gap:.7rem}
.laurel{width:40px;height:88px;color:var(--cream);opacity:.82}
.laurel--r{transform:scaleX(-1)}
.reviews__fav-num strong{font-family:var(--serif);font-weight:500;font-size:clamp(3rem,2rem + 4vw,4.6rem);color:var(--cream);line-height:1;letter-spacing:-.01em}
.reviews__fav-title{text-align:center;color:var(--cream);font-weight:600;font-size:1.05rem;margin-top:.5rem}
.reviews__fav-sub{text-align:center;color:var(--linen-dim);font-size:.86rem;margin:.4rem 0 2.8rem}
.reviews .review-card__stars{color:var(--airbnb);letter-spacing:.12em}
.reviews .review-card__ava{background:linear-gradient(135deg,var(--airbnb),#ff7e8a);color:#fff}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .amen__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .gallery__item--wide{grid-column:span 2}
  .gallery__item--tall{grid-row:span 1}
  .reviews__grid{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:780px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(80vw,340px);flex-direction:column;align-items:flex-start;justify-content:center;gap:1.8rem;background:rgba(10,14,26,.97);backdrop-filter:blur(20px);padding:2rem 2.5rem;transform:translateX(100%);transition:transform .45s var(--ease);box-shadow:-20px 0 60px rgba(0,0,0,.6)}
  .nav__links.is-open{transform:translateX(0)}
  .nav__links a{font-size:1.2rem}
  .nav__toggle{display:flex}
  .nav__toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__toggle.is-open span:nth-child(2){opacity:0}
  .nav__toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .split,.book__inner{grid-template-columns:1fr}
  .split--reverse .split__media{order:0}
  .split__media img{aspect-ratio:4/3}
  .amen__feature{grid-template-columns:1fr}
  .stays__grid{grid-template-columns:1fr}
  .reviews__badge{gap:1.5rem;padding:1.4rem 1.6rem}
  .reviews__omg{border-left:0;border-top:1px solid rgba(245,241,232,.14);padding-left:0;padding-top:1.2rem}
  .footer__inner{grid-template-columns:1fr}
  .hero__badges{gap:1rem}
  .badge:not(:last-child){border-right:0;padding-right:0}
  .fab{display:block;bottom:1.1rem}
  .hero__scroll{display:none}
}
@media (max-width:480px){
  .amen__grid{grid-template-columns:1fr}
  .field--row{grid-template-columns:1fr}
  .hero__actions{flex-direction:column;width:100%}
  .hero__actions .btn{width:100%}
}

/* ============================================================
   ACCESSIBILITY — reduced motion
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .starfield{animation:none}
  .proof__track{animation:none;width:auto;flex-wrap:wrap;justify-content:center}
}
