/* ============================================================
   NORDR — Cooking the North
   New Nordic. Foraged, coastal, stark. Video-led, cold minimalism.
   Perf rules baked in: no filter:blur, no blend-mode overlays.
   ============================================================ */

:root{
  --ink:#140d0a;          /* cold near-black */
  --ink-2:#1c120d;
  --paper:#f0e6dd;        /* cool off-white */
  --muted:#a89386;        /* muted slate */
  --accent:#e2703a;       /* glacier frost */
  --accent-deep:#a83a1e;  /* spruce-slate */
  --hair:rgba(240,230,221,.13);
  --hair-strong:rgba(240,230,221,.24);
  --shadow:0 30px 80px -34px rgba(0,0,0,.85);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:'Jost',system-ui,sans-serif;
  font-weight:300;
  line-height:1.6;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--accent);color:var(--ink)}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.serif{font-family:'Bodoni Moda',serif;font-weight:400}
.micro{
  font-family:'Jost',sans-serif;font-weight:500;
  font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);
}
.section-label{display:inline-flex;align-items:center;gap:1rem;margin-bottom:1.6rem}
.section-label::before{content:"";width:34px;height:1px;background:var(--accent);opacity:.8}
.hairline{height:1px;width:100%;background:var(--hair);transform-origin:left}

/* film grain (no blend-mode — repaints cheaply) */
.grain{
  position:fixed;inset:0;z-index:90;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
}
.vignette{
  position:fixed;inset:0;z-index:88;pointer-events:none;
  background:radial-gradient(120% 92% at 50% 38%,transparent 54%,rgba(0,0,0,.5) 100%);
}

/* preloader */
.preloader{
  position:fixed;inset:0;z-index:200;background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;
  transition:opacity 1s ease,visibility 1s ease;
}
.preloader.done{opacity:0;visibility:hidden}
.preloader__mark{font-family:'Bodoni Moda',serif;font-weight:400;font-size:2.2rem;letter-spacing:.46em;color:var(--accent);text-indent:.46em}
.preloader__line{width:140px;height:1px;background:var(--hair);overflow:hidden}
.preloader__line span{display:block;height:100%;width:100%;background:var(--accent);transform:translateX(-100%);animation:load 1.6s cubic-bezier(.7,0,.3,1) infinite}
@keyframes load{to{transform:translateX(100%)}}

/* nav */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem clamp(1.25rem,4vw,3.5rem);
  transition:background .5s ease,padding .5s ease,backdrop-filter .5s ease;
}
.nav.scrolled{background:rgba(20,13,10,.74);backdrop-filter:blur(14px);padding:1rem clamp(1.25rem,4vw,3.5rem);border-bottom:1px solid var(--hair)}
.nav__mark{font-family:'Bodoni Moda',serif;font-weight:500;font-size:1.35rem;letter-spacing:.4em;color:var(--paper);text-indent:.4em}
.nav__links{display:flex;gap:2.2rem}
.nav__links a{position:relative;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--paper);opacity:.82}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--accent);transition:width .4s cubic-bezier(.16,1,.3,1)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__reserve{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;border:1px solid var(--hair-strong);border-radius:2px;padding:.65rem 1.4rem;transition:border-color .4s ease,color .4s ease}
.nav__reserve:hover{border-color:var(--accent);color:var(--accent)}
@media(max-width:880px){.nav__links{display:none}}

/* hero */
.hero{position:relative;height:100svh;min-height:640px;overflow:hidden;display:flex;align-items:flex-end}
.hero__media{position:absolute;inset:0;z-index:-3}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media img{position:absolute;inset:0}
.hero__media video{opacity:0;transition:opacity 1.2s ease}
.hero__media video.playing{opacity:1}
.hero__scrim{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(to top,rgba(20,13,10,.92) 0%,rgba(20,13,10,.4) 40%,rgba(20,13,10,.12) 64%,rgba(20,13,10,.5) 100%),
    linear-gradient(to right,rgba(20,13,10,.66) 0%,transparent 56%);
}
.hero__content{position:relative;width:100%;padding:0 clamp(1.25rem,5vw,5rem) clamp(3rem,9vh,6rem);max-width:1500px;margin:0 auto}
.hero__eyebrow{margin-bottom:1.5rem;color:var(--accent)}
.hero__title{font-family:'Bodoni Moda',serif;font-weight:400;font-size:clamp(3rem,10.5vw,9rem);line-height:.98;letter-spacing:-.01em;text-shadow:0 0 60px rgba(0,0,0,.5)}
.hero__title em{font-style:italic;color:var(--accent)}
.hero__line{display:block;overflow:hidden}
.hero__line>span{display:block;transform:translateY(110%)}
.hero.ready .hero__line>span{transform:translateY(0);transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.hero.ready .hero__line:nth-child(2)>span{transition-delay:.12s}
.hero__sub{margin-top:1.8rem;max-width:48ch;color:var(--paper);opacity:.85;font-size:clamp(.92rem,1.4vw,1.08rem)}
.hero__cta{margin-top:2.4rem;display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap}

.btn-solid{
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;
  padding:1rem 2.2rem;border-radius:2px;color:var(--ink);background:var(--accent);
  transition:transform .4s cubic-bezier(.16,1,.3,1),background .4s ease;
}
.btn-solid:hover{transform:translateY(-2px);background:#ef8456}
.btn-ghost{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;color:var(--paper);display:inline-flex;align-items:center;gap:.7rem;opacity:.85;transition:opacity .4s,gap .4s}
.btn-ghost::after{content:"";width:26px;height:1px;background:var(--accent);transition:width .4s}
.btn-ghost:hover{opacity:1;gap:1rem}
.btn-ghost:hover::after{width:42px}

.hero__scrollcue{position:absolute;right:clamp(1.25rem,5vw,5rem);bottom:clamp(3rem,9vh,6rem);display:flex;align-items:center;gap:.8rem;writing-mode:vertical-rl;z-index:2}
.hero__scrollcue .micro{letter-spacing:.3em}
.hero__cueline{width:1px;height:54px;background:var(--hair-strong);position:relative;overflow:hidden}
.hero__cueline::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--accent);animation:cue 2.2s cubic-bezier(.7,0,.3,1) infinite}
@keyframes cue{0%{transform:translateY(-100%)}60%,100%{transform:translateY(260%)}}

/* manifesto */
.manifesto{padding:clamp(6rem,16vh,11rem) clamp(1.25rem,6vw,6rem);max-width:1100px;margin:0 auto;text-align:center}
.manifesto__text{font-family:'Bodoni Moda',serif;font-weight:400;font-size:clamp(1.5rem,3.4vw,2.7rem);line-height:1.42}
.manifesto__text .w{display:inline-block;opacity:.18;transition:opacity .5s ease}
.manifesto__text .w.lit{opacity:1}
.manifesto__text em{font-style:italic;color:var(--accent)}
.manifesto .hairline{margin-top:clamp(3rem,7vh,5rem)}

/* split feature */
.feature{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,5rem);align-items:center;padding:clamp(3rem,8vh,7rem) clamp(1.25rem,6vw,6rem);max-width:1500px;margin:0 auto}
.feature__copy h2{font-family:'Bodoni Moda',serif;font-weight:400;font-size:clamp(2rem,4.5vw,3.6rem);line-height:1.08;margin-bottom:1.6rem}
.feature__copy h2 em{font-style:italic;color:var(--accent)}
.feature__copy p{color:var(--muted);max-width:48ch;margin-bottom:1.2rem;font-size:1.02rem}
.feature__copy p strong{color:var(--paper);font-weight:400}
.feature__media{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:2px;box-shadow:var(--shadow)}
.feature__media img{width:100%;height:120%;object-fit:cover;will-change:transform}
.feature__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,13,10,.5),transparent 60%)}
@media(max-width:880px){.feature{grid-template-columns:1fr}}

/* menu */
.menu{padding:clamp(4rem,10vh,8rem) clamp(1.25rem,6vw,6rem);max-width:1500px;margin:0 auto}
.menu__head{text-align:center;margin-bottom:clamp(3rem,7vh,5rem)}
.menu__title{font-family:'Bodoni Moda',serif;font-weight:400;font-size:clamp(2.2rem,5vw,4rem);line-height:1}
.menu__title em{font-style:italic;color:var(--accent)}
.menu__note{margin-top:1.2rem;color:var(--muted);font-size:.92rem;letter-spacing:.03em}
.menu__grid{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(3rem,6vw,7rem)}
@media(max-width:880px){.menu__grid{grid-template-columns:1fr}}
.course{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:start;padding:1.6rem 0;border-top:1px solid var(--hair)}
.course__num{font-family:'Bodoni Moda',serif;font-size:1rem;color:var(--accent);opacity:.8;padding-top:.2rem;min-width:2ch}
.course__name{font-family:'Bodoni Moda',serif;font-weight:400;font-size:1.28rem;line-height:1.25}
.course__desc{color:var(--muted);font-size:.92rem;margin-top:.45rem;max-width:42ch}

/* atmosphere */
.atmos{position:relative;height:80vh;min-height:520px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.atmos__bg{position:absolute;inset:-12% 0;z-index:-2}
.atmos__bg img{width:100%;height:100%;object-fit:cover;will-change:transform}
.atmos__scrim{position:absolute;inset:0;z-index:-1;background:radial-gradient(80% 80% at 50% 50%,rgba(20,13,10,.32),rgba(20,13,10,.84))}
.atmos__quote{font-family:'Bodoni Moda',serif;font-weight:400;font-size:clamp(1.6rem,4vw,3.2rem);line-height:1.32;text-align:center;max-width:20ch;padding:0 1.5rem;text-shadow:0 0 50px rgba(0,0,0,.6)}
.atmos__quote em{font-style:italic;color:var(--accent)}

/* chef */
.chef{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,5rem);align-items:center;padding:clamp(4rem,10vh,8rem) clamp(1.25rem,6vw,6rem);max-width:1500px;margin:0 auto}
.chef__media{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:2px;box-shadow:var(--shadow)}
.chef__media img{width:100%;height:115%;object-fit:cover;will-change:transform}
.chef__copy h2{font-family:'Bodoni Moda',serif;font-weight:400;font-size:clamp(2rem,4.5vw,3.4rem);margin-bottom:.4rem}
.chef__role{color:var(--accent);font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;margin-bottom:1.6rem;display:block}
.chef__copy p{color:var(--muted);margin-bottom:1.1rem;max-width:50ch}
.chef__sign{font-family:'Bodoni Moda',serif;font-style:italic;color:var(--paper);font-size:1.1rem;opacity:.8;margin-top:.4rem}
@media(max-width:880px){.chef{grid-template-columns:1fr}.chef__media{order:-1}}

/* reserve */
.reserve{position:relative;padding:clamp(5rem,13vh,9rem) clamp(1.25rem,6vw,6rem);text-align:center;overflow:hidden}
.reserve__title{font-family:'Bodoni Moda',serif;font-weight:400;font-size:clamp(2.6rem,7vw,5.5rem);line-height:1}
.reserve__title em{font-style:italic;color:var(--accent)}
.reserve__sub{margin-top:1.4rem;color:var(--muted);max-width:46ch;margin-inline:auto}
.reserve__cta{margin-top:2.6rem}
.reserve__cols{margin-top:clamp(3rem,7vh,5rem);display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:880px;margin-inline:auto}
.reserve__cols .micro{display:block;margin-bottom:.7rem;color:var(--accent)}
.reserve__cols p:not(.micro){color:var(--paper);opacity:.85;font-size:.95rem;line-height:1.7}
@media(max-width:680px){.reserve__cols{grid-template-columns:1fr;gap:1.6rem}}

/* footer */
.footer{padding:clamp(3rem,7vh,5rem) clamp(1.25rem,6vw,6rem) 3rem;max-width:1500px;margin:0 auto}
.footer__mark{font-family:'Bodoni Moda',serif;font-size:1.6rem;letter-spacing:.46em;color:var(--accent);text-indent:.46em;margin-bottom:2rem;text-align:center}
.footer__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2.4rem;font-size:.86rem;color:var(--muted);line-height:1.8}
.footer__grid a:hover{color:var(--accent)}
.footer__fine{margin-top:2.6rem;font-size:.72rem;color:var(--muted);opacity:.6;max-width:70ch}
@media(max-width:680px){.footer__grid{grid-template-columns:1fr 1fr}}

.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s ease,transform 1.1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .hero__line>span{transform:none}
}

/* ============================================================
   BRASA SIGNATURE — kinetic marquee + horizontal "stages of the fire"
   ============================================================ */
.hero__title{font-family:'Bodoni Moda',serif;font-weight:700;letter-spacing:-.02em}
.hero__title em{font-weight:600}

/* velocity marquee */
.marquee{
  overflow:hidden;white-space:nowrap;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);
  padding:clamp(1.4rem,3vh,2.4rem) 0;background:var(--ink-2);
}
.marquee__inner{display:inline-flex;will-change:transform}
.marquee__inner span{
  font-family:'Bodoni Moda',serif;font-weight:700;font-style:italic;
  font-size:clamp(2.4rem,7vw,6rem);line-height:1;padding:0 .35em;color:var(--paper);
  text-transform:uppercase;letter-spacing:.01em;
}
.marquee__inner span.ember{color:var(--accent);-webkit-text-stroke:0}
.marquee__inner span.out{color:transparent;-webkit-text-stroke:1.4px var(--accent-deep)}

/* stages — pinned horizontal */
.stages{height:100vh;overflow:hidden;position:relative;background:var(--ink)}
.stages__track{display:flex;width:max-content;height:100vh}
.stage{position:relative;width:100vw;height:100vh;display:flex;align-items:flex-end;overflow:hidden}
.stage__bg{position:absolute;inset:0;z-index:0}
.stage__bg img{width:100%;height:100%;object-fit:cover;opacity:.62}
.stage::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(20,13,10,.92),rgba(20,13,10,.25) 60%,rgba(20,13,10,.6))}
.stage__inner{position:relative;z-index:2;padding:clamp(2rem,6vw,6rem);max-width:46ch}
.stage__num{font-family:'Bodoni Moda',serif;font-weight:700;font-size:clamp(5rem,16vw,16rem);line-height:.8;color:var(--accent);opacity:.92;letter-spacing:-.04em}
.stage__name{font-family:'Bodoni Moda',serif;font-weight:600;font-size:clamp(1.8rem,4vw,3rem);margin-top:.4rem}
.stage__desc{color:var(--paper);opacity:.8;margin-top:1rem;max-width:38ch;font-size:1.02rem}
.stages__label{position:absolute;top:clamp(5rem,10vh,7rem);left:clamp(2rem,6vw,6rem);z-index:3}

/* ember particles drifting up the menu */
.menu{position:relative;overflow:hidden}
.ember-field{position:absolute;inset:0;pointer-events:none;z-index:0}
.ember-field i{position:absolute;bottom:-10px;width:3px;height:3px;border-radius:50%;background:var(--accent);opacity:0;
  animation:ember-rise linear infinite;box-shadow:0 0 6px var(--accent)}
@keyframes ember-rise{0%{transform:translateY(0) scale(1);opacity:0}10%{opacity:.8}100%{transform:translateY(-78vh) translateX(var(--drift,20px)) scale(.3);opacity:0}}
.menu__head,.menu__grid,.menu__note--lit{position:relative;z-index:1}
.menu__title{font-family:'Bodoni Moda',serif;font-weight:700}
.course__name{font-family:'Bodoni Moda',serif;font-weight:600}
@media (prefers-reduced-motion:reduce){.ember-field{display:none}}
@media (max-width:700px){
  .stages{height:auto}
  .stages__track{flex-direction:column;width:100%;height:auto}
  .stage{width:100%;height:auto;min-height:86vh}
  .stages__label{position:static;margin:0 0 -1rem}
}
