/* =====================================================================
   TAQASHI MANDI — STYLE.CSS  (v2 · refined alignment + polish)
   ===================================================================== */

:root{
  --bg:           #0B0907;
  --bg-2:         #110D0A;
  --bg-3:         #181210;
  --line:         rgba(241,231,214,0.10);
  --line-strong:  rgba(241,231,214,0.18);
  --ink:          #F1E7D6;
  --ink-2:        #C8B79C;
  --ink-3:        #8B7C66;
  --ember:        #E85A1A;
  --amber:        #F4A24C;
  --gold:         #D9B26A;
  --rose:         #C9714E;
  --shadow-1:     0 1px 0 rgba(241,231,214,0.04) inset, 0 30px 60px -30px rgba(0,0,0,0.7);
  --shadow-2:     0 40px 90px -40px rgba(232,90,26,0.35), 0 30px 60px -30px rgba(0,0,0,0.85);

  --serif:   'Cormorant Garamond', 'Italiana', Georgia, serif;
  --display: 'Italiana', 'Cormorant Garamond', serif;
  --sans:    'Inter Tight', system-ui, -apple-system, sans-serif;

  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-soft:   cubic-bezier(0.4, 0, 0.2, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);

  --container:   1280px;
  --gutter:      clamp(20px, 4vw, 56px);
  --section-py:  clamp(80px, 11vw, 160px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  cursor:none;
}
@media (hover:none) and (pointer:coarse){ body{cursor:auto} }

img,video,svg{display:block;max-width:100%}
img{height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
button,a{cursor:none}
@media (hover:none) and (pointer:coarse){ button,a{cursor:pointer} }

ul{list-style:none;margin:0;padding:0}
h1,h2,h3,h4,h5{margin:0;font-family:var(--display);font-weight:400;letter-spacing:-0.01em}
p{margin:0}

/* ------------------- TYPE ------------------- */
.section__num{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--sans);
  font-size:11px; font-weight:500;
  letter-spacing:0.32em; text-transform:uppercase;
  color:var(--ink-3);
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
  margin-bottom:28px;
  position:relative;
}
.section__num::before{
  content:"";
  display:inline-block;
  width:24px;height:1px;
  background:linear-gradient(90deg, var(--ember), transparent);
}
.section__title{
  font-size:clamp(36px, 5.4vw, 76px);
  line-height:1.05;
  font-weight:300;
  color:var(--ink);
  max-width:18ch;
}
.section__lede{
  margin-top:20px;
  font-size:clamp(15px, 1.2vw, 18px);
  color:var(--ink-2);
  max-width:54ch;
  font-family:var(--sans);
}
.section__head{
  padding:0 var(--gutter);
  max-width:var(--container);
  margin:0 auto clamp(48px, 6vw, 88px);
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--ink-2);font-weight:500;
  margin:0 0 28px;
}
.eyebrow__dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--ember);
  box-shadow:0 0 18px rgba(232,90,26,0.7);
  animation:eyebrowPulse 2.2s ease-in-out infinite;
}
@keyframes eyebrowPulse{
  0%  {box-shadow:0 0 0 0 rgba(232,90,26,0.7), 0 0 18px rgba(232,90,26,0.5)}
  60% {box-shadow:0 0 0 9px rgba(232,90,26,0), 0 0 18px rgba(232,90,26,0.2)}
  100%{box-shadow:0 0 0 0 rgba(232,90,26,0),   0 0 18px rgba(232,90,26,0.5)}
}

/* ------------------- BUTTONS ------------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;
  border-radius:999px;
  font-family:var(--sans);
  font-size:14px;font-weight:500;
  letter-spacing:0.02em;
  transition:transform .35s var(--ease-out), background .35s var(--ease-out), border-color .35s var(--ease-out), color .35s var(--ease-out), box-shadow .35s var(--ease-out);
  will-change:transform;
}
.btn--primary{
  background:linear-gradient(180deg, var(--ember) 0%, #C24816 100%);
  color:#fff;
  box-shadow:0 10px 30px -10px rgba(232,90,26,0.55);
  position:relative;overflow:hidden;
  isolation:isolate;
}
.btn--primary::after{
  content:"";
  position:absolute;
  top:0;left:-150%;
  width:80%;height:100%;
  background:linear-gradient(110deg, transparent, rgba(255,255,255,0.22), transparent);
  transform:skewX(-20deg);
  transition:left .9s var(--ease-out);
  z-index:-1;
}
.btn--primary:hover::after{left:150%}
.btn--primary:hover{
  background:linear-gradient(180deg, #F46821 0%, var(--ember) 100%);
  box-shadow:0 18px 40px -12px rgba(232,90,26,0.7);
}
.btn--ghost{
  border:1px solid var(--line-strong);
  color:var(--ink);
  background:rgba(255,255,255,0.02);
}
.btn--ghost:hover{
  border-color:var(--ember);
  background:rgba(232,90,26,0.08);
  color:var(--amber);
}
.btn--full{width:100%;justify-content:center}

/* ------------------- PRELOADER ------------------- */
.preloader{
  position:fixed;inset:0;z-index:1000;
  background:var(--bg);
  display:grid;place-items:center;
  transition:opacity .8s var(--ease-out), visibility 0s .8s;
}
.preloader.is-done{opacity:0;visibility:hidden;pointer-events:none}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:24px}
.preloader__logo{width:84px;height:84px;object-fit:contain;animation:pulse 2s var(--ease-in-out) infinite}
.preloader__line{width:120px;height:1px;background:rgba(241,231,214,0.08);overflow:hidden;border-radius:1px}
.preloader__line span{display:block;height:100%;width:40%;background:var(--ember);animation:slide 1.4s var(--ease-in-out) infinite}
@keyframes pulse{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}
@keyframes slide{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}

/* ------------------- CURSOR ------------------- */
.cursor{
  position:fixed;top:0;left:0;
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(241,231,214,0.45);
  pointer-events:none;z-index:999;
  transition:width .25s var(--ease-out), height .25s var(--ease-out), border-color .25s var(--ease-out), background .25s var(--ease-out);
  mix-blend-mode:difference;
}
.cursor--dot{width:6px;height:6px;border:0;background:var(--ink);transition:transform .12s linear, width .25s, height .25s}
.cursor.is-hover{width:60px;height:60px;border-color:var(--amber);background:rgba(244,162,76,0.06)}
.cursor--dot.is-hover{width:0;height:0}
@media (hover:none) and (pointer:coarse){ .cursor{display:none} }

/* ------------------- NAV ------------------- */
/* ======================================================
   PREMIUM NAV
   ====================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:0 var(--gutter);
  height:80px;
  transition:height .45s var(--ease-out),
             background .45s var(--ease-out),
             backdrop-filter .45s,
             border-color .45s,
             box-shadow .45s;
  border-bottom:1px solid transparent;
}

/* Frosted glass on scroll — adds a hairline amber top-glow too */
.nav.is-scrolled{
  height:64px;
  background:rgba(11,9,7,0.78);
  backdrop-filter:blur(24px) saturate(160%);
  -webkit-backdrop-filter:blur(24px) saturate(160%);
  border-bottom-color:rgba(232,90,26,0.12);
  box-shadow:0 1px 0 rgba(232,90,26,0.08),
             0 8px 32px rgba(0,0,0,0.35);
}
/* Thin amber top-line accent */
.nav::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(232,90,26,0.5) 30%,
    rgba(244,162,76,0.8) 50%,
    rgba(232,90,26,0.5) 70%,
    transparent 100%);
  opacity:0;
  transition:opacity .6s var(--ease-out);
}
.nav.is-scrolled::before{opacity:1}

/* ---- BRAND (col 1, left) ---- */
.nav__brand{
  display:flex;align-items:center;gap:14px;
  text-decoration:none;
  justify-self:start;
}
.nav__logo{
  width:84px;height:84px;
  object-fit:contain;
  filter:drop-shadow(0 2px 12px rgba(232,90,26,0.22));
  transition:transform .5s var(--ease-out),
             width .45s var(--ease-out),
             height .45s var(--ease-out),
             filter .45s;
  flex-shrink:0;
}
.nav.is-scrolled .nav__logo{width:56px;height:56px}
.nav__brand:hover .nav__logo{
  transform:scale(1.08) rotate(-4deg);
  filter:drop-shadow(0 4px 18px rgba(244,162,76,0.5));
}
/* Vertical divider between logo and wordmark */
.nav__brand::after{
  content:"";
  display:block;
  width:1px;height:28px;
  background:linear-gradient(180deg, transparent, rgba(241,231,214,0.2), transparent);
  flex-shrink:0;
}
.nav.is-scrolled .nav__brand::after{height:20px}
.nav__wordmark{
  display:flex;flex-direction:column;gap:1px;
}
.nav__wordmark strong{
  font-family:var(--display);
  font-size:20px;
  line-height:1;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink);
  font-weight:700;
  white-space:nowrap;
  transition:color .4s, font-size .45s;
}
.nav__wordmark span{
  font-family:var(--sans);
  font-size:8.5px;
  letter-spacing:0.42em;
  text-transform:uppercase;
  color:var(--amber);
  font-weight:500;
  white-space:nowrap;
  opacity:0.85;
  transition:opacity .4s;
}
.nav.is-scrolled .nav__wordmark strong{font-size:15px}
.nav.is-scrolled .nav__wordmark span{opacity:0.75;font-size:7.5px}
.nav__brand:hover .nav__wordmark strong{color:var(--amber)}

/* ---- LINKS (col 2, centre) — pill container ---- */
.nav__links{
  display:flex;gap:0;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:999px;
  padding:5px 8px;
  backdrop-filter:blur(8px);
  transition:background .45s, border-color .45s, padding .45s;
}
.nav.is-scrolled .nav__links{
  background:rgba(255,255,255,0.05);
  border-color:rgba(255,255,255,0.09);
}
.nav__links a{
  position:relative;
  font-size:12px;font-weight:500;letter-spacing:0.08em;
  color:rgba(241,231,214,0.55);
  padding:7px 14px;
  border-radius:999px;
  transition:color .3s, background .3s;
  text-transform:uppercase;
  white-space:nowrap;
}
.nav__links a:hover{
  color:var(--ink);
  background:rgba(255,255,255,0.07);
}
/* Remove old underline bar */
.nav__links a::after{display:none}

/* ---- CTA (col 3, right) ---- */
.nav__cta{
  justify-self:end;
  padding:10px 22px;
  border-radius:999px;
  border:1px solid rgba(232,90,26,0.45);
  font-size:12px;font-weight:500;letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--amber);
  background:rgba(232,90,26,0.08);
  position:relative;overflow:hidden;isolation:isolate;
  transition:all .4s var(--ease-out);
}
/* Shine sweep */
.nav__cta::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(110deg,
    transparent 30%,
    rgba(255,255,255,0.18) 50%,
    transparent 70%);
  transform:translateX(-100%);
  transition:transform .6s var(--ease-out);
}
.nav__cta:hover{
  background:var(--ember);
  border-color:var(--ember);
  color:#fff;
  box-shadow:0 6px 24px rgba(232,90,26,0.45);
}
.nav__cta:hover::before{transform:translateX(100%)}

/* ---- BURGER (mobile) ---- */
.nav__burger{
  display:none;width:40px;height:40px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
  border:1px solid var(--line);border-radius:10px;
  transition:border-color .3s, background .3s;
}
.nav__burger:hover{background:rgba(255,255,255,0.05);border-color:var(--line-strong)}
.nav__burger span{display:block;width:20px;height:1.5px;background:var(--ink);transition:transform .4s, opacity .3s}
.nav__burger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){opacity:0}
.nav__burger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media (max-width:960px){
  .nav{grid-template-columns:1fr auto}
  .nav__links{display:none}
  .nav__burger{display:flex}
}
/* Keep "Authentic Arabian Mandi" subtitle visible on mobile */

/* ------------------- DRAWER ------------------- */
.drawer{
  position:fixed;top:0;right:0;width:min(420px,86vw);height:100vh;
  background:var(--bg-2);
  z-index:55;
  transform:translateX(100%);
  transition:transform .55s var(--ease-out);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:100px var(--gutter) 40px;
  border-left:1px solid var(--line);
}
.drawer.is-open{transform:translateX(0)}
.drawer__links{display:flex;flex-direction:column;gap:8px}
.drawer__links a{
  font-family:var(--display);font-size:32px;line-height:1.3;
  color:var(--ink);padding:8px 0;
  border-bottom:1px solid var(--line);
}
.drawer__links a:hover{color:var(--amber)}
.drawer__foot{font-size:12px;letter-spacing:0.2em;color:var(--ink-3);text-transform:uppercase}

.drawer__close{
  position:absolute;
  top:20px;
  right:20px;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  background:transparent;
  border:1px solid rgba(241,231,214,0.15);
  border-radius:50%;
  color:var(--ink);
  cursor:pointer;
  transition:background .2s, border-color .2s;
}
.drawer__close:hover{background:rgba(255,255,255,0.05);border-color:var(--line-strong)}

/* =====================================================================
   HERO  — 200vh sticky scroll story · video ends after ~2 viewport scrolls
   ===================================================================== */
.hero{
  position:relative;
  width:100%;
  height:200vh;          /* 100vh sticky + 100vh travel = ~2 scrolls to finish */
}
.hero__sticky{
  position:sticky;
  top:0;
  height:100vh;
  width:100%;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero__videoWrap{
  position:absolute;inset:0;
  z-index:0;
  overflow:hidden;
  contain:layout paint;
  background:#0E0B08;   /* prevents flash before video paints first frame */
}
.hero__video{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center center;
  pointer-events:none;
  /* GPU compositing for buttery scrub — slight scale hides edge wobble during seek */
  transform:translate3d(0,0,0) scale(1.04);
  will-change:transform;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  /* Crisp first paint while frames decode */
  background:#0E0B08;
}
.hero__veil{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(11,9,7,0.92) 0%, rgba(11,9,7,0.3) 55%, transparent 80%),
    linear-gradient(90deg, rgba(11,9,7,0.55) 0%, transparent 40%, transparent 60%, rgba(11,9,7,0.45) 100%),
    linear-gradient(180deg, rgba(11,9,7,0.6) 0%, rgba(11,9,7,0.08) 28%, rgba(11,9,7,0.08) 65%, rgba(11,9,7,0.96) 100%);
}
.hero__grain{
  position:absolute;inset:0;opacity:0.18;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.05  0 0 0 0 0.04  0 0 0 0 0.03  0 0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  pointer-events:none;
}

.hero__content{
  position:relative;z-index:2;
  width:100%;max-width:var(--container);
  padding:0 var(--gutter);
  display:flex;flex-direction:column;
  align-items:flex-start;
  text-align:left;
  gap:36px;  /* explicit space between stages-block and CTA row */
}

/* Stages — crossfade with subtle transform; absolutely-positioned siblings
   need a parent tall enough to hold the tallest stage without overflowing
   into the CTA row below. */
.hero__stages{
  position:relative;
  width:100%;
  min-height:340px;
  margin-bottom:0;  /* gap on parent handles spacing now */
}
@media (min-width:1024px){ .hero__stages{ min-height:380px } }
@media (min-width:1440px){ .hero__stages{ min-height:440px } }

.hero__stage{
  position:absolute;
  inset:0;
  opacity:0;
  transform:translateY(24px) scale(0.98);
  transition:opacity 1s var(--ease-out), transform 1.2s cubic-bezier(0.22,1,0.36,1);
  pointer-events:none;
  will-change:opacity, transform;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.hero__stage.is-active{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}

.hero__title{
  font-family:var(--display);
  font-size:clamp(44px, 7.5vw, 112px);
  line-height:0.95;
  letter-spacing:-0.01em;
  font-weight:400;
  color:var(--ink);
  text-wrap:balance;
  margin:0;
}
.hero__title--line{display:block}
.hero__title--accent{
  font-style:italic;font-family:var(--serif);font-weight:400;
  color:var(--amber);
}
.hero__sub{
  margin-top:22px;
  font-size:clamp(15px, 1.2vw, 18px);
  color:var(--ink-2);
  max-width:52ch;
  line-height:1.55;
  letter-spacing:0.01em;
}

.hero__ctas{
  display:flex;gap:14px;flex-wrap:wrap;
  margin-top:0;
}

.hero__dots{
  position:absolute;
  right:var(--gutter);
  top:50%;
  transform:translateY(-50%);
  display:flex;flex-direction:column;gap:14px;
  z-index:3;
}
.hero__dots li{
  width:2px;height:22px;
  background:rgba(241,231,214,0.15);
  border-radius:2px;
  transition:background .6s var(--ease-out), height .6s var(--ease-out), opacity .6s;
  opacity:0.5;
}
.hero__dots li.is-active{background:var(--amber);height:40px;opacity:1;
  box-shadow:0 0 12px rgba(244,162,76,0.6);}

@media (max-width:768px){
  .hero__dots{display:none}
  .hero__stages{min-height:220px}
}

.hero__counter{
  position:absolute;
  left:var(--gutter);
  bottom:36px;
  font-family:var(--sans);
  font-size:11px;letter-spacing:0.22em;
  color:rgba(241,231,214,0.35);
  z-index:3;
  user-select:none;
}
.hero__counter span{
  color:var(--amber);
  font-size:14px;
  font-weight:500;
  margin-right:6px;
  transition:opacity .4s;
}
.hero__counter em{
  font-style:normal;
  margin:0 6px;
  opacity:0.4;
}
@media (max-width:640px){.hero__counter{display:none}}

.hero__scrollHint{
  position:absolute;left:50%;bottom:28px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:10px;letter-spacing:0.34em;text-transform:uppercase;
  color:var(--ink-3);
  z-index:3;
}
.hero__scrollHint i{
  display:block;width:1px;height:30px;background:var(--ink-3);
  position:relative;overflow:hidden;
}
.hero__scrollHint i::after{
  content:"";position:absolute;left:0;top:-30px;
  width:1px;height:30px;background:var(--amber);
  animation:scrollDown 1.8s var(--ease-in-out) infinite;
}
@keyframes scrollDown{0%{top:-30px}100%{top:30px}}

/* =====================================================================
   ABOUT  — Immersive split: bold quote left, cinematic image stack right.
   ===================================================================== */
.about{
  padding:var(--section-py) 0;
  background:
    radial-gradient(ellipse 80% 60% at 0% 50%, rgba(232,90,26,0.07), transparent 60%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
  border-top:1px solid var(--line);
  overflow:hidden;
  position:relative;
}
/* Subtle Arabic-pattern watermark */
.about::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60'><path d='M30 0 L60 30 L30 60 L0 30Z' fill='none' stroke='rgba(241,231,214,0.025)' stroke-width='0.6'/></svg>");
  background-size:60px 60px;
  pointer-events:none;
  z-index:0;
}

.menu::before,
.locations::before,
.team::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60'><path d='M30 0 L60 30 L30 60 L0 30Z' fill='none' stroke='rgba(241,231,214,0.025)' stroke-width='0.6'/></svg>");
  background-size:60px 60px;
  pointer-events:none;
  z-index:0;
}
/* ensure inner content sits above pattern */
.menu > *,
.locations > *,
.team > *{position:relative;z-index:1}
.about__inner{
  position:relative;z-index:1;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}
.about__head{
  padding:0;margin-left:0;margin-right:0;
  margin-bottom:clamp(40px,5vw,72px);
}

.about__grid{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(0, 1fr);
  gap:clamp(40px, 6vw, 96px);
  align-items:start;
}
.about__copy{padding-top:6px}

/* Big italic pull-quote at top */
.about__copy .lede{
  font-family:var(--display);
  font-size:clamp(26px, 2.8vw, 42px);
  line-height:1.22;
  color:var(--ink);
  margin-bottom:32px;
  font-weight:400;
  font-style:italic;
  position:relative;
  padding-left:28px;
}
.about__copy .lede::before{
  content:"";
  position:absolute;
  left:0;top:4px;bottom:4px;
  width:3px;
  background:linear-gradient(180deg, var(--ember), var(--amber));
  border-radius:3px;
}
.about__copy p{margin-bottom:18px;color:var(--ink-2);max-width:54ch;font-size:15px;line-height:1.7}

/* Stat row */
.about__stats{
  display:flex;gap:0;
  margin:36px 0 44px;
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  background:rgba(255,255,255,0.015);
}
.about__stat{
  flex:1;
  padding:22px 20px;
  border-right:1px solid var(--line);
  text-align:center;
}
.about__stat:last-child{border-right:0}
.about__stat strong{
  display:block;
  font-family:var(--display);
  font-size:clamp(28px,3.2vw,44px);
  color:var(--amber);
  font-weight:400;
  line-height:1;
  margin-bottom:6px;
}
.about__stat span{
  font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-3);
}

.about__pillars{
  margin-top:8px;
  display:grid;gap:0;
  border-top:1px solid var(--line);
}
.about__pillars li{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:20px;align-items:start;
  padding:20px 0;
  border-bottom:1px solid var(--line);
  transition:background .35s;
}
.about__pillars li:hover{background:rgba(232,90,26,0.04)}
.about__pillars span{
  font-family:var(--sans);font-size:11px;letter-spacing:0.2em;
  color:var(--ember);font-weight:600;padding-top:5px;
  text-transform:uppercase;
}
.about__pillars h4{font-family:var(--display);font-size:20px;color:var(--ink);margin-bottom:5px}
.about__pillars div p{margin:0;font-size:13px;color:var(--ink-3);max-width:none;line-height:1.6}

/* IMAGE STACK — two cards stacked vertically */
.about__visual{
  display:flex;
  flex-direction:column;
  gap:16px;
  position:sticky;
  top:96px;
}
.about__card{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  border:1px solid var(--line);
  background:
    radial-gradient(120% 80% at 50% 60%, rgba(232,90,26,0.18), transparent 60%),
    linear-gradient(160deg, #2a1a12 0%, #110D0A 100%);
  margin:0;
  transition:transform .6s var(--ease-out), box-shadow .6s var(--ease-out), border-color .6s var(--ease-out);
}
.about__card:hover{transform:translateY(-6px) scale(1.01);box-shadow:var(--shadow-2);border-color:rgba(232,90,26,0.35)}
.about__card--top{aspect-ratio:4/5}
.about__card--bot{aspect-ratio:16/10}

.about__card img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .9s var(--ease-out), filter .6s;
}
.about__card img.is-missing{opacity:0}
.about__card:hover img{transform:scale(1.07);filter:saturate(1.15) brightness(1.05)}

.about__card-veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(11,9,7,0.8) 100%);
  pointer-events:none;
}
.about__card figcaption{
  position:absolute;left:18px;bottom:16px;
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink);
  background:rgba(11,9,7,0.5);
  padding:7px 14px;border-radius:999px;
  border:1px solid rgba(241,231,214,0.12);
  backdrop-filter:blur(8px);
}
.about__card figcaption span{color:var(--amber);font-weight:600;margin-right:2px}

/* Decorative ember tag on top card */
.about__card--top::after{
  content:"SINCE 2020";
  position:absolute;top:18px;right:18px;
  font-family:var(--sans);font-size:9px;letter-spacing:0.28em;
  text-transform:uppercase;color:var(--ink);
  background:rgba(232,90,26,0.85);
  padding:5px 12px;border-radius:999px;
  backdrop-filter:blur(6px);
}

@media (max-width:960px){
  .about__grid{grid-template-columns:1fr}
  .about__visual{
    display:grid;grid-template-columns:1fr 1fr;gap:14px;
    position:static;
  }
  .about__card--top{aspect-ratio:3/4}
  .about__card--bot{aspect-ratio:3/4}
  .about__stats{flex-wrap:wrap}
  .about__stat{min-width:50%;border-bottom:1px solid var(--line)}
}

/* =====================================================================
   MARQUEE
   ===================================================================== */
.marquee{
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:26px 0;
  background:var(--bg);
}
.marquee__track{
  display:flex;align-items:center;gap:48px;
  animation:marquee 38s linear infinite;
  white-space:nowrap;width:max-content;
}
.marquee span{
  font-family:var(--display);
  font-size:clamp(28px, 3.5vw, 48px);
  color:var(--ink);
  font-weight:300;letter-spacing:0.01em;
}
.marquee i{color:var(--ember);font-style:normal;font-size:20px}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* =====================================================================
   MENU  —  REALIGNED. Feature row full-width + uniform 3-col grid below.
   ===================================================================== */
.menu{
  padding:var(--section-py) 0;
  background:
    radial-gradient(ellipse 70% 55% at 100% 0%, rgba(232,90,26,0.07), transparent 60%),
    linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
  position:relative;
  overflow:hidden;
}

.menu__tabs{
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;
  padding:0 var(--gutter);max-width:var(--container);
  margin:0 auto 56px;
}
.menu__tab{
  padding:11px 22px;border-radius:999px;
  font-size:13px;font-weight:500;letter-spacing:0.04em;
  color:var(--ink-2);
  border:1px solid var(--line);
  background:rgba(255,255,255,0.015);
  transition:all .4s var(--ease-out);
}
.menu__tab:hover{color:var(--ink);border-color:var(--line-strong)}
.menu__tab.is-active{
  background:var(--ember);border-color:var(--ember);color:#fff;
  box-shadow:0 8px 24px -8px rgba(232,90,26,0.55);
}

.menu__wrap{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
  display:flex;
  flex-direction:column;
  gap:24px;
}

/* Feature row — full-width hero card */
.menu__feature{display:block}
.dish--feature{
  display:grid;
  grid-template-columns:minmax(0, 1.1fr) minmax(0, 1fr);
  align-items:stretch;
}
.dish--feature .dish__media{aspect-ratio:auto;min-height:420px}
.dish--feature .dish__body{padding:44px;justify-content:center;gap:16px}
.dish--feature .dish__name{font-size:clamp(32px, 3.4vw, 48px)}
.dish--feature .dish__desc{font-size:15px;max-width:42ch;line-height:1.6}

/* Uniform grid below */
.menu__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
}
@media (max-width:1100px){
  .menu__grid{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .dish--feature{grid-template-columns:1fr;}
  .dish--feature .dish__media{aspect-ratio:16/10;min-height:0}
  .dish--feature .dish__body{padding:28px}
}
@media (max-width:640px){
  .menu__grid{grid-template-columns:1fr;gap:18px}
  .dish--feature .dish__body{padding:22px}
}

.dish{
  position:relative;
  display:flex;flex-direction:column;
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg, var(--bg-3) 0%, var(--bg-2) 100%);
  overflow:hidden;
  transition:transform .5s var(--ease-out), border-color .5s var(--ease-out), box-shadow .5s var(--ease-out);
}
.dish.is-hidden{display:none}
.dish:hover{
  transform:translateY(-6px);
  border-color:rgba(232,90,26,0.35);
  box-shadow:var(--shadow-2);
}

.dish__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 60%, rgba(232,90,26,0.32), transparent 60%),
    radial-gradient(circle at 30% 30%, rgba(244,162,76,0.18), transparent 55%),
    linear-gradient(160deg, #2a1a12 0%, #110D0A 100%);
}
.dish__media img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .9s var(--ease-out), filter .6s var(--ease-out);
}
.dish__media img.is-missing{opacity:0}
.dish:hover .dish__media img{transform:scale(1.08);filter:saturate(1.15) brightness(1.05)}
.dish__media-veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(11,9,7,0.55) 100%);
  pointer-events:none;
}

.dish__body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:12px;flex:1}

.dish__head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-bottom:2px;
}
.dish__tag{
  display:inline-block;
  padding:5px 11px;border-radius:999px;
  font-size:10px;letter-spacing:0.16em;text-transform:uppercase;font-weight:500;
  background:rgba(241,231,214,0.06);
  border:1px solid var(--line);
  color:var(--ink-2);
}
.dish__tag--signature{
  background:linear-gradient(180deg, rgba(232,90,26,0.18), rgba(232,90,26,0.06));
  border-color:rgba(232,90,26,0.4);color:var(--amber);
}
.dish__tag--family{
  background:rgba(244,162,76,0.1);border-color:rgba(244,162,76,0.3);color:var(--gold);
}
.dish__cat{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-3)}

.dish__name{
  font-family:var(--display);
  font-size:clamp(22px, 2vw, 28px);
  line-height:1.15;
  color:var(--ink);
  font-weight:400;
}
.dish__desc{font-size:14px;line-height:1.55;color:var(--ink-3);margin-bottom:4px}

.dish__prices{
  display:flex;gap:6px;margin-top:auto;
  border-top:1px solid var(--line);padding-top:16px;
}
.dish__prices span{
  flex:1;
  display:flex;align-items:baseline;justify-content:center;gap:5px;
  padding:10px 8px;
  border-radius:10px;
  background:rgba(241,231,214,0.025);
  border:1px solid var(--line);
  font-family:var(--serif);font-size:18px;color:var(--ink);
  transition:all .35s var(--ease-out);
}
.dish__prices span:hover{background:rgba(232,90,26,0.08);border-color:rgba(232,90,26,0.3)}
.dish__prices em{font-style:normal;font-family:var(--sans);font-size:10px;letter-spacing:0.18em;color:var(--ember);font-weight:600}

.dish__alt{
  font-size:12px;color:var(--ink-3);
  padding-top:10px;border-top:1px dashed var(--line);
}
.dish__alt strong{color:var(--ink-2);font-weight:500;letter-spacing:0.04em}
.dish__alt em{font-style:normal;color:var(--ember);font-family:var(--sans);font-size:10px;letter-spacing:0.18em;font-weight:600;margin-right:3px}

.menu__foot{
  text-align:center;font-size:13px;color:var(--ink-3);
  margin-top:48px;padding:0 var(--gutter);
  letter-spacing:0.02em;
}


/* =====================================================================
   LOCATIONS
   ===================================================================== */
.locations{
  padding:var(--section-py) 0;
  background:
    radial-gradient(ellipse 75% 50% at 0% 100%, rgba(232,90,26,0.07), transparent 60%),
    radial-gradient(ellipse 50% 40% at 100% 0%, rgba(244,162,76,0.04), transparent 55%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
  border-top:1px solid var(--line);
  position:relative;
  overflow:hidden;
}
.locations__layout{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:48px;
  padding:0 var(--gutter);
  max-width:var(--container);margin:0 auto;
}
.locations__cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;align-content:start}
.loc{
  padding:26px;
  border-radius:16px;
  background:var(--bg-3);
  border:1px solid var(--line);
  opacity:0;
  transform:translateX(-32px) scale(0.96);
  transition:opacity .65s var(--ease-out), transform .75s var(--ease-out), border-color .5s, box-shadow .5s;
}
.loc.is-in{opacity:1;transform:translateX(0) scale(1)}
.loc.is-in:hover{transform:translateY(-4px);border-color:rgba(232,90,26,0.3);box-shadow:var(--shadow-1)}
.loc header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}
.loc h3{font-family:var(--display);font-size:26px;color:var(--ink);font-weight:400}
.loc header span{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ember)}
.loc__hours{font-size:13px;color:var(--ink-2);margin-bottom:6px}
.loc__addr{font-size:13px;color:var(--ink-3);margin-bottom:20px;line-height:1.55}
.loc__ctas{display:flex;gap:8px;flex-wrap:wrap}
.loc__btn{
  padding:8px 14px;border-radius:999px;
  font-size:12px;letter-spacing:0.02em;font-weight:500;
  background:var(--ember);color:#fff;
  transition:all .35s;
}
.loc__btn:hover{background:#F46821}
.loc__btn--ghost{background:transparent;border:1px solid var(--line-strong);color:var(--ink-2)}
.loc__btn--ghost:hover{background:rgba(232,90,26,0.08);border-color:var(--ember);color:var(--amber)}

.locations__map{
  border-radius:18px;overflow:hidden;border:1px solid var(--line);
  background:var(--bg-3);height:100%;min-height:520px;
}
.locations__map svg{width:100%;height:100%}
.pin circle:nth-child(2){animation:pulsePin 2.4s var(--ease-in-out) infinite}
@keyframes pulsePin{0%,100%{transform-origin:center;opacity:.4}50%{opacity:1}}

/* Route line draws in when section enters viewport (now spans all 6 outlets) */
.locations__map #route{
  stroke-dasharray:720;
  stroke-dashoffset:720;
  transition:stroke-dashoffset 2.8s var(--ease-out);
}
.locations.is-in .locations__map #route{
  stroke-dashoffset:0;
}
/* Pins fade + scale in, staggered by index */
.locations__map .pin{
  opacity:0;
  transform:scale(0.4);
  transform-origin:center;
  transform-box:fill-box;
  transition:opacity .9s var(--ease-out), transform 1.1s cubic-bezier(0.22,1,0.36,1);
}
.locations.is-in .locations__map .pin{
  opacity:1;
  transform:scale(1);
}
.locations.is-in .locations__map .pin:nth-of-type(1){transition-delay:.6s}
.locations.is-in .locations__map .pin:nth-of-type(2){transition-delay:1.2s}
.locations.is-in .locations__map .pin:nth-of-type(3){transition-delay:1.8s}
.locations.is-in .locations__map .pin:nth-of-type(4){transition-delay:2.4s}
.locations.is-in .locations__map .pin:nth-of-type(5){transition-delay:3.0s}
.locations.is-in .locations__map .pin:nth-of-type(6){transition-delay:3.6s}

@media (max-width:980px){
  .locations__layout{grid-template-columns:1fr}
  .locations__cards{grid-template-columns:1fr}
  .locations__map{min-height:420px}
}

/* =====================================================================
   TEAM  — deck-to-shuffle on scroll into view
   Cards start stacked (deck), then fan/spread on section enter.
   ===================================================================== */
.team{
  padding:var(--section-py) 0;
  background:
    radial-gradient(ellipse 80% 55% at 0% 0%, rgba(232,90,26,0.07), transparent 60%),
    radial-gradient(ellipse 60% 40% at 100% 100%, rgba(244,162,76,0.04), transparent 55%),
    linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
  border-top:1px solid var(--line);
  position:relative;
  overflow:hidden;
}

/* Shared member card */
.member{
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  background:var(--bg-3);
  transition:border-color .5s var(--ease-out), box-shadow .5s var(--ease-out);
}
.member__ph{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 35%, rgba(232,90,26,0.4), transparent 55%),
    linear-gradient(160deg, #2a1812, #0E0B08);
}
.member__ph img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .9s var(--ease-out);
}
.member__ph img.is-missing{opacity:0}
.member:hover .member__ph img{transform:scale(1.06)}
.member__info{padding:16px 18px 20px}
.member__info h4{font-family:var(--display);font-size:22px;color:var(--ink);margin-bottom:4px}
.member__info span{display:block;font-size:12px;letter-spacing:0.06em;color:var(--ink-3)}
.member > h4{font-family:var(--display);font-size:22px;color:var(--ink);padding:18px 18px 4px}
.member > span{display:block;font-size:12px;letter-spacing:0.06em;color:var(--ink-3);padding:0 18px 22px}

/* Deck wrapper — normal flow, no sticky */
.team__scroll{
  position:relative;
}
.team__stage{
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  overflow:visible;
  padding-bottom:var(--section-py);
}
/* Deck: starts stacked, JS fans out on enter */
.team__deck{
  position:relative;
  width:100%;
  max-width:var(--container);
  padding:0 var(--gutter);
  height:clamp(340px, 55vh, 520px);
}
/* Cards: absolutely positioned for deck-to-spread effect */
.team__deck .member{
  position:absolute;
  width:clamp(200px, 20vw, 268px);
  top:50%;
  left:50%;
  /* Pre-JS default: centered + scaled exactly like deck state.
     Prevents any flash at top-left before script runs. */
  transform:translate(-50%, -50%) scale(1);
  opacity:0;
  will-change:transform, opacity;
  cursor:default;
  transition:transform 0.9s cubic-bezier(0.22,1,0.36,1),
             border-color 0.5s, box-shadow 0.5s, opacity 0.7s;
}
.team__deck .member:hover{
  border-color:rgba(232,90,26,0.3);
  box-shadow:var(--shadow-2);
}

@media (max-width:640px){
  /* Mobile: horizontal scroll rail instead of absolute deck */
  .team__deck{
    display:flex;
    flex-direction:row;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    scrollbar-width:none;
    gap:16px;
    padding:0 var(--gutter) 24px;
    height:auto;
    align-items:stretch;
    position:static; /* override relative/absolute stack */
    -webkit-overflow-scrolling:touch;
    -webkit-mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
            mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
  }
  .team__deck::-webkit-scrollbar{display:none}
  .team__deck .member{
    position:static;        /* override absolute */
    top:auto; left:auto;
    transform:none !important; /* override JS deck transform */
    opacity:1 !important;
    flex:0 0 72vw;
    max-width:280px;
    scroll-snap-align:center;
    border-radius:18px;
    overflow:hidden;
  }
  .team__deck .member__info h4{font-size:17px}
  .team__deck .member__info span{font-size:11px}
  .team__stage{padding-bottom:0}
  .team__hint{display:none}
}

/* Scroll hint */
.team__hint{
  position:absolute;
  bottom:24px;left:50%;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:10px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--ink-3);
  transition:opacity .6s;
  pointer-events:none;
}
.team__hint.is-hidden{opacity:0}
.team__hint i{
  display:block;width:1px;height:28px;
  background:var(--ink-3);position:relative;overflow:hidden;
}
.team__hint i::after{
  content:"";position:absolute;
  left:0;top:-28px;width:1px;height:28px;
  background:var(--amber);
  animation:scrollDown 1.8s var(--ease-in-out) infinite;
}

/* Hide old mobile track if it somehow persists */
.team__mobile{display:none !important}

/* =====================================================================
   REVIEWS — premium 3D tilt cards, staggered fast reveal
   ===================================================================== */
.reviews{
  padding:var(--section-py) 0;
  background:
    radial-gradient(circle at 20% 0%, rgba(232,90,26,0.08), transparent 50%),
    radial-gradient(circle at 85% 100%, rgba(232,90,26,0.06), transparent 55%),
    var(--bg-2);
  border-top:1px solid var(--line);
  overflow:hidden;
  position:relative;
  perspective:none;
}

/* Outer rail: clips overflow, fades edges */
.reviews__rail{
  overflow:hidden;
  position:relative;
  padding:24px 0;
  -webkit-mask-image:linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
          mask-image:linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
}

/* Inner track: auto-scrolls horizontally */
.reviews__grid{
  display:flex;
  gap:22px;
  padding:0 var(--gutter);
  width:max-content;
  animation:reviewsScroll 60s linear infinite;
  will-change:transform;
}
/* No pause on hover — continuous scroll */
.reviews__grid .rcard{
  flex:0 0 clamp(280px, 32vw, 380px);
  min-height:280px;
}

@keyframes reviewsScroll{
  from{transform:translateX(0)}
  to  {transform:translateX(-50%)}
}

@media (max-width:640px){
  .reviews__grid{animation-duration:42s}
}
@media (prefers-reduced-motion: reduce){
  .reviews__grid{animation:none;overflow-x:auto;width:auto}
  .reviews__rail{overflow-x:auto}
}

.rcard{
  position:relative;
  border-radius:20px;
  background:
    linear-gradient(155deg, rgba(255,255,255,0.045), rgba(255,255,255,0.012));
  border:1px solid rgba(255,255,255,0.07);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  box-shadow:0 6px 28px rgba(0,0,0,0.2);
  will-change:transform, opacity;
  /* horizontal slide-in: starts right + invisible */
  opacity:0;
  transform:translateX(48px) scale(0.96);
  transition:
    opacity .6s var(--ease-out),
    transform .75s cubic-bezier(0.22, 1, 0.36, 1),
    border-color .5s,
    box-shadow .5s;
  overflow:hidden;
  outline:none;
}
/* landed state */
.rcard.is-in{
  opacity:1;
  transform:translateX(0) scale(1);
}
.rcard.is-in:hover{
  transform:translateY(-4px);
  border-color:rgba(232,90,26,0.45);
  box-shadow:
    0 22px 56px rgba(0,0,0,0.4),
    0 0 0 1px rgba(232,90,26,0.18),
    0 0 70px -10px rgba(232,90,26,0.4);
}
.rcard--accent{
  background:
    linear-gradient(155deg, rgba(232,90,26,0.10), rgba(244,162,76,0.04) 60%, rgba(255,255,255,0.012));
  border-color:rgba(232,90,26,0.18);
}


.rcard__inner{
  position:relative;
  padding:30px 28px 26px;
  display:flex;
  flex-direction:column;
  height:100%;
  transform-style:preserve-3d;
}

.rcard__top{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:18px;
  transform:translateZ(20px);
}
.rcard__stars{color:var(--amber);font-size:14px;letter-spacing:3px}
.rcard__outlet{
  font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-3);font-weight:500;
  padding:4px 10px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.02);
}

.rcard__quote{
  font-family:var(--serif);
  font-style:italic;
  font-size:17px;
  line-height:1.55;
  color:var(--ink);
  margin:0 0 22px;
  flex-grow:1;
  position:relative;
  transform:translateZ(15px);
}
.rcard__quote::before{
  content:"C";
  position:absolute;
  top:-30px;left:-8px;
  font-family:var(--display);
  font-size:90px;line-height:1;
  color:rgba(232,90,26,0.14);
  pointer-events:none;
}

.rcard__foot{
  display:flex;align-items:center;gap:12px;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,0.06);
  transform:translateZ(15px);
}
.rcard__avatar{
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg, var(--ember), var(--amber));
  color:#fff;font-family:var(--display);font-size:16px;
  flex-shrink:0;
}
.rcard__foot strong{
  display:block;
  font-family:var(--sans);font-size:13px;color:var(--ink-2);font-weight:500;
}
.rcard__foot span{
  display:block;
  font-size:10px;letter-spacing:0.14em;color:var(--ink-3);text-transform:uppercase;
  margin-top:2px;
}

.rcard__glow{
  position:absolute;
  inset:-2px;
  border-radius:22px;
  background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%), rgba(232,90,26,0.18), transparent 50%);
  opacity:0;
  pointer-events:none;
  transition:opacity .5s var(--ease-out);
}
.rcard:hover .rcard__glow{opacity:1}

/* Faster review reveal — overrides .reveal default */
.reviews .reveal{
  transition:opacity .45s var(--ease-out), transform .45s var(--ease-out);
}

@media (max-width:640px){
  .rcard__inner{padding:24px 22px}
  .rcard__quote{font-size:15px}
}

@media (prefers-reduced-motion: reduce){
  .rcard{transform:none !important}
}

/* =====================================================================
   CONTACT
   ===================================================================== */
.contact{padding:var(--section-py) 0;background:var(--bg);border-top:1px solid var(--line)}
.contact__inner{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  padding:0 var(--gutter);max-width:var(--container);margin:0 auto;
}
.contact__channels{margin:32px 0 28px;display:grid;gap:14px}
.contact__channels li{
  display:grid;grid-template-columns:80px 1fr;gap:16px;
  padding:14px 0;border-bottom:1px solid var(--line);
}
.contact__channels span{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-3)}
.contact__channels a{color:var(--ink);font-family:var(--serif);font-size:18px;transition:color .3s}
.contact__channels a:hover{color:var(--amber)}
.contact__social{display:flex;gap:10px}
.contact__social a{
  width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  border:1px solid var(--line-strong);color:var(--ink-2);
  transition:all .3s;
}
.contact__social a:hover{background:var(--ember);border-color:var(--ember);color:#fff;transform:translateY(-2px)}

.contact__form{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
  padding:36px;border:1px solid var(--line);border-radius:18px;
  background:var(--bg-3);
}
.field{display:flex;flex-direction:column;gap:8px}
.field--full{grid-column:1 / -1}
.field span{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.field input,.field select,.field textarea{
  background:rgba(255,255,255,0.02);
  border:1px solid var(--line);
  border-radius:10px;
  padding:14px 16px;
  font-family:var(--sans);font-size:14px;
  color:var(--ink);
  transition:border-color .3s, background .3s;
  outline:none;
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--ember);background:rgba(232,90,26,0.05);
}
.field textarea{resize:vertical;min-height:100px;font-family:var(--sans)}
.field select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--ink-2) 50%), linear-gradient(135deg, var(--ink-2) 50%, transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px), calc(100% - 13px) calc(50% - 2px);background-size:5px 5px;background-repeat:no-repeat}
.field select option{background:#1a1410;color:var(--ink)}
.contact__form button[type="submit"]{grid-column:1 / -1;margin-top:8px}
.contact__formNote{grid-column:1 / -1;font-size:13px;color:var(--ink-2);min-height:18px;text-align:center}

@media (max-width:980px){
  .contact__inner{grid-template-columns:1fr;gap:40px}
  .contact__form{grid-template-columns:1fr;padding:24px}
}

/* =====================================================================
   FOOTER
   ===================================================================== */
.foot{background:var(--bg-2);border-top:1px solid var(--line);padding:64px var(--gutter) 28px}
.foot__top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  max-width:var(--container);margin:0 auto;padding-bottom:48px;
  border-bottom:1px solid var(--line);
}
.foot__brand img{width:60px;margin-bottom:18px}
.foot__brand p{font-size:14px;color:var(--ink-3);max-width:36ch;line-height:1.6}
.foot__col h5{font-family:var(--sans);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ember);margin-bottom:18px;font-weight:500}
.foot__col li{font-size:14px;color:var(--ink-2);margin-bottom:10px;transition:color .3s}
.foot__col a:hover{color:var(--amber)}
.foot__bot{
  max-width:var(--container);margin:24px auto 0;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:12px;color:var(--ink-3);letter-spacing:0.06em;
}
@media (max-width:760px){.foot__top{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.foot__top{grid-template-columns:1fr}}

/* =====================================================================
   FLOAT BUTTONS
   ===================================================================== */
.float{
  position:fixed;width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;
  z-index:40;
  box-shadow:0 14px 30px -8px rgba(0,0,0,0.5);
  transition:transform .35s var(--ease-out), background .35s, opacity .35s;
}
.float--wa{
  right:24px;bottom:24px;
  background:#25D366;color:#fff;
}
.float--wa:hover{transform:translateY(-3px) scale(1.06)}
.float--top{
  right:24px;bottom:90px;
  background:var(--bg-3);border:1px solid var(--line-strong);color:var(--ink);
  opacity:0;pointer-events:none;
}
.float--top.is-visible{opacity:1;pointer-events:auto}
.float--top:hover{background:var(--ember);border-color:var(--ember);color:#fff}

/* =====================================================================
   REVEAL
   ===================================================================== */
/* POP — premium card entrance: scale + lift + fade with soft overshoot */
.pop{
  opacity:0;
  transform:translateY(28px) scale(0.94);
  transition:opacity .7s var(--ease-out),
             transform .85s cubic-bezier(0.34, 1.46, 0.64, 1);
}
.pop.pop--in{
  opacity:1;
  transform:translateY(0) scale(1);
}

.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease-out), transform .8s var(--ease-out)}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* =====================================================================
   REDUCED MOTION
   ===================================================================== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
  .hero{height:100vh}
  .hero__sticky{position:relative}
  .hero__stage{position:relative;opacity:1;transform:none}
  .hero__stage:not(:first-child){display:none}
  .about__visual{position:static}
}

@media (max-width:560px){
  .hero__content{padding:0 24px}
  .section__head{padding:0 24px}
}

/* =====================================================================
   HERO — MOBILE TUNING (smooth scrub, no URL-bar jumps, wider crop)
   ===================================================================== */
@media (max-width:768px){
  /* Use small viewport height to prevent jumps when iOS URL bar shows/hides.
     Total hero stays "2 scrolls" but anchored to the stable viewport. */
  .hero{ height:200svh; height:200vh; }   /* fallback for older browsers */
  .hero__sticky{ height:100svh; height:100vh; }

  /* Show MORE of the video frame on mobile — wider, less aggressive crop.
     Use contain-style sizing: video fills width, height auto-centers.
     This makes the dish read as wider and more cinematic on phones. */
  .hero__videoWrap{
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .hero__video{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
    transform:translate3d(0,0,0) scale(1.04);
  }

  /* Title scales down so 2-line layout doesn't overflow on small phones */
  .hero__title{ font-size:clamp(38px, 11vw, 64px); line-height:0.98 }
  .hero__sub{ font-size:14px; line-height:1.55 }
  .hero__stages{ min-height:300px }

  /* Hide scroll hint sooner on mobile — it overlaps the bottom safe area */
  .hero__scrollHint{ bottom:18px; font-size:9px }
}

@media (max-width:420px){
  .hero__stages{ min-height:320px }
  .hero__title{ font-size:clamp(34px, 10vw, 52px) }
}


/* =====================================================================
   PREMIUM ANIMATIONS  — word split + dish tilt + ripple + grain
   ===================================================================== */

/* Word-by-word title reveal */
.section__title .word{
  display:inline-block;
  overflow:hidden;
  vertical-align:bottom;
  padding-bottom:0.06em;
  margin-right:0.22em;
}
.section__title .word > span{
  display:inline-block;
  transform:translateY(110%);
  opacity:0;
  transition:transform 0.9s cubic-bezier(0.22, 1, 0.36, 1),
             opacity 0.9s var(--ease-out);
}
.section__title.is-in .word > span{
  transform:translateY(0);
  opacity:1;
}
/* stagger via nth */
.section__title.is-in .word:nth-child(1) > span{transition-delay:0.05s}
.section__title.is-in .word:nth-child(2) > span{transition-delay:0.13s}
.section__title.is-in .word:nth-child(3) > span{transition-delay:0.21s}
.section__title.is-in .word:nth-child(4) > span{transition-delay:0.29s}
.section__title.is-in .word:nth-child(5) > span{transition-delay:0.37s}
.section__title.is-in .word:nth-child(6) > span{transition-delay:0.45s}
.section__title.is-in .word:nth-child(7) > span{transition-delay:0.53s}
.section__title.is-in .word:nth-child(8) > span{transition-delay:0.61s}

/* Dish 3D tilt */
.dish{transform-style:preserve-3d}
.dish__media, .dish__body{transform-style:preserve-3d}
.dish__name{transition:transform 0.3s var(--ease-out)}
.dish:hover .dish__name{transform:translateZ(20px)}

/* Magnetic button ripple */
.magnetic{position:relative;overflow:hidden;isolation:isolate}
.magnetic .ripple{
  position:absolute;
  border-radius:50%;
  transform:scale(0);
  animation:rippleExpand 0.7s ease-out forwards;
  background:radial-gradient(circle, rgba(255,255,255,0.4), transparent 70%);
  pointer-events:none;
  z-index:0;
}
@keyframes rippleExpand{
  to{transform:scale(4);opacity:0}
}

/* Cinematic film grain overlay */
.grain{
  position:fixed;
  inset:-50%;
  width:200%;
  height:200%;
  pointer-events:none;
  z-index:9998;
  opacity:0.04;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' seed='3'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.5'/></svg>");
  animation:grainShift 8s steps(8) infinite;
}
@keyframes grainShift{
  0%   {transform:translate(0%, 0%)}
  10%  {transform:translate(-2%, -3%)}
  20%  {transform:translate(-4%, 2%)}
  30%  {transform:translate(2%, -4%)}
  40%  {transform:translate(-2%, 5%)}
  50%  {transform:translate(-4%, 2%)}
  60%  {transform:translate(3%, 0%)}
  70%  {transform:translate(0%, 3%)}
  80%  {transform:translate(-3%, 0%)}
  90%  {transform:translate(2%, 2%)}
  100% {transform:translate(0%, 0%)}
}

@media (prefers-reduced-motion: reduce){
  .grain{display:none}
  .section__title .word > span{transform:none;opacity:1}
}
/* =====================================================================
   PERFORMANCE — GPU layers, paint containment, smooth scroll
   ===================================================================== */
.hero__video{will-change:transform}
.cursor,.cursor--dot{will-change:transform}
.nav{will-change:background,height}
.dish,.loc,.rcard,.member{contain:layout style}
.marquee__track{will-change:transform}
.reviews__grid{will-change:transform}
/* Reduce grain animation cost on low-end */
@media (prefers-reduced-motion: no-preference){
  .grain{animation-duration:12s}
}
/* Float button position fix after removing WhatsApp btn */
.float--top{bottom:24px}

/* =====================================================================
   MOBILE OPTIMISATION  (≤768px)
   - Larger tap targets
   - Remove hover-only effects that cause jank on touch
   - Smoother touch scrolling
   - Reduce repaints: kill grain + film animations on mobile
   - Better spacing and readability on small screens
   ===================================================================== */
@media (max-width:768px){
  /* Smooth native scroll on iOS */
  html{-webkit-overflow-scrolling:touch}

  /* Kill expensive grain on mobile — biggest perf win */
  .grain{display:none}

  /* Disable cursor (already touch-hidden, but ensure no rAF loop) */
  .cursor,.cursor--dot{display:none!important}

  /* Nav — compact, no overflow */
  .nav{padding:0 16px;height:64px}
  .nav__logo{width:56px;height:56px}
  .nav.is-scrolled .nav__logo{width:44px;height:44px}
  .nav__wordmark strong{font-size:15px}
  .nav__wordmark span{font-size:7px;letter-spacing:0.28em}
  .nav.is-scrolled{height:52px}

  /* Burger — bigger tap target */
  .nav__burger{width:44px;height:44px}

  /* Hero content padding */
  .hero__content{padding:0 20px;gap:24px}
  .hero__stages{min-height:260px}
  .hero__title{font-size:clamp(36px,10vw,60px)}
  .hero__sub{font-size:13px;line-height:1.5;max-width:34ch}

  /* CTA buttons — full width on mobile */
  .hero__ctas{flex-direction:column;width:100%;gap:10px}
  .hero__ctas .btn{width:100%;justify-content:center}

  /* Section padding tighter */
  .section__head{padding:0 20px}
  .section__title{font-size:clamp(28px,8vw,48px)}

  /* Menu grid — single column */
  .menu__grid{grid-template-columns:1fr}
  .menu__feature .dish--feature{flex-direction:column}
  .menu__tabs{padding:0 20px;gap:6px;flex-wrap:wrap}
  .menu__tab{font-size:11px;padding:7px 14px}

  /* Location cards — full width, bigger tap */
  .loc__ctas{gap:8px}
  .loc__btn{padding:10px 16px;font-size:13px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}

  /* Contact form — single col already at 980px, tighten further */
  .contact__form{padding:20px;gap:14px}
  .field input,.field select,.field textarea{padding:13px 14px;font-size:16px}/* 16px prevents iOS zoom */

  /* Footer */
  .foot{padding:40px 20px 24px}

  /* Reviews marquee — reduce speed for readability */
  .reviews__grid{animation-duration:28s}

  /* Drawer font size comfortable on mobile */
  .drawer__links a{font-size:26px}
}

@media (max-width:480px){
  .hero__title{font-size:clamp(32px,9.5vw,52px)}
  .hero__stages{min-height:280px}
  .nav__wordmark span{letter-spacing:0.2em}
  .menu__feature{display:block} /* keep Beef Ribs Mandi visible on mobile */
  .dish--feature{grid-template-columns:1fr;} /* already set above but ensure stack layout */
  .dish--feature .dish__media{aspect-ratio:16/10;min-height:0}
  .dish--feature .dish__body{padding:20px}
  .contact__inner{padding:0 4px}
}

/* Touch: disable 3D tilt (causes jank, not useful on touch) */
@media (hover:none) and (pointer:coarse){
  .dish{transform:none!important;transition:none}
  .magnetic{transform:none!important}
  .pop{opacity:1;transform:none;transition:opacity .4s ease}
  .pop.pop--in{opacity:1;transform:none}
}
