/* ============================================================
   Pande Homestay — Website UI kit layout
   Section + page-chrome classes. Built on the design-system tokens
   (styles.css). Component primitives come from the bundle.
   ============================================================ */

/* skip link */
.skip{position:absolute;left:-999px;top:8px;z-index:10000;background:var(--earth);color:var(--chalk);padding:.6rem 1rem;border-radius:6px}
.skip:focus{left:12px}

/* top strip */
.topstrip{background:var(--earth);color:var(--chalk-deep);font-size:.72rem;letter-spacing:.08em}
.topstrip .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 0;flex-wrap:wrap}
.topstrip a:hover{color:#fff}
.langs{display:flex;gap:.85rem}
.langs button{background:none;border:0;color:inherit;font:inherit;cursor:pointer;letter-spacing:.08em;opacity:.6;transition:opacity .2s}
.langs button[aria-current="true"],.langs button:hover{opacity:1;color:#fff}

/* header */
header.site{position:sticky;top:0;z-index:200;transition:background .4s var(--ease),box-shadow .4s,padding .4s;padding:.55rem 0;background:rgba(243,235,221,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line-soft),0 12px 30px -24px rgba(46,33,23,.5)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.4rem}
.brand{display:flex;align-items:center;gap:.7rem;line-height:1}
.brand img{height:42px;width:auto}
.brand .txt{display:flex;flex-direction:column;gap:.15rem}
.brand .mark{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--earth)}
.brand .sub{font-size:.56rem;letter-spacing:.32em;text-transform:uppercase;font-weight:600;color:var(--sienna)}
nav.main{display:flex;align-items:center;gap:2rem}
nav.main a{font-size:.82rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--earth);position:relative;padding:.2rem 0;cursor:pointer}
nav.main a::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;background:var(--coral);transition:width .3s var(--ease)}
nav.main a:hover::after,nav.main a[aria-current="page"]::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:1rem}

/* hero */
.hero{position:relative;min-height:86vh;min-height:86dvh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;isolation:isolate;padding-bottom:clamp(1.5rem,4vw,3rem)}

/* 3D layered courtyard diorama */
.hero--3d{perspective:1300px;perspective-origin:50% 42%}
.hero__scene{position:absolute;inset:0;z-index:-3;transform-style:preserve-3d;will-change:transform;transition:transform .5s var(--ease)}
.hero--3d .hero__bg{position:absolute;inset:-10%;z-index:0;transform:translateY(var(--sy,0))}
.hero--3d .hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 60%;transform:scale(1.12)}
.hero__sun{position:absolute;top:8%;right:14%;width:min(34vw,420px);aspect-ratio:1;border-radius:50%;z-index:1;pointer-events:none;background:radial-gradient(circle, rgba(255,206,150,.5), rgba(242,112,78,.16) 42%, transparent 68%);filter:blur(2px);mix-blend-mode:screen}
.hero__frond{position:absolute;z-index:2;pointer-events:none;opacity:.9}
.hero__frond--l{left:-4%;bottom:-6%;width:min(46vw,560px);transform-origin:bottom left;filter:blur(1.5px);opacity:.82}
.hero__frond--r{right:-6%;top:-8%;width:min(36vw,440px);transform-origin:top right;filter:blur(.5px);opacity:.55}
.hero__veil{position:absolute;inset:0;z-index:-2;background:radial-gradient(120% 80% at 80% 8%, rgba(255,221,176,.3), transparent 55%),linear-gradient(180deg, rgba(28,21,16,.42) 0%, rgba(28,21,16,.05) 32%, rgba(28,21,16,.18) 62%, rgba(28,21,16,.82) 100%)}
/* readability scrim — sits above the 3D diorama, below the text. Keeps the
   subtitle/eyebrow/CTAs legible over bright sky / sun-flare areas of the photo. */
.hero__veil--front{z-index:-1;background:linear-gradient(180deg, rgba(28,21,16,.34) 0%, rgba(28,21,16,.26) 42%, rgba(28,21,16,.56) 66%, rgba(28,21,16,.86) 100%)}
.hero__bg{position:absolute;inset:0;z-index:-3}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 60%}
.hero__inner{position:relative;z-index:2;color:#fff;padding-top:5rem;transform-style:preserve-3d;will-change:transform;transition:transform .4s var(--ease)}
.hero__eyebrow{color:#ffd9c4!important;text-shadow:0 1px 14px rgba(28,21,16,.7),0 0 3px rgba(28,21,16,.55)}
.hero__eyebrow span{background:#ffd9c4!important}
.hero h1{font-size:var(--fs-hero);color:#fff;margin:.6rem 0 1rem;font-weight:500;text-shadow:0 4px 40px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:#ffc7ad;font-weight:500}
.hero__sub{max-width:46ch;font-size:clamp(1rem,1.45vw,1.18rem);color:#f4e8da;font-weight:300;margin-bottom:2rem;text-shadow:0 2px 16px rgba(0,0,0,.4)}
.hero__cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:clamp(1.5rem,4vw,2.4rem)}

/* page hero (inner pages) */
.page-hero{position:relative;padding:clamp(6rem,12vw,9rem) 0 clamp(3rem,6vw,5rem);overflow:hidden;isolation:isolate;color:#fff}
.page-hero__bg{position:absolute;inset:0;z-index:-2}
.page-hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 55%}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(28,21,16,.55),rgba(28,21,16,.35) 50%,rgba(28,21,16,.7))}
.page-hero h1{font-size:var(--fs-page);color:#fff}
.page-hero p{max-width:52ch;color:#f4e8da;font-weight:300;margin-top:1rem}
.crumbs{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#ffd9c4;margin-bottom:1rem;display:flex;gap:.5rem;align-items:center}

/* marquee */
.marquee{background:var(--earth);color:var(--chalk-deep);overflow:hidden;border-block:1px solid var(--line-on-dark)}
.marquee__track{display:flex;gap:2.5rem;white-space:nowrap;padding:.95rem 0;width:max-content;animation:scrollx 34s linear infinite;font-family:var(--font-display);font-style:italic;font-size:1.35rem}
.marquee__track span{display:inline-flex;gap:2.5rem;align-items:center}
.marquee__track span::after{content:"✦";color:var(--coral);font-style:normal;font-size:.7rem}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* section base */
section.block{padding:var(--section-y) 0;position:relative}
.center{margin-inline:auto;text-align:center;align-items:center}

/* rooms bento — 3D tilt */
.rooms{display:grid;grid-template-columns:repeat(6,1fr);gap:1.1rem;margin-top:3rem;perspective:1400px}
.rooms .pande-room{transform-style:preserve-3d;will-change:transform;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.rooms .pande-room:hover{box-shadow:0 36px 70px -30px rgba(28,21,16,.7)}
.rooms .pande-room::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;border-radius:inherit;background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,221,176,.5), transparent 46%);opacity:var(--glare,0);transition:opacity .3s;mix-blend-mode:screen}
.rooms .pande-room img{transition:transform .9s var(--ease)}
.rooms .pande-room:hover img{transform:scale(1.07)}

/* amenities */
.amenities{background:var(--chalk-deep)}
.amenities__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.6rem}
.amen-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem}

/* belong */
.belong{background:linear-gradient(180deg,var(--chalk) 0%,#efe0cb 100%)}
.belong__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.belong__img{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow);margin:0}
.belong__img img{width:100%;aspect-ratio:4/4.6;object-fit:cover}
.belong__img figcaption{position:absolute;left:1rem;bottom:1rem;background:var(--coral);color:#fff;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:.45rem .8rem;border-radius:var(--r-pill)}
.belong p.body{color:var(--earth-soft);font-size:1.05rem;margin:1.4rem 0}
.pull{font-family:var(--font-display);font-style:italic;font-size:var(--fs-quote);line-height:1.18;color:var(--earth);margin:1.8rem 0;border-left:3px solid var(--coral);padding-left:1.4rem}
.trust{display:flex;gap:1.6rem;flex-wrap:wrap;margin-top:2rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.trust div{display:flex;flex-direction:column}
.trust b{font-family:var(--font-display);font-size:2rem;font-weight:600;line-height:1}
.trust small{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--earth-soft);margin-top:.3rem}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem;margin-top:3rem}
.gallery a{overflow:hidden;border-radius:var(--r-md);box-shadow:var(--shadow-sm);cursor:pointer}
.gallery a img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gallery a:hover img{transform:scale(1.08)}
.gallery a.tall{grid-row:span 2}

/* reviews */
/* asymmetric testimonials — one featured tall card + two stacked (avoids the generic 3-equal-column row) */
.reviews__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:1.2rem;margin-top:3rem;align-items:stretch}
.reviews__grid>:first-child{grid-row:span 2;display:flex;flex-direction:column;justify-content:center}

/* explore */
.explore__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;margin-top:3rem}
.xcards{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.xcard{background:var(--chalk-deep);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:1.6rem 1.5rem;transition:transform .3s var(--ease),background .3s}
.xcard:hover{transform:translateY(-5px);background:#fff}
.xcard .ic{font-size:1.6rem}
.xcard h3{font-size:1.5rem;margin:.7rem 0 .4rem}
.xcard p{font-size:.88rem;color:var(--earth-soft)}
.map{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);min-height:380px;border:1px solid var(--line);background:var(--chalk-deep)}
.map iframe{width:100%;height:100%;min-height:380px;border:0;filter:sepia(.18) saturate(1.05)}
.map__link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-size:.84rem;font-weight:500;color:var(--sienna);border-bottom:1.5px solid var(--coral);padding-bottom:2px;cursor:pointer}

/* book / compare */
.book{background:var(--earth);color:var(--chalk);position:relative;overflow:hidden}
.book::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 90% 0%,rgba(242,112,78,.22),transparent 55%);z-index:0}
.book .wrap{position:relative;z-index:1}
.book .section-head h2{color:#fff}
.book .section-head p{color:var(--chalk-deep)}
.compare{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:2.5rem 0}
.compare__col{border-radius:var(--r-lg);padding:1.6rem;border:1px solid var(--line-on-dark)}
.compare__col h3{font-size:1.4rem;margin-bottom:1rem}
.compare__col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.compare__col li{font-size:.9rem;display:flex;gap:.6rem;color:var(--chalk-deep)}
.compare__col li::before{content:"✓";color:var(--coral);font-weight:700}
.compare--ota{opacity:.7}
.compare--ota li::before{content:"–";color:var(--brick)}
.compare--direct{background:rgba(242,112,78,.08);border-color:rgba(242,112,78,.4)}
.perks{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:3rem 0}
.book__cta{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;background:rgba(243,235,221,.05);border:1px solid var(--line-on-dark);border-radius:20px;padding:clamp(1.6rem,3vw,2.6rem)}
.book__price b{font-family:var(--font-display);font-size:2.8rem;font-weight:600;color:#fff;display:block;line-height:1}
.book__price small{color:var(--chalk-deep);font-size:.82rem}
.book__note{font-size:.72rem;color:var(--brick);margin-top:.8rem;letter-spacing:.04em}

/* footer */
footer.site{background:var(--night);color:var(--chalk-deep);padding:clamp(3.5rem,7vw,6rem) 0 2rem}
.foot__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.2rem}
.foot .mark{font-family:var(--font-display);font-size:2rem;color:var(--chalk);font-weight:600}
.foot p{font-size:.88rem;margin-top:1rem;max-width:32ch;color:#bba88f}
.foot h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brick);margin-bottom:1rem}
.foot a{display:block;font-size:.9rem;padding:.25rem 0;color:var(--chalk-deep);transition:color .2s;cursor:pointer}
.foot a:hover{color:var(--coral)}
.foot__bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line-on-dark);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.74rem;color:#937e64}
.proto-flag{background:rgba(242,112,78,.14);color:#ffb59c;border:1px solid rgba(242,112,78,.3);border-radius:8px;padding:.3rem .7rem;font-size:.7rem}

/* whatsapp float */
.wa{position:fixed;right:18px;bottom:18px;z-index:300;width:58px;height:58px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 12px 28px -8px rgba(0,0,0,.45);transition:transform .25s var(--ease);cursor:pointer}
.wa:hover{transform:scale(1.08)}
.wa svg{width:30px;height:30px;fill:#fff}

/* room detail rows (rooms screen) */
.roomrow{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;padding:clamp(2rem,5vw,4rem) 0;border-bottom:1px solid var(--line)}
.roomrow:nth-child(even) .roomrow__img{order:2}
.roomrow__img{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow);margin:0}
.roomrow__img img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .9s var(--ease)}
.roomrow__img:hover img{transform:scale(1.05)}
.roomrow h3{font-size:var(--fs-h3)}
.roomrow .feat{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 1.4rem}
.roomrow p{color:var(--earth-soft)}

/* responsive */
@media (max-width:920px){.foot__grid{grid-template-columns:1fr 1fr}}
@media (max-width:860px){
  nav.main{display:none}
  .rooms{grid-template-columns:1fr 1fr}
  .rooms .pande-room{grid-column:span 1!important;min-height:260px!important}
  .amenities__grid{grid-template-columns:1fr 1fr}
  .belong__grid,.explore__grid,.contact__grid,.compare{grid-template-columns:1fr}
  .reviews__grid{grid-template-columns:1fr}
  .reviews__grid>:first-child{grid-row:auto}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:170px}
  .perks{grid-template-columns:1fr 1fr}
  .roomrow{grid-template-columns:1fr}
  .roomrow:nth-child(even) .roomrow__img{order:0}
}
