/* ============================================================================
   BANDANA · Pizza & Cucina — style.css  ·  "MANIFESTO GIALLO"
   Poster flat / neo-rustico: carta kraft + giallo insegna + nero, bordi spessi,
   ombre piene, marquee, motivo paisley/bandana. Font: Anton + Space Grotesk.
   ========================================================================== */
:root{
  --paper:#f5ecd6; --paper-2:#ecdfbc; --cream:#fcf7ea;
  --ink:#17130c; --ink-2:#2a2316;
  --yellow:#e6b43c; --yellow-2:#f1c863; --yellow-deep:#bc8a20;
  --red:#d23b1e; --red-deep:#a82a13;
  --muted:#6c6047; --muted-d:#bcae8e;
  --maxw:1200px;
  --b:3px;                 /* spessore bordo */
  --bd:var(--b) solid var(--ink);
  --hard:6px 6px 0 var(--ink);
  --hard-sm:4px 4px 0 var(--ink);
  --hard-red:6px 6px 0 var(--red);
  --rad:10px; --rad-sm:7px;
  --ease:cubic-bezier(.2,.7,.3,1);
  --pop:cubic-bezier(.34,1.56,.64,1);
  --t:.18s var(--ease);
  --acc:var(--red);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:clip}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--paper);color:var(--ink);
  font:430 clamp(15.5px,.5vw+14.5px,17px)/1.62 "Space Grotesk",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;overflow-x:clip;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(23,19,12,.05) 1px, transparent 0);
  background-size:22px 22px;}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3,h4{margin:0;font-family:"Anton",Impact,sans-serif;font-weight:400;
  letter-spacing:.01em;line-height:.98;text-transform:uppercase}
::selection{background:var(--ink);color:var(--yellow)}
.wrap{width:min(100% - 2.2rem,var(--maxw));margin-inline:auto}
.num{font-variant-numeric:tabular-nums}
.skip{position:fixed;left:-999px;top:8px;z-index:200;background:var(--ink);color:var(--yellow);
  padding:.6rem 1rem;border-radius:6px;font-weight:700}
.skip:focus{left:12px}

/* ---- wordmark ------------------------------------------------------------- */
.wm{font-family:"Anton",Impact,sans-serif;text-transform:uppercase;letter-spacing:.02em;
  color:var(--yellow);-webkit-text-stroke:2.5px var(--ink);
  paint-order:stroke fill;line-height:.85;display:inline-block}

/* ---- paisley (motivo bandana) -------------------------------------------- */
.paisley{width:1.05em;height:1.25em;color:currentColor;flex:0 0 auto;overflow:visible}

/* ---- buttons -------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  background:var(--yellow);color:var(--ink);font-family:"Space Grotesk";font-weight:700;
  letter-spacing:.01em;padding:.74em 1.25em;border:var(--bd);border-radius:99px;
  box-shadow:var(--hard-sm);transition:transform var(--t),box-shadow var(--t),background var(--t)}
.btn:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink);background:var(--yellow-2)}
.btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.btn .ic{width:1.15em;height:1.15em}
.btn-lg{padding:.92em 1.5em;font-size:1.05rem}
.btn-sm{padding:.55em 1em;font-size:.9rem;box-shadow:3px 3px 0 var(--ink)}
.btn-ink{background:var(--ink);color:var(--yellow)}
.btn-ink:hover{background:var(--ink-2)}
.btn-red{background:var(--red);color:#fff}
.ic{width:1.25em;height:1.25em;flex:0 0 auto}

/* ---- sezioni -------------------------------------------------------------- */
.section{padding:clamp(3.4rem,6.5vw,6rem) 0}
.section-yellow{background:var(--yellow);
  background-image:radial-gradient(circle at 1px 1px, rgba(23,19,12,.08) 1px, transparent 0);
  background-size:22px 22px;border-block:var(--b) solid var(--ink)}
.section-dark{background:var(--ink);color:var(--cream)}
.section-dark h2,.section-dark h3,.section-dark .sec-head h2{color:var(--yellow)}
.sec-head{max-width:48rem;margin-bottom:clamp(2rem,4vw,3.2rem)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(2.1rem,5.2vw,4rem)}
.sec-lead{font-size:1.05rem;color:var(--muted);margin:.9rem 0 0;max-width:42rem;font-weight:500}
.center .sec-lead{margin-inline:auto}
.section-dark .sec-lead{color:var(--muted-d)}
.sec-lead a{color:var(--ink);text-decoration:underline;text-decoration-thickness:2px;
  text-underline-offset:3px;font-weight:700}
.section-dark .sec-lead a{color:var(--yellow)}
.eyebrow{display:inline-flex;align-items:center;gap:.5em;font-family:"Space Grotesk";
  font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:.76rem;
  color:var(--ink);background:var(--yellow);border:var(--b) solid var(--ink);
  padding:.4em .85em;border-radius:99px;box-shadow:var(--hard-sm)}
.section-yellow .eyebrow{background:var(--cream)}
.section-dark .eyebrow{background:var(--yellow);color:var(--ink)}
.eyebrow .paisley,.eyebrow .ic{width:1.1em;height:1.2em;color:var(--ink)}

/* ---- reveal cinematografici (progressive enhancement) -------------------- */
.reveal,.reveal-l,.reveal-r,.reveal-pop{transition:opacity .7s var(--ease),transform .85s var(--pop)}
.js .reveal{opacity:0;transform:translateY(48px)}
.js .reveal-l{opacity:0;transform:translateX(-70px) rotate(-1deg)}
.js .reveal-r{opacity:0;transform:translateX(70px) rotate(1deg)}
.js .reveal-pop{opacity:0;transform:scale(.78) translateY(26px)}
.reveal.in,.reveal-l.in,.reveal-r.in,.reveal-pop.in{opacity:1;transform:none}
.fade{transition:opacity .8s var(--ease)}
.js .fade{opacity:0}
.fade.in{opacity:1}

/* heading: salita dietro una maschera (clip wipe) */
.r-mask{transition:clip-path .95s var(--ease),transform .95s var(--ease),opacity .5s ease}
.js .r-mask{opacity:0;clip-path:inset(0 0 110% 0);transform:translateY(36px)}
.r-mask.in{opacity:1;clip-path:inset(-8% 0 -8% 0);transform:none}

/* immagini: tendina che si apre + zoom interno */
.r-img{overflow:hidden;transition:clip-path 1s var(--ease)}
.js .r-img{clip-path:inset(0 0 0 100%)}
.r-img.in{clip-path:inset(0 0 0 0)}
.r-img img{transition:transform 1.3s var(--ease)}
.js .r-img img{transform:scale(1.22)}
.r-img.in img{transform:none}

/* ken-burns lento sulla foto hero */
@keyframes kenburns{0%{transform:scale(1.02)}50%{transform:scale(1.12) translate(-1.5%,1%)}100%{transform:scale(1.02)}}
.hero-fig img{animation:kenburns 22s ease-in-out infinite}

/* tilt 3D al mouse */
[data-tilt]{transform-style:preserve-3d;transition:transform .25s var(--ease)}

@media (prefers-reduced-motion:reduce){
  .js .reveal,.js .reveal-l,.js .reveal-r,.js .reveal-pop,.js .fade,
  .js .r-mask,.js .r-img,.js .r-img img{
    opacity:1 !important;transform:none !important;clip-path:none !important;transition:none !important}
  .hero-fig img{animation:none}
  [data-tilt]{transform:none !important}}

/* ---- barra di avanzamento scroll ----------------------------------------- */
.prog{position:fixed;top:0;left:0;height:4px;width:100%;z-index:110;
  background:linear-gradient(90deg,var(--red),var(--yellow));
  transform:scaleX(0);transform-origin:0 50%;will-change:transform}
@media (prefers-reduced-motion:reduce){.prog{display:none}}
[data-par]{will-change:transform}

/* ---- marquee -------------------------------------------------------------- */
.marquee{overflow:hidden;background:var(--yellow);border-block:var(--b) solid var(--ink);
  padding:.6rem 0}
.marquee.mq-ink{background:var(--ink)}
.mq-skew{display:block;transition:transform .3s var(--ease);will-change:transform;transform-origin:center}
.mq-track{display:flex;align-items:center;gap:0;width:max-content;
  animation:mq var(--mqd,30s) linear infinite}
.marquee:hover .mq-track{animation-play-state:paused}
.mq-track span{font-family:"Anton",sans-serif;text-transform:uppercase;letter-spacing:.04em;
  font-size:clamp(1.1rem,2.4vw,1.7rem);color:var(--ink);white-space:nowrap;padding:0 .2em}
.mq-ink .mq-track span{color:var(--yellow)}
.mq-track i{display:inline-flex;color:var(--red);padding:0 1.1rem}
.mq-ink .mq-track i{color:var(--yellow)}
.mq-track i .paisley{width:1em;height:1.2em}
@keyframes mq{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.mq-track{animation:none}}

/* ---- intro (animazione d'apertura) --------------------------------------- */
.intro{position:fixed;inset:0;z-index:300;display:grid;place-items:center;background:var(--yellow);
  background-image:radial-gradient(circle at 1px 1px, rgba(23,19,12,.1) 1px, transparent 0);
  background-size:22px 22px;animation:introLift .7s 1.3s var(--ease) forwards;will-change:transform}
.intro-in{text-align:center;padding:1.2rem}
.intro-wm{display:block;font-family:"Anton",Impact,sans-serif;text-transform:uppercase;letter-spacing:.02em;
  line-height:.82;color:var(--ink);font-size:clamp(3.4rem,15vw,9.5rem);animation:introPop .7s var(--ease) both}
.intro-sub{display:block;margin-top:.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;
  font-size:clamp(.68rem,2.2vw,1rem);color:var(--ink);animation:introPop .7s .12s var(--ease) both}
.intro-pais{display:flex;justify-content:center;gap:1.1rem;margin-top:1.1rem;color:var(--ink);
  animation:introPop .7s .22s var(--ease) both}
.intro-pais .paisley{width:1.2em;height:1.45em}
.intro.done{display:none}
@keyframes introPop{0%{opacity:0;transform:translateY(28px) scale(.9)}
  60%{opacity:1;transform:translateY(0) scale(1.03)}100%{transform:none;opacity:1}}
@keyframes introLift{to{transform:translateY(-102%)}}
@media (prefers-reduced-motion:reduce){.intro{display:none !important}}

/* ============================ NAV ========================================== */
.nav{position:sticky;top:0;z-index:90;transition:background var(--t),box-shadow var(--t)}
.nav-in{display:flex;align-items:center;gap:1rem;padding:.85rem 0}
.nav.scrolled{background:var(--ink);box-shadow:0 var(--b) 0 var(--yellow)}
.brand{display:flex;align-items:baseline;gap:.55rem;margin-right:auto}
.brand-wm{font-size:1.55rem;-webkit-text-stroke-width:1.6px}
.nav.scrolled .brand-wm{-webkit-text-stroke-color:var(--ink)}
.brand-sub{font-family:"Space Grotesk";font-weight:700;font-size:.66rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink);white-space:nowrap}
.nav.scrolled .brand-sub{color:var(--yellow)}
.nav-links{display:flex;gap:.2rem}
.nav-links a{padding:.5rem .8rem;border-radius:99px;font-weight:600;font-size:.95rem;color:var(--ink);
  transition:background var(--t),color var(--t)}
.nav.scrolled .nav-links a{color:var(--cream)}
.nav-links a:hover{background:var(--ink);color:var(--yellow)}
.nav.scrolled .nav-links a:hover{background:var(--yellow);color:var(--ink)}
.nav-cta{display:inline-flex}
.nav-toggle{display:none;width:46px;height:46px;align-items:center;justify-content:center;
  color:var(--ink);background:var(--yellow);border:var(--bd);border-radius:10px;box-shadow:var(--hard-sm)}
.nav.scrolled .nav-toggle{color:var(--ink)}
.nav-toggle .ic{width:24px;height:24px}

/* drawer (shell ritaglia il pannello chiuso → niente scroll orizzontale) */
.drawer-shell{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:95}
.drawer{position:absolute;inset:0 0 0 auto;width:min(86vw,360px);pointer-events:auto;
  background:var(--ink);border-left:var(--b) solid var(--yellow);padding:5rem 1.5rem 2rem;
  transform:translateX(100%);transition:transform .32s var(--ease)}
.drawer.open{transform:none}.drawer[hidden]{display:block}
.drawer-links{display:flex;flex-direction:column}
.drawer-links a{padding:.9rem .2rem;font-family:"Anton";font-size:1.7rem;text-transform:uppercase;
  color:var(--cream);border-bottom:2px solid rgba(243,194,0,.25)}
.drawer-links a:hover{color:var(--yellow)}
.drawer-cta{display:flex;flex-direction:column;gap:.7rem;margin-top:1.5rem}
.scrim{position:fixed;inset:0;background:rgba(10,8,4,.55);z-index:94;opacity:0;visibility:hidden;
  transition:opacity var(--t),visibility var(--t)}
.scrim.show{opacity:1;visibility:visible}
body.no-scroll{overflow:hidden}

/* ============================ HERO ========================================= */
.hero{position:relative;padding-top:1rem}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;padding:clamp(1.5rem,4vw,3.5rem) 0 clamp(2rem,5vw,4rem)}
.hero-place{display:inline-flex;align-items:center;gap:.45em;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;font-size:.78rem;background:var(--ink);color:var(--yellow);
  padding:.45em .9em;border-radius:99px}
.hero-place .ic{width:1.1em;height:1.1em}
.hero-wm{margin:1rem 0 .2rem;line-height:.8}
.hero-wm .wm{font-size:clamp(3.6rem,13vw,9rem);-webkit-text-stroke-width:clamp(2px,.6vw,4px)}
.hero-tag{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin:.3rem 0 0}
.hero-tag b{font-family:"Anton";font-weight:400;text-transform:uppercase;font-size:clamp(1.4rem,3.4vw,2.3rem)}
.hero-tag .amp{display:inline-grid;place-items:center;width:1.7em;height:1.7em;background:var(--red);
  color:#fff;border:var(--bd);border-radius:50%;font-family:"Anton";font-size:1.1rem;
  box-shadow:var(--hard-sm)}
.hero-desc{max-width:34rem;margin:1.3rem 0 0;font-size:1.1rem;font-weight:500;color:var(--ink-2)}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.8rem}
.hero-photo{position:relative;justify-self:center}
.hero-fig{margin:0;border:var(--b) solid var(--ink);border-radius:var(--rad);overflow:hidden;
  box-shadow:var(--hard);rotate:2.5deg;aspect-ratio:4/3.4;max-width:480px}
.hero-fig img{width:100%;height:100%;object-fit:cover}
.tape{position:absolute;width:92px;height:30px;background:rgba(243,194,0,.78);
  border:2px dashed rgba(23,19,12,.4);z-index:3}
.tape-1{top:-14px;left:24%;rotate:-7deg}
.tape-2{bottom:-12px;right:20%;rotate:5deg}
/* timbro */
.stamp{position:absolute;right:-22px;bottom:-22px;width:118px;height:118px;z-index:4;
  display:grid;place-items:center;color:var(--red);rotate:-9deg;filter:drop-shadow(0 2px 0 rgba(0,0,0,.06))}
.stamp svg{position:absolute;inset:0;width:100%;height:100%;animation:spin 22s linear infinite}
.stamp-arc{font:700 10.5px "Space Grotesk";letter-spacing:.14em;text-transform:uppercase;fill:var(--red)}
.stamp b{font-family:"Anton";font-size:1.15rem;text-transform:uppercase;color:var(--red);text-align:center;
  line-height:.85;border:2.5px solid var(--red);border-radius:50%;width:60px;height:60px;display:grid;
  place-items:center;padding:.3em}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.stamp svg{animation:none}}
@media (max-width:820px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-place,.hero-tag{justify-content:center}
  .hero-cta{justify-content:center}
  .hero-photo{margin-top:1.5rem}
}

/* ============================ STORY ======================================== */
.story-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.story-media{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;align-items:start}
.photo{margin:0;border:var(--bd);border-radius:var(--rad-sm);overflow:hidden;background:var(--cream);
  box-shadow:var(--hard)}
.photo img{width:100%;aspect-ratio:1;object-fit:cover;border-bottom:var(--bd)}
.photo figcaption{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  padding:.5em .7em;color:var(--ink)}
.photo-a{rotate:-2deg}.photo-b{rotate:2.5deg;margin-top:1.6rem}
.story-body h2{font-size:clamp(2.1rem,5.2vw,3.6rem)}
.mark{background:linear-gradient(transparent 12%,var(--yellow) 12% 86%,transparent 86%);
  padding:0 .12em;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.lede{margin:1.3rem 0 0;font-size:1.06rem;font-weight:500;color:var(--ink-2)}
.lede p{margin:0 0 .9rem}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:2rem}
.stat{background:var(--cream);border:var(--bd);border-radius:var(--rad-sm);padding:1rem 1.1rem;
  box-shadow:var(--hard-sm)}
.stat b{display:block;font-family:"Anton";font-size:1.7rem;line-height:1;color:var(--ink)}
.stat span{font-size:.86rem;font-weight:600;color:var(--muted)}
@media (max-width:820px){.story-grid{grid-template-columns:1fr}.story-media{max-width:460px;order:2}}

/* ============================ HIGHLIGHTS (yellow) ========================== */
.hl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.hl{display:flex;flex-direction:column;background:var(--cream);border:var(--bd);border-radius:var(--rad);
  overflow:hidden;box-shadow:var(--hard);transition:transform var(--t),box-shadow var(--t)}
.hl:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink)}
.hl-img{position:relative;aspect-ratio:4/3;overflow:hidden;border-bottom:var(--bd)}
.hl-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.hl:hover .hl-img img{transform:scale(1.06)}
.hl-num{position:absolute;top:0;left:0;font-family:"Anton";font-size:1.05rem;color:var(--yellow);
  background:var(--ink);padding:.2em .55em;border-bottom-right-radius:var(--rad-sm)}
.hl-body{padding:1.1rem 1.15rem 1.3rem;display:flex;flex-direction:column;gap:.3rem;flex:1}
.hl-sub{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--red)}
.hl-body h3{font-size:1.45rem}
.hl-body p{margin:0;font-size:.94rem;font-weight:500;color:var(--muted);flex:1}
.hl-go{display:inline-flex;align-items:center;gap:.35em;font-weight:700;text-transform:uppercase;
  font-size:.82rem;letter-spacing:.06em;margin-top:.5rem}
.hl-go .ic{width:1.1em;height:1.1em;transition:transform var(--t)}
.hl:hover .hl-go .ic{transform:translateX(5px)}
@media (max-width:980px){.hl-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.hl-grid{grid-template-columns:1fr}}

/* ============================ MENU ========================================= */
.menu{background:var(--paper)}
.mtabs{position:sticky;top:var(--nav-h,62px);z-index:40;display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;
  padding:.8rem .2rem;margin:0 -.2rem 2.2rem;background:var(--paper);border-bottom:var(--b) solid var(--ink)}
.mtabs::-webkit-scrollbar{display:none}
.mtab{flex:0 0 auto;min-height:44px;display:inline-flex;align-items:center;padding:.4em 1.05em;
  border:2.5px solid var(--ink);border-radius:99px;font-weight:700;
  font-size:.92rem;background:var(--cream);transition:all var(--t);white-space:nowrap;box-shadow:2px 2px 0 var(--ink)}
.mtab:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}
.mtab.is-active{background:var(--yellow);box-shadow:2px 2px 0 var(--ink)}
.m-block{scroll-margin-top:calc(var(--nav-h,62px) + 58px);margin-bottom:clamp(2.4rem,5vw,3.6rem)}
.m-bhead{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.4rem;
  border-left:8px solid var(--acc);padding:.2rem 0 .2rem 1rem}
.m-tag{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--acc)}
.m-bhead h3{font-size:clamp(1.8rem,4vw,2.7rem)}
.m-bhead p{margin:0;font-weight:500;color:var(--muted);max-width:44rem}
.m-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:0 2.8rem}
.m-item{padding:.8rem 0;border-bottom:2px dotted rgba(23,19,12,.2);min-width:0}
.m-row{display:flex;align-items:baseline;gap:.5rem;min-width:0}
.m-name{font-family:"Space Grotesk";font-weight:700;font-size:1.08rem;display:inline-flex;
  align-items:baseline;gap:.4rem;flex-wrap:wrap}
.m-dot{flex:1;min-width:1.2rem}
.m-price{font-family:"Anton";font-weight:400;color:var(--ink);background:var(--yellow);
  border:2px solid var(--ink);border-radius:6px;padding:.04em .4em;white-space:nowrap;font-size:.95rem}
.m-var{display:inline-flex;gap:.4rem;white-space:nowrap}
.m-var span{display:inline-flex;align-items:baseline;gap:.25rem;font-family:"Anton";color:var(--ink);
  background:var(--yellow);border:2px solid var(--ink);border-radius:6px;padding:.04em .4em;font-size:.85rem}
.m-var i{font-style:normal;font-family:"Space Grotesk";font-size:.62rem;font-weight:700;text-transform:uppercase}
.m-desc{display:block;font-size:.92rem;font-weight:500;color:var(--muted);margin-top:.2rem;max-width:42rem}
.allerg{display:inline-flex;gap:.22rem;align-self:center}
.alg{position:relative;width:1.4em;height:1.4em;display:inline-grid;place-items:center;padding:0;
  font-family:"Space Grotesk";font-size:.62rem;font-weight:700;line-height:1;color:var(--cream);
  background:var(--ink);border:0;border-radius:50%;cursor:pointer;transition:background var(--t),transform var(--t)}
.alg:hover,.alg:focus-visible,.alg.show{background:var(--red);transform:scale(1.18);outline:none}
.alg-tip{position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(5px) scale(.96);
  background:var(--ink);color:var(--cream);font-size:.74rem;font-weight:600;letter-spacing:.01em;
  text-transform:none;white-space:nowrap;padding:.4em .65em;border-radius:8px;border:2px solid var(--yellow);
  box-shadow:var(--hard-sm);opacity:0;visibility:hidden;pointer-events:none;z-index:30;
  transition:opacity .16s var(--ease),transform .16s var(--pop)}
.alg-tip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--yellow)}
.alg:hover .alg-tip,.alg:focus-visible .alg-tip,.alg.show .alg-tip{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0) scale(1)}
.m-block[data-accent="rosse"]{--acc:var(--red)}
.m-block[data-accent="bianche"]{--acc:#9a7b1f}
.m-block[data-accent="gialle"]{--acc:var(--yellow-deep)}
.m-block[data-accent="family"]{--acc:#1f6f4a}
.m-block[data-cat="carne"]{--acc:#8f2f17}
.m-block[data-cat="antipasti"]{--acc:#b3791a}
.m-block[data-cat="birre"]{--acc:#3a6ea5}
.m-block[data-cat="cantina"]{--acc:#7d2438}
.m-foot{margin-top:2rem;padding:1.2rem 1.3rem;background:var(--cream);border:var(--bd);border-radius:var(--rad);
  box-shadow:var(--hard-sm);font-size:.88rem;font-weight:500;color:var(--muted)}
.m-notes{margin:0 0 .6rem}.m-notes b{color:var(--ink)}.m-notes i{color:var(--red);font-style:normal;font-weight:700}
.m-legend{margin:0;display:flex;flex-wrap:wrap;gap:.25rem .7rem;align-items:center;line-height:1.9}
.m-legend span{font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--ink)}
.m-legend b{display:inline-grid;place-items:center;width:1.5em;height:1.5em;font-size:.66rem;
  background:var(--ink);color:var(--cream);border-radius:50%}
.m-allerg-note{display:flex;gap:.6rem;align-items:flex-start;margin:1rem 0 0;padding:.85rem 1rem;
  background:var(--yellow);border:2.5px solid var(--ink);border-radius:var(--rad-sm);
  font-size:.9rem;font-weight:500;color:var(--ink);line-height:1.5}
.m-allerg-note .ic{flex:0 0 auto;margin-top:.15em;width:1.3em;height:1.3em}
.m-allerg-note b{font-weight:700}
.is-filtered .m-block{display:none}.is-filtered .m-block.show{display:block}
@media (max-width:900px){.m-list{grid-template-columns:1fr;gap:0}}
/* mobile: i prezzi a varianti (singola/x2, taglie) vanno a capo sotto il nome,
   così i tag non vengono tagliati dal bordo */
@media (max-width:600px){
  .m-row.has-var{flex-wrap:wrap}
  .has-var .m-var{flex-basis:100%;margin-top:.45rem;flex-wrap:wrap;white-space:normal}
  .has-var .m-var span{margin-left:0}
}

/* ============================ GALLERY (ink) =============================== */
.gfilters{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2rem}
.gfil{min-height:44px;display:inline-flex;align-items:center;padding:.4em 1.05em;
  border:2.5px solid var(--yellow);border-radius:99px;font-weight:700;font-size:.9rem;
  color:var(--yellow);background:transparent;transition:all var(--t)}
.gfil:hover{background:rgba(243,194,0,.15)}
.gfil.is-active{background:var(--yellow);color:var(--ink)}
.gmasonry{columns:4;column-gap:1rem}
.gcell{position:relative;width:100%;break-inside:avoid;margin:0 0 1rem;padding:0;display:block;
  border:var(--b) solid var(--yellow);border-radius:var(--rad-sm);overflow:hidden;background:var(--ink-2);
  box-shadow:5px 5px 0 rgba(243,194,0,.35);transition:transform var(--t),box-shadow var(--t)}
.gcell img{width:100%;transition:transform .5s var(--ease)}
.gcell:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--yellow)}
.gcell:hover img{transform:scale(1.05)}
.gcap{position:absolute;left:0;right:0;bottom:0;padding:1.3rem .8rem .7rem;color:#fff;font-size:.82rem;
  font-weight:600;text-align:left;background:linear-gradient(transparent,rgba(10,7,3,.85));
  opacity:0;transform:translateY(8px);transition:all var(--t)}
.gcell:hover .gcap,.gcell:focus-visible .gcap{opacity:1;transform:none}
.gcell.hide{display:none}
@media (max-width:1000px){.gmasonry{columns:3}}
@media (max-width:680px){.gmasonry{columns:2;column-gap:.7rem}.gcell{margin-bottom:.7rem}}
@media (max-width:420px){.gmasonry{columns:1}}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;
  background:rgba(12,9,4,.93);padding:clamp(1rem,4vw,3rem);opacity:0;transition:opacity .25s var(--ease)}
.lightbox.show{opacity:1}.lightbox[hidden]{display:none}
.lb-fig{margin:0;max-width:min(1080px,94vw);max-height:88svh;display:flex;flex-direction:column;gap:.7rem}
.lb-fig img{max-height:78svh;width:auto;margin:auto;border:var(--b) solid var(--yellow);border-radius:8px;object-fit:contain}
.lb-fig figcaption{color:var(--yellow);text-align:center;font-weight:600;font-size:.95rem}
.lb-close,.lb-prev,.lb-next{position:absolute;color:var(--ink);background:var(--yellow);width:52px;height:52px;
  border:var(--b) solid var(--ink);border-radius:50%;display:grid;place-items:center;
  box-shadow:var(--hard-sm);transition:transform var(--t)}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{transform:scale(1.08)}
.lb-close{top:1.1rem;right:1.1rem}.lb-close .ic{width:24px;height:24px}
.lb-prev{left:1.1rem;top:50%;translate:0 -50%}.lb-prev .ic{transform:rotate(180deg)}
.lb-next{right:1.1rem;top:50%;translate:0 -50%}
@media (max-width:600px){.lb-prev,.lb-next{top:auto;bottom:1.1rem;translate:0}.lb-prev{left:30%}.lb-next{right:30%}}

/* ============================ INFO ========================================= */
.info{background:var(--paper-2)}
.info-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4rem)}
.info-col h2{font-size:clamp(1.9rem,4.2vw,2.8rem);margin-bottom:1rem}
.hours{width:100%;border-collapse:separate;border-spacing:0;border:var(--bd);border-radius:var(--rad);
  overflow:hidden;background:var(--cream);box-shadow:var(--hard-sm)}
.hours th,.hours td{padding:.7rem .9rem;text-align:left;border-bottom:2px solid rgba(23,19,12,.12)}
.hours tr:last-child th,.hours tr:last-child td{border-bottom:0}
.hours th{font-weight:600}.hours td{text-align:right;color:var(--muted);font-variant-numeric:tabular-nums;font-weight:600}
.hours .is-closed td{color:var(--red);font-weight:700}
.hours tr.today{background:var(--yellow)}
.hours tr.today th,.hours tr.today td{color:var(--ink);font-weight:700}
.hours tr.today th::after{content:"oggi";margin-left:.6em;font-size:.62rem;text-transform:uppercase;
  letter-spacing:.08em;background:var(--ink);color:var(--yellow);padding:.18em .5em;border-radius:99px}
.hours-note{font-size:.9rem;font-weight:500;color:var(--muted);margin:.9rem 0 0}.hours-note b{color:var(--red)}
.contacts{list-style:none;margin:.3rem 0 0;padding:0;display:flex;flex-direction:column;gap:1rem}
.contacts li{display:flex;gap:.8rem;align-items:flex-start}
.contacts .ic{flex:0 0 auto;margin-top:.1rem;width:1.5em;height:1.5em;color:var(--ink);background:var(--yellow);
  border:2px solid var(--ink);border-radius:7px;padding:3px}
.contacts b,.contacts a{font-weight:700;font-size:1.04rem}
.contacts a:hover{color:var(--red)}
.contacts span{display:block;font-size:.88rem;font-weight:500;color:var(--muted)}
.info-cta{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem}
.socials{display:flex;gap:.6rem;margin-top:1.3rem}
.socials a{width:46px;height:46px;display:grid;place-items:center;border:var(--bd);border-radius:50%;
  background:var(--cream);box-shadow:var(--hard-sm);transition:transform var(--t)}
.socials a:hover{transform:translate(-2px,-2px);background:var(--yellow)}
.foot .socials a{background:var(--ink);border-color:var(--yellow);color:var(--yellow);box-shadow:none}
.foot .socials a:hover{background:var(--yellow);color:var(--ink)}
.map-card{position:relative;border:var(--bd);border-radius:var(--rad);overflow:hidden;box-shadow:var(--hard)}
.map{width:100%;height:340px;border:0;display:block}
.map-open{position:absolute;left:1rem;bottom:1rem;display:inline-flex;align-items:center;gap:.4em;
  background:var(--yellow);color:var(--ink);font-weight:700;font-size:.88rem;padding:.55em 1em;border-radius:99px;
  border:var(--bd);box-shadow:var(--hard-sm)}
.map-open:hover{background:var(--cream)}
.faqs{margin-top:1.8rem}
.faqs h3{font-size:1.5rem;margin-bottom:.7rem}
.faq{border:var(--bd);border-radius:var(--rad-sm);background:var(--cream);margin-bottom:.7rem;
  box-shadow:var(--hard-sm);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  gap:1rem;padding:.85rem 1rem;font-weight:700;font-size:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ic{flex:0 0 auto;color:var(--ink);transition:transform var(--t)}
.faq[open] summary{background:var(--yellow)}
.faq[open] summary .ic{transform:rotate(180deg)}
.faq p{margin:0;padding:0 1rem 1rem;font-size:.95rem;font-weight:500;color:var(--muted)}
@media (max-width:820px){.info-grid{grid-template-columns:1fr}}

/* ============================ FOOTER ======================================= */
.foot{background:var(--ink);color:var(--cream);position:relative}
.bandana-strip{display:flex;align-items:center;justify-content:center;gap:1.4rem;flex-wrap:wrap;
  background:var(--yellow);border-bottom:var(--b) solid var(--ink);padding:.7rem 1rem;color:var(--ink);
  overflow:hidden;max-height:42px}
.bandana-strip .paisley{width:1.1em;height:1.3em}
.foot-in{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:2rem;padding:clamp(2.6rem,5vw,4rem) 0 0}
.foot-wm{font-size:2.6rem;-webkit-text-stroke-width:2px;-webkit-text-stroke-color:var(--yellow);color:var(--ink)}
.foot-brand p{margin:.5rem 0 0;color:var(--muted-d);font-weight:500}
.foot-brand .foot-claim{max-width:30rem;font-size:.94rem;margin-top:.7rem}
.foot-col h4{font-family:"Space Grotesk";font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  font-size:.78rem;color:var(--yellow);margin:0 0 .7rem}
.foot-col p{margin:0 0 .6rem;color:var(--muted-d);font-size:.95rem;font-weight:500}
.foot-col a:hover{color:var(--yellow)}
.foot-bot{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:2.4rem;
  padding:1.3rem 0;border-top:2px solid rgba(243,194,0,.25);font-size:.8rem;color:var(--muted-d);font-weight:500}
.totop{position:fixed;right:1.1rem;bottom:1.1rem;z-index:80;width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;background:var(--yellow);color:var(--ink);border:var(--bd);
  box-shadow:var(--hard-sm);transform:rotate(180deg) translateY(12px);opacity:0;visibility:hidden;
  transition:opacity var(--t),visibility var(--t),transform var(--t)}
.totop .ic{transition:none}
.totop.show{opacity:1;visibility:visible;transform:rotate(180deg) translateY(0)}
.totop:hover{transform:rotate(180deg) translateY(-3px)}
@media (max-width:760px){.foot-in{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}
@media (max-width:440px){.foot-in{grid-template-columns:1fr}}

/* ============================ NAV RESPONSIVE =============================== */
@media (max-width:860px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:inline-flex}
}



