/* Beyt al Salaam — "Heritage Stone" · ivory + wood-brown + brass-gold
   Playfair Display + Source Sans 3 · Stone Town merchant house · mobile-first, weak-net safe */
:root{
  --ivory:#f6f0e6; --paper:#fbf7ef; --sand:#efe6d6; --line:rgba(58,43,28,.14); --line2:rgba(58,43,28,.26);
  --brass:#a9803f; --brass-lt:#c99b51; --accent:#b58a47; --accent2:#7c5a2c;
  --wood:#5e4326; --wood-dk:#3a2b1c; --ink:#2c2114; --soft:#6b5a44; --muted:#937e60;
  --wa:#1faa53; --wa-dark:#188a44; --radius:6px;
  --disp:"Playfair Display",Georgia,serif; --sans:"Source Sans 3",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--ivory);color:var(--ink);line-height:1.68;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--disp);font-weight:500;line-height:1.1;letter-spacing:.005em}
h2{font-size:clamp(1.95rem,4.8vw,3.3rem)}
.wrap{max-width:1160px;margin:0 auto;padding:0 1.4rem}
.kick{display:inline-block;font:600 .72rem var(--sans);letter-spacing:.3em;text-transform:uppercase;color:var(--brass);margin-bottom:1rem}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font:600 .68rem var(--sans);letter-spacing:.2em;text-transform:uppercase;color:#f3e8d4;border:1px solid rgba(255,255,255,.34);border-radius:999px;padding:.42rem .95rem;background:rgba(58,43,28,.28);backdrop-filter:blur(4px)}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brass-lt)}

/* ornamental marks */
.orn{display:flex;align-items:center;justify-content:center;gap:.8rem;color:var(--brass-lt);margin:1.3rem 0 .2rem}
.orn i{display:block;width:46px;height:1px;background:linear-gradient(90deg,transparent,var(--brass-lt))}
.orn i:last-child{background:linear-gradient(90deg,var(--brass-lt),transparent)}
.divider{display:flex;align-items:center;justify-content:center;gap:1rem;color:var(--brass);margin:0 auto 2.4rem;max-width:24rem}
.divider span{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--line2),transparent)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font:600 .9rem var(--sans);padding:.82rem 1.6rem;border-radius:999px;transition:transform .15s,background .2s,box-shadow .2s,color .2s;white-space:nowrap;cursor:pointer;border:0}
.btn:active{transform:scale(.97)}
.btn--brass{background:linear-gradient(135deg,var(--brass-lt),var(--brass));color:#fff;box-shadow:0 8px 22px rgba(124,90,44,.26)}
.btn--brass:hover{box-shadow:0 10px 30px rgba(124,90,44,.4)}
.btn--wa{background:var(--wa);color:#fff}.btn--wa:hover{background:var(--wa-dark)}
.btn--glass{background:rgba(255,255,255,.75);color:var(--wood);border:1px solid var(--line2)}.btn--glass:hover{background:#fff}
.btn--ghost{background:transparent;border:1.5px solid var(--line2);color:var(--wood)}.btn--ghost:hover{border-color:var(--brass);color:var(--brass)}
.btn--block{width:100%}.btn--lg{padding:.98rem 2rem;font-size:1rem}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,box-shadow .3s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(246,240,230,.9);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.nav__in{max-width:1160px;margin:0 auto;padding:1rem 1.4rem;display:flex;align-items:center;gap:1.4rem}
.brand{font:500 1.32rem var(--disp);color:#fff;line-height:1;text-shadow:0 1px 12px rgba(0,0,0,.35)}.nav.scrolled .brand{color:var(--wood);text-shadow:none}
.brand small{display:block;font:600 .56rem var(--sans);letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-top:.22rem;font-family:var(--sans)}
.nav.scrolled .brand small{color:var(--brass)}
.nav__links{display:flex;gap:1.7rem;margin-left:auto;font:500 .92rem var(--sans);color:#f2e8d6}
.nav.scrolled .nav__links{color:var(--soft)}.nav__links a{transition:color .2s;opacity:.94}.nav__links a:hover{color:var(--brass-lt)}
.nav__act{display:flex;align-items:center;gap:.8rem}
.lang{display:flex;border:1px solid rgba(255,255,255,.34);border-radius:999px;overflow:hidden;background:rgba(58,43,28,.22)}
.nav.scrolled .lang{border-color:var(--line2);background:#fff}
.lang__btn{border:0;background:transparent;font:600 .74rem var(--sans);padding:.4rem .58rem;cursor:pointer;color:#f2e8d6}
.nav.scrolled .lang__btn{color:var(--muted)}
.lang__btn.is-active{background:var(--brass);color:#fff}
.navtog{display:none;background:none;border:0;cursor:pointer;padding:.4rem}.navtog span{display:block;width:22px;height:2px;background:#fff;margin:4.5px 0;border-radius:2px}.nav.scrolled .navtog span{background:var(--ink)}

/* hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--wood-dk)}
.hero__bg{position:absolute;inset:-7% 0 0;z-index:0;will-change:transform}
.hero__bg img{width:100%;height:100%;object-fit:cover;filter:saturate(.96)}
.hero__tint{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(38,28,17,.72) 0%,rgba(38,28,17,.34) 46%,rgba(38,28,17,.08) 72%),linear-gradient(180deg,rgba(38,28,17,.36),rgba(38,28,17,0) 30%,rgba(38,28,17,.5) 100%)}
.hero__in{position:relative;z-index:4;width:100%;max-width:1160px;margin:0 auto;padding:7rem 1.4rem 5rem;display:grid;grid-template-columns:1fr 20rem;gap:2.8rem;align-items:center}
.hero__copy{text-align:center;max-width:36rem;justify-self:center}
.hero__title{font-size:clamp(2.5rem,6.6vw,4.7rem);color:#fff;letter-spacing:.01em;text-shadow:0 2px 26px rgba(0,0,0,.34)}
.hero__title em{font-style:italic;color:var(--brass-lt)}
.hero__sub{margin-top:.4rem;color:#f1e7d6;font-size:1.04rem;opacity:.96}
.hero__scroll{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);z-index:4;color:rgba(255,255,255,.85);font:600 .64rem var(--sans);letter-spacing:.26em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.4rem}
.hero__scroll::after{content:"";width:1px;height:26px;background:linear-gradient(#fff,transparent);animation:sd 1.9s ease-in-out infinite}
@keyframes sd{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* rate calc — compact panel */
.rcalc{background:rgba(251,247,239,.92);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:11px;padding:.85rem .95rem;box-shadow:0 26px 60px rgba(38,28,17,.34);max-height:80vh;overflow:auto;width:100%;max-width:20rem;justify-self:end}
.rcalc__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}
.rcalc__title{font:500 1.05rem var(--disp);color:var(--wood)}
.rcalc__ai{font:600 .5rem var(--sans);letter-spacing:.12em;text-transform:uppercase;color:var(--brass);border:1px solid var(--line2);border-radius:999px;padding:.2rem .5rem}
.rcalc label{display:block;font:600 .56rem var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--soft);margin-bottom:.4rem}
.rcalc label span{display:block;margin-bottom:.18rem}
.rcalc select,.rcalc input[type=number]{width:100%;padding:.42rem .55rem;border:1px solid var(--line2);border-radius:7px;font:500 .82rem var(--sans);color:var(--ink);background:#fff}
.rcalc select:focus,.rcalc input:focus{outline:2px solid var(--brass-lt);outline-offset:0;border-color:var(--brass)}
.rcalc__grid{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.rcalc__chk{display:flex!important;align-items:center;gap:.45rem;font:500 .74rem var(--sans)!important;letter-spacing:0!important;text-transform:none!important;color:var(--soft)!important;cursor:pointer;margin-bottom:.32rem}
.rcalc__chk input{width:auto;accent-color:var(--brass)}.rcalc__chk span{margin:0!important}
.rcalc__total{display:flex;align-items:baseline;justify-content:space-between;border-top:1px solid var(--line);margin:.35rem 0 .6rem;padding-top:.5rem}
.rcalc__total span{font:600 .6rem var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--soft)}
.rcalc__total strong{font:500 1.5rem var(--disp);color:var(--brass)}
.rcalc__note{font-size:.62rem;color:var(--muted);text-align:center;margin-top:.45rem;line-height:1.4}
.rcalc .btn{padding:.6rem 1.2rem;font-size:.82rem}

/* sections */
.sec{padding:clamp(3.5rem,8vw,6rem) 0;position:relative}
.sec--intro{padding-bottom:clamp(2.5rem,6vw,4rem)}
.sec__head{max-width:46rem;margin:0 auto 2.8rem}
.sec__head.center{text-align:center}
.sec__head p.lead{color:var(--soft);margin-top:.9rem;font-size:1.05rem}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line2);border-bottom:1px solid var(--line2)}
.stat{padding:1.6rem 1rem;text-align:center;border-left:1px solid var(--line)}.stat:first-child{border-left:0}
.stat strong{display:block;font:500 1.85rem var(--disp);color:var(--brass);line-height:1}
.stat span{font:500 .8rem var(--sans);color:var(--muted);margin-top:.45rem;display:block}

/* rooms */
.rcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.rcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.rcard__img{overflow:hidden}
.rcard__img img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform .6s ease}
.rcard:hover .rcard__img img{transform:scale(1.05)}
.rcard__b{padding:1.3rem 1.4rem 1.4rem}
.rcard__b h3{font-size:1.5rem;margin-bottom:.4rem;color:var(--wood)}.rcard__b p{color:var(--soft);font-size:.92rem;min-height:5.4em}
.rcard__f{display:flex;align-items:center;justify-content:space-between;margin-top:1.1rem;gap:1rem}
.rcard__price{font:500 1.4rem var(--disp);color:var(--brass);white-space:nowrap}.rcard__price small{font:500 .68rem var(--sans);color:var(--muted)}

/* feature split — dining */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--paper)}
.feat__media{position:relative;min-height:380px;overflow:hidden}
.feat__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feat__b{padding:clamp(1.9rem,4vw,3.2rem);display:flex;flex-direction:column;justify-content:center}
.feat__b h2{margin-bottom:1rem;color:var(--wood);font-size:clamp(1.7rem,3.4vw,2.5rem)}.feat__b p{color:var(--soft)}
.flist{list-style:none;margin:1.4rem 0 0;display:grid;gap:.6rem}.flist li{padding-left:1.7rem;position:relative;font-weight:500;color:var(--ink)}
.flist li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border:1px solid var(--brass);transform:rotate(45deg)}
.feat__meta{margin:1.3rem 0 1.6rem;font:500 .82rem var(--sans);color:var(--muted);letter-spacing:.01em}

/* bento — the house */
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.bento__c{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem 1.5rem;display:flex;flex-direction:column}
.bento__c--wide{grid-column:span 2}
.bento__c--wide:first-child{padding:0;overflow:hidden;flex-direction:column}
.bento__media{height:clamp(200px,22vw,260px);overflow:hidden}
.bento__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.bento__c--wide:first-child:hover .bento__media img{transform:scale(1.05)}
.bento__t{padding:1.4rem 1.6rem 1.6rem}
.bento__ic{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:10px;background:var(--sand);color:var(--brass);margin-bottom:1rem;border:1px solid var(--line)}
.bento__ic svg{width:24px;height:24px}
.bento__c h3{font-size:1.25rem;margin-bottom:.4rem;color:var(--wood)}
.bento__c p{color:var(--soft);font-size:.9rem}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:1rem}
.gal figure{border-radius:var(--radius);overflow:hidden;position:relative;background:var(--sand)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}.gal figure:hover img{transform:scale(1.06)}
.gal .tall{grid-row:span 2}.gal .wide{grid-column:span 2}

/* tours */
.tours{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.tour{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem 1.4rem}
.tour__ic{display:inline-flex;color:var(--brass);margin-bottom:.8rem}.tour__ic svg{width:30px;height:30px}
.tour h3{font-size:1.25rem;margin-bottom:.35rem;color:var(--wood)}.tour p{color:var(--soft);font-size:.88rem}

/* reviews */
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.rev{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem 1.8rem;display:flex;flex-direction:column}
.rev__stars{color:var(--brass-lt);letter-spacing:.14em;margin-bottom:.9rem}
.rev blockquote{font:italic 500 1.18rem/1.5 var(--disp);color:var(--ink)}
.rev figcaption{margin-top:1.2rem;font:600 .82rem var(--sans);color:var(--muted)}
.ratepill{display:inline-flex;align-items:center;gap:.6rem;background:var(--paper);border:1px solid var(--line2);border-radius:999px;padding:.5rem 1.1rem;margin-bottom:1.1rem}
.ratepill strong{color:var(--brass);font:500 1.1rem var(--disp)}.ratepill span{font:500 .82rem var(--sans);color:var(--soft)}
.revs__note{text-align:center;color:var(--muted);font-size:.82rem;margin-top:1.6rem}

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

/* faq */
.faqwrap{max-width:760px}
.faq{display:grid;gap:.7rem}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:1.1rem 1.3rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font:500 1.08rem var(--disp);color:var(--wood)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font:400 1.5rem var(--sans);color:var(--brass);line-height:1;flex:0 0 auto;transition:transform .25s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq summary:hover{color:var(--brass)}
.faq__a{padding:0 1.3rem 1.2rem;color:var(--soft);font-size:.94rem}

/* cta band */
.cta{position:relative;text-align:center;padding:clamp(3.5rem,8vw,5.5rem) 1.4rem;color:#fff;overflow:hidden}
.cta__bg{position:absolute;inset:0;z-index:0}.cta__bg img{width:100%;height:100%;object-fit:cover}
.cta__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(38,28,17,.88),rgba(124,90,44,.6))}
.cta__in{position:relative;z-index:1}.cta h2{color:#fff}.cta p{color:#f1e7d6;margin:.8rem 0 1.8rem;opacity:.95}

/* footer */
.footer{background:var(--wood-dk);color:#b9a98e;font-size:.92rem}
.footer__in{max-width:1160px;margin:0 auto;padding:3rem 1.4rem 2rem;display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2rem}
.footer__brand{font:500 1.32rem var(--disp);color:#fff;margin-bottom:.2rem}.footer__brand small{display:block;font:600 .56rem var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--brass-lt);margin-top:.25rem}
.footer h4{color:#fff;font:600 .76rem var(--sans);letter-spacing:.14em;text-transform:uppercase;margin-bottom:.7rem}
.footer a:hover{color:var(--brass-lt)}
.footer__legal{border-top:1px solid rgba(255,255,255,.14);max-width:1160px;margin:0 auto;padding:1.1rem 1.4rem 1.5rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.76rem;color:#8c7c63}.footer__demo{font-style:italic}

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

/* wow */
.prog{position:fixed;top:0;left:0;height:3px;width:0;z-index:70;background:linear-gradient(90deg,var(--brass-lt),var(--brass));transition:width .1s linear}
.rv{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}
.card{transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 46px rgba(38,28,17,.16);border-color:var(--line2)}
/* headline shimmer on accent word */
.hero__title em{background:linear-gradient(100deg,var(--brass-lt) 30%,#fff7e6 50%,var(--brass-lt) 70%);background-size:230% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 6s linear infinite}
@keyframes shimmer{to{background-position:-230% 0}}
.stats.in strong{animation:pop .6s ease}
@keyframes pop{0%{transform:scale(.7);opacity:0}60%{transform:scale(1.06)}100%{transform:scale(1);opacity:1}}

/* responsive */
@media(max-width:920px){
  .hero{align-items:flex-end;min-height:auto}
  .hero__in{grid-template-columns:1fr;gap:2rem;padding:6rem 1.4rem 3.5rem}
  .hero__copy{text-align:center}.hero__scroll{display:none}
  .rcalc{justify-self:center;max-width:23rem}
  .hero__bg{inset:0!important;transform:none!important}
  .feat,.loc{grid-template-columns:1fr;gap:0}.loc{gap:1.8rem}
  .rcards{grid-template-columns:1fr;gap:1.2rem}.rcard__b p{min-height:0}
  .tours{grid-template-columns:1fr 1fr}.revs{grid-template-columns:1fr}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:150px}.gal .wide{grid-column:span 2}.gal .tall{grid-row:span 1}
  .feat__media{min-height:260px}
  .bento{grid-template-columns:1fr 1fr}.bento__c--wide{grid-column:span 2}
  .stats{grid-template-columns:1fr 1fr}.stat:nth-child(3){border-left:0}.stat:nth-child(n+3){border-top:1px solid var(--line)}
}
@media(max-width:600px){
  .nav__links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:rgba(246,240,230,.98);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
  .nav__links.open{display:flex}.nav__links a{padding:.9rem 1.4rem;border-top:1px solid var(--line);color:var(--ink)}
  .navtog{display:block}.nav__act .btn--brass{display:none}
  .fab{display:flex}.tours{grid-template-columns:1fr}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:130px}
  .bento{grid-template-columns:1fr}.bento__c--wide{grid-column:auto}
  .footer__in{grid-template-columns:1fr}
  .rcalc{backdrop-filter:none;background:#fbf7ef}
}
@media(prefers-reduced-motion:reduce){
  .hero__bg{transform:none!important}.rv{opacity:1;transform:none;transition:none}
  .hero__scroll::after{animation:none}.hero__title em{animation:none;-webkit-text-fill-color:var(--brass-lt)}
  .stats.in strong{animation:none}.rcard__img img,.gal img,.bento__media img{transition:none}
}
.save-data .hero__bg{transform:none!important}
