/* ================================================================
   AMUNÌ — Trattoria e Pizzeria Sicula · Milano
   Direzione: POSTER editoriale bold contemporaneo, caldo siciliano.
   Base sabbia/crema · blocchi terracotta + espresso · accento pistacchio.
   Font: Archivo (display grotesk) · Hanken Grotesk (corpo) · Space Mono (etichette/prezzi)
   ================================================================ */

/* ---------- FONT SELF-HOST ---------- */
@font-face{font-family:'Archivo';src:url('fonts/archivo-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:'Archivo';src:url('fonts/archivo-800.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap;}
@font-face{font-family:'Archivo';src:url('fonts/archivo-900.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap;}
@font-face{font-family:'Hanken Grotesk';src:url('fonts/hanken-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Hanken Grotesk';src:url('fonts/hanken-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'Hanken Grotesk';src:url('fonts/hanken-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:'Hanken Grotesk';src:url('fonts/hanken-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:'Space Mono';src:url('fonts/spacemono-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Space Mono';src:url('fonts/spacemono-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap;}

/* ---------- TOKENS ---------- */
:root{
  --sabbia:#F3ECDF;        /* base */
  --sabbia-2:#EBE2D0;      /* base alt */
  --crema:#F7F2E8;
  --terra:#C24A2C;         /* terracotta */
  --terra-d:#A33A1F;
  --espresso:#281B14;      /* espresso */
  --espresso-2:#1C120C;
  --pistacchio:#6E7A3A;    /* accento Bronte */
  --pistacchio-d:#586230;
  --ink:#241710;
  --muted:#6b5848;
  --line:#d9cdb8;
  --line-dk:rgba(247,242,232,.16);
  --disp:'Archivo',system-ui,sans-serif;
  --body:'Hanken Grotesk',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;
  --maxw:1280px;
  --pad:clamp(18px,5vw,68px);
  --r:4px;
  --shadow:0 24px 60px -28px rgba(40,27,20,.5);
}

/* ---------- RESET ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{
  overflow-x:hidden;            /* mai su body (regola Q) */
  scroll-padding-top:88px;
  -webkit-text-size-adjust:100%;
}
body{
  font-family:var(--body);
  background:var(--sabbia);
  color:var(--ink);
  line-height:1.6;
  font-size:clamp(16px,1.05vw,17.5px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
h1,h2,h3,h4{font-family:var(--disp);font-weight:900;line-height:.95;letter-spacing:-.02em;text-transform:uppercase}
h1,h2,h3,h4,p,span,a,li{overflow-wrap:break-word}
::selection{background:var(--terra);color:var(--crema)}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.mono{font-family:var(--mono)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
[hidden]{display:none!important}

/* ================================================================
   INTRO CINEMATOGRAFICA
   ================================================================ */
#intro{
  position:fixed;inset:0;z-index:9000;
  background:var(--espresso);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  overflow:hidden;
}
#intro .iwrap{position:relative;text-align:center;z-index:2}
#intro .ilogo{display:block;width:clamp(220px,58vw,360px);height:auto;margin:0 auto 24px;
  background:var(--crema);padding:22px 30px;border-radius:22px;opacity:0;transform:scale(.7) translateY(8px);
  animation:iLogo .9s .15s cubic-bezier(.2,.9,.2,1) forwards;box-shadow:0 22px 60px rgba(0,0,0,.5)}
#intro .iword{font-family:var(--disp);font-weight:900;font-size:clamp(58px,15vw,150px);color:var(--crema);
  letter-spacing:-.03em;line-height:.9;position:relative;display:inline-block}
#intro .iword span{display:inline-block;opacity:0;transform:translateY(120%) rotate(8deg);
  animation:iChar .7s cubic-bezier(.2,.9,.2,1) forwards}
#intro .isub{margin-top:14px;font-family:var(--mono);font-size:13px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--terra);opacity:0;animation:iSub .6s 1.05s ease forwards}
/* impasto/pizza che ruota */
#intro .idisk{position:absolute;left:50%;top:50%;width:340px;height:340px;margin:-170px 0 0 -170px;border-radius:50%;
  border:2px dashed rgba(247,242,232,.18);opacity:0;animation:iDisk 1.1s .2s ease forwards,spin 14s linear infinite;z-index:1}
#intro .idisk::after{content:"";position:absolute;inset:34px;border-radius:50%;border:1px solid rgba(194,74,44,.4)}
#intro .ibar{position:absolute;left:0;bottom:0;height:4px;width:0;background:var(--terra);animation:iBar 1.9s .1s cubic-bezier(.6,0,.2,1) forwards}
/* uscita: split tradizione↔contemporaneo */
#intro.out .ipanel-l{transform:translateY(-100%)}
#intro.out .ipanel-r{transform:translateY(100%)}
#intro.out .iwrap{opacity:0;transition:opacity .35s ease}
.ipanel{position:absolute;left:0;width:100%;height:50%;background:var(--espresso);transition:transform .8s cubic-bezier(.7,0,.2,1);z-index:0}
.ipanel-l{top:0}.ipanel-r{bottom:0}
@keyframes iLogo{to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes iChar{to{opacity:1;transform:translateY(0) rotate(0)}}
@keyframes iSub{to{opacity:1}}
@keyframes iDisk{to{opacity:1}}
@keyframes iBar{to{width:100%}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ================================================================
   HEADER
   ================================================================ */
.head{position:sticky;top:0;z-index:1000;background:rgba(243,236,223,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);transition:padding .25s ease,background .25s ease}
.head.shrunk{background:rgba(243,236,223,.96)}
.head .bar{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding-top:12px;padding-bottom:12px;transition:padding .25s ease}
.head.shrunk .bar{padding-top:7px;padding-bottom:7px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand img{height:42px;width:auto;object-fit:contain;transition:height .25s ease}
.head.shrunk .brand img{height:34px}
.brand .bt{display:flex;flex-direction:column;line-height:1}
.brand .bn{font-family:var(--disp);font-weight:900;font-size:23px;letter-spacing:-.02em;color:var(--espresso)}
.brand .bs{font-family:var(--mono);font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--terra);margin-top:3px}
@media(max-width:560px){.brand .bt{display:none}}

.nav{display:flex;align-items:center;gap:4px}
.nav a{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--espresso);
  padding:9px 12px;border-radius:var(--r);transition:color .15s,background .15s;white-space:nowrap}
.nav a:hover{background:var(--espresso);color:var(--crema)}
.nav a.active{color:var(--terra)}
.nav a.active:hover{color:var(--crema)}
@media(max-width:1024px){.nav.main{display:none}}

.htools{display:flex;align-items:center;gap:8px}
.langbtn{display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--espresso);border-radius:999px;
  padding:7px 12px;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--espresso);background:transparent;
  transition:background .15s,color .15s}
.langbtn:hover{background:var(--espresso);color:var(--crema)}
.langbtn .flag{font-size:15px;line-height:1}
.langbtn svg{width:12px;height:12px}
.btn-book{display:inline-flex;align-items:center;gap:8px;background:var(--terra);color:var(--crema);
  font-family:var(--mono);font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.05em;
  padding:10px 16px;border-radius:var(--r);transition:background .15s,transform .15s}
.btn-book:hover{background:var(--terra-d);transform:translateY(-1px)}
@media(max-width:680px){.btn-book{display:none}}
.burger{display:none;width:46px;height:46px;border:1.5px solid var(--espresso);border-radius:var(--r);
  align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{width:20px;height:2px;background:var(--espresso);transition:.25s}
@media(max-width:1024px){.burger{display:inline-flex}}

/* mobile drawer */
#drawer{position:fixed;inset:0;z-index:1200}
#drawer .scrim{position:absolute;inset:0;background:rgba(40,27,20,.5);backdrop-filter:blur(3px);opacity:0;transition:opacity .3s}
#drawer.show .scrim{opacity:1}
#drawer .panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:var(--espresso);
  transform:translateX(100%);transition:transform .35s cubic-bezier(.6,0,.2,1);padding:24px;display:flex;flex-direction:column;overflow-y:auto}
#drawer.show .panel{transform:translateX(0)}
#drawer .panel .x{align-self:flex-end;width:44px;height:44px;border:1px solid var(--line-dk);border-radius:var(--r);
  color:var(--crema);font-size:22px;display:flex;align-items:center;justify-content:center}
#drawer .panel a{font-family:var(--disp);font-weight:800;font-size:26px;text-transform:uppercase;color:var(--crema);
  padding:13px 0;border-bottom:1px solid var(--line-dk)}
#drawer .panel a:last-of-type{border-bottom:none}
#drawer .panel a.active{color:var(--terra)}
#drawer .dcta{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:20px}
#drawer .dcta a{font-family:var(--mono);font-size:14px;text-transform:none;padding:13px;text-align:center;border-radius:var(--r);border-bottom:none}
#drawer .dcta .p{background:var(--terra)}
#drawer .dcta .w{border:1px solid var(--line-dk)}

/* ================================================================
   LANG MODAL (Uniswap-dialog)
   ================================================================ */
#langModal{position:fixed;inset:0;z-index:9500;display:flex;align-items:center;justify-content:center;padding:18px}
#langModal .lscrim{position:absolute;inset:0;background:rgba(40,27,20,.42);backdrop-filter:blur(2px);opacity:0;transition:opacity .25s}
#langModal.show .lscrim{opacity:1}
#langModal .ldlg{position:relative;width:100%;max-width:400px;max-height:min(82vh,520px);background:var(--crema);
  border-radius:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;
  opacity:0;transform:scale(.96);filter:blur(4px);transition:opacity .3s,transform .3s,filter .3s;border:1px solid var(--line)}
#langModal.show .ldlg{opacity:1;transform:scale(1);filter:blur(0)}
.ldlg .lhd{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 12px}
.ldlg .lhd h3{font-family:var(--disp);font-weight:800;font-size:18px;letter-spacing:-.01em;color:var(--espresso)}
.ldlg .lhd .lx{width:38px;height:38px;border-radius:50%;background:var(--sabbia-2);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--espresso)}
.ldlg .lsearch{margin:0 18px 12px;display:flex;align-items:center;gap:9px;background:var(--sabbia);border:1px solid var(--line);border-radius:12px;padding:11px 13px}
.ldlg .lsearch svg{width:16px;height:16px;color:var(--muted);flex:none}
.ldlg .lsearch input{flex:1;border:none;background:none;outline:none;font-family:var(--body);font-size:15px;color:var(--ink)}
.ldlg .llist{overflow-y:auto;padding:0 10px 12px}
.ldlg .llist::-webkit-scrollbar{width:8px}
.ldlg .llist::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.lrow{display:flex;align-items:center;gap:12px;width:100%;padding:12px;border-radius:12px;text-align:left;transition:background .12s}
.lrow:hover{background:var(--sabbia-2)}
.lrow .flag{font-size:22px;line-height:1}
.lrow .nm{flex:1;font-weight:600;font-size:15px;color:var(--ink)}
.lrow .ck{width:18px;height:18px;color:var(--terra);opacity:0}
.lrow.on .ck{opacity:1}
.lrow.on{background:var(--sabbia-2)}

/* ================================================================
   HERO
   ================================================================ */
.hero{position:relative;overflow:hidden;background:var(--sabbia)}
.hero .hgrid{display:grid;grid-template-columns:1.05fr .95fr;min-height:clamp(560px,82svh,860px)}
@media(max-width:880px){.hero .hgrid{grid-template-columns:1fr;min-height:auto}}
.hero .hl{display:flex;flex-direction:column;justify-content:center;padding:clamp(30px,6vw,70px) var(--pad);position:relative;z-index:2}
.hero .htag{display:inline-flex;align-items:center;gap:9px;align-self:flex-start;font-family:var(--mono);font-size:12px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--terra);margin-bottom:22px}
.hero .htag::before{content:"";width:30px;height:2px;background:var(--terra)}
.hero h1{font-size:clamp(64px,13vw,168px);line-height:.84;color:var(--espresso);margin-bottom:8px}
.hero h1 .ll{color:var(--terra)}
.hero .hsub{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:clamp(15px,2.4vw,24px);
  letter-spacing:.02em;color:var(--pistacchio);line-height:1.05;margin-bottom:22px}
.hero .hdesc{max-width:46ch;color:var(--muted);font-size:clamp(15.5px,1.5vw,18px);margin-bottom:30px}
.hero .hcta{display:flex;flex-wrap:wrap;gap:12px}
.hero .hmeta{margin-top:34px;display:flex;flex-wrap:wrap;gap:10px 26px;font-family:var(--mono);font-size:12px;
  text-transform:uppercase;letter-spacing:.05em;color:var(--espresso)}
.hero .hmeta b{color:var(--terra)}
/* right visual: rotating pizza + espresso block */
.hero .hr{position:relative;background:var(--espresso);overflow:hidden;display:flex;align-items:center;justify-content:center}
@media(max-width:880px){.hero .hr{width:100%;max-width:100%;min-height:0;aspect-ratio:4/3;align-self:stretch}}
@media(max-width:560px){.hero .hr{aspect-ratio:1/1}}
.hero .hr .hphoto{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.94}
.hero .hr .hscrim{position:absolute;inset:0;background:linear-gradient(120deg,rgba(40,27,20,.42),transparent 55%)}
.hero .hr .pizza{position:absolute;left:50%;top:50%;width:min(82%,520px);aspect-ratio:1/1;transform:translate(-50%,-50%);
  border-radius:50%;border:2px dashed rgba(247,242,232,.28);animation:spin 26s linear infinite;pointer-events:none}
.hero .hr .pizza::after{content:"";position:absolute;inset:13%;border-radius:50%;border:1px solid rgba(194,74,44,.5)}
.hero .hr .stamp{position:absolute;right:18px;bottom:18px;z-index:3;background:var(--terra);color:var(--crema);
  font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:9px 13px;border-radius:999px}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-weight:700;font-size:13px;
  text-transform:uppercase;letter-spacing:.05em;padding:14px 22px;border-radius:var(--r);transition:transform .15s,background .15s,color .15s}
.btn-primary{background:var(--terra);color:var(--crema)}
.btn-primary:hover{background:var(--terra-d);transform:translateY(-2px)}
.btn-dark{background:var(--espresso);color:var(--crema)}
.btn-dark:hover{background:var(--espresso-2);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid var(--espresso);color:var(--espresso)}
.btn-ghost:hover{background:var(--espresso);color:var(--crema);transform:translateY(-2px)}
.btn svg{width:15px;height:15px}

/* ================================================================
   GENERIC SECTION / PAGE HEAD
   ================================================================ */
section{position:relative}
.sec{padding:clamp(56px,9vw,118px) 0}
.sec.dk{background:var(--espresso);color:var(--crema)}
.sec.dk h2,.sec.dk h3{color:var(--crema)}
.sec.terra{background:var(--terra);color:var(--crema)}
.sec.terra h2,.sec.terra h3{color:var(--crema)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--terra);margin-bottom:16px}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor}
.sec.dk .eyebrow,.sec.terra .eyebrow{color:var(--crema);opacity:.9}
.sec.dk .eyebrow{color:var(--terra)}
.h2{font-size:clamp(34px,6vw,76px);line-height:.9;color:var(--espresso);margin-bottom:18px}
.sec.dk .h2,.sec.terra .h2{color:var(--crema)}
.lead{max-width:62ch;font-size:clamp(16px,1.5vw,19px);color:var(--muted)}
.sec.dk .lead,.sec.terra .lead{color:rgba(247,242,232,.85)}

/* page hero (sub pages) */
.phead{background:var(--espresso);color:var(--crema);padding:clamp(96px,14vw,150px) 0 clamp(40px,7vw,72px);position:relative;overflow:hidden}
.phead .pdisk{position:absolute;right:-90px;top:50%;width:380px;height:380px;margin-top:-190px;border-radius:50%;
  border:2px dashed rgba(247,242,232,.13);animation:spin 30s linear infinite}
.phead .pdisk::after{content:"";position:absolute;inset:48px;border-radius:50%;border:1px solid rgba(194,74,44,.35)}
.phead .crumb{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);margin-bottom:18px}
.phead .crumb a{color:rgba(247,242,232,.7)}
.phead .crumb a:hover{color:var(--crema)}
.phead h1{font-size:clamp(46px,10vw,118px);line-height:.86;color:var(--crema)}
.phead .psub{margin-top:18px;max-width:60ch;color:rgba(247,242,232,.82);font-size:clamp(16px,1.6vw,19px)}

/* ================================================================
   DUALITÀ TRADIZIONE ↔ CONTEMPORANEO  (split)
   ================================================================ */
.duo{display:grid;grid-template-columns:1fr 1fr}
@media(max-width:760px){.duo{grid-template-columns:1fr}}
.duo .dcell{padding:clamp(40px,6vw,84px) var(--pad);min-height:clamp(320px,46vw,520px);display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}
.duo .trad{background:var(--sabbia-2);color:var(--espresso)}
.duo .cont{background:var(--espresso);color:var(--crema)}
.duo .dnum{font-family:var(--mono);font-size:13px;letter-spacing:.2em;opacity:.7;margin-bottom:auto}
.duo .dttl{font-family:var(--disp);font-weight:900;font-size:clamp(40px,7vw,86px);line-height:.86;text-transform:uppercase;margin:24px 0 12px}
.duo .trad .dttl{color:var(--terra)}
.duo .cont .dttl{color:var(--crema)}
.duo .dtxt{max-width:40ch;font-size:16px}
.duo .trad .dtxt{color:var(--muted)}
.duo .cont .dtxt{color:rgba(247,242,232,.82)}

/* ================================================================
   POSTER BLOCKS / FEATURES
   ================================================================ */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.4vw,18px)}
.bento .card{background:var(--crema);border:1px solid var(--line);border-radius:var(--r);padding:clamp(22px,2.6vw,34px);position:relative;overflow:hidden}
.bento .card .ic{width:46px;height:46px;border-radius:50%;background:var(--terra);color:var(--crema);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.bento .card .ic svg{width:22px;height:22px}
.bento .card h3{font-size:clamp(19px,1.8vw,24px);color:var(--espresso);margin-bottom:9px;letter-spacing:-.01em}
.bento .card p{color:var(--muted);font-size:15.5px}
.bento .c-6{grid-column:span 6}.bento .c-4{grid-column:span 4}.bento .c-8{grid-column:span 8}.bento .c-12{grid-column:span 12}.bento .c-3{grid-column:span 3}
@media(max-width:880px){.bento .c-6,.bento .c-4,.bento .c-8,.bento .c-3{grid-column:span 6}}
@media(max-width:560px){.bento .c-6,.bento .c-4,.bento .c-8,.bento .c-3,.bento .c-12{grid-column:span 12}}

/* number stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:38px}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{border-top:3px solid var(--terra);padding-top:14px}
.stat .n{font-family:var(--disp);font-weight:900;font-size:clamp(34px,5vw,58px);line-height:1;color:var(--espresso)}
.sec.dk .stat .n{color:var(--crema)}
.stat .l{font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:8px}
.sec.dk .stat .l{color:rgba(247,242,232,.7)}

/* ================================================================
   MENU
   ================================================================ */
.menubar{position:sticky;top:84px;z-index:90;background:var(--sabbia);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px 0}
.menubar .inner{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none}
.menubar .inner::-webkit-scrollbar{display:none}
.mtab{flex:none;font-family:var(--mono);font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  color:var(--espresso);padding:9px 15px;border-radius:999px;border:1.5px solid var(--line);white-space:nowrap;transition:.15s}
.mtab:hover{border-color:var(--espresso)}
.mtab.on{background:var(--espresso);color:var(--crema);border-color:var(--espresso)}

.mcat{margin-bottom:clamp(40px,6vw,70px);scroll-margin-top:150px}
.mcat .chead{display:flex;align-items:baseline;gap:16px;margin-bottom:26px;border-bottom:2px solid var(--espresso);padding-bottom:14px}
.mcat .chead .cnum{font-family:var(--mono);font-size:13px;color:var(--terra)}
.mcat .chead h2{font-size:clamp(28px,5vw,56px);color:var(--espresso);line-height:.9}
.mcat .chead .cnote{margin-left:auto;font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:right;max-width:42%}
@media(max-width:620px){.mcat .chead{flex-wrap:wrap}.mcat .chead .cnote{display:none}}
.mitems{display:grid;grid-template-columns:1fr 1fr;gap:6px 48px}
@media(max-width:760px){.mitems{grid-template-columns:1fr}}
.mitem{display:grid;grid-template-columns:1fr auto;gap:6px 14px;padding:15px 0;border-bottom:1px dashed var(--line);align-items:start}
.mitem .mi-l{min-width:0}
.mitem .mi-name{font-family:var(--disp);font-weight:800;font-size:17.5px;text-transform:uppercase;letter-spacing:-.01em;color:var(--espresso)}
.mitem .mi-desc{font-size:14px;color:var(--muted);margin-top:4px;line-height:1.45}
.mitem .mi-price{font-family:var(--mono);font-weight:700;font-size:16px;color:var(--terra);white-space:nowrap;padding-top:2px}
.mnote{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:8px}
.degust{background:var(--terra);color:var(--crema);border-radius:var(--r);padding:clamp(22px,3vw,34px);display:flex;flex-wrap:wrap;
  align-items:center;justify-content:space-between;gap:18px;margin-bottom:clamp(36px,5vw,56px)}
.degust .dg-l h3{font-size:clamp(24px,3.4vw,38px);color:var(--crema);margin-bottom:6px}
.degust .dg-l p{color:rgba(247,242,232,.86);font-size:15px;max-width:48ch}
.degust .dg-r{display:flex;gap:26px;font-family:var(--mono)}
.degust .dg-r .pp{text-align:center}
.degust .dg-r .pp .pn{font-family:var(--disp);font-weight:900;font-size:clamp(30px,4vw,46px);line-height:1}
.degust .dg-r .pp .pl{font-size:11px;text-transform:uppercase;letter-spacing:.08em;opacity:.85;margin-top:6px}

/* ================================================================
   GALLERY GRID
   ================================================================ */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.2vw,16px)}
@media(max-width:880px){.gal{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.gal{grid-template-columns:1fr}}
.gfig{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--r);background:var(--espresso);cursor:pointer;margin:0}
.gfig.tall{aspect-ratio:4/5}
.gfig img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.gfig:hover img{transform:scale(1.06)}
.gfig figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 16px 14px;
  background:linear-gradient(transparent,rgba(40,27,20,.78));color:var(--crema);
  font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;opacity:0;transform:translateY(8px);transition:.3s}
.gfig:hover figcaption{opacity:1;transform:translateY(0)}
.gspan2{grid-column:span 2}
@media(max-width:480px){.gspan2{grid-column:span 1}}

/* lightbox */
#lbx{position:fixed;inset:0;z-index:9600;background:rgba(28,18,12,.92);display:flex;align-items:center;justify-content:center;padding:20px}
#lbx img{max-width:92vw;max-height:84vh;border-radius:var(--r);box-shadow:0 30px 80px rgba(0,0,0,.6)}
#lbx .lcap{position:absolute;left:0;right:0;bottom:26px;text-align:center;color:var(--crema);font-family:var(--mono);font-size:13px;letter-spacing:.05em}
#lbx .lclose{position:absolute;top:18px;right:18px;width:48px;height:48px;border:1px solid rgba(247,242,232,.3);border-radius:50%;color:var(--crema);font-size:24px;display:flex;align-items:center;justify-content:center}
#lbx .larr{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border:1px solid rgba(247,242,232,.3);border-radius:50%;color:var(--crema);font-size:24px;display:flex;align-items:center;justify-content:center}
#lbx .lprev{left:14px}#lbx .lnext{right:14px}
@media(max-width:560px){#lbx .larr{width:44px;height:44px}}

/* ================================================================
   REVIEWS MARQUEE
   ================================================================ */
.revhd{display:flex;flex-wrap:wrap;align-items:flex-end;gap:18px 40px;margin-bottom:34px}
.revagg{display:flex;flex-wrap:wrap;gap:14px 28px;align-items:center}
.revagg .ra{display:flex;flex-direction:column}
.revagg .ra .rn{font-family:var(--disp);font-weight:900;font-size:clamp(30px,4vw,48px);line-height:1;color:var(--crema)}
.revagg .ra .rl{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:rgba(247,242,232,.7);margin-top:6px}
.revagg .star{color:#f0b840}
.marquee{position:relative;overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.mtrack{display:flex;width:max-content;gap:18px;animation:marq 64s linear infinite}
.marquee:hover .mtrack{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rcard{flex:none;width:360px;background:rgba(247,242,232,.06);border:1px solid var(--line-dk);border-radius:var(--r);padding:24px}
.rcard .rstars{color:#f0b840;font-size:15px;letter-spacing:2px;margin-bottom:12px}
.rcard .rtext{color:rgba(247,242,232,.92);font-size:15px;line-height:1.55;margin-bottom:16px}
.rcard .rwho{display:flex;align-items:center;gap:11px}
.rcard .rav{width:38px;height:38px;border-radius:50%;background:var(--terra);color:var(--crema);display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-weight:900;font-size:16px}
.rcard .rmeta{font-family:var(--mono);font-size:11px;color:rgba(247,242,232,.65);line-height:1.4}
.rcard .rmeta b{color:var(--crema);font-family:var(--body);font-weight:600;font-size:13px;display:block}
@media(max-width:480px){.rcard{width:300px}}

/* ================================================================
   FAQ
   ================================================================ */
.faq{max-width:880px;margin:0 auto}
.fq{border-bottom:1px solid var(--line)}
.fq button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:24px 0;text-align:left}
.fq button .q{font-family:var(--disp);font-weight:800;font-size:clamp(18px,2.2vw,24px);text-transform:uppercase;letter-spacing:-.01em;color:var(--espresso)}
.fq button .pm{flex:none;width:34px;height:34px;border:1.5px solid var(--espresso);border-radius:50%;position:relative;transition:.25s}
.fq button .pm::before,.fq button .pm::after{content:"";position:absolute;left:50%;top:50%;background:var(--espresso);transition:.25s}
.fq button .pm::before{width:13px;height:2px;transform:translate(-50%,-50%)}
.fq button .pm::after{width:2px;height:13px;transform:translate(-50%,-50%)}
.fq.open button .pm{background:var(--terra);border-color:var(--terra)}
.fq.open button .pm::before,.fq.open button .pm::after{background:var(--crema)}
.fq.open button .pm::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.fq .a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.fq .a p{padding:0 0 24px;color:var(--muted);font-size:16px;max-width:70ch}

/* ================================================================
   CONTACT / MAP / FORM
   ================================================================ */
.cgrid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(24px,4vw,56px)}
@media(max-width:880px){.cgrid{grid-template-columns:1fr}}
.cinfo .crow{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.cinfo .crow:first-child{padding-top:0}
.cinfo .crow .cic{flex:none;width:44px;height:44px;border-radius:50%;background:var(--espresso);color:var(--crema);display:flex;align-items:center;justify-content:center}
.cinfo .crow .cic svg{width:20px;height:20px}
.cinfo .crow .ct .cl{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--terra);margin-bottom:5px}
.cinfo .crow .ct .cv{font-size:16.5px;color:var(--espresso);font-weight:600}
.cinfo .crow .ct .cv a{color:var(--espresso)}
.cinfo .crow .ct .cv a:hover{color:var(--terra)}
.cinfo .crow .ct .csub{font-size:13.5px;color:var(--muted);margin-top:3px}
.mapwrap{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:var(--sabbia-2)}
.mapwrap iframe{width:100%;height:clamp(300px,42vw,440px);border:0;display:block;filter:saturate(.92)}
.mapbtns{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}

.cform{display:grid;gap:14px}
.cform .ff{display:flex;flex-direction:column;gap:7px}
.cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.cform .row2{grid-template-columns:1fr}}
.cform label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.cform input,.cform textarea,.cform select{font-family:var(--body);font-size:15.5px;color:var(--ink);background:var(--crema);
  border:1.5px solid var(--line);border-radius:var(--r);padding:13px 14px;outline:none;transition:border .15s;width:100%}
.cform input:focus,.cform textarea:focus,.cform select:focus{border-color:var(--terra)}
.cform textarea{resize:vertical;min-height:110px}
.formnote{font-size:12.5px;color:var(--muted)}

/* ================================================================
   CTA STRIP / FOOTER
   ================================================================ */
.ctastrip{background:var(--terra);color:var(--crema);text-align:center;padding:clamp(48px,8vw,96px) 0}
.ctastrip h2{font-size:clamp(34px,7vw,86px);line-height:.9;color:var(--crema);margin-bottom:18px}
.ctastrip p{max-width:54ch;margin:0 auto 28px;color:rgba(247,242,232,.9);font-size:17px}
.ctastrip .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.ctastrip .btn-primary{background:var(--espresso)}
.ctastrip .btn-primary:hover{background:var(--espresso-2)}
.ctastrip .btn-ghost{border-color:var(--crema);color:var(--crema)}
.ctastrip .btn-ghost:hover{background:var(--crema);color:var(--terra)}

/* ribbon marquee (poster signature) */
.ribbon{background:var(--espresso);color:var(--crema);overflow:hidden;padding:16px 0;border-top:1px solid var(--line-dk);border-bottom:1px solid var(--line-dk)}
.ribbon .rtrack{display:flex;width:max-content;gap:26px;animation:marq 40s linear infinite;align-items:center}
.ribbon span{font-family:var(--disp);font-weight:900;font-size:clamp(20px,3vw,34px);text-transform:uppercase;letter-spacing:.02em;color:var(--crema);white-space:nowrap}
.ribbon .dot{color:var(--terra);font-size:20px}

footer.ft{background:var(--espresso-2);color:var(--crema);padding:clamp(48px,7vw,84px) 0 28px}
footer.ft .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
@media(max-width:880px){footer.ft .fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){footer.ft .fgrid{grid-template-columns:1fr}}
footer.ft .fb img{width:172px;height:auto;background:var(--crema);padding:13px 18px;border-radius:14px;margin-bottom:16px}
footer.ft .fb p{color:rgba(247,242,232,.72);font-size:14.5px;max-width:34ch}
footer.ft h4{font-family:var(--mono);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--terra);margin-bottom:16px}
footer.ft ul{list-style:none}
footer.ft li{margin-bottom:10px}
footer.ft a,footer.ft .fv{color:rgba(247,242,232,.8);font-size:14.5px}
footer.ft a:hover{color:var(--crema)}
footer.ft .fsoc{display:flex;gap:10px;margin-top:6px}
footer.ft .fsoc a{width:40px;height:40px;border:1px solid var(--line-dk);border-radius:50%;display:flex;align-items:center;justify-content:center}
footer.ft .fsoc svg{width:18px;height:18px}
footer.ft .fbot{margin-top:44px;padding-top:22px;border-top:1px solid var(--line-dk);display:flex;flex-wrap:wrap;gap:10px 24px;
  justify-content:space-between;font-family:var(--mono);font-size:11.5px;color:rgba(247,242,232,.6);text-transform:uppercase;letter-spacing:.04em}

/* FAB whatsapp */
.fab{position:fixed;right:18px;bottom:18px;z-index:800;width:58px;height:58px;border-radius:50%;background:#25D366;
  display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.6);transition:transform .2s}
.fab:hover{transform:scale(1.08)}
.fab svg{width:30px;height:30px;fill:#fff}

/* reveal */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}.rv.d4{transition-delay:.32s}

/* utility */
.section-split{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,5vw,64px);align-items:center}
@media(max-width:880px){.section-split{grid-template-columns:1fr}}
.imgblock{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/5;background:var(--espresso)}
.imgblock img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.imgblock.wide{aspect-ratio:5/4}
.pill{display:inline-block;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;
  background:var(--pistacchio);color:var(--crema);padding:5px 11px;border-radius:999px;margin-bottom:8px}

/* ================= reduced motion ================= */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .rv{opacity:1!important;transform:none!important}
  /* marquee resta in movimento (regola K) */
  .mtrack,.ribbon .rtrack{animation:marq 64s linear infinite!important}
  .hero .hr .pizza,.phead .pdisk,#intro .idisk{animation:spin 30s linear infinite!important}
}
