*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--y:#F5C800;--yd:#D4A900;--b:#0A0A0A;--bs:#111;--w:#fff;--wo:#F5F5F0;--g:#888;--gl:#ccc}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--b);color:var(--w);overflow-x:hidden}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 48px;display:flex;align-items:center;justify-content:space-between;transition:all .4s}
nav.scrolled{background:rgba(10,10,10,.97);padding:14px 48px;border-bottom:1px solid rgba(245,200,0,.15);backdrop-filter:blur(12px)}
.logo{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.15em;color:var(--y);text-decoration:none}
.logo span{color:var(--w)}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{text-decoration:none;color:var(--w);font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;font-weight:500;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--y);transition:width .3s}
.nav-links a:hover{color:var(--y)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--y)!important;color:var(--b)!important;padding:10px 22px;font-weight:700!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--yd)!important;color:var(--b)!important}

/* Mobile right group - desktop me hidden */
.mob-right{display:none;align-items:center;gap:10px}
.mob-reserve-btn{background:var(--y);color:var(--b);padding:9px 16px;font-family:'DM Sans',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;border:none;white-space:nowrap;display:inline-block;transition:background .3s}
.mob-reserve-btn:hover{background:var(--yd)}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{width:26px;height:2px;background:var(--w);display:block;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mob-menu{position:fixed;top:0;right:-100%;width:260px;height:100vh;background:var(--bs);border-left:1px solid rgba(245,200,0,.2);z-index:99;padding:90px 36px;transition:right .4s cubic-bezier(.77,0,.175,1)}
.mob-menu.open{right:0}
.mob-menu ul{list-style:none;display:flex;flex-direction:column;gap:28px}
.mob-menu a{text-decoration:none;color:var(--w);font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.1em;transition:color .3s}
.mob-menu a:hover{color:var(--y)}

/* HERO */
.hero{height:100vh;min-height:650px;position:relative;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?w=1800&q=80') center/cover no-repeat;filter:brightness(.28);animation:hzoom 14s ease-in-out infinite alternate}
@keyframes hzoom{from{transform:scale(1.04)}to{transform:scale(1.1)}}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(245,200,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(245,200,0,.03) 1px,transparent 1px);background-size:60px 60px}
.hero-content{position:relative;z-index:2;padding:0 60px;max-width:860px}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(3.2rem,8.5vw,7.5rem);font-weight:900;line-height:.92;margin-bottom:28px;animation:fadeUp .8s .15s ease both}
.hero h1 em{color:var(--y);font-style:italic}
.hero p{font-size:clamp(.95rem,1.4vw,1.15rem);color:var(--gl);max-width:460px;line-height:1.75;margin-bottom:44px;animation:fadeUp .8s .3s ease both;font-weight:300}
.hero-btns{display:flex;gap:18px;flex-wrap:wrap;animation:fadeUp .8s .45s ease both}
.btn-y{background:var(--y);color:var(--b);padding:15px 38px;font-weight:700;font-size:.82rem;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;display:inline-block;transition:all .3s;border:none;cursor:pointer}
.btn-y:hover{background:var(--yd);transform:translateY(-2px)}
.btn-o{border:1px solid rgba(255,255,255,.3);color:var(--w);padding:15px 38px;font-size:.82rem;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;display:inline-block;transition:all .3s}
.btn-o:hover{border-color:var(--y);color:var(--y)}
.hero-scroll{position:absolute;bottom:36px;left:60px;display:flex;align-items:center;gap:14px;color:var(--g);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;animation:fadeUp 1s .6s ease both}
.sline{width:55px;height:1px;background:var(--y);position:relative;overflow:hidden}
.sline::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--w);animation:sl 1.6s 1s infinite}
@keyframes sl{to{left:100%}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* MARQUEE */
.marquee{background:var(--y);padding:16px 0;overflow:hidden}
.mtrack{display:flex;gap:50px;white-space:nowrap;animation:mq 22s linear infinite}
.mtrack span{font-family:'Bebas Neue',sans-serif;font-size:.95rem;letter-spacing:.2em;color:var(--b);text-transform:uppercase;flex-shrink:0}
.mdot{font-size:.4rem!important;vertical-align:middle;margin:0 8px}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ABOUT */
.about{padding:clamp(60px,10vw,120px) 60px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;background:var(--b)}
.about-imgs{position:relative;height:580px}
.aimg1{position:absolute;top:0;left:0;width:72%;height:78%;object-fit:cover;border:4px solid var(--y);display:block}
.aimg2{position:absolute;bottom:0;right:0;width:58%;height:53%;object-fit:cover;border:4px solid rgba(255,255,255,.1);display:block}
.abadge{position:absolute;top:50%;left:58%;transform:translate(-50%,-50%);background:var(--y);width:110px;height:110px;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2}
.abadge strong{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--b);line-height:1}
.abadge span{font-size:.6rem;font-weight:700;color:var(--b);letter-spacing:.08em;text-transform:uppercase;text-align:center}
.slabel{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.slabel::before{content:'';width:36px;height:2px;background:var(--y)}
.slabel span{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--y);font-weight:600}
.about h2{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,3.8vw,3.8rem);font-weight:900;line-height:1.05;margin-bottom:24px}
.about h2 em{color:var(--y);font-style:italic}
.about p{color:var(--gl);line-height:1.8;margin-bottom:18px;font-weight:300;font-size:.95rem}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.stat{border-top:2px solid var(--y);padding-top:14px}
.snum{font-family:'Bebas Neue',sans-serif;font-size:2.3rem;color:var(--y);line-height:1}
.slbl{font-size:.72rem;color:var(--g);letter-spacing:.1em;text-transform:uppercase;margin-top:3px}

/* MENU */
.menu-sec{padding:clamp(60px,10vw,120px) 60px;background:var(--bs)}
.sec-hdr{text-align:center;margin-bottom:50px}
.sec-hdr .slabel{justify-content:center}
.sec-hdr h2{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,4.5vw,4rem);font-weight:900;line-height:1.05}
.sec-hdr h2 em{color:var(--y);font-style:italic}

/* ── MENU TABS ── */
.mtabs{
  display:flex;
  justify-content:center;
  margin-bottom:44px;
  border:1px solid rgba(255,255,255,.1);
  width:fit-content;
  margin-inline:auto;
  /* mobile scroll ke liye */
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;          /* Firefox */
  max-width:100%;
}
.mtabs::-webkit-scrollbar{display:none}  /* Chrome/Safari */

.mtab{
  padding:13px 30px;
  background:transparent;
  border:none;
  color:var(--g);
  font-family:'DM Sans',sans-serif;
  font-size:.78rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .3s;
  font-weight:500;
  white-space:nowrap;   /* tab text wrap na ho */
  flex-shrink:0;        /* tab squeeze na ho */
}
.mtab.active{background:var(--y);color:var(--b);font-weight:700}
.mtab:not(.active):hover{color:var(--w)}

.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.mcard{background:var(--b);overflow:hidden}
.mcard-img{width:100%;height:260px;object-fit:cover;transition:transform .6s;display:block}
.mcard:hover .mcard-img{transform:scale(1.06)}
.mcard-body{padding:26px}
.mcard-tag{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--y);font-weight:700;margin-bottom:8px}
.mcard h3{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;margin-bottom:9px;line-height:1.2}
.mcard p{font-size:.83rem;color:var(--g);line-height:1.6;margin-bottom:18px;font-weight:300}
.mcard-foot{display:flex;align-items:center;justify-content:space-between}
.mprice{font-family:'Bebas Neue',sans-serif;font-size:1.7rem;color:var(--y)}
.morder{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--g);border-bottom:1px solid var(--g);padding-bottom:2px;cursor:pointer;transition:color .3s,border-color .3s}
.mcard:hover .morder{color:var(--y);border-color:var(--y)}

/* EXPERIENCE */
.exp{min-height:75vh;background:url('https://images.unsplash.com/photo-1559339352-11d035aa65de?w=1800&q=80') center/cover fixed;position:relative;display:flex;align-items:center;justify-content:center;padding:clamp(60px,10vw,120px) 60px}
.exp::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,10,10,.92) 0%,rgba(10,10,10,.72) 100%)}
.exp-inner{position:relative;z-index:1;max-width:780px;text-align:center}
.exp-inner h2{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,4.5vw,4.5rem);font-weight:900;line-height:1;margin-bottom:20px}
.exp-inner h2 em{color:var(--y);font-style:italic}
.exp-inner > p{color:var(--gl);font-size:1.05rem;line-height:1.75;margin-bottom:36px;font-weight:300}
.feat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:50px;text-align:left}
.feat{border-left:2px solid var(--y);padding-left:20px}
.feat h4{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;margin-bottom:8px}
.feat p{font-size:.82rem;color:var(--g);line-height:1.6;font-weight:300}

/* GALLERY */
.gallery{padding:clamp(60px,10vw,120px) 60px;background:var(--b)}
.ggrid{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(2,260px);gap:4px;margin-top:44px}
.gi{overflow:hidden;position:relative}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform .6s,filter .6s;filter:brightness(.82);display:block}
.gi:hover img{transform:scale(1.07);filter:brightness(1)}
.gi:nth-child(1){grid-column:1/6;grid-row:1/2}
.gi:nth-child(2){grid-column:6/9;grid-row:1/2}
.gi:nth-child(3){grid-column:9/13;grid-row:1/3}
.gi:nth-child(4){grid-column:1/4;grid-row:2/3}
.gi:nth-child(5){grid-column:4/9;grid-row:2/3}
.gov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 60%);opacity:0;transition:opacity .4s;display:flex;align-items:flex-end;padding:18px}
.gi:hover .gov{opacity:1}
.gov span{font-family:'Playfair Display',serif;font-size:.88rem;color:var(--w);font-style:italic}

/* TESTIMONIALS */
.testi{padding:clamp(60px,10vw,120px) 60px;background:var(--bs)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:50px}
.tcard{background:var(--b);padding:36px;border-top:3px solid transparent;transition:border-color .3s}
.tcard:hover{border-color:var(--y)}
.tstars{color:var(--y);font-size:.95rem;letter-spacing:3px;margin-bottom:18px}
.ttext{font-family:'Playfair Display',serif;font-style:italic;font-size:.95rem;line-height:1.7;color:var(--gl);margin-bottom:24px}
.tauthor{display:flex;align-items:center;gap:13px}
.tavatar{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid var(--y)}
.tname{font-weight:700;font-size:.88rem}
.trole{font-size:.73rem;color:var(--g);margin-top:2px}

/* RESERVATION */
.res{padding:clamp(60px,10vw,120px) 60px;background:var(--y)}
.res-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.res h2{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,3.8vw,3.8rem);font-weight:900;color:var(--b);line-height:1.05}
.res h2 em{font-style:italic}
.res-sub{color:rgba(0,0,0,.6);margin-top:18px;font-size:.95rem;line-height:1.7;font-weight:300}
.rinfo{margin-top:36px}
.rrow{display:flex;gap:18px;margin-bottom:20px}
.rlabel{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--b);min-width:75px;padding-top:3px}
.rval{font-size:.9rem;color:rgba(0,0,0,.7);line-height:1.6}
.form{display:flex;flex-direction:column;gap:14px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg label{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;font-weight:700;color:rgba(0,0,0,.55)}
.fg input,.fg select,.fg textarea{background:rgba(0,0,0,.08);border:1.5px solid rgba(0,0,0,.15);padding:13px 15px;font-size:.88rem;font-family:'DM Sans',sans-serif;color:var(--b);outline:none;transition:border-color .3s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--b)}
.fg select{appearance:none;cursor:pointer}
.fg textarea{resize:none;height:90px}
.btn-dk{background:var(--b);color:var(--y);padding:15px;font-weight:700;font-size:.82rem;letter-spacing:.15em;text-transform:uppercase;border:none;cursor:pointer;width:100%;transition:all .3s;font-family:'DM Sans',sans-serif}
.btn-dk:hover{background:#1a1a1a;transform:translateY(-2px)}

/* FOOTER */
footer{background:var(--bs);border-top:1px solid rgba(255,255,255,.06);padding:55px 60px 28px}
.ftop{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;margin-bottom:44px}
.fbrand .logo{font-size:2rem;display:block;margin-bottom:14px}
.fbrand p{font-size:.83rem;color:var(--g);line-height:1.7;font-weight:300}
.fsoc{display:flex;gap:10px;margin-top:22px}
.soc{width:36px;height:36px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:var(--g);text-decoration:none;font-size:.72rem;font-weight:700;transition:all .3s}
.soc:hover{border-color:var(--y);color:var(--y)}
.fcol h5{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--y);margin-bottom:22px;font-weight:700}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.fcol ul li,.fcol ul li a{text-decoration:none;color:var(--g);font-size:.83rem;transition:color .3s;font-weight:300}
.fcol ul li a:hover{color:var(--w)}
.fbot{border-top:1px solid rgba(255,255,255,.06);padding-top:22px;display:flex;align-items:center;justify-content:space-between}
.fbot p{font-size:.73rem;color:rgba(255,255,255,.3)}
.fbot span{font-size:.73rem;color:var(--y);letter-spacing:.1em}

/* REVEAL ANIM */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s ease,transform .8s ease}
.reveal.vis{opacity:1;transform:translateY(0)}
.rd1{transition-delay:.1s}.rd2{transition-delay:.2s}.rd3{transition-delay:.3s}

/* ══════════════════════
   RESPONSIVE
══════════════════════ */
@media(max-width:1024px){
  nav{padding:18px 24px}
  nav.scrolled{padding:12px 24px}
  .nav-links{display:none}
  .mob-right{display:flex}
  .hamburger{display:flex}
  .about{grid-template-columns:1fr;gap:44px}
  .about-imgs{height:380px}
  .mgrid{grid-template-columns:repeat(2,1fr)}
  .ggrid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}
  .gi,.gi:nth-child(1),.gi:nth-child(2),.gi:nth-child(3),.gi:nth-child(4),.gi:nth-child(5){grid-column:auto!important;grid-row:auto!important;height:220px}
  .tgrid{grid-template-columns:1fr 1fr}
  .res-inner{grid-template-columns:1fr;gap:36px}
  .ftop{grid-template-columns:1fr 1fr;gap:36px}
  .feat-row{grid-template-columns:1fr;gap:20px}

  /* Tabs: scroll allow karo tablet pe bhi */
  .mtabs{
    width:100%;
    justify-content:flex-start;
  }
}

@media(max-width:700px){
  nav{padding:16px 20px}
  nav.scrolled{padding:11px 20px}
  .mob-reserve-btn{font-size:.64rem;padding:8px 11px}
  .hero-content{padding:0 20px}
  .hero-scroll{left:20px}
  .about,.menu-sec,.gallery,.testi,.res,footer{padding-left:20px!important;padding-right:20px!important}
  .exp{padding-left:20px!important;padding-right:20px!important;background-attachment:scroll}
  .mgrid{grid-template-columns:1fr}
  .tgrid{grid-template-columns:1fr}
  .ftop{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(3,1fr)}

  /* ── MENU TABS MOBILE FIX ── */
  .mtabs{
    width:100%;
    justify-content:flex-start;
    border:1px solid rgba(255,255,255,.1);
    margin-bottom:32px;
  }
  .mtab{
    padding:12px 20px;
    font-size:.72rem;
    letter-spacing:.1em;
  }
}

/* ── GLOBAL MOBILE OVERFLOW FIX ── */
html,body{
  width:100%;
  overflow-x:hidden;
}
img{
  max-width:100%;
  height:auto;
  display:block;
}
section{
  width:100%;
  overflow:hidden;
}
.hero{
  min-height:100dvh;
  width:100%;
}
.mob-menu{
  width:80%;
  max-width:260px;
  height:100dvh;
}

@media(max-width:700px){
  body{overflow-x:hidden}
  nav{width:100%;padding:16px 20px}
  nav.scrolled{padding:11px 20px}
  .hero{min-height:100dvh;padding-top:80px}
  .hero-content{width:100%;padding:0 20px}
  .hero h1{font-size:3rem;line-height:1}
  .hero p{max-width:100%;font-size:.95rem}
  .hero-btns{flex-direction:column;width:100%}
  .btn-y,.btn-o{width:100%;text-align:center}
  .hero-scroll{left:20px;bottom:20px}
  .about{grid-template-columns:1fr;gap:40px}
  .about-imgs{height:340px}
  .stats{grid-template-columns:1fr;gap:20px}
  .mgrid,.tgrid,.ftop,.frow,.res-inner{grid-template-columns:1fr}
  .exp{background-attachment:scroll}
}