/* Hallmark · pre-emit critique: P5 H4 E4 S4 R4 V5 */
/* Hallmark · macrostructure: Marquee Hero · genre: editorial · theme: Sport
 * tone: bold-appetite · anchor hue: ember-orange
 * diversifies from sofa-demo on: display style (condensed-sans vs italic-serif) + accent hue (ember vs sage) */

:root{
  --color-paper:oklch(97.5% 0.005 95);--color-paper-2:oklch(99% 0.003 95);--color-paper-3:oklch(94.5% 0.006 95);
  --color-char:oklch(14% 0.007 50);--color-char-2:oklch(20% 0.01 48);
  --color-ink:oklch(17% 0.008 50);--color-ink-70:oklch(17% 0.008 50 / 0.70);--color-ink-45:oklch(17% 0.008 50 / 0.45);
  --color-cream-70:oklch(97.5% 0.005 95 / 0.74);--color-cream-45:oklch(97.5% 0.005 95 / 0.50);
  --color-accent:oklch(68% 0.215 50);--color-accent-2:oklch(57% 0.21 36);
  --color-line:oklch(17% 0.008 50 / 0.12);--color-line-2:oklch(17% 0.008 50 / 0.26);--color-line-dk:oklch(97.5% 0.005 95 / 0.16);
  --color-focus:oklch(68% 0.215 50);
  --font-display:"Anton","Arial Narrow",system-ui,sans-serif;
  --font-body:"Archivo",system-ui,-apple-system,Segoe UI,sans-serif;
  --text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.1875rem;--text-xl:1.5rem;--text-2xl:2rem;
  --text-3xl:2.75rem;--text-4xl:clamp(2.5rem,6vw,4.5rem);--text-display-s:clamp(3rem,9vw,6rem);--text-display:clamp(3.75rem,14vw,11rem);
  --space-2xs:4px;--space-xs:8px;--space-sm:16px;--space-md:24px;--space-lg:40px;--space-xl:64px;--space-2xl:96px;--space-3xl:144px;
  --dur-short:160ms;--dur-mid:320ms;--dur-long:640ms;
  --ease-out:cubic-bezier(0.22,0.61,0.36,1);--ease-in:cubic-bezier(0.55,0.06,0.68,0.19);--ease-in-out:cubic-bezier(0.65,0.05,0.36,1);
  --rule-hair:1px;--rule-thick:6px;--radius:4px;--radius-lg:10px;
  --z-base:1;--z-raise:10;--z-nav:40;--z-top:60;
}

*{box-sizing:border-box;margin:0;padding:0}
a{text-decoration:none}
html,body{overflow-x:clip}
html{scroll-behavior:auto}   /* NOT smooth: CSS smooth-scroll fights ScrollTrigger's pin/scrub and causes jumps */
body{font-family:var(--font-body);color:var(--color-ink);background:var(--color-paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.55}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:1280px;margin:0 auto;padding:0 var(--space-lg)}
@media(max-width:768px){.wrap{padding:0 var(--space-md)}}

.display{font-family:var(--font-display);font-weight:400;line-height:0.92;letter-spacing:0.005em;
  text-transform:uppercase;overflow-wrap:anywhere;min-width:0}
.eyebrow{font-family:var(--font-body);font-weight:700;font-size:var(--text-xs);letter-spacing:0.28em;
  text-transform:uppercase;color:var(--color-accent-2)}

/* ---------- NAV · N9 edge-aligned minimal ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);
  display:flex;justify-content:space-between;align-items:center;
  padding:var(--space-md) var(--space-lg);
  transition:background var(--dur-mid) var(--ease-out), padding var(--dur-mid) var(--ease-out), border-color var(--dur-mid);
  border-bottom:var(--rule-hair) solid transparent}
.nav.scrolled{background:var(--color-paper);border-bottom-color:var(--color-line);padding-top:var(--space-sm);padding-bottom:var(--space-sm)}
.nav .mark{font-family:var(--font-display);font-size:var(--text-2xl);letter-spacing:0.06em;color:var(--color-paper);line-height:1}
.nav.scrolled .mark{color:var(--color-ink)}
.nav .navlinks{display:flex;gap:var(--space-lg);align-items:center}
.nav .navlinks a{font-weight:600;font-size:var(--text-sm);letter-spacing:0.04em;text-decoration:none;color:var(--color-cream-70);
  text-transform:uppercase;white-space:nowrap;transition:color var(--dur-short)}
.nav.scrolled .navlinks a{color:var(--color-ink-70)}
.nav .navlinks a:hover{color:var(--color-accent)}
.nav .book{font-weight:700;font-size:var(--text-sm);letter-spacing:0.04em;text-transform:uppercase;white-space:nowrap;
  text-decoration:none;color:var(--color-char);background:var(--color-accent);padding:var(--space-xs) var(--space-md);
  border-radius:var(--radius);transition:background var(--dur-short) var(--ease-out), transform var(--dur-short) var(--ease-out)}
.nav .book:hover{background:var(--color-accent-2);transform:translateY(-1px)}
.nav a:focus-visible,.book:focus-visible{outline:2px solid var(--color-focus);outline-offset:3px}
/* hamburger */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:var(--space-xs);border-radius:var(--radius);-webkit-tap-highlight-color:transparent}
.nav-burger span{display:block;width:22px;height:2px;background:var(--color-paper);border-radius:1px;transition:transform var(--dur-short) var(--ease-out),opacity var(--dur-short)}
.nav.scrolled .nav-burger span{background:var(--color-ink)}
.nav.open .nav-burger span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav.open .nav-burger span:nth-child(2){opacity:0}
.nav.open .nav-burger span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
@media(max-width:768px){
  .nav{padding:var(--space-sm) var(--space-md)}
  .nav .navlinks{gap:var(--space-sm)}
  .nav .navlinks a:not(.book){display:none}
  .nav .book{min-height:40px;display:inline-flex;align-items:center}
  .nav-burger{display:flex}
  /* open state — full-width dropdown panel anchored under the bar */
  .nav.open .navlinks{position:absolute;left:0;right:0;top:100%;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--color-char);padding:var(--space-2xs) var(--space-md) var(--space-md);
    border-top:var(--rule-hair) solid var(--color-line-dk);box-shadow:0 24px 44px oklch(0% 0 0 / 0.45)}
  .nav.open .navlinks a:not(.book){display:block;padding:var(--space-md) 0;
    border-bottom:var(--rule-hair) solid var(--color-line-dk);color:var(--color-cream-70) !important;
    font-size:var(--text-base);letter-spacing:0.06em;text-transform:uppercase;font-weight:600}
  .nav.open .navlinks .book{margin-top:var(--space-md);text-align:center;min-height:46px;display:flex;align-items:center;justify-content:center}
}

/* ---------- HERO · Marquee Hero, scroll-scrubbed video ---------- */
.hero{position:relative;height:100vh;min-height:560px}
body.pinned .hero{height:100vh}   /* scroll distance comes from ScrollTrigger end:'+=300%', not an explicit tall height (avoids a double pin-spacer / blank gap) */
.hero-stage{position:relative;height:100vh;min-height:560px;overflow:hidden;background:var(--color-char)}
.hero-stage canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:var(--z-base)}
body.no-seq .hero-stage canvas{visibility:hidden}

/* CSS ember fallback — glowing coals, shown until a real hero.mp4 exists */
.hero-fallback{position:absolute;inset:0;z-index:var(--z-base);display:none;
  background:
    radial-gradient(120% 90% at 50% 118%, var(--color-accent) 0%, var(--color-accent-2) 22%, transparent 52%),
    radial-gradient(70% 55% at 22% 108%, oklch(72% 0.2 50) 0%, transparent 46%),
    radial-gradient(60% 50% at 80% 112%, oklch(64% 0.18 38) 0%, transparent 44%),
    linear-gradient(180deg, oklch(16% 0.01 50) 0%, oklch(22% 0.02 45) 60%, oklch(30% 0.05 42) 100%)}
body.no-seq .hero-fallback{display:block}
.hero-fallback::after{content:"";position:absolute;inset:0;mix-blend-mode:multiply;opacity:0.4;
  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='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.6'/></svg>");
  animation:flicker 4s var(--ease-in-out) infinite}
@keyframes flicker{0%,100%{opacity:0.34}50%{opacity:0.46}}
.hero-scrim{position:absolute;inset:0;z-index:var(--z-raise);pointer-events:none;
  background:linear-gradient(180deg, oklch(18% 0.01 50 / 0.55) 0%, transparent 26%, transparent 52%, oklch(18% 0.01 50 / 0.78) 100%)}

/* hero content holds the swapping title "beats" */
.hero-content{position:absolute;inset:0;z-index:var(--z-raise);pointer-events:none}
.beats{position:absolute;inset:0}
.beat{position:absolute;bottom:var(--space-2xl);max-width:min(52ch,90vw);opacity:0;will-change:opacity,transform}
.beat[data-i="0"]{opacity:1}
.beat[data-side="left"]{left:var(--space-lg);text-align:left}
.beat[data-side="right"]{right:var(--space-lg);text-align:right}
.beat-num{font-family:var(--font-body);font-weight:700;font-size:var(--text-xs);letter-spacing:0.28em;text-transform:uppercase;color:var(--color-accent)}
.beat-title{font-family:var(--font-display);text-transform:uppercase;color:var(--color-paper);
  font-size:clamp(2.5rem,6.5vw,6rem);line-height:0.9;letter-spacing:0.01em;margin-top:var(--space-sm);overflow-wrap:anywhere;min-width:0}
.beat-sub{font-family:var(--font-body);font-weight:500;font-size:var(--text-xl);color:var(--color-cream-70);margin-top:var(--space-md);max-width:36ch}
.beat[data-side="right"] .beat-sub{margin-left:auto}
.beat-cta{pointer-events:auto;margin-top:var(--space-lg)}
.hero-cue{position:absolute;left:50%;bottom:var(--space-md);transform:translateX(-50%);display:flex;align-items:center;gap:var(--space-sm);
  color:var(--color-cream-45);font-size:var(--text-sm);letter-spacing:0.2em;text-transform:uppercase}
.hero-cue .scroll-dot{width:22px;height:36px;border:var(--rule-hair) solid var(--color-cream-45);border-radius:999px;position:relative;flex:none}
.hero-cue .scroll-dot::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:2px;
  background:var(--color-accent);transform:translateX(-50%);animation:dot 1.8s var(--ease-in-out) infinite}
@keyframes dot{0%,100%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,9px)}}
body.static-hero .hero-cue,body.no-seq .hero-cue{display:none}
@media(max-width:768px){
  .beat{bottom:var(--space-xl);max-width:90vw}
  .beat[data-side="left"],.beat[data-side="right"]{left:var(--space-md);right:var(--space-md);text-align:left}
  .beat[data-side="right"] .beat-sub{margin-left:0}
  .beat-sub{font-size:var(--text-base);max-width:32ch}
}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--color-char);color:var(--color-paper);border-top:var(--rule-thick) solid var(--color-accent);
  padding:var(--space-md) 0;overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-block;will-change:transform;animation:slide 26s linear infinite}
.marquee-track span{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-2xl);letter-spacing:0.04em;padding:0 var(--space-md)}
.marquee-track .sep{color:var(--color-accent)}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none;padding-left:var(--space-lg)}}

/* ---------- A CASA · story ---------- */
.casa{position:relative;background:var(--color-char);color:var(--color-paper);padding-block:var(--space-3xl);overflow:hidden}
.casa::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(115% 75% at 82% -8%, var(--color-accent) 0%, oklch(48% 0.17 45 / 0.34) 16%, transparent 52%)}
.casa>*{position:relative;z-index:1}
.casa-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:var(--space-2xl);align-items:center}
.casa .eyebrow{color:var(--color-accent)}
.casa h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2.75rem,6vw,5rem);line-height:0.84;letter-spacing:0.005em;color:var(--color-paper);margin-top:var(--space-sm)}
.casa h2 .em{color:var(--color-accent)}
.casa .lead{font-size:var(--text-lg);color:var(--color-cream-70);margin-top:var(--space-lg);max-width:48ch}
.casa .lead + p{margin-top:var(--space-md);color:var(--color-cream-45);max-width:48ch}
.casa-facts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-md);
  border-top:var(--rule-hair) solid var(--color-line-dk);padding-top:var(--space-lg);margin-top:var(--space-xl)}
.casa-facts .n{font-family:var(--font-display);font-size:clamp(2.5rem,5vw,3.25rem);color:var(--color-accent);line-height:1;font-variant-numeric:tabular-nums}
.casa-facts .n .u{color:var(--color-paper)}
.casa-facts .k{font-size:var(--text-xs);letter-spacing:0.16em;text-transform:uppercase;color:var(--color-cream-45);margin-top:var(--space-2xs)}
.casa-hero{position:relative;align-self:stretch;min-height:clamp(440px,50vw,640px);display:flex;align-items:flex-end;justify-content:center}
.casa-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:20%;z-index:3;pointer-events:none;
  background:linear-gradient(to top,var(--color-char) 6%,transparent)}
.casa-fighter{position:relative;z-index:2;max-height:min(70vh,640px);width:auto;max-width:100%;object-fit:contain;filter:drop-shadow(0 28px 38px oklch(0% 0 0 / 0.55))}
.casa-medallion{position:absolute;z-index:4;left:0;bottom:14%;width:clamp(150px,17vw,224px);aspect-ratio:1;border-radius:50%;overflow:hidden;border:3px solid var(--color-accent);box-shadow:0 18px 42px oklch(0% 0 0 / 0.6)}
.casa-medallion video{width:100%;height:100%;object-fit:cover;display:block}
.casa-medallion .cap{position:absolute;inset:auto 0 0 0;z-index:1;text-align:center;font-size:0.56rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--color-paper);background:linear-gradient(to top,oklch(0% 0 0 / 0.78),transparent);padding:var(--space-sm) 0 var(--space-2xs)}
@media(max-width:900px){
  .casa-grid{grid-template-columns:1fr;gap:var(--space-xl)}
  .casa-hero{order:-1;min-height:auto;padding-top:var(--space-md)}
  .casa-fighter{max-height:58vh}
  .casa-medallion{left:auto;right:4%;bottom:18%}
}
@media(max-width:480px){.casa-facts{grid-template-columns:1fr;gap:var(--space-sm)}}

/* ---------- O FOGO · menu ---------- */
.fogo{background:var(--color-char);color:var(--color-paper);padding:var(--space-3xl) 0}
.fogo .head{text-align:center;margin-bottom:var(--space-2xl)}
.fogo .head .eyebrow{display:block;color:var(--color-accent);margin-bottom:var(--space-sm)}
.fogo .head h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(3.25rem,10vw,9rem);line-height:0.86;letter-spacing:0.01em}
.fogo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-2xl) var(--space-lg)}
.dish{display:flex;flex-direction:column;transition:transform var(--dur-mid) var(--ease-out)}
.dish-img{position:relative;aspect-ratio:4/3;display:grid;place-items:center}
.dish-img::before{content:"";position:absolute;inset:-6%;z-index:0;background:url(images/menu/splash.png) center/contain no-repeat;--r:0deg;transform:rotate(var(--r));transition:transform var(--dur-long) var(--ease-out);opacity:0.96}
.dish:nth-child(2n) .dish-img::before{--r:-16deg}.dish:nth-child(3n) .dish-img::before{--r:13deg}.dish:nth-child(5n) .dish-img::before{--r:-9deg}
.dish-img img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 16px 20px rgba(0,0,0,0.5));transition:transform var(--dur-mid) var(--ease-out)}
.dish:hover .dish-img img{transform:scale(1.08) translateY(-5px)}
.dish:hover .dish-img::before{transform:rotate(var(--r)) scale(1.07)}
.dish:hover{transform:translateY(-6px)}
.dish-num{font-family:var(--font-body);font-weight:700;font-size:var(--text-xs);letter-spacing:0.2em;text-transform:uppercase;color:var(--color-cream-45);margin-top:var(--space-md)}
.dish-name{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-3xl);line-height:0.9;letter-spacing:0.01em;margin-top:var(--space-2xs);color:var(--color-paper)}
.dish-desc{font-size:var(--text-sm);color:var(--color-cream-70);margin-top:var(--space-xs);line-height:1.5;max-width:36ch}
.dish-price{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-sm);border-top:var(--rule-hair) solid var(--color-line-dk)}
.dish-price span{font-size:var(--text-xs);letter-spacing:0.16em;text-transform:uppercase;color:var(--color-cream-45)}
.dish-price b{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-accent);font-variant-numeric:tabular-nums}
.fogo-note{margin-top:var(--space-2xl);color:var(--color-cream-45);font-size:var(--text-xs);letter-spacing:0.06em;text-align:center}
@media(max-width:900px){.fogo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.fogo-grid{grid-template-columns:1fr}.fogo .head h2{font-size:clamp(2.75rem,14vw,5rem)}}
/* ---------- MENU · infinite-scroll strip (homepage teaser; full list lives on menu.html) ---------- */
.dish-strip{overflow:hidden;position:relative;margin:0 calc(-1*var(--space-lg))}
.dish-strip::before,.dish-strip::after{content:"";position:absolute;top:0;bottom:0;width:64px;z-index:2;pointer-events:none}
.dish-strip::before{left:0;background:linear-gradient(90deg,var(--color-char),transparent)}
.dish-strip::after{right:0;background:linear-gradient(270deg,var(--color-char),transparent)}
.dish-track2{display:flex;gap:var(--space-lg);width:max-content;padding:0 var(--space-lg);animation:dishscroll 60s linear infinite}
.dish-strip:hover .dish-track2{animation-play-state:paused}
.dish-track2 .dish{width:clamp(220px,72vw,290px);flex:none;height:clamp(380px,96vw,430px)}
.dish-track2 .dish-desc{display:none}
.dish-track2 .dish-num{margin-top:var(--space-sm)}
.dish-track2 .dish-price{margin-top:auto}
@keyframes dishscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.fogo-cta{text-align:center;margin-top:var(--space-2xl)}
@media(prefers-reduced-motion:reduce){.dish-strip{overflow-x:auto}.dish-track2{animation:none}}

/* ---------- GALLERY ---------- */
.gallery{padding:var(--space-3xl) 0 var(--space-2xl)}
.gallery .head{margin-bottom:var(--space-lg)}
.gallery .head h2{font-size:var(--text-4xl);color:var(--color-ink);margin-top:var(--space-sm)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-auto-rows:220px;gap:var(--space-sm)}
.shot{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--color-paper-3);
  display:grid;place-items:center;border:var(--rule-hair) solid var(--color-line)}
.shot.tall{grid-row:span 2}
.shot.wide{grid-column:span 2}
.shot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform var(--dur-long) var(--ease-out)}
.shot:hover img{transform:scale(1.07)}
.shot::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 46%,oklch(16% 0.01 50 / 0.82) 100%);transition:opacity var(--dur-mid)}
.shot:hover::after{opacity:0.78}
.shot .cap{position:absolute;left:0;bottom:0;z-index:1;padding:var(--space-sm) var(--space-md);font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-lg);letter-spacing:0.04em;color:var(--color-paper);transition:transform var(--dur-mid) var(--ease-out)}
.shot:hover .cap{transform:translateY(-4px)}
@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:auto}.shot{aspect-ratio:3/2}.shot.tall,.shot.wide{grid-column:auto;grid-row:auto}}
@media(max-width:560px){
  .gallery-grid{grid-template-columns:1fr;gap:var(--space-xs)}
  .shot{aspect-ratio:auto}                                   /* let height follow the photo */
  .shot img{position:relative;width:100%;height:auto;object-fit:contain}  /* show the WHOLE photo, no crop/cutout */
}

/* ---------- AVIS · pull quotes (no fake aggregate rating) ---------- */
.avis{padding:var(--space-2xl) 0 var(--space-3xl)}
.avis .eyebrow{display:block;text-align:center}
.avis-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-lg);margin-top:var(--space-xl)}
.quote{border-top:var(--rule-thick) solid var(--color-accent);padding-top:var(--space-md)}
.quote p{font-size:var(--text-lg);line-height:1.45;color:var(--color-ink)}
.quote .who{margin-top:var(--space-md);font-size:var(--text-sm);color:var(--color-ink-70);text-transform:uppercase;letter-spacing:0.1em}
@media(max-width:900px){.avis-grid{grid-template-columns:1fr;gap:var(--space-md)}}

/* ---------- VISITE / RESERVATION · full orange location block ---------- */
.visite{background:var(--color-accent);color:var(--color-char);padding:var(--space-3xl) 0}
.visite-title{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(3.25rem,11vw,10rem);line-height:0.84;letter-spacing:0.005em;color:var(--color-char);overflow-wrap:anywhere;min-width:0;max-width:14ch}
.visite-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-lg);margin-top:var(--space-xl);padding-top:var(--space-md);border-top:var(--rule-thick) solid var(--color-char)}
.vr{display:flex;flex-direction:column;gap:var(--space-2xs)}
.vr-k{font-family:var(--font-body);font-weight:700;font-size:var(--text-xs);letter-spacing:0.22em;text-transform:uppercase;color:oklch(20% 0.012 55 / 0.66)}
.vr-v{font-size:var(--text-lg);color:var(--color-char);font-weight:600}
.vr-cta{font-family:var(--font-body);font-weight:700;text-transform:uppercase;letter-spacing:0.04em;font-size:var(--text-lg);color:var(--color-char);text-decoration:none;border-bottom:3px solid var(--color-char);padding-bottom:3px;width:fit-content;white-space:nowrap;transition:color var(--dur-short),border-color var(--dur-short)}
.vr-cta:hover{color:var(--color-paper);border-color:var(--color-paper)}
.cta{display:inline-flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-lg);
  font-family:var(--font-body);font-weight:700;font-size:var(--text-base);letter-spacing:0.04em;text-transform:uppercase;white-space:nowrap;
  text-decoration:none;color:var(--color-char);background:var(--color-accent);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius);
  transition:background var(--dur-short) var(--ease-out), transform var(--dur-short) var(--ease-out)}
.cta:hover{background:var(--color-paper);transform:translateY(-1px)}
.cta:focus-visible{outline:2px solid var(--color-paper);outline-offset:3px}
@media(max-width:760px){.visite-row{grid-template-columns:1fr;gap:var(--space-md)}}

/* ---------- FOOTER · statement + oversized off-edge wordmark ---------- */
footer{background:var(--color-char);color:var(--color-paper);padding:var(--space-2xl) 0 0;overflow:hidden}
footer .statement{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-4xl);line-height:0.94;color:var(--color-paper);max-width:18ch}
footer .statement .em{color:var(--color-accent)}
footer .foot-row{display:flex;flex-wrap:wrap;gap:var(--space-lg);justify-content:space-between;align-items:baseline;
  margin-top:var(--space-xl);padding-top:var(--space-md);border-top:var(--rule-hair) solid var(--color-line-dk);color:var(--color-cream-70);font-size:var(--text-sm)}
footer .foot-row a{color:inherit;text-decoration:none;white-space:nowrap;text-transform:uppercase;letter-spacing:0.08em;font-weight:600}
footer .foot-row a:hover{color:var(--color-accent)}
footer .foot-copy{color:var(--color-cream-45)}
footer .foot-mark{font-family:var(--font-display);text-transform:uppercase;color:var(--color-accent);
  font-size:clamp(3rem,15.5vw,12rem);line-height:0.82;letter-spacing:0.01em;white-space:nowrap;text-align:center;
  margin-top:var(--space-xl);padding-bottom:var(--space-lg);user-select:none}
footer .legal{margin-top:var(--space-md);padding-bottom:var(--space-md);font-size:var(--text-xs);color:var(--color-cream-45)}

/* ---------- INSTAGRAM STRIP ---------- */
.insta{padding-block:var(--space-2xl)}
.insta-head{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-lg);flex-wrap:wrap}
.insta-head h2{font-size:var(--text-4xl);color:var(--color-ink);margin-top:var(--space-sm)}
.insta-head h2 .em{color:var(--color-accent)}
.insta-cta{font-family:var(--font-body);font-weight:700;text-transform:uppercase;letter-spacing:0.04em;font-size:var(--text-lg);
  color:var(--color-ink);text-decoration:none;border-bottom:3px solid var(--color-accent);padding-bottom:3px;white-space:nowrap;transition:color var(--dur-short)}
.insta-cta:hover{color:var(--color-accent)}
.insta-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:var(--space-sm);margin-top:var(--space-lg)}
.ig{position:relative;aspect-ratio:1;overflow:hidden;border-radius:var(--radius);display:block;background:var(--color-paper-3)}
.ig img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-mid) var(--ease-out)}
.ig::after{content:"";position:absolute;inset:0;background:var(--color-accent);opacity:0;mix-blend-mode:multiply;transition:opacity var(--dur-mid)}
.ig:hover img{transform:scale(1.09)}
.ig:hover::after{opacity:0.2}
@media(max-width:760px){.insta-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}

/* ---------- STICKY WHATSAPP ORDER BUTTON ---------- */
.wa-fab{position:fixed;right:clamp(14px,3vw,28px);bottom:clamp(14px,3vw,28px);z-index:var(--z-top);
  display:inline-flex;align-items:center;gap:var(--space-xs);text-decoration:none;white-space:nowrap;
  background:var(--color-accent);color:var(--color-char);font-family:var(--font-body);font-weight:700;
  text-transform:uppercase;letter-spacing:0.04em;font-size:var(--text-sm);
  padding:var(--space-sm) var(--space-md);border-radius:999px;box-shadow:0 12px 34px oklch(20% 0.012 55 / 0.4);
  transform:translateY(150%);opacity:0;transition:transform var(--dur-mid) var(--ease-out),opacity var(--dur-mid),background var(--dur-short)}
body.past-hero .wa-fab{transform:translateY(0);opacity:1}
.wa-fab:hover{background:var(--color-accent-2)}
.wa-fab:focus-visible{outline:2px solid var(--color-char);outline-offset:3px}
.wa-fab svg{width:18px;height:18px;display:block;fill:currentColor}
@media(prefers-reduced-motion:reduce){.wa-fab{transition:opacity 150ms linear}}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto}
  .hero-fallback::after,.hero-cue .scroll-dot::after{animation:none}
  .hero-state{transition:opacity 150ms linear;transform:none}
}

/* ---------- CREED · "Why Ali's" dark manifesto band ---------- */
.creed{background:#DC5C14;color:var(--color-char);padding:var(--space-3xl) 0}
.creed .eyebrow{color:var(--color-char);opacity:0.82}
.creed-head{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-4xl);line-height:0.92;letter-spacing:0.005em;color:var(--color-char);margin-top:var(--space-sm);max-width:16ch}
.creed-head .em{color:var(--color-paper)}
.creed-list{margin-top:var(--space-2xl)}
.creed-line{display:grid;grid-template-columns:2.5rem 1fr;column-gap:var(--space-lg);align-items:baseline;padding:var(--space-lg) 0;border-top:var(--rule-hair) solid oklch(20% 0.03 45 / 0.32)}
.creed-line:last-of-type{border-bottom:var(--rule-hair) solid oklch(20% 0.03 45 / 0.32)}
.creed-num{font-family:var(--font-body);font-weight:700;font-size:var(--text-sm);letter-spacing:0.16em;color:var(--color-paper)}
.creed-main{min-width:0}
.creed-title{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.8rem,4.8vw,3.25rem);line-height:0.98;letter-spacing:0.01em;color:var(--color-char);overflow-wrap:anywhere}
.creed-sub{margin-top:var(--space-xs);font-size:var(--text-lg);line-height:1.5;color:oklch(18% 0.02 45 / 0.82);max-width:52ch}
.creed-foot{display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap;margin-top:var(--space-2xl)}
.creed-cta{font-family:var(--font-body);font-weight:700;text-transform:uppercase;letter-spacing:0.04em;font-size:var(--text-lg);color:var(--color-paper);background:var(--color-char);text-decoration:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius);white-space:nowrap;transition:background var(--dur-short) var(--ease-out),transform var(--dur-short) var(--ease-out)}
.creed-cta:hover{background:var(--color-char-2);transform:translateY(-1px)}
.creed-cta:focus-visible{outline:2px solid var(--color-paper);outline-offset:3px}
.creed-aside{font-size:var(--text-sm);letter-spacing:0.04em;color:oklch(18% 0.02 45 / 0.62)}
@media(max-width:680px){
  .creed-line{grid-template-columns:1fr;row-gap:var(--space-2xs)}
}

/* ---------- SCROLL REVEAL · progressive-enhancement, reduced-motion safe ---------- */
body.reveal-on [data-reveal]{opacity:0;transform:translateY(16px);transition:opacity 0.7s var(--ease-out),transform 0.7s var(--ease-out)}
body.reveal-on [data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){body.reveal-on [data-reveal]{opacity:1;transform:none;transition:none}}
/* ---------- LOCATIONS · real branches ---------- */
.locations{padding-block:var(--space-3xl)}
.locations .head{margin-bottom:var(--space-xl)}
.locations .head h2{font-size:var(--text-4xl);color:var(--color-ink);margin-top:var(--space-sm)}
.locations .head h2 .em{color:var(--color-accent)}
.loc-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-md)}
.loc{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-lg);border:var(--rule-hair) solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-paper-2);transition:transform var(--dur-mid) var(--ease-out),border-color var(--dur-mid),box-shadow var(--dur-mid)}
.loc:hover{transform:translateY(-4px);border-color:var(--color-accent);box-shadow:0 14px 30px var(--color-line)}
.loc-top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}
.loc-name{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-2xl);line-height:0.95;color:var(--color-ink)}
.loc-badge{font-size:var(--text-xs);font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--color-ink-45);white-space:nowrap}
.loc.halal .loc-badge{color:var(--color-char);background:var(--color-accent);padding:2px 8px;border-radius:999px}
.loc-addr{font-size:var(--text-sm);color:var(--color-ink-70);line-height:1.5}
.loc-hours{font-size:var(--text-xs);letter-spacing:0.08em;text-transform:uppercase;color:var(--color-ink-45)}
.loc-foot{margin-top:auto;padding-top:var(--space-sm);display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-sm);border-top:var(--rule-hair) solid var(--color-line)}
.loc-tel{font-weight:700;font-size:var(--text-sm);color:var(--color-ink);font-variant-numeric:tabular-nums;text-decoration:none}
.loc-tel:hover{color:var(--color-accent)}
.loc-dir{font-weight:700;font-size:var(--text-sm);letter-spacing:0.04em;text-transform:uppercase;color:var(--color-accent-2);white-space:nowrap;text-decoration:none}
.loc-dir:hover{color:var(--color-accent)}
@media(max-width:900px){.loc-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.loc-grid{grid-template-columns:1fr}}

/* ---------- CHAMPIONS · 3D coverflow slider ---------- */
.champ{background:var(--color-char);color:var(--color-paper);padding:var(--space-3xl) 0;overflow:hidden}
.champ .head{text-align:center;margin-bottom:var(--space-2xl)}
.champ .head .eyebrow{color:var(--color-accent);display:block;margin-bottom:var(--space-sm)}
.champ .head h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2.5rem,7vw,5.5rem);line-height:0.9;letter-spacing:0.01em}
.champ .head h2 .em{color:var(--color-accent)}
.coverflow{position:relative;height:clamp(340px,58vw,460px);perspective:1600px;margin:0 auto;max-width:980px}
.cf-track{position:absolute;inset:0;transform-style:preserve-3d}
.cf-card{position:absolute;top:50%;left:50%;width:clamp(210px,58vw,300px);height:clamp(280px,74vw,400px);
  margin-top:calc(-0.5 * clamp(280px,74vw,400px));margin-left:calc(-0.5 * clamp(210px,58vw,300px));
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 30px 70px oklch(0% 0 0 / 0.55);
  transition:transform 0.6s var(--ease-out),opacity 0.6s var(--ease-out);cursor:pointer;background:var(--color-char-2)}
.cf-card img{width:100%;height:100%;object-fit:cover}
.cf-card .cap{position:absolute;left:0;right:0;bottom:0;padding:var(--space-md);
  background:linear-gradient(180deg,transparent,oklch(0% 0 0 / 0.82));
  font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-lg);letter-spacing:0.02em;color:var(--color-paper)}
.cf-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:50;width:48px;height:48px;border-radius:999px;
  border:var(--rule-hair) solid var(--color-line-dk);background:oklch(20% 0.012 55 / 0.62);color:var(--color-paper);
  font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background var(--dur-short),color var(--dur-short)}
.cf-arrow:hover{background:var(--color-accent);color:var(--color-char)}
.cf-arrow.prev{left:var(--space-sm)}.cf-arrow.next{right:var(--space-sm)}
.cf-dots{display:flex;gap:var(--space-xs);justify-content:center;margin-top:var(--space-xl)}
.cf-dot{width:10px;height:10px;border-radius:999px;border:none;background:var(--color-cream-45);cursor:pointer;padding:0;transition:background var(--dur-short),transform var(--dur-short)}
.cf-dot[aria-current="true"]{background:var(--color-accent);transform:scale(1.35)}
.cf-arrow:focus-visible,.cf-dot:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}

/* ---------- FOOD REEL · sticky-pinned scroll-scrubbed explosion ---------- */
.foodreel{position:relative;background:#DC5C14;color:var(--color-paper);min-height:220vh}
.foodreel-pin{position:sticky;top:0;height:100svh;overflow:hidden}
.foodreel-bg{position:absolute;inset:0;z-index:0}
.foodreel-bg canvas{display:block;width:100%;height:100%}
.foodreel-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(0deg, oklch(13% 0.035 45 / 0.70) 0%, oklch(13% 0.035 45 / 0.20) 24%, transparent 48%),
  linear-gradient(90deg, oklch(13% 0.035 45 / 0.42) 0%, transparent 46%)}
.foodreel-copy{position:absolute;left:0;bottom:0;z-index:2;text-align:left;max-width:min(92vw,42rem);
  padding:0 var(--space-md) clamp(var(--space-xl),6vh,var(--space-3xl)) clamp(var(--space-md),5vw,var(--space-3xl))}
.foodreel-copy .eyebrow{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--color-paper);opacity:0.95}
.foodreel-copy .eyebrow::before{content:"";width:36px;height:2px;background:var(--color-accent);display:inline-block;flex:none}
.foodreel-copy h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(3rem,8.5vw,7.5rem);line-height:0.82;letter-spacing:0.005em;color:var(--color-paper);margin-top:var(--space-md);text-shadow:0 4px 44px oklch(0% 0 0 / 0.55),0 1px 3px oklch(0% 0 0 / 0.4)}
.foodreel-copy h2 .em{color:var(--color-accent)}
.foodreel-copy p{margin-top:var(--space-lg);font-size:var(--text-sm);font-weight:700;text-transform:uppercase;letter-spacing:0.2em;color:var(--color-paper);opacity:0.9;text-shadow:0 1px 12px oklch(0% 0 0 / 0.5)}
@media(prefers-reduced-motion:reduce){.foodreel{min-height:100svh}}
