/* =========================================================================
   NAPÒ · Sushi & Pizza — Teggiano
   Dark / warm-wood / enso. Cormorant Garamond + Inter + Shippori Mincho.
   ========================================================================= */
:root{
  --bg:#16110d; --bg-2:#1b1510; --bg-3:#100c08; --surface:#211a14; --surface-2:#2a211a;
  --line:rgba(255,255,255,.09); --line-amber:rgba(232,182,92,.20);
  --ink:#f4ece0; --ink-soft:#cdbca6; --muted:#9c8b76;
  --amber:#e8b65c; --amber-deep:#c8923a; --red:#d0593c;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  --jp:'Shippori Mincho',serif;
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html{overflow-x:hidden}
body{
  background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-weight:400;line-height:1.65;overflow-x:clip;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--amber);color:#1a130b}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.05;letter-spacing:.01em}

/* ---- grain & texture overlay ---- */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;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='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---- enso mark ---- */
.enso{width:100%;height:100%;overflow:visible;color:var(--amber)}
.enso-ring,.enso-ring2{stroke:currentColor;fill:none}
.enso-ring{stroke-width:6.2}
.enso-ring2{stroke-width:3.4;opacity:.85}
.enso-stick{stroke:currentColor;stroke-width:2.4;stroke-linecap:round;opacity:.7}
.enso--ghost{color:rgba(232,182,92,.16)}

/* =======================  INTRO (animazione logo)  ======================= */
.intro{position:fixed;inset:0;z-index:200;overflow:hidden}
.intro.done{display:none}
.intro-curtain{position:absolute;left:0;width:100%;height:50.5%;background:var(--bg-3);z-index:1}
.intro-curtain--top{top:0}
.intro-curtain--bottom{bottom:0}
.intro-logo{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem}
.intro-logo-img{display:block;width:clamp(260px,42vw,400px);height:auto;opacity:0;transform:scale(.84);
  filter:drop-shadow(0 0 30px rgba(232,182,92,.32));
  animation:introLogoIn 1.1s var(--ease) .25s forwards, introLogoGlow 1.7s ease 1s}
@keyframes introLogoIn{to{opacity:1;transform:scale(1)}}
@keyframes introLogoGlow{0%{filter:drop-shadow(0 0 20px rgba(232,182,92,.22))}45%{filter:drop-shadow(0 0 58px rgba(232,182,92,.6))}100%{filter:drop-shadow(0 0 30px rgba(232,182,92,.32))}}
.intro-mark{position:relative;display:grid;place-items:center}
.intro-stack{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.enso--intro{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:clamp(245px,40vw,360px);height:clamp(245px,40vw,360px);
  color:var(--amber);filter:drop-shadow(0 0 26px rgba(232,182,92,.25));animation:ensoFlash 1.7s ease 1.15s}
@keyframes ensoFlash{0%{filter:drop-shadow(0 0 20px rgba(232,182,92,.2))}
  45%{filter:drop-shadow(0 0 58px rgba(232,182,92,.68))}100%{filter:drop-shadow(0 0 26px rgba(232,182,92,.25))}}
.enso--intro .enso-ring{stroke-dasharray:232;stroke-dashoffset:232;animation:draw 1s var(--ease) .15s forwards}
.enso--intro .enso-ring2{opacity:0;animation:introFade .4s ease .95s forwards}
.enso--intro .enso-stick{opacity:0;transform-origin:60% 40%;animation:stickIn .55s var(--ease) 1.05s forwards}
.intro-word{position:relative;display:flex;padding:0 .04em;
  font-family:var(--serif);font-weight:700;font-size:clamp(2.7rem,8vw,5rem);line-height:1;letter-spacing:.02em;color:#fff}
.intro-word span{display:inline-block;transform:translateY(62%) scale(.8);opacity:0;filter:blur(8px);
  animation:letterUp .85s var(--ease) forwards;animation-delay:calc(1s + var(--i) * .09s)}
.intro-sub{font-family:var(--sans);font-size:clamp(.66rem,1.7vw,.86rem);font-weight:500;letter-spacing:.4em;text-transform:uppercase;
  color:#f3e8d2;padding-left:.4em;text-shadow:0 2px 12px rgba(8,6,4,.95);
  opacity:0;transform:translateY(8px);animation:introFadeUp .8s var(--ease) 1.55s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes introFade{to{opacity:.85}}
@keyframes introFadeUp{to{opacity:1;transform:none}}
@keyframes letterUp{to{transform:none;opacity:1;filter:blur(0)}}
@keyframes stickIn{from{opacity:0;transform:translate(10px,-10px) scale(.5)}to{opacity:.7;transform:none}}
@keyframes ruleGrow{to{width:min(240px,62vw)}}
.intro.exit .intro-logo{animation:introLogoOut .55s var(--ease) forwards}
.intro.exit .intro-curtain--top{animation:curtainUp .85s var(--ease) .25s forwards}
.intro.exit .intro-curtain--bottom{animation:curtainDown .85s var(--ease) .25s forwards}
@keyframes introLogoOut{to{opacity:0;transform:scale(1.07)}}
@keyframes curtainUp{to{transform:translateY(-101%)}}
@keyframes curtainDown{to{transform:translateY(101%)}}

/* =======================  NAV  ======================= */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem clamp(1.1rem,4vw,3rem);
  transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s}
.nav.scrolled{background:rgba(17,12,8,.62);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);
  padding:.7rem clamp(1.1rem,4vw,3rem);box-shadow:0 8px 30px -12px rgba(0,0,0,.5),0 1px 0 rgba(255,255,255,.07)}
.logo{display:flex;align-items:center;gap:.7rem}
.logo-mark{width:42px;height:42px;flex:0 0 auto;display:block;transition:transform .6s var(--ease)}
.logo:hover .logo-mark{transform:rotate(-18deg)}
.logo-type{display:flex;flex-direction:column;line-height:1}
.logo-type b{font-family:var(--serif);font-weight:700;font-size:1.35rem;letter-spacing:.14em;color:var(--ink)}
.logo-type i{font-style:normal;font-size:.56rem;letter-spacing:.42em;color:var(--amber);text-transform:uppercase;margin-top:.18rem}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.82rem;letter-spacing:.06em;color:var(--ink-soft);position:relative;transition:color .3s}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--amber);transition:width .35s var(--ease)}
.nav-links a:not(.nav-cta):hover{color:var(--ink)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{padding:.55rem 1.3rem;border:1px solid var(--line-amber);border-radius:40px;color:var(--amber)!important;
  letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;transition:.35s var(--ease)}
.nav-cta:hover{background:var(--amber);color:#1a130b!important;border-color:var(--amber)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;z-index:110}
.burger span{width:26px;height:2px;background:var(--ink);transition:.4s var(--ease)}
.burger[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded=true] span:nth-child(2){opacity:0}
.burger[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =======================  BUTTONS  ======================= */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;font-family:var(--sans);
  padding:1rem 2rem;border-radius:44px;cursor:pointer;transition:.4s var(--ease);border:1px solid transparent;background:transparent}
.btn--solid{background:var(--amber);color:#1a130b}
.btn--solid:hover{background:#f2c674;transform:translateY(-3px);box-shadow:0 14px 34px -12px rgba(232,182,92,.6)}
.btn--ghost{border-color:rgba(244,236,224,.3);color:var(--ink)}
.btn--ghost:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-3px)}

/* =======================  HERO (3D)  ======================= */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;overflow:hidden;text-align:center;background:#0b0806}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:kenburns 26s ease-in-out infinite alternate;will-change:transform}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.17) translate(-1.5%,-1.5%)}}
.hero-scrim{position:absolute;inset:0;z-index:1;background:
  radial-gradient(115% 88% at 50% 44%,rgba(20,14,9,.46),rgba(8,5,3,.9) 74%),
  linear-gradient(180deg,rgba(8,5,3,.8),rgba(8,5,3,.26) 34%,rgba(8,5,3,.97))}
.hero::before{content:"";position:absolute;top:0;left:0;right:0;height:24%;z-index:2;pointer-events:none;
  background:linear-gradient(rgba(8,5,3,.72),transparent)}
.hero-glow{position:absolute;left:50%;top:46%;width:min(720px,108vw);aspect-ratio:1;z-index:1;pointer-events:none;
  transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(232,182,92,.22),rgba(208,89,60,.05) 42%,transparent 64%);
  filter:blur(24px);animation:glowPulse 6s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.65;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}
.hero-particles{position:absolute;inset:0;z-index:2;pointer-events:none}
.hero-orbit{position:absolute;inset:0;z-index:2;transform-style:preserve-3d;pointer-events:none;
  will-change:transform;transition:transform .45s ease-out}
.float-dish{position:absolute;top:var(--top);left:var(--left);width:var(--size);height:var(--size);
  margin:calc(var(--size)/-2) 0 0 calc(var(--size)/-2);will-change:transform;transition:transform .3s ease-out;pointer-events:auto}
.float-inner{position:relative;width:100%;height:100%;border-radius:50%;overflow:hidden;
  border:1px solid var(--line-amber);box-shadow:0 26px 54px -18px rgba(0,0,0,.8);cursor:pointer;
  animation-name:floatA;animation-duration:12s;animation-timing-function:ease-in-out;
  animation-iteration-count:infinite;animation-delay:var(--delay,0s)}
.float-dish:nth-child(2) .float-inner{animation-name:floatB;animation-duration:14s}
.float-dish:nth-child(3) .float-inner{animation-name:floatC;animation-duration:13s}
.float-dish:nth-child(4) .float-inner{animation-name:floatD;animation-duration:15s}
.float-dish:nth-child(5) .float-inner{animation-name:floatB;animation-duration:12.5s}
.float-dish:nth-child(6) .float-inner{animation-name:floatC;animation-duration:13.5s}
.float-inner img{width:100%;height:100%;object-fit:cover;animation:dishZoom 14s ease-in-out infinite alternate}
.float-inner:hover{box-shadow:0 30px 60px -16px rgba(0,0,0,.85),0 0 0 1px var(--amber)}
.float-label{position:absolute;left:50%;bottom:9px;transform:translateX(-50%) translateY(6px);opacity:0;
  background:rgba(11,8,6,.82);color:var(--ink);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.28rem .65rem;border-radius:30px;white-space:nowrap;transition:.3s var(--ease);pointer-events:none;z-index:2}
.float-inner:hover .float-label{opacity:1;transform:translateX(-50%)}
@keyframes floatA{0%{transform:translate(0,0) rotate(-3deg) scale(1)}30%{transform:translate(16px,-28px) rotate(3deg) scale(1.04)}60%{transform:translate(-7px,-14px) rotate(-2deg) scale(1)}100%{transform:translate(0,0) rotate(-3deg) scale(1)}}
@keyframes floatB{0%{transform:translate(0,0) rotate(2deg)}30%{transform:translate(-18px,-23px) rotate(-3deg)}60%{transform:translate(12px,-33px) rotate(2deg)}100%{transform:translate(0,0) rotate(2deg)}}
@keyframes floatC{0%{transform:translate(0,0) rotate(-2deg) scale(1.03)}50%{transform:translate(21px,17px) rotate(3deg) scale(.99)}100%{transform:translate(0,0) rotate(-2deg) scale(1.03)}}
@keyframes floatD{0%{transform:translate(0,0) rotate(3deg)}50%{transform:translate(-17px,24px) rotate(-3deg)}100%{transform:translate(0,0) rotate(3deg)}}
@keyframes dishZoom{from{transform:scale(1.03)}to{transform:scale(1.13)}}
.hero-inner{position:relative;z-index:3;padding:6rem 1.2rem 0}
.hero-kicker{display:inline-block;font-size:.78rem;letter-spacing:.4em;text-transform:uppercase;font-weight:500;
  color:#f0cd86;margin-bottom:clamp(4rem,9vw,6.5rem);padding-left:.4em;text-shadow:0 2px 18px rgba(0,0,0,.95)}
.hero-logo{position:relative;display:grid;place-items:center;width:max-content;max-width:100%;margin:.2rem auto clamp(3.5rem,9vw,5.5rem)}
.hero-logo::before{content:"";position:absolute;left:50%;top:48%;transform:translate(-50%,-50%);
  width:clamp(380px,54vw,540px);aspect-ratio:1;z-index:-1;pointer-events:none;
  background:radial-gradient(circle,rgba(8,5,3,.92) 26%,rgba(8,5,3,.55) 46%,transparent 68%)}
.enso--hero{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:clamp(245px,40vw,360px);height:clamp(245px,40vw,360px);
  color:var(--amber);filter:drop-shadow(0 0 26px rgba(232,182,92,.28));
  animation:ensoBreathe 4.5s ease-in-out infinite}
@keyframes ensoBreathe{0%,100%{transform:translate(-50%,-50%) scale(1);filter:drop-shadow(0 0 22px rgba(232,182,92,.16))}
  50%{transform:translate(-50%,-50%) scale(1.03);filter:drop-shadow(0 0 46px rgba(232,182,92,.46))}}
.hero-mark{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.hero-logo h1{position:relative;font-family:var(--serif);font-size:clamp(2.7rem,8vw,5rem);font-weight:700;letter-spacing:.02em;
  color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.85),0 8px 44px rgba(0,0,0,.6);line-height:1;animation:napoGlow 5s ease-in-out infinite}
@keyframes napoGlow{0%,100%{text-shadow:0 2px 12px rgba(0,0,0,.85),0 8px 44px rgba(0,0,0,.6)}
  50%{text-shadow:0 2px 12px rgba(0,0,0,.85),0 8px 44px rgba(0,0,0,.6),0 0 34px rgba(232,182,92,.5)}}
.hero-sub{position:relative;font-family:var(--sans);font-size:clamp(.66rem,1.7vw,.86rem);font-weight:500;
  letter-spacing:.4em;text-transform:uppercase;color:#f3e8d2;padding-left:.4em;
  text-shadow:0 2px 14px rgba(8,6,4,.95),0 0 24px rgba(8,6,4,.85)}
.hero-sub span{color:var(--amber);padding:0 .05em}
/* ---- logo reale (immagine) ---- */
.hero-logo-stack{position:relative;display:block;width:clamp(280px,42vw,430px);aspect-ratio:1;will-change:transform,opacity}
.hero-logo-ring,.hero-logo-text{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;will-change:transform}
.hero-logo-ring{filter:drop-shadow(0 0 24px rgba(232,182,92,.32));animation:ringIdle 5s ease-in-out infinite}
@keyframes ringIdle{0%,100%{filter:drop-shadow(0 0 20px rgba(232,182,92,.25))}50%{filter:drop-shadow(0 0 40px rgba(232,182,92,.52))}}
.hero-logo-text{filter:drop-shadow(0 2px 14px rgba(0,0,0,.5));animation:logoTextGlow 4.5s ease-in-out infinite}
@keyframes logoTextGlow{0%,100%{filter:drop-shadow(0 2px 14px rgba(0,0,0,.5))}50%{filter:drop-shadow(0 2px 14px rgba(0,0,0,.5)) drop-shadow(0 0 20px rgba(232,182,92,.55))}}
.logo-img{height:46px;width:auto;display:block;transition:height .5s var(--ease)}
.nav.scrolled .logo-img{height:40px}
.logo--foot .logo-img{height:58px}
.hero-tag{font-size:clamp(.82rem,2vw,1rem);letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft);margin-top:1rem}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.4rem}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;color:var(--ink-soft)}
.hero-scroll span{width:1px;height:46px;background:linear-gradient(var(--amber),transparent);position:relative;overflow:hidden}
.hero-scroll span::after{content:"";position:absolute;top:-46px;left:0;width:1px;height:46px;background:var(--amber);animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{to{top:46px}}
.hero-scroll em{font-style:normal;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase}

/* =======================  SECTION SHELL  ======================= */
section{position:relative;z-index:2}
.sec-head{max-width:var(--maxw);margin:0 auto;text-align:center;padding:0 1.2rem}
.kicker{display:inline-block;font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--amber);margin-bottom:1rem}
.sec-head h2{font-size:clamp(2rem,5vw,3.4rem)}
.sec-lead{max-width:560px;margin:1.1rem auto 0;color:var(--ink-soft);font-size:1.02rem}

/* =======================  MANIFESTO  ======================= */
.manifesto{padding:clamp(5rem,11vw,9rem) 1.2rem;text-align:center;background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.mani-glyph{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--jp);
  font-size:clamp(14rem,40vw,32rem);color:rgba(232,182,92,.035);pointer-events:none;line-height:1}
.mani-glyph span{margin-left:-.15em}
.manifesto p{position:relative;max-width:820px;margin:0 auto;font-family:var(--serif);
  font-size:clamp(1.4rem,3.6vw,2.4rem);line-height:1.42;color:var(--ink);font-weight:500}
.manifesto strong{color:var(--amber);font-weight:600}

/* =======================  STORIA  ======================= */
.storia{max-width:var(--maxw);margin:0 auto;padding:clamp(5rem,10vw,8rem) clamp(1.2rem,4vw,2.5rem);
  display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.storia-media{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:4/5}
.storia-media .par{position:absolute;inset:-11% 0;z-index:0;will-change:transform;transform:translateY(var(--py,0))}
.storia-media .par img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.storia-media:hover .par img{transform:scale(1.06)}
.storia-media::after{content:"";position:absolute;inset:0;z-index:1;box-shadow:inset 0 0 0 1px var(--line-amber);border-radius:6px}
.storia-badge{z-index:2}
.storia-badge{position:absolute;left:1.2rem;bottom:1.2rem;background:rgba(16,12,8,.78);backdrop-filter:blur(6px);
  border:1px solid var(--line-amber);border-radius:4px;padding:.7rem 1.1rem;text-align:center;line-height:1}
.storia-badge span{display:block;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--amber)}
.storia-badge b{font-family:var(--serif);font-size:2rem;color:var(--ink)}
.storia-text h2{font-size:clamp(2rem,4.6vw,3.2rem);margin-bottom:1.3rem}
.storia-text p{color:var(--ink-soft);margin-bottom:1rem;max-width:52ch}
.storia-text strong{color:var(--ink);font-weight:600}
.stats{display:flex;gap:clamp(1.2rem,4vw,2.6rem);margin-top:2.2rem;flex-wrap:wrap}
.stat b{display:block;font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem);color:var(--amber);line-height:1}
.stat span{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* =======================  SIGNATURE  ======================= */
.signature{padding:clamp(4rem,9vw,7rem) 0}
.signature .sec-head{margin-bottom:clamp(2.5rem,5vw,4rem)}
.sig-grid{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.sig-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;will-change:transform;
  display:flex;flex-direction:column;transition:transform .5s var(--ease),border-color .5s,box-shadow .5s}
.sig-card:hover{transform:translateY(-8px);border-color:var(--line-amber);box-shadow:0 26px 50px -26px rgba(0,0,0,.8)}
.sig-media{position:relative;aspect-ratio:1;overflow:hidden}
.sig-media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.sig-card:hover .sig-media img{transform:scale(1.09)}
.sig-tag{position:absolute;top:.8rem;left:.8rem;background:rgba(16,12,8,.7);backdrop-filter:blur(4px);
  color:var(--amber);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;padding:.35rem .7rem;border-radius:30px;border:1px solid var(--line-amber)}
.sig-text{padding:1.2rem 1.2rem 1.4rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.sig-text h3{font-size:1.4rem;color:var(--ink)}
.sig-text p{font-size:.86rem;color:var(--muted);flex:1;line-height:1.55}
.sig-price{font-family:var(--serif);font-size:1.3rem;color:var(--amber)}

/* =======================  MENU  ======================= */
.menu{padding:clamp(4.5rem,9vw,7.5rem) 0;background:var(--bg-2);border-top:1px solid var(--line)}
.menu .sec-head{margin-bottom:2.4rem}
.menu-controls{max-width:var(--maxw);margin:0 auto 2.6rem;padding:0 clamp(1.2rem,4vw,2.5rem);
  display:flex;flex-direction:column;gap:1.4rem;align-items:center}
.tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.tab{display:inline-flex;align-items:center;gap:.55rem;background:transparent;border:1px solid var(--line);
  color:var(--ink-soft);padding:.7rem 1.4rem;border-radius:44px;cursor:pointer;font-family:var(--sans);
  font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;transition:.35s var(--ease)}
.tab-jp{font-family:var(--jp);font-size:1rem;color:var(--amber);transition:.35s}
.tab:hover{border-color:var(--line-amber);color:var(--ink)}
.tab.is-active{background:var(--amber);border-color:var(--amber);color:#1a130b}
.tab.is-active .tab-jp{color:#1a130b}
.menu-search{width:100%;max-width:420px}
.menu-search input{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:44px;
  padding:.85rem 1.4rem;color:var(--ink);font-family:var(--sans);font-size:.92rem;transition:border-color .3s}
.menu-search input::placeholder{color:var(--muted)}
.menu-search input:focus{outline:none;border-color:var(--amber)}

.menu-panels{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem);min-height:200px}
.menu-panel{display:none;animation:panelIn .5s var(--ease)}
.menu-panel.is-active{display:block}
@keyframes panelIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.menu-group{margin-bottom:3rem}
.menu-group-title{font-size:1.6rem;color:var(--ink);margin-bottom:1.4rem;padding-bottom:.7rem;
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:.7rem}
.menu-group-title::before{content:"";width:26px;height:1px;background:var(--amber)}

.dish-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:1.1rem}
.dish{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;will-change:transform;
  display:flex;flex-direction:column;transform-style:preserve-3d;
  transition:transform .5s var(--ease),border-color .45s,box-shadow .5s,background .45s}
.dish:hover{transform:translateY(-10px);border-color:var(--amber);
  box-shadow:0 34px 60px -28px rgba(0,0,0,.92),0 0 0 1px rgba(232,182,92,.16),0 14px 44px -16px rgba(232,182,92,.24);
  background:linear-gradient(180deg,var(--surface),#1d1610)}
/* sheen sweep diagonale all'hover */
.dish::after{content:"";position:absolute;inset:0;z-index:4;pointer-events:none;border-radius:inherit;opacity:0;
  background:linear-gradient(115deg,transparent 32%,rgba(255,241,214,.16) 47%,rgba(255,244,222,.36) 50%,rgba(255,241,214,.16) 53%,transparent 68%);
  background-size:280% 280%;background-position:130% 0;transition:opacity .35s}
.dish:hover::after{opacity:1;animation:dishSheen 1.05s ease forwards}
@keyframes dishSheen{to{background-position:-50% 0}}
.dish-media{position:relative;aspect-ratio:1;overflow:hidden;background:var(--bg-3)}
.dish-media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,0) 52%,rgba(8,5,2,.62));opacity:.72;transition:opacity .5s}
.dish:hover .dish-media::after{opacity:.4}
.dish-media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .6s}
.dish:hover .dish-media img{transform:scale(1.14);filter:brightness(1.07) saturate(1.08)}
.dish-media--empty{display:grid;place-items:center;padding:2.4rem}
.dish-media--empty .enso{width:64px;height:64px}
.dish-body{padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.dish-name{font-size:1.16rem;color:var(--ink);line-height:1.2}
.dish-desc{font-size:.82rem;color:var(--muted);line-height:1.5}
.dish-foot{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-top:auto;padding-top:.75rem}
.dish-price{font-family:var(--serif);font-size:1.28rem;color:var(--amber);white-space:nowrap;line-height:1}
.dish-price--ask{font-size:.78rem;font-family:var(--sans);color:var(--muted);font-style:italic;letter-spacing:.02em}

/* drink list */
.drink-list{list-style:none;display:flex;flex-direction:column;gap:.1rem}
.drink-row{display:flex;align-items:baseline;gap:.7rem;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.05)}
.row-name{color:var(--ink);font-size:1rem;display:flex;flex-direction:column}
.row-desc{font-size:.78rem;color:var(--muted);font-style:italic;margin-top:.1rem}
.row-dots{flex:1;border-bottom:1px dotted rgba(232,182,92,.28);transform:translateY(-4px);min-width:24px}
.row-price{font-family:var(--serif);font-size:1.12rem;color:var(--amber);white-space:nowrap}
.menu-note{margin-top:1.4rem;font-size:.82rem;color:var(--muted);font-style:italic;text-align:center}
.menu-empty{text-align:center;color:var(--muted);font-family:var(--serif);font-size:1.4rem;padding:3rem 0}

/* =======================  GALLERIA  ======================= */
.galleria{padding:clamp(4.5rem,9vw,7.5rem) 0}
.galleria .sec-head{margin-bottom:clamp(2.4rem,5vw,3.5rem)}
.gal-grid{max-width:1340px;margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;grid-auto-flow:dense}
.gal-cell{position:relative;overflow:hidden;border-radius:5px;cursor:pointer;aspect-ratio:1;
  border:0;padding:0;background:var(--bg-3)}
.gal-cell--wide{grid-column:span 2;grid-row:span 2}
.gal-cell img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .6s}
.gal-cell:hover img{transform:scale(1.08)}
.gal-cell::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(16,12,8,.85));opacity:0;transition:opacity .4s}
.gal-cell:hover::after{opacity:1}
.gal-cap{position:absolute;left:.9rem;bottom:.8rem;right:.9rem;z-index:2;color:var(--ink);
  font-family:var(--serif);font-size:1.05rem;text-align:left;opacity:0;transform:translateY(8px);transition:.4s var(--ease)}
.gal-cell:hover .gal-cap{opacity:1;transform:none}

/* =======================  ESPERIENZA  ======================= */
.exp{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5rem) clamp(1.2rem,4vw,2.5rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.exp-card{background:linear-gradient(160deg,rgba(255,255,255,.055),rgba(255,255,255,.012));
  backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);
  border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem 1.5rem;text-align:center;will-change:transform;
  transition:transform .45s var(--ease),border-color .45s,box-shadow .45s,background .45s;
  box-shadow:0 20px 50px -30px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.06)}
.exp-card:hover{border-color:var(--line-amber);box-shadow:0 30px 60px -28px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.1)}
.exp-ico{font-family:var(--jp);font-size:2.4rem;color:var(--amber);display:block;margin-bottom:.9rem;line-height:1}
.exp-card h3{font-size:1.4rem;color:var(--ink);margin-bottom:.5rem}
.exp-card p{font-size:.84rem;color:var(--muted);line-height:1.55}

/* =======================  CONTATTI  ======================= */
.contatti{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) clamp(1.2rem,4vw,2.5rem);
  display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:stretch}
.contatti-info h2{font-size:clamp(2rem,4.4vw,3rem);margin-bottom:1.8rem}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:1.1rem;margin-bottom:1.8rem}
.contact-list li{display:grid;grid-template-columns:120px 1fr;gap:1rem;align-items:start;
  padding-bottom:1.1rem;border-bottom:1px solid var(--line)}
.ci-lab{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--amber);padding-top:.25rem}
.ci-val{color:var(--ink);line-height:1.5}
.ci-val em{font-style:normal;color:var(--muted);font-size:.86rem}
.ci-val a:hover{color:var(--amber)}
.hours{margin-bottom:1.8rem}
.hours .ci-lab{display:block;margin-bottom:.8rem}
.hours-list{list-style:none}
.hours-list li{display:flex;justify-content:space-between;padding:.45rem 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.92rem;color:var(--ink-soft)}
.hours-list li.is-closed span:last-child{color:var(--red);letter-spacing:.05em}
.socials{display:flex;gap:1.4rem;margin-bottom:2rem;flex-wrap:wrap}
.socials a{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);position:relative;padding-bottom:4px}
.socials a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--line-amber);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.socials a:hover{color:var(--amber)}
.socials a:hover::after{transform:scaleX(1)}
.contatti-map{position:relative;border-radius:6px;overflow:hidden;min-height:380px;border:1px solid var(--line-amber)}
.vmap{position:relative;width:100%;height:100%;min-height:380px;display:grid;place-items:center;background:radial-gradient(120% 100% at 50% 0%,#241a12,#100c08)}
.vmap-bg{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(232,182,92,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(232,182,92,.06) 1px,transparent 1px);
  background-size:34px 34px;-webkit-mask:radial-gradient(70% 70% at 50% 50%,#000,transparent);mask:radial-gradient(70% 70% at 50% 50%,#000,transparent)}
.vmap-pill{position:relative;z-index:2;display:inline-flex;align-items:center;gap:.6rem;background:var(--surface-2);
  border:1px solid var(--line-amber);color:var(--ink);border-radius:40px;padding:.85rem 1.5rem;cursor:pointer;
  font-family:var(--sans);font-size:.95rem;font-weight:500;transition:.35s var(--ease);box-shadow:0 14px 36px -14px rgba(0,0,0,.7)}
.vmap-pill svg{width:20px;height:20px;color:var(--amber)}
.vmap-pill:hover{transform:scale(1.04);border-color:var(--amber)}
.vmap-pill:active{transform:scale(.97)}
.vmap.vmap-open .vmap-pill{opacity:0;transform:scale(.9);pointer-events:none}
.vmap-card{position:absolute;inset:0;z-index:3;overflow:hidden;opacity:0;transform:scale(.92);transition:opacity .45s var(--ease),transform .45s var(--ease)}
.vmap-card[hidden]{display:none}
.vmap.vmap-open .vmap-card{opacity:1;transform:none}
.vmap-frame{width:100%;height:100%;border:0;filter:grayscale(.55) contrast(1.05) brightness(.85)}
.vmap-addr{position:absolute;left:1rem;bottom:1rem;z-index:2;max-width:68%;background:rgba(13,10,7,.85);backdrop-filter:blur(6px);
  border:1px solid var(--line-amber);color:var(--ink);font-size:.78rem;line-height:1.35;padding:.55rem .85rem;border-radius:8px}
.vmap-close{position:absolute;top:.8rem;right:.8rem;z-index:4;width:38px;height:38px;border-radius:50%;
  background:rgba(13,10,7,.85);backdrop-filter:blur(6px);border:1px solid var(--line-amber);color:var(--ink);
  font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.2s}
.vmap-close:hover{background:var(--amber);color:#1a130b}
.vmap-link{position:absolute;right:.8rem;bottom:.8rem;z-index:4;background:rgba(13,10,7,.85);backdrop-filter:blur(6px);
  border:1px solid var(--line-amber);color:var(--amber);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.5rem .85rem;border-radius:40px;transition:.25s}
.vmap-link:hover{background:var(--amber);color:#1a130b}

/* =======================  FOOTER  ======================= */
.footer{background:var(--bg-3);border-top:1px solid var(--line);padding:clamp(3rem,6vw,4.5rem) clamp(1.2rem,4vw,2.5rem) 2rem}
.foot-top{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1.5rem;padding-bottom:2rem;border-bottom:1px solid var(--line)}
.logo--foot .logo-mark{width:46px;height:46px}
.foot-nav{display:flex;gap:1.8rem;flex-wrap:wrap}
.foot-nav a{font-size:.8rem;letter-spacing:.08em;color:var(--ink-soft);transition:color .3s}
.foot-nav a:hover{color:var(--amber)}
.foot-bottom{max-width:var(--maxw);margin:1.6rem auto 0;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:.6rem;font-size:.76rem;color:var(--muted)}
.foot-credit{font-family:var(--serif);font-style:italic;color:var(--ink-soft)}

/* =======================  TO-TOP  ======================= */
.to-top{position:fixed;right:1.4rem;bottom:1.4rem;z-index:90;width:46px;height:46px;border-radius:50%;
  background:var(--amber);color:#1a130b;border:0;cursor:pointer;font-size:1.1rem;
  opacity:0;visibility:hidden;transform:translateY(12px);transition:.4s var(--ease);box-shadow:0 10px 26px -10px rgba(232,182,92,.6)}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:#f2c674}

/* =======================  LIGHTBOX  ======================= */
.lightbox{position:fixed;inset:0;z-index:150;background:rgba(8,6,4,.94);backdrop-filter:blur(8px);
  display:grid;place-items:center;opacity:0;animation:lbIn .35s var(--ease) forwards}
.lightbox[hidden]{display:none}
@keyframes lbIn{to{opacity:1}}
.lb-fig{max-width:88vw;max-height:84vh;display:flex;flex-direction:column;align-items:center;gap:1rem}
.lb-fig img{max-width:88vw;max-height:76vh;object-fit:contain;border-radius:4px;box-shadow:0 30px 80px -20px #000}
.lb-fig figcaption{font-family:var(--serif);font-size:1.3rem;color:var(--ink)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.06);border:1px solid var(--line);
  color:var(--ink);cursor:pointer;border-radius:50%;transition:.3s;display:grid;place-items:center}
.lb-close{top:1.4rem;right:1.4rem;width:48px;height:48px;font-size:1.6rem}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:56px;height:56px;font-size:2rem}
.lb-prev{left:1.4rem}.lb-next{right:1.4rem}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--amber);color:#1a130b;border-color:var(--amber)}

/* =======================  REVEAL  ======================= */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease);transition-delay:var(--d,0ms)}
.reveal--left{transform:translateX(-48px)}
.reveal--right{transform:translateX(48px)}
.reveal--scale{transform:scale(.92)}
.reveal.in{opacity:1;transform:none}

/* ---- movimento ambientale continuo (home) ---- */
.storia-badge{animation:badgeFloat 5s ease-in-out infinite}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.exp-ico{animation:icoFloat 4.2s ease-in-out infinite}
.exp-card:nth-child(2) .exp-ico{animation-delay:.5s}
.exp-card:nth-child(3) .exp-ico{animation-delay:1s}
.exp-card:nth-child(4) .exp-ico{animation-delay:1.5s}
@keyframes icoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.menu-group-title::before{animation:dashPulse 3.2s ease-in-out infinite}
@keyframes dashPulse{0%,100%{width:26px;opacity:.65}50%{width:42px;opacity:1}}
[data-parallax]{transform:translateY(var(--py,0))}
/* senza JS: contenuti sempre visibili e intro non bloccante */
html:not(.js) .reveal{opacity:1;transform:none}
html:not(.js) .intro{display:none}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
  .hero-bg img{animation:none}
}

/* =======================  ACCESSIBILITY  ======================= */
.vh{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--amber);outline-offset:3px;border-radius:3px}
.btn:focus-visible,.nav-cta:focus-visible,.tab:focus-visible{outline-offset:4px}
.skip-link{position:fixed;top:-70px;left:1rem;z-index:300;background:var(--amber);color:#1a130b;
  padding:.7rem 1.2rem;border-radius:6px;font-size:.85rem;font-weight:600;transition:top .3s var(--ease)}
.skip-link:focus{top:1rem}

/* =======================  STATUS PILL (aperto/chiuso)  ======================= */
.hero-status{display:inline-flex;align-items:center;gap:.55rem;margin-top:1.8rem;padding:.5rem 1.1rem;
  border:1px solid var(--line);border-radius:40px;background:rgba(16,12,8,.45);backdrop-filter:blur(6px);
  font-size:.76rem;letter-spacing:.06em;color:var(--ink-soft)}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted)}
.hero-status.is-open .status-dot{background:#5bbf6a;animation:pulse 2.2s infinite}
.hero-status.is-closed .status-dot{background:var(--red)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(91,191,106,.5)}70%{box-shadow:0 0 0 9px rgba(91,191,106,0)}100%{box-shadow:0 0 0 0 rgba(91,191,106,0)}}
.hours-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.9rem}
.hours-head .ci-lab{margin-bottom:0}
.hours-status{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .75rem;border-radius:30px;border:1px solid var(--line)}
.hours-status.is-open{color:#85d491;border-color:rgba(91,191,106,.45)}
.hours-status.is-closed{color:var(--red);border-color:rgba(208,89,60,.4)}

/* =======================  FAQ  ======================= */
.faq{max-width:840px;margin:0 auto;padding:clamp(4rem,8vw,6.5rem) clamp(1.2rem,4vw,2.5rem)}
.faq .sec-head{margin-bottom:clamp(2.2rem,4vw,3rem)}
.faq-list{display:flex;flex-direction:column;gap:.8rem}
.faq-item{border:1px solid var(--line);border-radius:8px;background:var(--surface);transition:border-color .4s var(--ease)}
.faq-item.open{border-color:var(--line-amber)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;background:none;
  border:0;cursor:pointer;padding:1.2rem 1.4rem;text-align:left;font-family:var(--serif);
  font-size:clamp(1.05rem,2.4vw,1.3rem);color:var(--ink);transition:color .3s}
.faq-q:hover{color:var(--amber)}
.faq-ico{position:relative;width:16px;height:16px;flex:0 0 auto}
.faq-ico::before,.faq-ico::after{content:"";position:absolute;background:var(--amber);transition:transform .35s var(--ease)}
.faq-ico::before{top:7px;left:0;width:16px;height:2px}
.faq-ico::after{top:0;left:7px;width:2px;height:16px}
.faq-item.open .faq-ico::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .42s var(--ease)}
.faq-a p{padding:0 1.4rem 1.35rem;color:var(--ink-soft);font-size:.95rem;line-height:1.62;margin:0}

/* =======================  STICKY CTA (mobile)  ======================= */
.sticky-cta{position:fixed;left:0;bottom:0;width:100%;z-index:95;display:none;gap:.6rem;
  padding:.7rem .8rem calc(.7rem + env(safe-area-inset-bottom,0px));
  background:rgba(13,10,7,.93);backdrop-filter:blur(12px);border-top:1px solid var(--line);
  transform:translateY(110%);transition:transform .45s var(--ease)}
.sticky-cta.show{transform:none}
.scta{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px;
  padding:.85rem;border-radius:44px;font-size:.86rem;font-weight:600;letter-spacing:.03em}
.scta svg{width:18px;height:18px;fill:currentColor;flex:0 0 auto}
.scta--call{background:transparent;border:1px solid var(--amber);color:var(--amber)}
.scta--wa{background:#25d366;color:#06351a}
.scta--wa:active{background:#1fb558}

/* =======================  ADD-TO-ORDER BUTTONS  ======================= */
.dish-add,.row-add{position:relative;flex:0 0 auto;border-radius:50%;border:1.5px solid var(--line-amber);
  background:rgba(232,182,92,.05);color:var(--amber);line-height:0;cursor:pointer;overflow:visible;
  display:grid;place-items:center;touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  transition:transform .34s cubic-bezier(.34,1.56,.64,1),background .28s,color .28s,border-color .28s,box-shadow .3s}
.dish-add{width:40px;height:40px;font-size:1.5rem}
.row-add{width:32px;height:32px;font-size:1.25rem;margin-left:.7rem}
.dish-add span,.row-add span{margin-top:-2px;transition:transform .25s,opacity .18s}
.dish:hover .dish-add{border-color:var(--amber);background:rgba(232,182,92,.14);box-shadow:0 0 22px -6px rgba(232,182,92,.45)}
.dish-add:hover,.row-add:hover{background:var(--amber);color:#1a130b;border-color:var(--amber);transform:scale(1.14) rotate(90deg)}
.dish-add:active,.row-add:active{transform:scale(.88)}
.dish-add.added,.row-add.added{background:#3fbf66;border-color:#3fbf66;color:#06351a;transform:scale(1.1);animation:addPulse .6s ease}
.dish-add.added span,.row-add.added span{opacity:0;transform:scale(0) rotate(-90deg)}
/* spunta disegnata che compare su "added" */
.dish-add::before,.row-add::before{content:"";position:absolute;width:11px;height:6px;
  border-left:2.5px solid #06351a;border-bottom:2.5px solid #06351a;
  transform:translateY(-1px) rotate(-45deg) scale(0);opacity:0;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1) .04s,opacity .18s}
.dish-add.added::before,.row-add.added::before{transform:translateY(-1px) rotate(-45deg) scale(1);opacity:1}
@keyframes addPulse{0%{box-shadow:0 0 0 0 rgba(63,191,102,.5)}100%{box-shadow:0 0 0 15px rgba(63,191,102,0)}}

/* =======================  NAV CART  ======================= */
.nav-right{display:flex;align-items:center;gap:1.3rem}
.nav-cart{position:relative;background:none;border:0;color:var(--ink);cursor:pointer;padding:6px;display:grid;place-items:center;transition:color .3s}
.nav-cart svg{width:24px;height:24px}
.nav-cart:hover{color:var(--amber)}
.cart-count{position:absolute;top:-3px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:10px;
  background:var(--red);color:#fff;font-size:.66rem;font-weight:600;display:grid;place-items:center;line-height:1;
  transform:scale(0);transition:transform .3s var(--ease)}
.cart-count:not([data-empty]){transform:scale(1)}
.nav-cart.bump{animation:bump .45s var(--ease)}
@keyframes bump{0%,100%{transform:scale(1)}40%{transform:scale(1.25)}}

/* =======================  CART DRAWER  ======================= */
.cart-backdrop{position:fixed;inset:0;z-index:140;background:rgba(8,6,4,.5);backdrop-filter:blur(10px) saturate(.9);-webkit-backdrop-filter:blur(10px) saturate(.9);opacity:0;transition:opacity .4s var(--ease)}
.cart-backdrop.show{opacity:1}
.cart{position:fixed;top:50%;left:50%;z-index:145;width:min(460px,93vw);max-height:88vh;
  background:linear-gradient(165deg,rgba(44,34,25,.72),rgba(20,15,11,.85));
  backdrop-filter:blur(28px) saturate(1.35);-webkit-backdrop-filter:blur(28px) saturate(1.35);
  border:1px solid rgba(255,255,255,.14);border-radius:26px;
  box-shadow:0 44px 130px -26px rgba(0,0,0,.9),inset 0 1px 0 rgba(255,255,255,.09);
  display:flex;flex-direction:column;padding:1.6rem;overflow-y:auto;
  transform:perspective(1300px) translate(-50%,-44%) scale(.92) rotateX(9deg);opacity:0;pointer-events:none;
  transition:transform .5s var(--ease),opacity .38s var(--ease)}
.cart.open{transform:perspective(1300px) translate(-50%,-50%) scale(1) rotateX(0);opacity:1;pointer-events:auto}
.cart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.cart-head h3{font-size:1.7rem;color:var(--ink)}
.cart-close{background:none;border:0;color:var(--ink-soft);font-size:2rem;line-height:1;cursor:pointer;transition:color .3s}
.cart-close:hover{color:var(--amber)}
.cart-fields{display:flex;gap:.8rem;margin-bottom:1.2rem}
.cart-field{flex:1;display:flex;flex-direction:column;gap:.45rem;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cart-field input{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.6rem .8rem;color:var(--ink);font-family:var(--sans);font-size:1rem;text-transform:none;letter-spacing:0}
.cart-field input:focus{outline:none;border-color:var(--amber)}
.stepper{display:inline-flex;align-items:center;gap:.1rem;background:var(--surface-2);border:1px solid var(--line);border-radius:30px;padding:.22rem;align-self:flex-start}
.step-btn{width:30px;height:30px;border-radius:50%;border:0;background:transparent;color:var(--amber);font-size:1.2rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.18s var(--ease)}
.step-btn:hover{background:var(--amber);color:#1a130b}
.step-btn:active{transform:scale(.88)}
.stepper-val{min-width:30px;text-align:center;color:var(--ink);font-size:1.02rem;font-variant-numeric:tabular-nums;display:inline-block;will-change:transform}
.stepper-val.tick{animation:digitTick .32s var(--ease)}
@keyframes digitTick{0%{transform:translateY(calc(var(--dir,1)*9px)) scale(.55);opacity:0;filter:blur(2.5px)}100%{transform:translateY(0) scale(1);opacity:1;filter:blur(0)}}
.stepper--sm{padding:.16rem}
.stepper--sm .step-btn{width:26px;height:26px;font-size:1.1rem}
.stepper--sm .stepper-val{min-width:24px;font-size:.95rem}
.cart-items{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}
.cart-item{display:flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.55rem .6rem;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{color:var(--ink);font-size:.92rem;display:block;line-height:1.25}
.cart-item-price{color:var(--muted);font-size:.78rem}
.cart-item-del{flex:0 0 auto;width:30px;height:30px;border-radius:8px;border:0;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:.18s var(--ease)}
.cart-item-del svg{width:17px;height:17px}
.cart-item-del:hover{background:rgba(208,89,60,.14);color:var(--red)}
.cart-item.removing{opacity:0;transform:translateX(26px)}
.cart-item--undo{justify-content:space-between;border-color:rgba(208,89,60,.32);background:rgba(208,89,60,.06)}
.undo-text{flex:1;min-width:0;color:var(--muted);font-size:.85rem}
.undo-text b{color:var(--ink-soft);font-weight:600}
.undo-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:.45rem;background:transparent;border:1px solid var(--line-amber);color:var(--amber);border-radius:30px;padding:.28rem .85rem .28rem .3rem;cursor:pointer;font-family:var(--sans);font-size:.8rem;font-weight:500;transition:.2s var(--ease)}
.undo-btn:hover{background:var(--amber);color:#1a130b}
.undo-ico-wrap{position:relative;width:26px;height:26px;display:grid;place-items:center;flex:0 0 auto}
.undo-ring{position:absolute;inset:0;transform:rotate(-90deg)}
.undo-ring-bg{fill:none;stroke:rgba(255,255,255,.14);stroke-width:3}
.undo-ring-fg{fill:none;stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-dasharray:100.5;stroke-dashoffset:0;animation:undoCountdown 2.5s linear forwards}
@keyframes undoCountdown{to{stroke-dashoffset:100.5}}
.undo-ico{width:13px;height:13px}
.cart-empty{color:var(--muted);text-align:center;font-style:italic;padding:2.5rem 1rem;line-height:1.6}
.cart-summary{border-top:1px solid var(--line);padding-top:1rem;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.1rem}
.cart-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--ink-soft)}
.cart-row--tot{font-family:var(--serif);font-size:1.3rem;color:var(--ink);border-top:1px solid var(--line);padding-top:.7rem;margin-top:.2rem}
.cart-row--tot span:last-child{color:var(--amber)}
.cart-actions{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.8rem}
.cart-actions .btn{width:100%;padding:.9rem}
.cart-clear{background:none;border:0;color:var(--muted);font-size:.8rem;cursor:pointer;text-decoration:underline;text-underline-offset:3px;transition:color .2s;margin-bottom:.8rem;align-self:center}
.cart-clear:hover{color:var(--red)}
.cart-note{font-size:.72rem;color:var(--muted);line-height:1.5;text-align:center;margin-top:auto}

/* =======================  WAITER VIEW  ======================= */
.waiter{position:fixed;inset:0;z-index:160;background:rgba(8,6,4,.93);backdrop-filter:blur(10px);display:grid;place-items:center;padding:1.2rem;animation:lbIn .35s var(--ease) forwards}
.waiter[hidden]{display:none}
.waiter-card{position:relative;background:var(--bg-2);border:1px solid var(--line-amber);border-radius:14px;padding:2.2rem 1.8rem;width:min(460px,94vw);max-height:88vh;overflow-y:auto;text-align:center;box-shadow:0 40px 90px -20px #000}
.waiter-close{position:absolute;top:1rem;right:1.1rem;background:none;border:0;color:var(--ink-soft);font-size:1.8rem;cursor:pointer}
.waiter-close:hover{color:var(--amber)}
.waiter-brand{display:flex;flex-direction:column;align-items:center;gap:.3rem;margin-bottom:.6rem}
.waiter-logo-img{width:clamp(150px,38vw,190px);height:auto;display:block}
/* logo che gira → QR */
.waiter-flip{display:block;width:clamp(168px,44vw,208px);aspect-ratio:1;border:0;background:none;padding:0;cursor:pointer;perspective:1000px;-webkit-tap-highlight-color:transparent}
.waiter-flip-inner{position:relative;display:block;width:100%;height:100%;transform-style:preserve-3d;transition:transform .9s cubic-bezier(.45,.05,.2,1)}
.waiter-flip.flipped .waiter-flip-inner{transform:rotateY(540deg)}
.waiter-face{position:absolute;inset:0;display:grid;place-items:center;backface-visibility:hidden;-webkit-backface-visibility:hidden}
.waiter-face--front .waiter-logo-img{width:100%;filter:drop-shadow(0 0 16px rgba(232,182,92,.32))}
.waiter-face--back{transform:rotateY(180deg);background:#fdf9f0;border-radius:18px;padding:8%;box-shadow:0 16px 44px -16px #000,0 0 0 1px rgba(232,182,92,.5)}
.waiter-qr{display:block;width:100%;height:100%}
.waiter-qr img{width:100%;height:100%;display:block;image-rendering:pixelated;image-rendering:crisp-edges}
.waiter-qr .qr-load,.waiter-qr .qr-fail{display:grid;place-items:center;width:100%;height:100%;color:#7a2a17;font-size:.82rem;font-weight:600;text-align:center}
.waiter-flip-hint{font-size:.76rem;color:var(--amber);letter-spacing:.02em;text-align:center;max-width:230px;line-height:1.4}
.waiter-card h3{font-size:1.5rem;color:var(--ink);margin-bottom:1.3rem}
.waiter-card h3 b{color:var(--amber)}
.waiter-list{list-style:none;display:flex;flex-direction:column;gap:.1rem;text-align:left;margin-bottom:1.2rem}
.waiter-list li{display:flex;justify-content:space-between;gap:1rem;padding:.7rem 0;border-bottom:1px solid var(--line);font-size:1.05rem;color:var(--ink)}
.waiter-list .q{color:var(--amber);font-weight:600;font-family:var(--serif);flex:0 0 auto}
.waiter-tot{display:flex;justify-content:space-between;font-size:1.15rem;color:var(--ink);padding-top:.4rem}
.waiter-tot b{font-family:var(--serif);color:var(--amber);font-size:1.5rem}
.waiter-note{font-size:.78rem;color:var(--muted);margin-top:1rem}

/* =======================  TOAST  ======================= */
.toast{position:fixed;left:50%;bottom:2rem;transform:translateX(-50%) translateY(20px);z-index:170;background:var(--surface-2);
  border:1px solid var(--line-amber);color:var(--ink);padding:.85rem 1.4rem;border-radius:44px;font-size:.9rem;
  box-shadow:0 16px 40px -12px rgba(0,0,0,.7);opacity:0;transition:.35s var(--ease);pointer-events:none;max-width:90vw;text-align:center}
.toast[hidden]{display:none}
.toast.show{opacity:1;transform:translateX(-50%)}
.toast b{color:var(--amber)}

/* =======================  RESPONSIVE  ======================= */
@media(max-width:980px){
  .sig-grid{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:repeat(3,1fr)}
  .exp{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:820px){
  .nav-links{position:fixed;inset:0;background:rgba(14,10,6,.97);backdrop-filter:blur(16px);
    flex-direction:column;justify-content:center;gap:2rem;transform:translateX(100%);transition:transform .5s var(--ease)}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.4rem;font-family:var(--serif)}
  .nav-cta{font-size:1rem!important;padding:.7rem 2rem}
  .burger{display:flex}
  .storia,.contatti{grid-template-columns:1fr}
  .storia-media{aspect-ratio:16/11;max-height:440px}
  .contatti-map{min-height:320px;order:2}
  .sticky-cta{display:flex}
  .to-top{display:none}
  .toast{bottom:6rem}
  body{padding-bottom:0}
  /* foto fluttuanti centrali troppo invadenti su mobile: le nascondo */
  .float-dish:nth-child(3),.float-dish:nth-child(4){display:none}
}
@media(max-width:560px){
  .float-dish{transform:scale(.62)}
  .float-inner{opacity:.95}
  .float-dish:nth-child(1){top:24%;left:2%}
  .float-dish:nth-child(2){top:19%;left:86%}
  .float-dish:nth-child(5){top:84%;left:3%}
  .float-dish:nth-child(6){top:86%;left:86%}
  .cart-fields{flex-direction:column}
  .sig-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}
  .gal-cell--wide{grid-column:span 2;grid-row:span 1;aspect-ratio:2/1}
  .exp{grid-template-columns:1fr}
  .dish-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem}
  .dish-name{font-size:1.04rem}
  .contact-list li{grid-template-columns:1fr;gap:.2rem}
  .hero-cta{flex-direction:column;width:100%;max-width:300px;margin-inline:auto}
  .hero-cta .btn{width:100%}
  .stats{justify-content:space-between;width:100%}
}

/* =======================  MENU CINEMATIC — ingresso, fly-to-cart, reazioni  ======================= */
/* ingresso 3D a cascata: applicato solo quando il pannello opta-in (così ricerca e no-JS restano visibili) */
@keyframes dishIn{from{opacity:0;transform:translateY(34px) rotateX(15deg) scale(.94)}to{opacity:1;transform:none}}
.menu-panel.reveal-dishes .dish{animation:dishIn .6s cubic-bezier(.16,.84,.34,1) backwards;animation-delay:calc(var(--i,0)*42ms)}
.menu-panel.reveal-dishes .drink-row{animation:dishIn .5s cubic-bezier(.16,.84,.34,1) backwards;animation-delay:calc(var(--i,0)*32ms)}

/* prezzo che pulsa all'hover (dichiarato tardi per vincere la cascata) */
.dish-price{transition:transform .4s var(--ease),text-shadow .4s}
.dish:hover .dish-price{transform:scale(1.07);text-shadow:0 0 20px rgba(232,182,92,.5)}

/* clone volante verso il carrello + scintille */
.fly-clone{position:fixed;z-index:1200;width:62px;height:62px;left:0;top:0;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle at 36% 30%,#f6da93,#c8902f 72%);background-size:cover;background-position:center;
  box-shadow:0 10px 34px rgba(0,0,0,.55),0 0 26px rgba(232,182,92,.6);will-change:transform,opacity}
.fly-clone.has-img{border:2px solid rgba(244,214,137,.85)}
.spark{position:fixed;z-index:1190;width:7px;height:7px;left:0;top:0;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,#ffeebc,#e8b65c 70%);box-shadow:0 0 9px rgba(232,182,92,.85);will-change:transform,opacity}

/* reazione "succosa" del carrello in nav */
.nav-cart{position:relative}
.nav-cart.bump{animation:cartBump .55s cubic-bezier(.34,1.56,.64,1)}
@keyframes cartBump{0%{transform:scale(1)}28%{transform:scale(1.3) rotate(-9deg)}55%{transform:scale(.92) rotate(5deg)}100%{transform:scale(1) rotate(0)}}
.nav-cart.catch::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:2px solid var(--amber);
  animation:cartCatch .6s ease forwards;pointer-events:none}
@keyframes cartCatch{from{transform:scale(.55);opacity:.85}to{transform:scale(1.7);opacity:0}}
.cart-count.pop{animation:countPop .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes countPop{0%{transform:scale(1)}40%{transform:scale(1.55)}100%{transform:scale(1)}}

/* righe bevande vive */
.drink-row{border-radius:10px;transition:background .35s var(--ease),box-shadow .35s,transform .35s var(--ease)}
.drink-row:hover{background:linear-gradient(90deg,rgba(232,182,92,.1),rgba(232,182,92,0));transform:translateX(4px);
  box-shadow:inset 2px 0 0 var(--amber)}

@media (prefers-reduced-motion:reduce){
  .menu-panel.reveal-dishes .dish,.menu-panel.reveal-dishes .drink-row{animation:none}
  .dish:hover::after{animation:none;opacity:0}
  .dish-add:hover,.row-add:hover{transform:none}
  .dish-add.added,.row-add.added{animation:none}
  .fly-clone,.spark{display:none}
}

/* =======================  CARRELLO — redesign premium  ======================= */
.cart{width:min(472px,94vw);max-height:90vh;padding:1.5rem 1.5rem 1.25rem;overflow-y:auto;
  background:linear-gradient(165deg,rgba(50,38,28,.85),rgba(17,12,8,.93));
  border-radius:28px;box-shadow:0 50px 140px -28px rgba(0,0,0,.92),inset 0 1px 0 rgba(255,255,255,.10)}
.cart::before{content:"";position:absolute;top:0;left:9%;right:9%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,182,92,.75),transparent)}
.cart-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.15rem}
.cart-head-brand{display:flex;align-items:center;gap:.7rem;min-width:0}
.cart-logo{width:44px;height:44px;flex:0 0 auto;filter:drop-shadow(0 0 12px rgba(232,182,92,.35))}
.cart-head-tt{display:flex;flex-direction:column;gap:.18rem}
.cart-head h3{font-family:var(--serif);font-size:1.55rem;font-weight:600;color:var(--ink);line-height:1}
.cart-count-chip{align-self:flex-start;font-size:.7rem;letter-spacing:.05em;color:var(--amber);
  background:rgba(232,182,92,.12);border:1px solid var(--line-amber);border-radius:20px;padding:.08rem .55rem}
.cart-close{flex:0 0 auto;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;
  display:grid;place-items:center;transition:.25s var(--ease)}
.cart-close:hover{background:rgba(208,89,60,.16);border-color:rgba(208,89,60,.4);color:#f0a08c;transform:rotate(90deg)}
.cart-fields{gap:.7rem;margin-bottom:1.05rem}
.cart-field{gap:.4rem;font-size:.65rem;letter-spacing:.13em}
.cart-field input{background:rgba(0,0,0,.26);border-radius:12px;padding:.7rem .85rem;font-size:1.05rem;transition:.2s var(--ease)}
.cart-field input:focus{box-shadow:0 0 0 3px rgba(232,182,92,.14)}
.cart-items{gap:.55rem;margin:0 0 1rem}
.cart-item{gap:.6rem;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012));
  border:1px solid var(--line);border-radius:14px;padding:.6rem .7rem;
  animation:cartItemIn .42s cubic-bezier(.16,.84,.34,1) both}
@keyframes cartItemIn{from{opacity:0;transform:translateY(11px) scale(.98)}to{opacity:1;transform:none}}
.cart-item:hover{border-color:var(--line-amber);background:linear-gradient(180deg,rgba(232,182,92,.08),rgba(255,255,255,.012))}
.cart-item-name{font-size:.95rem;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cart-item{align-items:center}
.cart-item-del{width:32px;height:32px;border-radius:9px}
.cart-item-del:hover{transform:scale(1.06)}
.cart-item-thumb{width:48px;height:48px;flex:0 0 auto;border-radius:11px;background-size:cover;background-position:center;
  border:1px solid var(--line-amber);box-shadow:0 6px 16px -8px #000;background-color:var(--bg-3)}
.cart-item-thumb--empty{background:radial-gradient(circle at 35% 30%,#f4d589,#c8902f 75%)}
#cartTot{display:inline-block}
#cartTot.bump{animation:totBump .45s var(--ease)}
@keyframes totBump{0%{transform:scale(1)}40%{transform:scale(1.14);color:#fff}100%{transform:scale(1)}}
.cart-summary{padding-top:1rem;gap:.5rem;margin-bottom:1rem}
.cart-row--tot{align-items:center;font-family:var(--serif);font-size:1.5rem;
  background:linear-gradient(90deg,rgba(232,182,92,.12),transparent);border:1px solid var(--line-amber);
  border-radius:14px;padding:.6rem .85rem;margin-top:.4rem}
.cart-row--tot span:last-child{font-weight:600}
.cart-actions{gap:.55rem;margin-bottom:.7rem}
.cart-actions-row{display:flex;gap:.55rem}
.cart-actions-row .btn{flex:1;padding:.85rem .5rem;width:auto}
.cart-actions #cartSend{background:linear-gradient(180deg,#f0cd84,#d49f3f);border-color:transparent;color:#231708;
  font-weight:700;box-shadow:0 14px 30px -12px rgba(232,182,92,.55);position:relative;overflow:hidden}
.cart-actions #cartSend::after{content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.5) 50%,transparent 62%);
  transform:translateX(-130%);transition:transform .65s var(--ease)}
.cart-actions #cartSend:hover::after{transform:translateX(130%)}
.cart-actions #cartSend:active{transform:scale(.985)}
@media (prefers-reduced-motion:reduce){
  .cart-item{animation:none}
  .cart-actions #cartSend::after{display:none}
  .cart-close:hover{transform:none}
}

/* =======================  CARRELLO — slide-to-delete  ======================= */
.cart-item{position:relative;overflow:hidden;display:block;padding:0;background:transparent;align-items:initial}
/* superficie = stesso vetro translucido di prima (nessun colore nuovo a riposo) */
.cart-item-surface{display:flex;align-items:center;gap:.6rem;padding:.6rem .7rem;position:relative;z-index:1;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012));
  transition:transform .28s var(--ease);touch-action:pan-y;will-change:transform}
.cart-item:hover .cart-item-surface{background:linear-gradient(180deg,rgba(232,182,92,.08),rgba(255,255,255,.012))}
.cart-item.swiping .cart-item-surface{transition:none}
/* sfondo "Elimina" NASCOSTO a riposo, compare solo durante lo swipe, solo a destra */
.cart-item-del-bg{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:flex-end;
  gap:.45rem;padding:0 1.15rem;color:#fff;opacity:0;transition:opacity .18s var(--ease);
  background:linear-gradient(90deg,transparent 34%,#b13c25)}
.cart-item.swiping .cart-item-del-bg{opacity:1}
.cart-item-del-bg::before{content:"Elimina";font-size:.82rem;font-weight:700;letter-spacing:.02em}
.cart-item-del-bg svg{width:22px;height:22px}
.cart-item.will-delete .cart-item-del-bg{background:linear-gradient(90deg,transparent 20%,#e0633c)}
.cart-item--undo{display:flex;align-items:center;justify-content:space-between;padding:.6rem .7rem;overflow:hidden}
@media (prefers-reduced-motion:reduce){.cart-item-surface{transition:none}}

/* =======================  TRACKING ORDINE (lato cliente)  ======================= */
.track{position:fixed;inset:0;z-index:150;display:grid;place-items:center;padding:1.2rem;
  background:rgba(8,6,4,.62);backdrop-filter:blur(11px);-webkit-backdrop-filter:blur(11px);animation:lbIn .35s var(--ease) forwards}
.track[hidden]{display:none}
.track-card{position:relative;width:min(460px,94vw);max-height:88vh;overflow-y:auto;
  background:linear-gradient(165deg,rgba(48,37,27,.96),rgba(18,13,9,.98));border:1px solid var(--line-amber);
  border-radius:24px;padding:1.6rem;box-shadow:0 44px 120px -28px #000,inset 0 1px 0 rgba(255,255,255,.08)}
.track-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:var(--ink);font-size:1.4rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.2s}
.track-close:hover{background:rgba(208,89,60,.16);color:#f0a08c}
.track-head{display:flex;align-items:center;gap:.7rem;margin-bottom:1.1rem}
.track-logo{width:46px;height:46px;flex:0 0 auto;filter:drop-shadow(0 0 12px rgba(232,182,92,.35))}
.track-head h3{font-family:var(--serif);font-size:1.5rem;color:var(--ink);line-height:1}
.track-table{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.track-prog{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.track-bar-wrap{flex:1;height:8px;border-radius:8px;background:rgba(255,255,255,.08);overflow:hidden}
.track-bar{height:100%;width:0;border-radius:8px;background:linear-gradient(90deg,#6fd790,#3fb869);transition:width .55s var(--ease)}
.track-prog>span{font-size:.76rem;color:var(--amber);font-weight:600;white-space:nowrap}
.track-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}
.track-row{display:flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;padding:.6rem .7rem;transition:.3s var(--ease)}
.track-q{flex:0 0 auto;color:var(--amber);font-weight:700;font-variant-numeric:tabular-nums}
.track-n{flex:1;min-width:0;font-size:.92rem;color:var(--ink);line-height:1.25}
.track-pill{flex:0 0 auto;font-size:.7rem;font-weight:700;padding:.22rem .6rem;border-radius:20px;border:1px solid var(--line);color:var(--muted);white-space:nowrap}
.trk-in_preparazione .track-pill{color:#7cc0ea;border-color:rgba(124,192,234,.5);background:rgba(124,192,234,.08)}
.trk-pronto{border-color:rgba(111,215,144,.4)}
.trk-pronto .track-pill{color:#6fd790;border-color:rgba(111,215,144,.5);background:rgba(111,215,144,.12)}
.trk-servito .track-pill{color:var(--amber);border-color:var(--line-amber);background:rgba(232,182,92,.1)}
.trk-servito .track-n{color:var(--muted);text-decoration:line-through}
.track-empty{color:var(--muted);text-align:center;font-style:italic;padding:1.6rem 1rem;line-height:1.5}
.track-note{font-size:.74rem;color:var(--muted);text-align:center;line-height:1.5}
.track-fab{position:fixed;right:14px;bottom:calc(env(safe-area-inset-bottom,0px) + 78px);z-index:120;
  display:flex;align-items:center;gap:.5rem;background:linear-gradient(180deg,#f0cd84,#d49f3f);color:#231708;border:0;border-radius:40px;
  padding:.7rem 1.3rem;font-weight:700;font-size:.9rem;font-family:var(--sans);cursor:pointer;box-shadow:0 16px 40px -12px rgba(232,182,92,.6)}
.track-fab[hidden]{display:none}
.track-fab-dot{width:9px;height:9px;border-radius:50%;background:#3a2a10;animation:fabPulse 1.6s infinite}
@keyframes fabPulse{0%,100%{opacity:1}50%{opacity:.35}}
@media (max-width:560px){ .track-fab{bottom:calc(env(safe-area-inset-bottom,0px) + 70px)} }

/* badge "Tavolo N" dal QR del tavolo */
.table-badge{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + 78px);left:14px;z-index:95;display:flex;align-items:center;gap:.5rem;
  background:rgba(20,15,10,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--line-amber);
  border-radius:30px;padding:.4rem .45rem .4rem .9rem;color:var(--ink);font-size:.82rem;font-weight:600;
  box-shadow:0 14px 34px -14px #000;animation:badgeIn .5s var(--ease)}
.table-badge[hidden]{display:none}
.table-badge b{color:var(--amber)}
@keyframes badgeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.table-badge-x{width:24px;height:24px;flex:0 0 auto;border-radius:50%;border:0;background:rgba(255,255,255,.07);color:var(--muted);
  cursor:pointer;font-size:1.1rem;line-height:1;display:grid;place-items:center;transition:.2s}
.table-badge-x:hover{background:rgba(208,89,60,.18);color:#f0a08c}
#cartTable[readonly]{border-color:var(--line-amber);background:rgba(232,182,92,.07);cursor:default;font-weight:700}

/* ===== Selettore lingua (pill + dialog animato, skin oro/enso) ===== */
.lang-pill{display:inline-flex;align-items:center;gap:.32rem;height:38px;padding:0 .6rem;border-radius:999px;
  border:1px solid var(--line-amber);background:rgba(255,255,255,.04);color:var(--ink);cursor:pointer;
  transition:background .2s var(--ease),border-color .2s,transform .2s}
.lang-pill:hover{background:rgba(232,182,92,.12);border-color:rgba(232,182,92,.4)}
.lang-pill:active{transform:scale(.96)}
.lang-pill-flag{font-size:1.15rem;line-height:1}
.lang-pill-chev{width:15px;height:15px;color:var(--amber);opacity:.85}

.lang-backdrop{position:fixed;inset:0;z-index:1400;background:rgba(8,5,3,.46);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
  opacity:0;transition:opacity .26s var(--ease)}
.lang-backdrop.open{opacity:1}
.lang-modal{position:fixed;inset:0;z-index:1401;display:grid;place-items:center;padding:18px}
.lang-card{width:min(400px,100%);max-height:min(520px,86vh);display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line-amber);
  border-radius:28px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7),0 0 0 1px rgba(232,182,92,.06);overflow:hidden;
  opacity:0;transform:scale(.96);filter:blur(4px);transition:opacity .3s var(--ease),transform .3s var(--ease),filter .3s var(--ease)}
.lang-modal.open .lang-card{opacity:1;transform:scale(1);filter:blur(0)}
.lang-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.3rem .65rem}
.lang-ttl{margin:0;font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--ink);letter-spacing:.01em}
.lang-x{width:34px;height:34px;flex:0 0 auto;border:0;border-radius:50%;background:rgba(255,255,255,.06);color:var(--ink-soft);
  font-size:1.4rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.2s}
.lang-x:hover{background:rgba(208,89,60,.18);color:#f0a08c;transform:rotate(90deg)}
.lang-search{display:flex;align-items:center;gap:.55rem;margin:.2rem 1.3rem .7rem;padding:.6rem .85rem;
  border:1px solid var(--line);border-radius:14px;background:rgba(0,0,0,.22)}
.lang-search svg{width:18px;height:18px;color:var(--muted);flex:0 0 auto}
.lang-search-in{flex:1;border:0;background:transparent;color:var(--ink);font-family:var(--sans);font-size:1rem;outline:none}
.lang-search-in::placeholder{color:var(--muted)}
.lang-list{overflow-y:auto;padding:.2rem .6rem 1rem;display:flex;flex-direction:column;gap:.15rem;
  scrollbar-width:thin;scrollbar-color:var(--line-amber) transparent}
.lang-list::-webkit-scrollbar{width:8px}
.lang-list::-webkit-scrollbar-thumb{background:var(--line-amber);border-radius:8px}
.lang-row{display:flex;align-items:center;gap:.85rem;width:100%;padding:.7rem .75rem;border:0;border-radius:14px;
  background:transparent;color:var(--ink);font-family:var(--sans);font-size:1.04rem;text-align:left;cursor:pointer;transition:background .18s}
.lang-row:hover{background:rgba(232,182,92,.1)}
.lang-row.is-active{background:rgba(232,182,92,.14)}
.lang-row-flag{font-size:1.4rem;line-height:1;flex:0 0 auto}
.lang-row-name{flex:1;font-weight:500}
.lang-row-check{width:20px;height:20px;color:var(--amber);opacity:0;transform:scale(.6);transition:.2s var(--ease);flex:0 0 auto}
.lang-row.is-active .lang-row-check{opacity:1;transform:scale(1)}
@media (max-width:560px){.lang-ttl{font-size:1.3rem}.lang-pill{height:36px;padding:0 .5rem}}
@media (prefers-reduced-motion:reduce){
  .lang-card{transition:opacity .2s ease;transform:none;filter:none}
  .lang-modal.open .lang-card{transform:none;filter:none}
  .lang-x:hover{transform:none}
}
