/* ============================================================
   Elliebum Boutique Hotel — styles.css
   Palette: cream · dusty rose (brand) · champagne gold · espresso
   ============================================================ */
:root{
  --cream:#F7F2E9;
  --cream-2:#EFE7D8;
  --rose:#B0807B;        /* brand colour from logo */
  --rose-dk:#946863;
  --gold:#B8924A;
  --gold-lt:#D4AF6A;
  --espresso:#3A2E22;
  --espresso-2:#2A2017;
  --ink:#4A3F33;
  --line:rgba(58,46,34,.14);
  --bistro-pink:#C5409D;
  --bistro-cyan:#3EC8D5;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter','Noto Sans Thai',system-ui,sans-serif;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
/* Thai language → use Noto Sans Thai everywhere (headings + body) */
html[lang="th"]{--serif:'Noto Sans Thai','Inter',sans-serif;--sans:'Noto Sans Thai','Inter',sans-serif}
html[lang="th"] .h-serif,html[lang="th"] .room__name,html[lang="th"] .bistro__lead,
html[lang="th"] .review blockquote,html[lang="th"] .faq__item summary{font-weight:600}
html[lang="th"] .review blockquote{font-style:normal}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:78px}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-weight:400;line-height:1.15;color:var(--espresso)}
.h-serif{font-family:var(--serif);font-weight:500;letter-spacing:.01em}

.container{max-width:var(--maxw);margin:0 auto;padding:0 28px;width:100%}
.container--narrow{max-width:820px}

/* ---------- Section base ---------- */
.section{padding:clamp(64px,9vw,120px) 0}
.section--cream{background:var(--cream-2)}
.section--dark{background:var(--espresso);color:#E9DFD0}
.section__head{text-align:center;max-width:760px;margin:0 auto clamp(40px,5vw,64px)}
.section__head h2{font-size:clamp(2rem,4.4vw,3.2rem)}
.section__intro{margin-top:18px;font-size:1.05rem;color:var(--ink)}
.section--dark .section__intro{color:#CDBFAC}

.kicker{
  display:inline-block;font-family:var(--sans);font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;font-size:.72rem;
  color:var(--rose);margin-bottom:16px;
}
.kicker--light{color:var(--gold-lt)}
.kicker::after{content:"";display:block;width:46px;height:1px;background:var(--gold);margin:12px auto 0}
.section__head .kicker::after{margin:12px auto 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-weight:500;font-size:.82rem;letter-spacing:.16em;
  text-transform:uppercase;padding:15px 32px;border-radius:2px;
  cursor:pointer;border:1px solid transparent;transition:.4s var(--ease);
  position:relative;overflow:hidden;white-space:nowrap;
}
.btn--lg{padding:18px 46px;font-size:.86rem}
.btn--gold{background:linear-gradient(120deg,var(--gold),var(--gold-lt));color:#fff;box-shadow:0 8px 24px rgba(184,146,74,.28)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(184,146,74,.4)}
.btn--gold::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-20deg)}
.btn--gold:hover::after{animation:shimmer 1s var(--ease)}
@keyframes shimmer{to{left:130%}}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn--outline{background:transparent;color:var(--espresso);border-color:var(--gold)}
.btn--outline:hover{background:var(--gold);color:#fff}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============ NAVBAR ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:.45s var(--ease)}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:16px 28px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.nav__logo{flex-shrink:0;justify-self:start}
.nav__logo-img{height:54px;width:auto;transition:.4s}
.nav__logo-img--color{display:none}
.nav__links{display:flex;gap:30px;justify-content:center}
.nav__links a{font-size:.84rem;letter-spacing:.08em;color:#fff;position:relative;padding:4px 0;font-weight:400;text-shadow:0 1px 8px rgba(0,0,0,.35)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold-lt);transition:.35s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:14px;justify-self:end}

/* nav scrolled state */
.nav.scrolled{background:var(--cream);box-shadow:0 4px 24px rgba(58,46,34,.1)}
.nav.scrolled .nav__logo-img--white{display:none}
.nav.scrolled .nav__logo-img--color{display:block}
.nav.scrolled .nav__logo-img{height:46px}
.nav.scrolled .nav__links a{color:var(--ink);text-shadow:none}
.nav.scrolled .lang__btn{color:var(--ink);border-color:var(--line)}

/* Language switcher */
.lang{position:relative}
.lang__btn{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.5);color:#fff;border-radius:2px;padding:8px 12px;
  font-family:var(--sans);font-size:.78rem;letter-spacing:.1em;cursor:pointer;
  backdrop-filter:blur(6px);transition:.3s}
.lang__btn:hover{background:rgba(255,255,255,.22)}
.lang__menu{position:absolute;top:calc(100% + 10px);right:0;background:var(--cream);
  border:1px solid var(--line);border-radius:4px;box-shadow:0 16px 40px rgba(58,46,34,.2);
  list-style:none;min-width:170px;padding:6px;opacity:0;visibility:hidden;
  transform:translateY(-8px);transition:.3s var(--ease);z-index:10}
.lang.open .lang__menu{opacity:1;visibility:visible;transform:none}
.lang__menu li{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:3px;
  cursor:pointer;font-size:.9rem;color:var(--ink);transition:.2s}
.lang__menu li:hover{background:var(--cream-2)}
.lang__menu li.active{color:var(--rose);font-weight:500}
.lang__menu li .flag{font-size:1.1rem}

.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__toggle span{width:26px;height:2px;background:#fff;transition:.3s;display:block}
.nav.scrolled .nav__toggle span{background:var(--espresso)}
/* mobile-only menu extras — hidden on desktop */
.nav__close{display:none}
.nav__book-m{display:none}

/* ============ HERO ============ */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:kenburns 18s ease-out infinite alternate}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.12)}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(36,27,19,.62),rgba(36,27,19,.5) 45%,rgba(28,20,13,.74)),radial-gradient(ellipse at center,rgba(28,20,13,.32),transparent 68%)}
.hero__content{position:relative;z-index:2;color:#fff;padding:0 24px;max-width:880px}
.hero__logo{height:120px;width:auto;margin:0 auto 28px;filter:drop-shadow(0 4px 20px rgba(0,0,0,.4))}
.hero__tagline{font-family:var(--serif);font-size:clamp(2rem,5.2vw,3.7rem);font-weight:500;line-height:1.16;letter-spacing:.01em;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.hero__sub{margin-top:18px;font-size:clamp(.95rem,1.8vw,1.15rem);font-weight:300;letter-spacing:.04em;color:#F0E7D8;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.hero__cta{margin-top:38px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero .reveal{transition-delay:.1s}
.hero .hero__sub.reveal{transition-delay:.25s}
.hero .hero__cta.reveal{transition-delay:.4s}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;width:26px;height:42px;border:1px solid rgba(255,255,255,.6);border-radius:14px}
.hero__scroll span{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:3px;height:8px;background:#fff;border-radius:2px;animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;top:8px}40%{opacity:1}80%{opacity:0;top:22px}100%{opacity:0}}

/* ============ ABOUT ============ */
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.about__text h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:22px}
.about__text p{margin-bottom:18px}
.about__badge{display:inline-block;margin-top:10px;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose);border-top:1px solid var(--gold);padding-top:14px}
.about__img{position:relative}
.about__img img{border-radius:3px;box-shadow:0 30px 60px rgba(58,46,34,.22);aspect-ratio:4/5;object-fit:cover}
.about__img::after{content:"";position:absolute;inset:18px -18px -18px 18px;border:1px solid var(--gold);border-radius:3px;z-index:-1}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:clamp(56px,7vw,90px);text-align:center}
.stat{padding:22px 10px;border-left:1px solid var(--line)}
.stat:first-child{border-left:none}
.stat__num{display:block;font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.4rem);color:var(--rose);font-weight:600;line-height:1}
.stat__label{display:block;margin-top:10px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}

/* ============ WHY ============ */
.why__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.why__card{background:var(--cream);border:1px solid var(--line);border-radius:4px;padding:38px 30px;transition:.45s var(--ease)}
.why__card:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(58,46,34,.14);border-color:var(--gold)}
.why__icon{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border:1px solid var(--gold);border-radius:50%;color:var(--rose);font-size:1.3rem;margin-bottom:20px}
.why__card h3{font-family:var(--serif);font-size:1.55rem;margin-bottom:10px}
.why__card p{font-size:.96rem}

/* Why — room photo backdrop (dark, swap /assets/img/why-bg.jpg to change) */
#why{position:relative;color:#E9DFD0;background:radial-gradient(ellipse at 50% 38%,rgba(42,32,23,.74),rgba(42,32,23,.9) 70%,rgba(26,20,14,.95)),url('/assets/img/why-bg.jpg') center/cover fixed}
#why .kicker{color:var(--gold-lt)}
#why .section__head h2{color:#F3EADB}
#why .why__card{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
#why .why__card:hover{background:rgba(255,255,255,.1);border-color:var(--gold);box-shadow:0 24px 50px rgba(0,0,0,.35)}
#why .why__card h3{color:#F3EADB}
#why .why__card p{color:#CFC2B1}
#why .why__icon{color:var(--gold-lt);border-color:var(--gold-lt)}
@media (hover:none){#why,.bistro{background-attachment:scroll}}

/* ============ ROOMS ============ */
.rooms__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.room{background:var(--cream);border:1px solid var(--line);border-radius:4px;overflow:hidden;display:flex;flex-direction:column;transition:.45s var(--ease)}
.room:hover{transform:translateY(-6px);box-shadow:0 28px 56px rgba(58,46,34,.16)}
.room__media{position:relative;aspect-ratio:4/3;overflow:hidden;cursor:pointer}
.room__media img{width:100%;height:100%;object-fit:cover;transition:1.1s var(--ease)}
.room:hover .room__media img{transform:scale(1.07)}
.room__count{position:absolute;bottom:12px;right:12px;background:rgba(42,32,23,.72);color:#fff;font-size:.72rem;letter-spacing:.05em;padding:5px 11px;border-radius:2px;backdrop-filter:blur(4px);display:flex;align-items:center;gap:5px}
.room__body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.room__name{font-family:var(--serif);font-size:1.7rem;margin-bottom:10px}
.room__desc{font-size:.94rem;flex:1;margin-bottom:22px}
.room__actions{display:flex;gap:12px;flex-wrap:wrap}
.room__view{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rose);border-bottom:1px solid var(--rose);padding-bottom:3px;cursor:pointer;transition:.3s;align-self:center}
.room__view:hover{color:var(--gold);border-color:var(--gold)}
.room .btn{flex:1;min-width:140px}

.rooms__amenities{margin-top:54px;text-align:center;border-top:1px solid var(--line);padding-top:46px}
.rooms__amenities h3{font-size:1.7rem;margin-bottom:22px}
.amen-list{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:14px 30px}
.amen-list li{display:inline-flex;align-items:center;gap:9px;font-size:.92rem;letter-spacing:.02em}
.amen-list .ic{font-size:1.18rem;line-height:1}

/* ============ BISTRO ============ */
.bistro{background:linear-gradient(150deg,rgba(40,18,34,.93),rgba(42,32,23,.9) 52%,rgba(18,42,48,.9)),url('/assets/img/bistro/7.jpg') center/cover fixed;color:#EBE0D0;overflow:hidden}
.bistro .container{position:relative;z-index:2}
.bistro__head{text-align:center;margin-bottom:32px}
.kicker--bistro{color:var(--bistro-cyan)}
.kicker--bistro::after{background:var(--bistro-pink)}
.bistro__logo{height:120px;width:auto;margin:6px auto 14px;filter:drop-shadow(0 6px 24px rgba(197,64,157,.3))}
.bistro__hours{font-size:.84rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bistro-cyan)}
.bistro__body{max-width:820px;margin:0 auto;text-align:center}
.bistro__lead{font-family:var(--serif);font-size:1.5rem;line-height:1.5;color:#fff;margin-bottom:20px}
.bistro__body p{margin-bottom:16px;color:#CFC2B1;font-size:1rem}
.bistro__links{margin-top:24px;display:flex;gap:18px;justify-content:center;align-items:center;flex-wrap:wrap;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
.bistro__links span{color:var(--bistro-cyan)}
.bistro__links a{color:#EBE0D0;border-bottom:1px solid var(--bistro-pink);padding-bottom:2px;transition:.3s}
.bistro__links a:hover{color:var(--bistro-pink)}
.bistro__slider{margin-top:46px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.bistro__track{display:flex;gap:16px;width:max-content;animation:bistroScroll 50s linear infinite}
.bistro__slider:hover .bistro__track{animation-play-state:paused}
.bistro__track img{height:200px;width:auto;border-radius:4px;object-fit:cover;box-shadow:0 12px 30px rgba(0,0,0,.35)}
@keyframes bistroScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ TRUST ============ */
.trust{padding:clamp(56px,7vw,90px) 0;background:var(--cream)}
.trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.trust__badge{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;
  background:var(--cream-2);border:1px solid var(--line);border-radius:6px;padding:32px 18px;transition:.4s var(--ease)}
.trust__badge:hover{transform:translateY(-5px);border-color:var(--gold);box-shadow:0 20px 44px rgba(58,46,34,.14)}
.trust__score{font-family:var(--serif);font-size:2.6rem;color:var(--gold);font-weight:600;line-height:1}
.trust__name{font-size:1rem;letter-spacing:.04em;color:var(--espresso);font-weight:500}
.trust__meta{font-size:.76rem;color:var(--ink);letter-spacing:.03em}

/* ============ AMENITIES ============ */
.amen-grid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.amen-grid li{display:flex;align-items:center;gap:14px;background:var(--cream);border:1px solid var(--line);border-radius:4px;padding:20px 22px;font-size:.94rem;transition:.4s var(--ease)}
.amen-grid li:hover{border-color:var(--gold);transform:translateY(-3px)}
.amen-grid__ic{font-size:1.5rem;line-height:1}

/* ============ LOCATION ============ */
.location__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(36px,5vw,68px);align-items:center}
.location__text h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin-bottom:20px}
.location__addr{font-size:1.05rem;margin-bottom:24px}
.location__nearby-t{font-family:var(--serif);font-size:1.5rem;margin:34px 0 16px}
.nearby{list-style:none;display:grid;gap:0}
.nearby li{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:13px 0;border-bottom:1px solid var(--line)}
.nearby li span{font-weight:400}
.nearby li em{font-style:normal;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--rose);white-space:nowrap}
.location__map{border-radius:4px;overflow:hidden;box-shadow:0 24px 50px rgba(58,46,34,.18);border:1px solid var(--line)}
.location__map iframe{width:100%;height:440px;border:0;display:block;filter:saturate(.92)}

/* ============ REVIEWS ============ */
.reviews__viewport{overflow:hidden;max-width:860px;margin:0 auto}
.reviews__track{display:flex;transition:transform .7s var(--ease)}
.review{min-width:100%;text-align:center;padding:0 18px}
.review blockquote{font-family:var(--serif);font-size:clamp(1.4rem,2.8vw,2rem);line-height:1.5;font-style:italic;color:#F3EADB}
.review blockquote::before{content:"“";color:var(--gold-lt);font-size:1.4em;line-height:0;vertical-align:-.35em;margin-right:.06em}
.review figcaption{margin-top:24px;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-lt)}
.reviews__dots{display:flex;gap:10px;justify-content:center;margin-top:40px}
.reviews__dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.28);cursor:pointer;transition:.3s;padding:0}
.reviews__dots button.active{background:var(--gold-lt);transform:scale(1.3)}

/* ============ GALLERY ============ */
.gallery{padding:0}
.gallery__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.gallery__grid figure{margin:0;overflow:hidden;cursor:pointer;aspect-ratio:1;background:var(--cream-2)}
.gallery__grid img{width:100%;height:100%;object-fit:cover;transition:1s var(--ease)}
.gallery__grid figure:hover img{transform:scale(1.1)}
.gallery__grid figure:nth-child(1),.gallery__grid figure:nth-child(8){grid-column:span 2;grid-row:span 2;aspect-ratio:auto}

/* ============ BOOK ============ */
.book{text-align:center}
.book__direct{display:flex;flex-direction:column;align-items:center;gap:14px}
.book__best{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rose)}
.book__or{margin:38px 0 20px;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);position:relative}
.book__otas{display:flex;flex-wrap:nowrap;justify-content:safe center;gap:12px;max-width:100%;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin}
.book__otas::-webkit-scrollbar{height:6px}
.book__otas::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.book__otas .ota{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:120px;height:90px;padding:12px 8px;border:1px solid var(--line);border-radius:6px;background:var(--cream);transition:.35s var(--ease)}
.book__otas .ota img{height:24px;width:auto;max-width:96px;object-fit:contain}
.book__otas .ota span{font-size:.72rem;letter-spacing:.02em;color:var(--ink);white-space:nowrap}
.book__otas .ota:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:0 16px 34px rgba(58,46,34,.12)}

/* ============ FAQ ============ */
.faq__item{border-bottom:1px solid var(--line);padding:6px 0}
.faq__item summary{font-family:var(--serif);font-size:1.3rem;color:var(--espresso);padding:18px 40px 18px 0;cursor:pointer;position:relative;list-style:none}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--gold);transition:.3s}
.faq__item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq__item p{padding:0 40px 22px 0;color:var(--ink)}

/* ============ FOOTER ============ */
.footer{background:var(--espresso);color:#CFC2B1;padding:72px 0 0}
.footer__grid{display:grid;grid-template-columns:1.6fr 1.2fr 1fr 1fr;gap:40px}
.footer__logo{height:74px;width:auto;margin-bottom:18px}
.footer__brand p{font-size:.94rem;max-width:300px}
.footer__col h4{color:#F3EADB;font-family:var(--serif);font-size:1.25rem;margin-bottom:16px;font-weight:500}
.footer__sub{margin-top:22px}
.footer__col p,.footer__col a{display:block;font-size:.9rem;margin-bottom:9px;color:#CFC2B1;transition:.3s}
.footer__col a:hover{color:var(--gold-lt)}
.footer__bottom{margin-top:56px;border-top:1px solid rgba(255,255,255,.1);padding:22px 0;text-align:center}
.footer__bottom p{font-size:.8rem;letter-spacing:.06em;color:#9C8E7C}

/* ============ FAB ============ */
.fab{position:fixed;bottom:22px;right:22px;z-index:90;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.fab__btn{display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(58,46,34,.28);transition:.35s var(--ease)}
.fab__btn--call{width:54px;height:54px;border-radius:50%;background:var(--rose);color:#fff}
.fab__btn--call:hover{background:var(--rose-dk);transform:scale(1.08)}
.fab__btn--book{padding:14px 26px;border-radius:30px;background:linear-gradient(120deg,var(--gold),var(--gold-lt));color:#fff;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500}
.fab__btn--book:hover{transform:translateY(-2px)}

/* ============ LIGHTBOX ============ */
.lb{position:fixed;inset:0;z-index:200;background:rgba(26,20,14,.94);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.4s}
.lb.open{opacity:1;visibility:visible}
.lb__img{max-width:90vw;max-height:70vh;border-radius:3px;box-shadow:0 30px 70px rgba(0,0,0,.6);user-select:none;margin-bottom:-30px}
.lb__btn{position:absolute;top:42%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.35);color:#fff;width:54px;height:54px;border-radius:50%;font-size:1.6rem;cursor:pointer;transition:.3s;display:flex;align-items:center;justify-content:center}
.lb__btn:hover{background:rgba(255,255,255,.25)}
.lb__prev{left:24px}.lb__next{right:24px}
.lb__close{position:absolute;top:24px;right:24px;background:none;border:none;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1;width:46px;height:46px;z-index:2}
.lb__count{position:absolute;bottom:108px;left:50%;transform:translateX(-50%);color:#EBE0D0;font-size:.82rem;letter-spacing:.18em}
.lb__thumbs{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:8px;max-width:92vw;overflow-x:auto;padding:8px 10px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}
.lb__thumbs::-webkit-scrollbar{height:6px}
.lb__thumbs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:3px}
.lb__thumb{height:56px;width:76px;flex:0 0 auto;object-fit:cover;border-radius:3px;opacity:.45;cursor:pointer;border:2px solid transparent;transition:.25s var(--ease)}
.lb__thumb:hover{opacity:.8}
.lb__thumb.active{opacity:1;border-color:var(--gold-lt)}

/* ============ RESPONSIVE ============ */
@media (max-width:980px){
  .why__grid,.rooms__grid{grid-template-columns:repeat(2,1fr)}
  .amen-grid{grid-template-columns:repeat(3,1fr)}
  .trust__grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .gallery__grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:820px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);height:100vh;
    background:var(--cream);flex-direction:column;justify-content:flex-start;gap:18px;
    padding:72px 30px 36px;overflow-y:auto;transform:translateX(100%);transition:.45s var(--ease);box-shadow:-20px 0 50px rgba(0,0,0,.2)}
  .nav__links.open{transform:none}
  .nav__links>a{color:var(--ink)!important;text-shadow:none;font-size:1.12rem}
  .nav__inner{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px}
  .nav__actions{gap:10px}
  .nav__toggle{display:flex}
  .nav__book{display:none}
  .nav__close{display:block;position:absolute;top:14px;right:16px;background:none;border:none;font-size:2.3rem;line-height:1;color:var(--espresso);cursor:pointer;width:44px;height:44px;padding:0}
  .nav__book-m{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:auto;border-top:1px solid var(--line);padding-top:22px}
  .nav__book-m .btn{width:100%;color:#fff!important}
  .nav__book-m-or{text-align:center;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink)}
  .nav__book-m-otas{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .nav__book-m-otas a{color:var(--ink)!important;text-align:center;padding:11px 8px;border:1px solid var(--line);border-radius:5px;font-size:.82rem;background:#fff}
  .nav__book-m-otas a:hover,.nav__book-m-otas a:active{border-color:var(--gold)}
  .about__grid,.location__grid{grid-template-columns:1fr}
  .about__img{order:-1;max-width:440px;margin:0 auto}
  .about__img::after{display:none}
  .stats{grid-template-columns:repeat(2,1fr);gap:8px}
  .stat:nth-child(3){border-left:none}
  /* Booking logos: show all at once (wrap), no horizontal scroll on mobile */
  .book__otas{flex-wrap:wrap;overflow-x:visible;justify-content:center;gap:10px}
  .book__otas .ota{width:calc(33.333% - 8px)}
}
@media (max-width:560px){
  .container{padding:0 20px}
  .why__grid,.rooms__grid,.amen-grid,.trust__grid,.footer__grid{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__grid figure:nth-child(1),.gallery__grid figure:nth-child(8){grid-column:span 2;grid-row:auto;aspect-ratio:16/10}
  .hero__logo{height:90px}
  .bistro__track img{height:150px}
  .fab__btn--book{padding:12px 20px;font-size:.74rem}
  .lb__prev{left:10px}.lb__next{right:10px}
  .lb__btn{width:46px;height:46px}
  .lb__img{max-height:62vh}
  .lb__thumb{height:46px;width:62px}
  .lb__count{bottom:96px}
}
