/* ===== MJ BURGER — design tokens ===== */
:root{
  --red:#E2231A; --red-dark:#B0140C; --red-deep:#3a0d09;
  --yellow:#FFC72C; --yellow-dark:#E8A800;
  --cream:#FFF6E9; --ink:#1b1210; --ink-2:#2a1c18;
  --surface:#211512; --surface-2:#2c1d18;
  --text:#f6efe7; --muted:#c9b8ad; --muted-2:#9c8a80;
  --glass:rgba(255,255,255,.06); --glass-bd:rgba(255,255,255,.12);
  --r-sm:10px; --r:16px; --r-lg:24px; --r-xl:32px;
  --shadow:0 10px 30px -12px rgba(0,0,0,.55);
  --shadow-lg:0 30px 60px -20px rgba(0,0,0,.6);
  --maxw:1200px; --pad:clamp(16px,4vw,40px);
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,sans-serif;background:var(--ink);color:var(--text);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:'Fredoka',sans-serif;line-height:1.05;font-weight:700;letter-spacing:-.01em}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.text-grad{background:linear-gradient(100deg,var(--yellow),#ffe39a 60%,var(--yellow-dark));-webkit-background-clip:text;background-clip:text;color:transparent;
  /* text-shadow bleeds through clipped transparent text and muddies the fill — use drop-shadow on the glyph alpha instead */
  text-shadow:none!important;filter:drop-shadow(0 2px 5px rgba(0,0,0,.55)) drop-shadow(0 10px 28px rgba(0,0,0,.4))}
.eyebrow{display:inline-block;font-weight:700;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--yellow)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--yellow);color:#111;padding:10px 16px;border-radius:8px;z-index:2000}
.skip-link:focus{left:12px;top:12px}
:focus-visible{outline:3px solid var(--yellow);outline-offset:3px;border-radius:6px}

/* ===== Buttons ===== */
.btn{
  --bg:var(--red);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:'Fredoka',sans-serif;font-weight:600;font-size:1rem;
  min-height:48px;padding:.7em 1.4em;border-radius:999px;border:0;cursor:pointer;
  background:var(--bg);color:var(--fg);transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s;
  box-shadow:0 8px 20px -8px rgba(226,35,26,.7);white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn--primary{--bg:var(--red)}
.btn--primary:hover{background:var(--red-dark)}
.btn--yellow{--bg:var(--yellow);--fg:#2a1500;box-shadow:0 8px 20px -8px rgba(255,199,44,.7)}
.btn--yellow:hover{background:var(--yellow-dark)}
.btn--ghost{--bg:transparent;--fg:#fff;border:1.5px solid rgba(255,255,255,.35);box-shadow:none;backdrop-filter:blur(6px)}
.btn--ghost:hover{background:rgba(255,255,255,.1)}
.btn--lg{min-height:54px;font-size:1.08rem;padding:.8em 1.7em}
.btn--sm{min-height:42px;font-size:.95rem;padding:.5em 1.1em}

/* ===== Nav ===== */
.nav{position:fixed;inset:0 0 auto 0;z-index:1000;transition:background .3s,box-shadow .3s,padding .3s;padding-block:14px}
.nav.scrolled{background:rgba(20,12,10,.78);backdrop-filter:saturate(1.4) blur(14px);box-shadow:0 1px 0 rgba(255,255,255,.06),0 12px 30px -20px #000;padding-block:8px}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav__brand{display:flex;align-items:center;gap:10px;font-family:'Fredoka',sans-serif;font-weight:700;font-size:1.25rem}
.nav__brand img{width:44px;height:44px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4))}
.nav__links{display:flex;align-items:center;gap:6px}
.nav__links>a:not(.btn){padding:10px 14px;border-radius:10px;font-weight:500;color:var(--text);transition:color .2s,background .2s}
.nav__links>a:not(.btn):hover{color:var(--yellow)}
.nav__cta{margin-left:8px}
.nav__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;background:var(--glass);border:1px solid var(--glass-bd);border-radius:12px;cursor:pointer}
.nav__toggle span{display:block;width:22px;height:2px;background:#fff;margin-inline:auto;transition:transform .3s,opacity .3s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:880px){
  .nav__toggle{display:flex}
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(82vw,340px);flex-direction:column;align-items:stretch;justify-content:flex-start;
    gap:6px;padding:90px 22px 30px;background:rgba(24,15,12,.96);backdrop-filter:blur(16px);
    transform:translateX(100%);transition:transform .38s var(--ease);box-shadow:var(--shadow-lg)
  }
  .nav__links.open{transform:translateX(0)}
  .nav__links>a:not(.btn){padding:14px 16px;font-size:1.1rem;border-bottom:1px solid rgba(255,255,255,.07)}
  .nav__cta{margin:14px 0 0}
}

/* ===== Hero ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:75% 50%}
.hero__scrim{position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(15,8,6,.96) 0%,rgba(15,8,6,.7) 38%,rgba(15,8,6,.15) 70%,transparent 100%),
  linear-gradient(0deg,rgba(15,8,6,.85) 0%,transparent 45%)}
.hero__content{position:relative;max-width:640px;padding-block:120px 90px}
.badge{display:inline-flex;align-items:center;gap:9px;background:var(--glass);border:1px solid var(--glass-bd);
  backdrop-filter:blur(8px);padding:8px 16px;border-radius:999px;font-weight:600;font-size:.82rem;letter-spacing:.06em;color:var(--cream)}
.badge__dot{width:9px;height:9px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 0 rgba(255,199,44,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,199,44,.6)}70%{box-shadow:0 0 0 12px rgba(255,199,44,0)}100%{box-shadow:0 0 0 0 rgba(255,199,44,0)}}
.hero__title{font-size:clamp(2.8rem,9vw,5.6rem);margin:22px 0 16px;text-shadow:0 6px 30px rgba(0,0,0,.5)}
.hero__sub{font-size:clamp(1.05rem,2.4vw,1.3rem);color:var(--muted);max-width:30ch;margin-bottom:30px}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px}
.hero__scroll{position:absolute;left:50%;bottom:26px;translate:-50% 0;width:26px;height:42px;border:2px solid rgba(255,255,255,.4);border-radius:14px}
.hero__scroll span{position:absolute;left:50%;top:8px;translate:-50% 0;width:4px;height:8px;border-radius:2px;background:var(--yellow);animation:scroll 1.6s infinite}
@keyframes scroll{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,14px)}100%{opacity:0}}

/* ===== Marquee ===== */
.marquee{background:var(--red);color:#fff;overflow:hidden;padding:14px 0;border-block:3px solid var(--yellow)}
.marquee__track{display:flex;gap:40px;white-space:nowrap;width:max-content;animation:marq 26s linear infinite;font-family:'Fredoka',sans-serif;font-weight:600;letter-spacing:.04em}
.marquee__track span{padding-right:40px}
@keyframes marq{to{transform:translateX(-50%)}}

/* ===== Sections ===== */
.section{padding-block:clamp(64px,10vw,120px)}
.section__head{text-align:center;max-width:640px;margin:0 auto clamp(36px,6vw,60px)}
.section__title{font-size:clamp(2rem,5vw,3.1rem);margin:12px 0 14px}
.section__lead{color:var(--muted);font-size:1.1rem}

/* ===== Featured ===== */
.featured{background:linear-gradient(180deg,var(--ink),var(--surface));padding-block:clamp(60px,9vw,110px)}
.featured__grid{display:grid;grid-template-columns:1fr;gap:clamp(30px,5vw,64px);align-items:center}
.featured__media{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.featured__media img{width:100%;aspect-ratio:1;object-fit:cover;transition:transform .6s var(--ease)}
.featured__media:hover img{transform:scale(1.05)}
.featured__price{position:absolute;right:18px;bottom:18px;background:var(--yellow);color:#2a1500;font-family:'Fredoka',sans-serif;font-weight:700;font-size:1.4rem;padding:8px 16px;border-radius:14px;box-shadow:var(--shadow)}
.featured__price small{font-size:.8rem;font-weight:600}
.featured__text h2{font-size:clamp(1.9rem,4.5vw,2.8rem);margin:12px 0 14px}
.featured__text p{color:var(--muted);font-size:1.08rem;margin-bottom:20px;max-width:52ch}
.ticks{list-style:none;margin:0 0 26px;display:grid;gap:12px}
.ticks li{display:flex;align-items:center;gap:12px;font-weight:500}
.ticks li::before{content:"";flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:var(--red) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/16px no-repeat}
@media(min-width:860px){.featured__grid{grid-template-columns:1fr 1fr}.featured__media{order:2}}

/* ===== Menu ===== */
.menu{background:var(--surface)}
.menu__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:clamp(18px,2.5vw,28px)}
.card{
  position:relative;background:var(--glass);border:1px solid var(--glass-bd);border-radius:var(--r-lg);overflow:hidden;
  backdrop-filter:blur(12px);box-shadow:var(--shadow);transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
  display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(255,199,44,.4)}
.card__img{position:relative;aspect-ratio:1;overflow:hidden;background:#181010}
.card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card:hover .card__img img{transform:scale(1.07)}
.card__tag{position:absolute;top:12px;left:12px;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);color:var(--yellow);font-size:.72rem;font-weight:700;letter-spacing:.08em;padding:5px 10px;border-radius:999px;text-transform:uppercase}
.card__body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.card__name{font-family:'Fredoka',sans-serif;font-size:1.3rem;font-weight:700}
.card__desc{color:var(--muted);font-size:.95rem;flex:1}
.card__foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:12px}
.card__price{font-family:'Fredoka',sans-serif;font-weight:700;font-size:1.3rem;color:var(--yellow);font-variant-numeric:tabular-nums}
.card__price small{font-size:.72rem;color:var(--muted-2);font-weight:600}
.card__btn{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--red);display:grid;place-items:center;transition:background .2s,transform .2s}
.card__btn:hover{background:var(--red-dark);transform:scale(1.06)}
.card__btn svg{width:22px;height:22px;fill:#fff}

/* ===== Gallery ===== */
.gallery{background:linear-gradient(180deg,var(--surface),var(--ink))}
.gallery__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.gallery__grid figure{margin:0;border-radius:var(--r);overflow:hidden;position:relative;box-shadow:var(--shadow)}
.gallery__grid img{width:100%;height:100%;object-fit:cover;aspect-ratio:1;transition:transform .6s var(--ease)}
.gallery__grid figure:hover img{transform:scale(1.08)}
.gallery__grid .g-wide{grid-column:span 2;aspect-ratio:auto}
.gallery__grid .g-wide img{aspect-ratio:16/9}
@media(min-width:760px){.gallery__grid{grid-template-columns:repeat(4,1fr)}.gallery__grid .g-tall{grid-row:span 2}.gallery__grid .g-tall img{aspect-ratio:1/2}.gallery__grid .g-wide{grid-column:span 2}}

/* ===== About ===== */
.about{background:var(--ink)}
.about__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,230px),1fr));gap:20px}
.feature{background:var(--glass);border:1px solid var(--glass-bd);border-radius:var(--r-lg);padding:30px 24px;text-align:center;transition:transform .3s var(--ease),border-color .3s}
.feature:hover{transform:translateY(-5px);border-color:rgba(255,199,44,.4)}
.feature__ic{width:64px;height:64px;margin:0 auto 16px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(140deg,var(--red),var(--red-dark));box-shadow:0 10px 22px -10px rgba(226,35,26,.8)}
.feature__ic svg{width:32px;height:32px;fill:#fff}
.feature h3{font-size:1.25rem;margin-bottom:8px}
.feature p{color:var(--muted);font-size:.96rem}

/* ===== Visit ===== */
.visit{background:linear-gradient(180deg,var(--ink),var(--red-deep))}
.visit__grid{display:grid;grid-template-columns:1fr;gap:clamp(28px,5vw,56px);align-items:center}
.visit__list{list-style:none;display:grid;gap:18px;margin:26px 0}
.visit__list li{display:flex;gap:14px;align-items:center}
.visit__list svg{flex:0 0 auto;width:26px;height:26px;fill:var(--yellow)}
.visit__list strong{display:block;font-family:'Fredoka',sans-serif}
.visit__list span{color:var(--muted);font-size:.95rem}
.visit__socials{display:flex;gap:12px;margin-top:8px}
.soc{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:var(--glass);border:1px solid var(--glass-bd);transition:transform .2s,background .2s}
.soc:hover{transform:translateY(-3px)}
.soc svg{width:24px;height:24px;fill:#fff}
.soc--ig:hover{background:linear-gradient(45deg,#f58529,#dd2a7b,#8134af)}
.soc--tg:hover{background:#29a9eb}
.soc--web:hover{background:var(--red)}
.visit__media{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.visit__media img{width:100%;aspect-ratio:16/10;object-fit:cover}
@media(min-width:860px){.visit__grid{grid-template-columns:1fr 1.1fr}}

/* ===== CTA band ===== */
.ctaband{background:var(--red);background-image:radial-gradient(circle at 20% 20%,rgba(255,199,44,.25),transparent 40%)}
.ctaband__inner{text-align:center;padding-block:clamp(56px,8vw,90px)}
.ctaband h2{font-size:clamp(2rem,5vw,3rem);margin-bottom:12px}
.ctaband p{color:rgba(255,255,255,.9);font-size:1.15rem;margin-bottom:26px}

/* ===== Footer ===== */
.footer{background:#140c0a;padding-top:clamp(50px,7vw,80px)}
.footer__inner{display:grid;grid-template-columns:1fr;gap:34px;padding-bottom:40px}
.footer__brand img{margin-bottom:14px}
.footer__brand p{color:var(--muted);max-width:34ch;font-size:.95rem}
.footer__nav{display:flex;flex-direction:column;gap:10px}
.footer__nav a,.footer__contact a{color:var(--muted);transition:color .2s}
.footer__nav a:hover,.footer__contact a:hover{color:var(--yellow)}
.footer__contact{display:flex;flex-direction:column;gap:10px}
.footer__contact strong{color:#fff;font-family:'Fredoka',sans-serif;margin-bottom:4px}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding-block:22px;text-align:center;color:var(--muted-2);font-size:.88rem}
@media(min-width:760px){.footer__inner{grid-template-columns:1.6fr 1fr 1.3fr}}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.stagger.in>*{opacity:1;transform:none}
.stagger.in>*:nth-child(2){transition-delay:.06s}
.stagger.in>*:nth-child(3){transition-delay:.12s}
.stagger.in>*:nth-child(4){transition-delay:.18s}
.stagger.in>*:nth-child(5){transition-delay:.24s}
.stagger.in>*:nth-child(6){transition-delay:.3s}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal,.stagger>*{opacity:1!important;transform:none!important;transition:none!important}
  /* brand ticker stays on (slow, decorative-but-expected); higher specificity wins the !important tie */
  .marquee__track{animation:marq 26s linear infinite!important}
}

/* ===== Scroll-scrub video hero ===== */
.svhero{position:relative;height:440vh;background:#0e0908}
.svhero__stage{position:sticky;top:0;height:100svh;overflow:hidden;display:grid;place-items:center;background:#0e0908}
.svhero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;background:#0e0908}
.svhero__veil{position:absolute;inset:0;pointer-events:none;background:linear-gradient(0deg,rgba(8,5,4,.8),transparent 36%),linear-gradient(180deg,rgba(8,5,4,.5),transparent 28%),radial-gradient(120% 80% at 50% 45%,transparent 46%,rgba(8,5,4,.5))}
.svhero__caps{position:absolute;inset:0;pointer-events:none}
/* cinematic scrim: appears only when the final caption is on (left on desktop, bottom on mobile) */
.svhero__scrim{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .7s var(--ease);
  background:linear-gradient(0deg,rgba(10,6,4,.94),rgba(10,6,4,.55) 32%,transparent 58%)}
.svhero.final .svhero__scrim{opacity:1}
.svcap{
  position:absolute;left:0;right:0;width:fit-content;margin-inline:auto;
  max-width:min(640px,92vw);text-align:center;padding-inline:var(--pad);
  opacity:0;transform:translateY(22px);transition:opacity .55s var(--ease),transform .55s var(--ease)
}
.svcap[data-pos="top"]{top:10vh}
.svcap.on{opacity:1;transform:translateY(0);pointer-events:auto}
.svcap .eyebrow{margin-bottom:10px;text-shadow:0 2px 10px rgba(0,0,0,.95)}
.svcap h2{font-size:clamp(1.6rem,4.8vw,2.7rem);text-shadow:0 2px 8px rgba(0,0,0,.95),0 12px 40px rgba(0,0,0,.75)}
.svcap .badge{margin-bottom:14px;background:rgba(0,0,0,.35);backdrop-filter:blur(6px)}
.svcap .hero__title{font-size:clamp(2.2rem,6.8vw,4rem);margin-bottom:12px;text-shadow:0 3px 10px rgba(0,0,0,.9),0 14px 46px rgba(0,0,0,.75)}
.svcap .hero__sub{margin:0 auto 22px;max-width:36ch;color:var(--cream);text-shadow:0 2px 8px rgba(0,0,0,.95)}
.svcap .hero__actions{justify-content:center;flex-wrap:wrap}
.svcap--final{top:auto;bottom:max(7vh,60px)}
@media(min-width:900px) and (orientation:landscape){
  .svhero__scrim{background:linear-gradient(90deg,rgba(10,6,4,.93),rgba(10,6,4,.55) 32%,transparent 60%)}
  .svcap--final{left:6vw;right:auto;margin:0;bottom:auto;top:50%;transform:translateY(calc(-50% + 22px));text-align:left;max-width:540px;padding-inline:0}
  .svcap--final.on{transform:translateY(-50%)}
  .svcap--final .hero__sub{margin-left:0}
  .svcap--final .hero__actions{justify-content:flex-start}
}
.scrollhint{position:absolute;bottom:24px;left:50%;translate:-50% 0;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--muted);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;z-index:3}
.scrollhint i{width:24px;height:38px;border:2px solid rgba(255,255,255,.4);border-radius:12px;position:relative}
.scrollhint i::after{content:"";position:absolute;left:50%;top:7px;translate:-50% 0;width:4px;height:7px;background:var(--yellow);border-radius:2px;animation:scroll 1.6s infinite}
@media(max-width:480px){.svcap .badge{font-size:.7rem;letter-spacing:.03em;padding:7px 13px}}
/* Scroll-scrub is user-driven (not autonomous motion), so it stays active
   even with prefers-reduced-motion; only decorative animations are reduced. */
@media(prefers-reduced-motion:reduce){
  .scrollhint i::after{animation:none}
}
