/* =========================================================
   On The Rocks — bespoke stylesheet
   Palette: warm obsidian · bone · ember · brass
   Type: Cormorant Garamond (display) / Jost (text)
   ========================================================= */

:root{
  --ink:        #0c0a09;
  --ink-2:      #14110e;
  --ink-3:      #1d1916;
  --bone:       #f4ece1;
  --bone-dim:   #c6b8a4;
  --bone-faint: #8c8073;
  --ember:      #e2622a;
  --ember-2:    #f59247;
  --ember-deep: #b5421c;
  --brass:      #cba35d;
  --line:       rgba(244,236,225,.14);
  --line-soft:  rgba(244,236,225,.08);

  --ff-disp: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --ff-text: "Jost", system-ui, -apple-system, "Segoe UI", sans-serif;

  --pad: clamp(20px, 5vw, 90px);
  --maxw: 1320px;

  --ease: cubic-bezier(.22,1,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
}
html.js.lenis{scroll-behavior:auto}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}
body{
  font-family:var(--ff-text);
  background:var(--ink);
  color:var(--bone);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.7;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--ember);color:var(--ink)}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

/* =========================================================
   Typography helpers
   ========================================================= */
.eyebrow{
  font-family:var(--ff-text);
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--ember-2);
  display:flex;align-items:center;gap:.9em;
}
.eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--brass);display:inline-block}
.eyebrow--light{color:var(--bone)}

.sec-title{
  font-family:var(--ff-disp);
  font-weight:500;
  font-optical-sizing:auto;
  font-size:clamp(2.6rem,6.6vw,5.8rem);
  line-height:1.0;
  letter-spacing:-.01em;
  margin-top:.35em;
}
.sec-title em{font-style:italic;color:var(--ember);font-weight:500}
.sec-title--light{color:var(--bone)}

.sec-sub{
  max-width:46ch;margin-top:1.4rem;color:var(--bone-dim);
  font-size:1.02rem;
}

.lead{font-size:clamp(1.12rem,1.7vw,1.4rem);line-height:1.55;color:var(--bone);font-weight:350}
.lead + p{margin-top:1.1rem;color:var(--bone-dim)}
p strong{color:var(--bone);font-weight:600}

/* section heading block */
.sec-head{position:relative;margin-bottom:clamp(2.5rem,5vw,4.5rem)}
.sec-head--center{text-align:center;display:flex;flex-direction:column;align-items:center}
.sec-head--center .eyebrow{justify-content:center}
.sec-index{
  position:absolute;top:-.2em;right:0;
  font-family:var(--ff-disp);font-size:clamp(3rem,9vw,7rem);
  line-height:1;color:transparent;-webkit-text-stroke:1px var(--line);
  font-weight:300;font-style:italic;pointer-events:none;user-select:none;
}
.sec-index--c{position:static;display:block;margin-bottom:.1em;-webkit-text-stroke:1px rgba(244,236,225,.18)}
.sec-index--light{-webkit-text-stroke:1px rgba(244,236,225,.28)}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  --bg:var(--ember);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--ff-text);font-weight:600;font-size:.82rem;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.95em 1.6em;border-radius:100px;
  position:relative;overflow:hidden;isolation:isolate;
  transition:color .4s var(--ease),border-color .4s var(--ease),transform .4s var(--ease);
  border:1px solid transparent;white-space:nowrap;
}
.btn--lg{padding:1.15em 2em;font-size:.86rem}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;background:var(--bg);
  transform:translateY(0);transition:transform .45s var(--ease);
}
.btn--ember{color:#1a0c05}
.btn--ember::before{background:linear-gradient(110deg,var(--ember-2),var(--ember) 60%,var(--ember-deep))}
.btn--ember:hover{color:#1a0c05;transform:translateY(-2px)}
.btn--ember:hover::before{transform:translateY(-6%) scale(1.05)}

.btn--ghost{color:var(--bone);border-color:var(--line)}
.btn--ghost::before{background:var(--bone);transform:translateY(101%)}
.btn--ghost:hover{color:var(--ink);transform:translateY(-2px)}
.btn--ghost:hover::before{transform:translateY(0)}

/* =========================================================
   Nav
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--pad);
  transition:background .5s var(--ease),padding .5s var(--ease),backdrop-filter .5s;
}
.nav.is-scrolled{
  background:rgba(12,10,9,.82);backdrop-filter:blur(14px) saturate(1.2);
  padding-top:.7rem;padding-bottom:.7rem;
  border-bottom:1px solid var(--line-soft);
}
.nav__brand{display:flex;align-items:center;gap:.55em}
.nav__mark{color:var(--ember);display:grid;place-items:center;transition:transform .6s var(--ease)}
.nav__brand:hover .nav__mark{transform:rotate(-8deg) scale(1.08)}
.nav__word{
  font-family:var(--ff-disp);font-size:1.3rem;font-weight:600;
  letter-spacing:.01em;
}
.nav__links{display:flex;gap:2rem}
.nav__links a{
  font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;
  color:var(--bone-dim);position:relative;padding:.2em 0;transition:color .3s;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;
  background:var(--ember);transform:scaleX(0);transform-origin:right;
  transition:transform .4s var(--ease);
}
.nav__links a:hover{color:var(--bone)}
.nav__links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav__actions{display:flex;align-items:center;gap:1.4rem}
.nav__tel{font-size:.82rem;letter-spacing:.08em;color:var(--bone-dim);font-weight:500}
.nav__tel:hover{color:var(--bone)}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px;z-index:90}
.nav__burger span{width:24px;height:2px;background:var(--bone);transition:transform .4s var(--ease),opacity .3s}
.nav.is-open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.is-open .nav__burger span:nth-child(2){transform:translateY(-0px) rotate(-45deg)}

/* mobile menu */
.mobilemenu{
  position:fixed;inset:0;z-index:70;background:var(--ink-2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;
  opacity:0;visibility:hidden;transform:translateY(-2%);
  transition:opacity .5s var(--ease),transform .5s var(--ease),visibility .5s;
}
.mobilemenu.is-open{opacity:1;visibility:visible;transform:translateY(0)}
.mobilemenu a{font-family:var(--ff-disp);font-size:2rem;letter-spacing:-.01em}
.mobilemenu a.btn{font-family:var(--ff-text);font-size:.9rem;margin-top:1rem}

/* =========================================================
   Hero
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0;will-change:transform}
.hero__img{
  width:100%;height:115%;object-fit:cover;object-position:center 38%;
  will-change:transform;transform:scale(1.22);
  filter:blur(7px) brightness(.42) saturate(1.15);
}
.hero__glow{
  position:absolute;inset:0;
  background:radial-gradient(120% 80% at 60% 34%,rgba(226,98,42,.5),transparent 55%),
             radial-gradient(60% 50% at 30% 85%,rgba(181,66,28,.32),transparent 60%);
  mix-blend-mode:screen;opacity:.95;
}
.hero__veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,10,9,.6) 0%,rgba(12,10,9,.35) 35%,rgba(12,10,9,.55) 72%,var(--ink) 100%),
             linear-gradient(90deg,rgba(12,10,9,.78),rgba(12,10,9,.2) 55%);
}

/* the dropping steak board */
.hero__stage{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  display:flex;align-items:center;justify-content:flex-end;
  padding-right:clamp(20px,5vw,90px);
}
.hero__board{
  position:relative;
  width:min(46vw,560px);aspect-ratio:16/10;
  border-radius:7px;overflow:hidden;transform-origin:center center;
  box-shadow:0 55px 95px -24px rgba(0,0,0,.92),0 22px 45px rgba(0,0,0,.6),
             0 0 0 1px rgba(0,0,0,.55),inset 0 0 0 6px rgba(26,18,14,.92);
  will-change:transform;
}
.hero__board img{width:100%;height:100%;object-fit:cover;object-position:center 60%}
.hero__sizzle{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 60% at 50% 40%,rgba(245,146,71,.25),transparent 70%);
  mix-blend-mode:screen;opacity:0;
}
.hero__salt{position:absolute;inset:0;width:100%;height:100%;z-index:2;pointer-events:none}

.hero__inner{position:relative;z-index:4;padding:0 var(--pad);padding-top:8vh;width:100%;max-width:var(--maxw);margin-inline:auto}
.hero__inner>*{max-width:min(600px,52vw)}
.hero__eyebrow{margin-bottom:1.6rem}
.hero__eyebrow .dot{width:4px;height:4px}
.hero__title{
  font-family:var(--ff-disp);font-weight:500;font-optical-sizing:auto;
  font-size:clamp(3.1rem,9.6vw,8.6rem);line-height:.98;letter-spacing:-.012em;
  max-width:16ch;
}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line>span{display:block}
.line--ember>span{color:var(--ember);font-style:italic;font-weight:500}
.hero__lede{
  margin-top:1.8rem;max-width:52ch;font-size:clamp(1.05rem,1.5vw,1.3rem);
  color:var(--bone-dim);line-height:1.6;
}
.hero__cta{margin-top:2.4rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero__scroll{
  position:absolute;right:var(--pad);bottom:clamp(4rem,9vh,8rem);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:.8rem;
  font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--bone-dim);
  writing-mode:vertical-rl;
}
.hero__scrollline{width:1px;height:70px;background:linear-gradient(var(--ember),transparent);position:relative;overflow:hidden}
.hero__scrollline::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--bone);animation:scrolldn 2.2s var(--ease) infinite}
@keyframes scrolldn{0%{transform:translateY(-100%)}60%,100%{transform:translateY(280%)}}

/* =========================================================
   Marquee
   ========================================================= */
.marquee{
  overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--ink-2);padding:1.5rem 0;
}
.marquee__track{
  display:flex;align-items:center;gap:2.6rem;width:max-content;
  animation:marq 38s linear infinite;
}
.marquee__track span{
  font-family:var(--ff-disp);font-style:italic;font-weight:500;
  font-size:clamp(1.6rem,4vw,3rem);color:var(--bone);white-space:nowrap;
}
.marquee__track i{color:var(--ember);font-size:1.2rem;font-style:normal}
@keyframes marq{to{transform:translateX(-50%)}}

/* =========================================================
   Experience
   ========================================================= */
.experience{padding:clamp(5rem,11vh,9rem) 0;position:relative}
.exp-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,5vw,6rem);align-items:center}
.exp-copy p{max-width:50ch}
.steps{list-style:none;margin-top:2.6rem;display:flex;flex-direction:column;gap:1.6rem}
.steps li{display:flex;gap:1.4rem;align-items:flex-start;padding-top:1.6rem;border-top:1px solid var(--line)}
.steps__num{
  font-family:var(--ff-disp);font-style:italic;font-size:1.5rem;color:var(--ember);
  flex:none;width:1.6em;line-height:1;padding-top:.1em;
}
.steps h3{font-family:var(--ff-disp);font-weight:600;font-size:1.5rem;letter-spacing:-.01em}
.steps p{color:var(--bone-dim);font-size:.98rem;margin-top:.25rem}

.exp-media{position:relative;align-self:stretch;min-height:520px}
.exp-fig{overflow:hidden;border-radius:6px;position:relative}
.exp-fig img{width:100%;height:100%;object-fit:cover;will-change:transform}
.exp-fig--tall{height:min(70vh,620px);box-shadow:0 40px 80px -30px rgba(0,0,0,.7)}
.exp-fig--small{
  position:absolute;right:-6%;bottom:-8%;width:58%;height:300px;
  border:6px solid var(--ink);box-shadow:0 30px 60px -20px rgba(0,0,0,.8);
}
.exp-fig figcaption{
  position:absolute;left:0;bottom:0;width:100%;padding:1.2rem 1rem .9rem;
  background:linear-gradient(transparent,rgba(12,10,9,.85));
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone-dim);
}

/* =========================================================
   Menu
   ========================================================= */
.menu{padding:clamp(5rem,11vh,9rem) 0;background:linear-gradient(180deg,var(--ink),var(--ink-2))}
.menu-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,7rem)}
.menu-col{display:flex;flex-direction:column;gap:clamp(2.2rem,4vw,3.2rem)}
.menu-block__title{
  font-family:var(--ff-disp);font-weight:600;font-size:clamp(1.7rem,2.6vw,2.3rem);
  letter-spacing:-.01em;padding-bottom:1rem;margin-bottom:1.2rem;border-bottom:1px solid var(--line);
}
.menu-block__title em{font-style:italic;color:var(--bone-faint);font-size:.7em;font-weight:300;letter-spacing:0}

.dishes{list-style:none;display:flex;flex-direction:column;gap:1.5rem}
.dishes li{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;column-gap:.75rem}
.dish__name{font-size:1.04rem;color:var(--bone);font-weight:500}
.dish__name em{font-style:normal;color:var(--bone-faint);font-size:.82em;font-weight:400;letter-spacing:.02em;margin-left:.2em}
.dish__dots{border-bottom:1px dotted rgba(244,236,225,.28);transform:translateY(-.35em);min-width:1.5rem}
.dish__price{
  font-family:var(--ff-disp);font-style:italic;font-size:1.3rem;font-weight:600;color:var(--ember);
  white-space:nowrap;font-variant-numeric:oldstyle-nums;
}
.dish__price::before{content:"£";font-size:.72em;opacity:.7;margin-right:.05em}
.dish__price[data-mp]::before{content:""}
.dish__price[data-mp]{font-size:.92rem;color:var(--bone-faint);letter-spacing:.06em}
.dish__desc{grid-column:1/-1;color:var(--bone-faint);font-size:.9rem;margin-top:.15rem;max-width:42ch}

.menu-note{font-size:.82rem;color:var(--bone-faint);font-style:italic;margin-top:1.2rem;letter-spacing:.01em}

.menu-fig{overflow:hidden;border-radius:6px;height:clamp(220px,30vw,340px)}
.menu-fig img{width:100%;height:120%;object-fit:cover;will-change:transform}
.menu-fig--first{margin-bottom:.4rem}

/* desserts band */
.desserts{
  margin-top:clamp(3rem,6vw,5rem);display:grid;grid-template-columns:.9fr 1.1fr;
  gap:clamp(2rem,4vw,4rem);align-items:center;
  background:var(--ink-3);border:1px solid var(--line);border-radius:8px;overflow:hidden;
}
.desserts__media{overflow:hidden;align-self:stretch;min-height:340px}
.desserts__media img{width:100%;height:100%;object-fit:cover;will-change:transform}
.desserts__copy{padding:clamp(2rem,4vw,3.5rem) clamp(2rem,4vw,3.5rem) clamp(2rem,4vw,3.5rem) 0}
.desserts__flat{font-family:var(--ff-text);font-style:italic;font-size:.6em;color:var(--ember);letter-spacing:0}
.dessert-list{list-style:none;columns:2;column-gap:2rem;margin-top:.5rem}
.dessert-list li{padding:.55rem 0;border-bottom:1px solid var(--line-soft);font-size:.98rem;break-inside:avoid}
.dessert-list li em{color:var(--bone-faint);font-style:italic;font-size:.85em}

.menu-disclaimer{text-align:center;margin-top:2.6rem;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-faint)}

/* =========================================================
   Story
   ========================================================= */
.story{padding:clamp(5rem,11vh,9rem) 0;position:relative;overflow:hidden}
.story__bg{
  position:absolute;inset:0;
  background:radial-gradient(60% 60% at 85% 10%,rgba(203,163,93,.08),transparent 60%);
  pointer-events:none;
}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,6rem);align-items:center}
.story-figs{position:relative;min-height:560px}
.story-fig{overflow:hidden;border-radius:6px;position:absolute}
.story-fig img{width:100%;height:100%;object-fit:cover;will-change:transform}
.story-fig--a{top:0;left:0;width:78%;height:64%;box-shadow:0 40px 80px -30px rgba(0,0,0,.7)}
.story-fig--b{bottom:0;right:0;width:56%;height:52%;border:6px solid var(--ink);box-shadow:0 30px 60px -20px rgba(0,0,0,.8)}
.story-copy p{max-width:46ch}
.story-stats{display:flex;gap:clamp(1.2rem,3vw,2.6rem);margin-top:2.6rem;flex-wrap:wrap}
.story-stats div{display:flex;flex-direction:column;gap:.2rem}
.stat__n{font-family:var(--ff-disp);font-size:clamp(2.2rem,4.4vw,3.3rem);line-height:1;color:var(--bone);font-weight:600}
.stat__n i{font-style:italic;font-size:.42em;color:var(--ember);margin-left:.1em;text-transform:uppercase;letter-spacing:.05em}
.stat__l{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-faint)}

/* =========================================================
   Quigley's
   ========================================================= */
.quigleys{position:relative;padding:clamp(7rem,16vh,12rem) 0;overflow:hidden;isolation:isolate}
.quigleys__media{position:absolute;inset:0;z-index:-1}
.quigleys__media img{width:100%;height:118%;object-fit:cover;object-position:center 30%}
.quigleys__tint{position:absolute;inset:0;background:linear-gradient(90deg,rgba(12,10,9,.92) 0%,rgba(12,10,9,.7) 45%,rgba(12,10,9,.35) 100%)}
.quigleys__inner{position:relative}
.quigleys__copy{max-width:46ch;margin-top:1.6rem;color:var(--bone-dim);font-size:1.1rem;line-height:1.6}
.quigleys__tags{list-style:none;display:flex;gap:.7rem;flex-wrap:wrap;margin-top:2rem}
.quigleys__tags li{
  border:1px solid var(--line);border-radius:100px;padding:.5em 1.1em;
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim);
  background:rgba(244,236,225,.03);
}

/* =========================================================
   Gallery (horizontal scroll)
   ========================================================= */
.gallery{padding:clamp(2rem,5vh,4rem) 0;overflow:hidden;background:var(--ink-2)}
.gallery__track{display:flex;gap:1rem;padding-inline:var(--pad);will-change:transform}
.gallery figure{flex:none;width:clamp(220px,26vw,360px);height:clamp(300px,34vw,460px);overflow:hidden;border-radius:6px}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease);filter:grayscale(.15) contrast(1.02)}
.gallery figure:hover img{transform:scale(1.06);filter:none}

/* =========================================================
   Visit
   ========================================================= */
.visit{padding:clamp(5rem,11vh,9rem) 0}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem)}
.visit-card{display:flex;flex-direction:column;gap:2rem}
.visit-row h3{
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ember-2);
  margin-bottom:.7rem;font-weight:600;
}
.visit-row p{font-size:1.45rem;font-family:var(--ff-disp);font-weight:500;line-height:1.4}
.visit-row .muted{font-size:.85rem;color:var(--bone-faint);font-family:var(--ff-text)}
.hours{width:100%;max-width:340px;border-collapse:collapse}
.hours td{padding:.55rem 0;border-bottom:1px solid var(--line-soft);font-size:1rem}
.hours td:last-child{text-align:right;color:var(--bone-dim);font-variant-numeric:tabular-nums}
.visit-link{display:block;font-family:var(--ff-disp);font-size:1.5rem;font-weight:500;color:var(--bone);transition:color .3s;width:fit-content}
.visit-link:hover{color:var(--ember)}
.visit-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.5rem}
.visit-map{border-radius:8px;overflow:hidden;border:1px solid var(--line);min-height:420px}
.visit-map iframe{width:100%;height:100%;min-height:420px;border:0;filter:invert(.92) hue-rotate(180deg) brightness(.92) contrast(.95) saturate(.7);}

/* =========================================================
   Footer
   ========================================================= */
.footer{background:var(--ink-2);border-top:1px solid var(--line);padding-top:clamp(3rem,6vw,5rem)}
.footer__inner{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3rem}
.footer__brand .nav__mark{color:var(--ember)}
.footer__word{font-family:var(--ff-disp);font-size:1.8rem;font-weight:600;display:block;margin-top:.6rem}
.footer__tag{color:var(--bone-faint);font-size:.85rem;margin-top:.4rem;letter-spacing:.04em}
.footer__nav{display:flex;flex-direction:column;gap:.7rem}
.footer__nav a{color:var(--bone-dim);font-size:.92rem;width:fit-content;transition:color .3s}
.footer__nav a:hover{color:var(--ember)}
.footer__contact a{display:block;color:var(--bone);font-size:.95rem;margin-bottom:.4rem;width:fit-content}
.footer__contact a:hover{color:var(--ember)}
.footer__contact p{color:var(--bone-faint);font-size:.9rem;margin-top:.3rem}
.footer__social{display:flex;gap:1.2rem;margin-top:1.2rem}
.footer__social a{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim)}
.footer__base{
  border-top:1px solid var(--line-soft);padding:1.6rem var(--pad);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.74rem;letter-spacing:.08em;color:var(--bone-faint);text-transform:uppercase;
  max-width:var(--maxw);margin-inline:auto;
}

/* =========================================================
   Grain + cursor + reveal
   ========================================================= */
.grain{
  position:fixed;inset:-50%;z-index:60;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grainshift 8s steps(6) infinite;
}
@keyframes grainshift{0%{transform:translate(0,0)}20%{transform:translate(-4%,3%)}40%{transform:translate(3%,-2%)}60%{transform:translate(-2%,4%)}80%{transform:translate(4%,-3%)}100%{transform:translate(0,0)}}

.cursor{
  position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;
  background:var(--ember);z-index:200;pointer-events:none;
  transform:translate(-50%,-50%);mix-blend-mode:difference;
  transition:width .35s var(--ease),height .35s var(--ease),background .3s,opacity .3s;
  display:none;opacity:0;
}
.cursor.is-active{opacity:1}
.cursor.is-hover{width:74px;height:74px;background:var(--bone)}
.cursor__label{
  font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);
  opacity:0;transition:opacity .3s;font-weight:600;
}
.cursor.is-hover .cursor__label{opacity:1}

/* reveal: split lines always stack; only hide/animate when engine active */
[data-reveal-lines] .rl-line{display:block;overflow:hidden}
[data-reveal-lines] .rl-line>span{display:block}
html.anim [data-reveal]{opacity:0;transform:translateY(28px)}
html.anim [data-reveal-lines] .rl-line>span{transform:translateY(105%)}
html.anim .hero__board{opacity:0}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1080px){
  .nav__links{display:none}
}
@media (max-width:900px){
  .hero{flex-direction:column;justify-content:center;align-items:center;gap:clamp(1.5rem,5vw,2.5rem);padding-block:15vh 9vh}
  .hero__stage{position:relative;inset:auto;width:100%;justify-content:center;padding-right:0}
  .hero__board{width:min(84vw,440px)}
  .hero__inner{padding-top:0}
  .hero__inner>*{max-width:100%}
  .exp-grid,.story-grid,.menu-layout,.desserts,.visit-grid,.footer__inner{grid-template-columns:1fr}
  .exp-media{min-height:auto;margin-top:1rem}
  .exp-fig--small{position:relative;right:auto;bottom:auto;width:72%;margin:-14% 0 0 auto;height:240px}
  .story-figs{min-height:480px}
  .desserts__copy{padding:0 clamp(1.4rem,5vw,2.5rem) clamp(2rem,6vw,2.5rem)}
  .desserts__media{min-height:280px}
  .visit-map{min-height:340px}
  .footer__base{flex-direction:column;gap:.5rem}
}
@media (max-width:680px){
  .nav__actions .nav__tel,.nav__actions .btn{display:none}
  .nav__burger{display:flex}
  .hero{align-items:center}
  .hero__inner{padding-bottom:0;padding-top:18vh}
  .hero__scroll{display:none}
  .dessert-list{columns:1}
  .dish__price{font-size:1rem}
  .story-fig--a{width:84%;height:60%}
  .story-fig--b{width:60%;height:46%}
}

/* =========================================================
   Reduced motion
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  html.anim [data-reveal]{opacity:1;transform:none}
  html.anim [data-reveal-lines] .rl-line>span{transform:none}
  .hero__img{transform:none;height:100%}
  .marquee__track{animation:none}
}
