/* ============================================================
   Vaanam One — Hotel & Stay · Ujjain
   Palette: Navy · Gold · Cream (peacock-teal accent)
   ============================================================ */

:root{
  --navy:#0B1F3A;
  --navy-2:#0E2647;
  --navy-deep:#081729;
  --gold:#C6A15B;
  --gold-soft:#D9BE7E;
  --gold-deep:#A9843F;
  --teal:#2E8B9E;
  --cream:#F7F2E8;
  --cream-2:#FBF8F1;
  --paper:#FFFEFB;
  --ink:#1C2434;
  --ink-soft:#4A5468;
  --line:rgba(11,31,58,.14);
  --line-on-dark:rgba(214,190,126,.24);

  --serif:"Fraunces",Georgia,serif;
  --sans:"Jost",system-ui,-apple-system,"Segoe UI",sans-serif;
  --deva:"Tiro Devanagari Hindi",serif;

  --wrap:1240px;
  --gutter:clamp(20px,5vw,72px);
  --radius:4px;
  --shadow:0 24px 60px -28px rgba(8,23,41,.45);
  --shadow-soft:0 18px 40px -30px rgba(8,23,41,.5);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  font-size:clamp(15px,1.05vw,17px);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;margin:0;letter-spacing:-.01em}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(72px,9vw,140px)}
.eyebrow{
  font-family:var(--sans);font-weight:500;font-size:.74rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--gold-deep);margin:0 0 18px;
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--gold);display:inline-block}
.display{font-size:clamp(2.1rem,5.2vw,4rem)}
.lede{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink-soft);line-height:1.75;max-width:60ch}
.deva{font-family:var(--deva);font-weight:400}
.center{text-align:center}
.center .lede{margin-inline:auto}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--gold);--fg:#1a1305;
  display:inline-flex;align-items:center;gap:.6em;
  padding:1em 1.9em;font-family:var(--sans);font-weight:500;
  font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  background:var(--bg);color:var(--fg);border:1px solid var(--bg);
  border-radius:2px;transition:transform .4s var(--ease),background .3s,color .3s,box-shadow .4s;
  position:relative;overflow:hidden;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -18px rgba(166,132,63,.85)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-deep);box-shadow:none}
.btn--ondark{--bg:transparent;--fg:var(--cream);border-color:var(--line-on-dark)}
.btn--ondark:hover{border-color:var(--gold);color:var(--gold-soft);box-shadow:none}
.btn svg{width:1.05em;height:1.05em;flex:none}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .45s var(--ease),padding .45s var(--ease),box-shadow .45s,border-color .45s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(11,31,58,.92);backdrop-filter:blur(14px);
  padding-block:12px;border-bottom-color:var(--line-on-dark);
  box-shadow:0 10px 40px -24px rgba(0,0,0,.6);
}
.brand{display:flex;align-items:center;gap:12px;color:var(--cream)}
.brand__mark{width:38px;height:38px;flex:none}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--serif);font-size:1.28rem;font-weight:600;letter-spacing:.02em}
.brand__sub{font-family:var(--sans);font-size:.56rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold-soft);margin-top:5px}
.nav__links{display:flex;align-items:center;gap:34px;list-style:none;margin:0;padding:0}
.nav__links a{
  color:var(--cream);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  font-weight:400;opacity:.86;position:relative;padding-block:4px;transition:opacity .3s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__cta{display:inline-flex;align-items:center;gap:.55em;color:var(--navy);background:var(--gold);
  padding:.7em 1.25em;border-radius:2px;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;transition:transform .35s var(--ease),box-shadow .35s}
.nav__cta:hover{transform:translateY(-2px);box-shadow:0 12px 22px -14px rgba(166,132,63,.9)}
.nav__cta svg{width:1em;height:1em}
.nav__toggle{display:none;background:none;border:0;width:44px;height:44px;color:var(--cream)}
.nav__toggle svg{width:26px;height:26px}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:70;background:var(--navy);display:flex;flex-direction:column;
  padding:24px var(--gutter);transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform .5s var(--ease),opacity .4s}
.mobile-menu.open{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-menu__top{display:flex;justify-content:space-between;align-items:center}
.mobile-menu__close{background:none;border:0;color:var(--cream);width:44px;height:44px}
.mobile-menu__close svg{width:26px;height:26px}
.mobile-menu ul{list-style:none;margin:auto 0;padding:0;display:flex;flex-direction:column;gap:6px}
.mobile-menu a{color:var(--cream);font-family:var(--serif);font-size:1.9rem;font-weight:500;padding:.25em 0;display:block}
.mobile-menu a .deva{color:var(--gold-soft);font-size:1rem;margin-left:.6em}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;color:var(--cream)}
.hero__slides{position:absolute;inset:0}
.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity 1.6s var(--ease)}
.hero__slide.active{opacity:1}
.hero__slide img{width:100%;height:100%;object-fit:cover;animation:kenburns 14s ease-out both}
.hero__slide.active img{animation-play-state:running}
@keyframes kenburns{from{transform:scale(1.08)}to{transform:scale(1.16)}}
.hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,23,41,.55) 0%,rgba(8,23,41,.15) 34%,rgba(8,23,41,.35) 62%,rgba(8,23,41,.86) 100%);z-index:1}
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--wrap);margin-inline:auto;padding:0 var(--gutter) clamp(64px,10vh,120px)}
.hero__kicker{font-size:.8rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-soft);margin:0 0 26px;
  display:flex;align-items:center;gap:16px}
.hero__kicker::before{content:"";width:46px;height:1px;background:var(--gold-soft)}
.hero h1{font-size:clamp(3rem,10vw,7.5rem);font-weight:400;letter-spacing:-.02em;line-height:.92;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero__deva{font-family:var(--deva);font-size:clamp(1.3rem,3vw,2rem);color:rgba(247,242,232,.72);margin:18px 0 0;font-weight:400}
.hero__tag{font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,2.2vw,1.7rem);color:var(--cream);margin:22px 0 0;opacity:.94}
.hero__actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:40px}
.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;
  align-items:center;gap:10px;color:rgba(247,242,232,.7);font-size:.64rem;letter-spacing:.3em;text-transform:uppercase}
.hero__scroll span{width:1px;height:44px;background:linear-gradient(var(--gold-soft),transparent);animation:scrolldrop 2.2s var(--ease) infinite}
@keyframes scrolldrop{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}}
.hero__dots{position:absolute;right:var(--gutter);bottom:clamp(64px,10vh,120px);z-index:2;display:flex;flex-direction:column;gap:12px}
.hero__dots button{width:9px;height:9px;border-radius:50%;border:1px solid var(--gold-soft);background:transparent;padding:0;transition:background .3s,transform .3s}
.hero__dots button.active{background:var(--gold-soft);transform:scale(1.25)}

/* trust strip */
.trust{background:var(--navy);color:var(--cream);border-top:1px solid var(--line-on-dark)}
.trust__row{display:flex;flex-wrap:wrap;gap:8px 40px;justify-content:center;padding-block:22px}
.trust__item{display:flex;align-items:center;gap:11px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(247,242,232,.82)}
.trust__item svg{width:20px;height:20px;color:var(--gold-soft);flex:none}

/* ============================================================
   ABOUT / INTRO
   ============================================================ */
.about{background:var(--cream-2);position:relative;overflow:hidden}
.about__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,90px);align-items:center}
.about__copy p{margin:0 0 1.15em;color:var(--ink-soft)}
.about__copy p.first::first-letter{font-family:var(--serif);float:left;font-size:3.6em;line-height:.72;padding:.06em .12em 0 0;color:var(--gold-deep)}
.about__sign{margin-top:26px;font-family:var(--serif);font-style:italic;font-size:1.15rem;color:var(--ink)}
.about__media{position:relative}
.about__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:4/5;object-fit:cover}
.about__badge{position:absolute;bottom:-26px;left:-26px;background:var(--navy);color:var(--cream);
  padding:22px 26px;border-radius:var(--radius);box-shadow:var(--shadow);max-width:200px}
.about__badge b{font-family:var(--serif);font-size:2.4rem;color:var(--gold-soft);display:block;line-height:1}
.about__badge span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,242,232,.8)}
.about__watermark{position:absolute;top:-40px;right:-30px;font-family:var(--deva);font-size:22vw;color:rgba(198,161,91,.06);
  pointer-events:none;line-height:1;z-index:0;user-select:none}

/* ============================================================
   ROOMS
   ============================================================ */
.rooms{background:var(--cream)}
.rooms__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:56px}
.rooms__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.room{background:var(--paper);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);
  display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s}
.room:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.room__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.room__media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.room:hover .room__media img{transform:scale(1.07)}
.room__tier{position:absolute;top:14px;left:14px;background:rgba(11,31,58,.82);backdrop-filter:blur(4px);
  color:var(--gold-soft);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;padding:.5em .9em;border-radius:2px}
.room__body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.room__name{font-size:1.65rem;display:flex;align-items:baseline;gap:.5em;flex-wrap:wrap}
.room__name .deva{font-size:.95rem;color:var(--gold-deep)}
.room__desc{color:var(--ink-soft);font-size:.96rem;margin:12px 0 18px}
.room__feats{list-style:none;margin:0 0 22px;padding:0;display:flex;flex-wrap:wrap;gap:8px 14px}
.room__feats li{display:flex;align-items:center;gap:7px;font-size:.8rem;color:var(--ink-soft)}
.room__feats svg{width:15px;height:15px;color:var(--gold-deep);flex:none}
.room__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding-top:20px;border-top:1px solid var(--line)}
.room__price small{display:block;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
.room__price b{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--navy)}
.room__price b span{font-size:.8rem;color:var(--ink-soft);font-family:var(--sans);font-weight:400}
.room__book{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);
  display:inline-flex;align-items:center;gap:.5em;font-weight:500;white-space:nowrap}
.room__book svg{width:1em;height:1em;transition:transform .35s var(--ease)}
.room:hover .room__book svg{transform:translateX(4px)}
.room__book--full{justify-content:center;width:100%;padding:.95em 1em;border:1px solid var(--line);
  border-radius:2px;color:var(--navy);transition:background .35s var(--ease),color .35s,border-color .35s}
.room__book--full svg{transition:transform .35s var(--ease)}
.room:hover .room__book--full{background:var(--gold);border-color:var(--gold);color:#1a1305}
.room:hover .room__book--full svg{transform:none}

/* ============================================================
   LOOK AROUND (property spaces)
   ============================================================ */
.look{background:var(--navy);color:var(--cream);position:relative;overflow:hidden}
.look .eyebrow{color:var(--gold-soft)}
.look .eyebrow::before,.look .eyebrow::after{background:var(--gold-soft)}
.look .lede{color:rgba(247,242,232,.74)}
.look__scroller{display:grid;grid-auto-flow:column;grid-auto-columns:min(78vw,420px);gap:22px;
  overflow-x:auto;scroll-snap-type:x mandatory;padding:48px 0 20px;margin-inline:calc(var(--gutter)*-1);
  padding-inline:var(--gutter);scrollbar-width:none}
.look__scroller::-webkit-scrollbar{display:none}
.look__card{scroll-snap-align:start;position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;
  box-shadow:var(--shadow)}
.look__card img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.look__card:hover img{transform:scale(1.08)}
.look__card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(8,23,41,.82))}
.look__cap{position:absolute;left:0;bottom:0;z-index:2;padding:26px}
.look__cap span{font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-soft)}
.look__cap h3{font-size:1.5rem;margin-top:8px}
.look__hint{display:flex;align-items:center;gap:10px;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(247,242,232,.6);margin-top:8px}
.look__hint svg{width:22px;height:22px;color:var(--gold-soft)}

/* ============================================================
   AMENITIES
   ============================================================ */
.amen{background:var(--cream-2)}
.amen__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-top:52px}
.amen__item{background:var(--cream-2);padding:38px 30px;display:flex;flex-direction:column;gap:16px;
  transition:background .4s,transform .4s var(--ease)}
.amen__item:hover{background:var(--paper);transform:translateY(-3px)}
.amen__ic{width:44px;height:44px;color:var(--gold-deep)}
.amen__ic svg{width:100%;height:100%;stroke-width:1.3}
.amen__item h3{font-size:1.2rem}
.amen__item p{margin:0;font-size:.88rem;color:var(--ink-soft)}

/* ============================================================
   EXPLORE UJJAIN (nearby places, animated distance)
   ============================================================ */
.explore{background:var(--navy-deep);color:var(--cream);position:relative;overflow:hidden}
.explore::before{content:"ॐ";position:absolute;top:-6vw;right:-2vw;font-size:34vw;color:rgba(198,161,91,.045);
  font-family:var(--deva);line-height:1;pointer-events:none;user-select:none}
.explore .eyebrow{color:var(--gold-soft)}
.explore .eyebrow::before,.explore .eyebrow::after{background:var(--gold-soft)}
.explore .lede{color:rgba(247,242,232,.76)}
.explore__filters{display:flex;flex-wrap:wrap;gap:10px;margin:38px 0 10px}
.chip{background:transparent;border:1px solid var(--line-on-dark);color:rgba(247,242,232,.8);
  padding:.6em 1.2em;border-radius:40px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  transition:all .35s var(--ease)}
.chip:hover{border-color:var(--gold-soft);color:var(--cream)}
.chip.active{background:var(--gold);border-color:var(--gold);color:#1a1305}
.places{margin-top:26px;display:flex;flex-direction:column}
.place{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(18px,3vw,48px);align-items:center;
  padding:30px 0;border-top:1px solid var(--line-on-dark);transition:opacity .5s,transform .5s var(--ease)}
.place:last-child{border-bottom:1px solid var(--line-on-dark)}
.place.hide{display:none}
.place__no{font-family:var(--serif);font-size:1.5rem;color:var(--gold-soft);opacity:.6;font-style:italic}
.place__main{min-width:0}
.place__cat{font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--teal)}
.place__name{font-size:clamp(1.35rem,2.4vw,1.9rem);margin:6px 0 4px}
.place__name .deva{font-size:.7em;color:var(--gold-soft);margin-left:.4em}
.place__desc{color:rgba(247,242,232,.66);font-size:.92rem;margin:0;max-width:56ch}
.place__dist{text-align:right;min-width:150px}
.place__km{font-family:var(--serif);font-size:2rem;color:var(--cream);line-height:1;font-weight:600}
.place__km span{font-size:.9rem;color:var(--gold-soft);font-family:var(--sans);font-weight:400}
.place__time{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(247,242,232,.6);margin-top:6px}
.place__meter{grid-column:1/-1;height:2px;background:var(--line-on-dark);margin-top:22px;position:relative;border-radius:2px;overflow:hidden}
.place__meter i{position:absolute;inset:0 100% 0 0;background:linear-gradient(90deg,var(--teal),var(--gold-soft));
  transition:right 1.3s var(--ease)}
.explore__note{margin-top:34px;font-size:.84rem;color:rgba(247,242,232,.5);display:flex;gap:10px;align-items:flex-start}
.explore__note svg{width:18px;height:18px;color:var(--gold-soft);flex:none;margin-top:3px}

/* ============================================================
   GETTING HERE (map)
   ============================================================ */
.getting{background:var(--cream)}
.getting__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);margin-top:52px;background:var(--navy)}
.getting__info{padding:clamp(32px,4vw,54px);color:var(--cream);display:flex;flex-direction:column}
.getting__info h3{font-size:1.9rem;margin-bottom:8px}
.getting__addr{color:rgba(247,242,232,.78);margin:0 0 26px;font-size:1rem;line-height:1.75}
.getting__list{list-style:none;padding:0;margin:0 0 30px;display:flex;flex-direction:column;gap:16px}
.getting__list li{display:flex;gap:14px;align-items:flex-start;font-size:.92rem;color:rgba(247,242,232,.82)}
.getting__list svg{width:20px;height:20px;color:var(--gold-soft);flex:none;margin-top:2px}
.getting__list a:hover{color:var(--gold-soft)}
.getting__map{min-height:420px;position:relative}
.getting__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.2) contrast(1.05)}
.getting__actions{margin-top:auto;display:flex;flex-wrap:wrap;gap:12px}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{background:var(--cream-2)}
.reviews__head{text-align:center;margin-bottom:16px}
.reviews__stars{display:flex;justify-content:center;gap:6px;color:var(--gold);margin:14px 0 6px}
.reviews__stars svg{width:22px;height:22px}
.reviews__sub{color:var(--ink-soft);font-size:.9rem;letter-spacing:.06em}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.review{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;
  display:flex;flex-direction:column;position:relative;transition:transform .5s var(--ease),box-shadow .5s}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft)}
.review__quote{font-family:var(--serif);font-size:4rem;line-height:.7;color:var(--gold);opacity:.35;margin-bottom:6px}
.review__stars{display:flex;gap:3px;color:var(--gold);margin-bottom:14px}
.review__stars svg{width:16px;height:16px}
.review__text{color:var(--ink);font-size:1rem;line-height:1.7;margin:0 0 22px;flex:1}
.review__by{display:flex;align-items:center;gap:14px;border-top:1px solid var(--line);padding-top:18px}
.review__av{width:44px;height:44px;border-radius:50%;background:var(--navy);color:var(--gold-soft);
  display:grid;place-items:center;font-family:var(--serif);font-size:1.1rem;flex:none}
.review__by b{font-family:var(--sans);font-weight:500;font-size:.95rem;display:block}
.review__by span{font-size:.78rem;color:var(--ink-soft)}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{background:var(--navy);color:var(--cream)}
.gallery .eyebrow{color:var(--gold-soft)}
.gallery .eyebrow::before,.gallery .eyebrow::after{background:var(--gold-soft)}
.gallery .lede{color:rgba(247,242,232,.74)}
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:52px}
.gallery__item{overflow:hidden;border-radius:var(--radius);position:relative;cursor:pointer;background:var(--navy-2)}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .5s}
.gallery__item:hover img{transform:scale(1.09)}
.gallery__item::after{content:"";position:absolute;inset:0;background:rgba(11,31,58,.0);transition:background .4s}
.gallery__item:hover::after{background:rgba(11,31,58,.28)}
.gallery__item .zoom{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);z-index:2;
  color:var(--cream);opacity:0;transition:opacity .4s,transform .4s var(--ease)}
.gallery__item:hover .zoom{opacity:1;transform:translate(-50%,-50%) scale(1)}
.gallery__item .zoom svg{width:34px;height:34px}
.g-wide{grid-column:span 2}.g-tall{grid-row:span 2}
@media (min-width:900px){.g-big{grid-column:span 2;grid-row:span 2}}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(6,18,32,.96);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:90vw;max-height:82vh;border-radius:var(--radius);box-shadow:0 40px 100px -30px #000;
  transform:scale(.94);transition:transform .5s var(--ease)}
.lightbox.open img{transform:scale(1)}
.lightbox__btn{position:absolute;background:rgba(247,242,232,.08);border:1px solid var(--line-on-dark);color:var(--cream);
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;transition:background .3s,transform .3s}
.lightbox__btn:hover{background:var(--gold);color:var(--navy)}
.lightbox__btn svg{width:24px;height:24px}
.lightbox__close{top:24px;right:24px}
.lightbox__prev{left:3vw;top:50%;transform:translateY(-50%)}
.lightbox__next{right:3vw;top:50%;transform:translateY(-50%)}
.lightbox__count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:rgba(247,242,232,.7);
  font-size:.8rem;letter-spacing:.2em}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy-deep);color:var(--cream);padding-top:clamp(64px,8vw,110px)}
.footer__cta{text-align:center;max-width:720px;margin:0 auto clamp(56px,7vw,90px)}
.footer__cta h2{font-size:clamp(2rem,4.5vw,3.4rem);font-weight:400}
.footer__cta h2 em{font-style:italic;color:var(--gold-soft)}
.footer__cta p{color:rgba(247,242,232,.7);margin:18px 0 30px}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;
  padding-block:clamp(46px,6vw,72px);border-top:1px solid var(--line-on-dark)}
.footer__brand .brand{color:var(--cream);margin-bottom:20px}
.footer__brand p{color:rgba(247,242,232,.66);font-size:.92rem;max-width:34ch}
.footer__tag{font-family:var(--serif);font-style:italic;color:var(--gold-soft);margin-top:16px}
.footer__col h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-soft);margin:0 0 20px;font-weight:500}
.footer__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.footer__col a,.footer__col li{color:rgba(247,242,232,.78);font-size:.92rem;transition:color .3s}
.footer__col a:hover{color:var(--gold-soft)}
.footer__col .ic{display:inline-flex;gap:11px;align-items:flex-start}
.footer__col .ic svg{width:17px;height:17px;color:var(--gold-soft);flex:none;margin-top:3px}
.socials{display:flex;gap:12px;margin-top:8px}
.socials a{width:44px;height:44px;border:1px solid var(--line-on-dark);border-radius:50%;display:grid;place-items:center;
  color:var(--cream);transition:all .35s var(--ease)}
.socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--navy);transform:translateY(-3px)}
.socials svg{width:19px;height:19px}
.footer__bar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-block:26px;
  border-top:1px solid var(--line-on-dark);font-size:.78rem;color:rgba(247,242,232,.5)}
.footer__bar a:hover{color:var(--gold-soft)}

/* floating mobile call */
.fab{position:fixed;right:18px;bottom:18px;z-index:55;background:var(--gold);color:var(--navy);
  width:58px;height:58px;border-radius:50%;display:none;place-items:center;box-shadow:0 14px 30px -10px rgba(166,132,63,.9);
  animation:fabpulse 2.6s ease-in-out infinite}
.fab svg{width:24px;height:24px}
@keyframes fabpulse{0%,100%{box-shadow:0 14px 30px -10px rgba(166,132,63,.9)}50%{box-shadow:0 14px 40px -6px rgba(198,161,91,1)}}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__slide img{animation:none}
  .hero__scroll span,.fab{animation:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .amen__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:900px){
  .nav__links,.nav__cta{display:none}
  .nav__toggle{display:grid;place-items:center}
  .about__grid{grid-template-columns:1fr;gap:48px}
  .about__media{max-width:440px;margin-inline:auto}
  .rooms__grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}
  .getting__grid{grid-template-columns:1fr}
  .getting__map{min-height:340px;order:2}
  .reviews__grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}
  .footer__grid{grid-template-columns:1fr 1fr;gap:36px}
  .fab{display:grid}
  .place{grid-template-columns:1fr auto;gap:14px 20px}
  .place__no{display:none}
  .hero__dots{display:none}
}
@media (max-width:560px){
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .g-big{grid-column:span 2;grid-row:span 1}
  .footer__grid{grid-template-columns:1fr}
  .trust__row{gap:8px 22px}
  .place__desc{display:none}
  .about__badge{left:0}
}
