/* ============================================================
   TUTTA 'NATA STORIA — Doppia Insegna
   carta paglierino · rosso pizzeria #941913 · azzurro trattoria #3296d3
   Young Serif · Albert Sans · IBM Plex Mono
   ============================================================ */

:root{
  --carta:#F6E9BE;
  --carta-chiara:#FBF4DD;
  --carta-scura:#EFDCA4;
  --ink:#26160A;
  --ink-soft:#5C4326;
  --rosso:#941913;
  --rosso-scuro:#6B110D;
  --azzurro:#3296D3;
  --blu:#1E429A;
  --arancio:#EF7427;
  --bruno:#211208;
  --bruno-2:#2E1B0D;
  --bianco:#FFFDF6;
  --f-disp:'Young Serif',Georgia,serif;
  --f-body:'Albert Sans',-apple-system,'Helvetica Neue',Arial,sans-serif;
  --f-mono:'IBM Plex Mono','SF Mono',Menlo,monospace;
  --header-h:84px;
  --r:18px;
  --shadow:0 18px 50px -18px rgba(38,22,10,.28);
  --maxw:1180px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-padding-top:96px;overflow-x:clip}
body{
  font-family:var(--f-body);
  background:var(--carta);
  color:var(--ink);
  line-height:1.7;
  font-size:16.5px;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
}
[hidden]{display:none!important}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
h1,h2,h3,h4,p,span,a,li,dt,dd{min-width:0;overflow-wrap:break-word}
h1,h2,h3,h4{font-family:var(--f-disp);font-weight:400;line-height:1.12;letter-spacing:-.01em}
::selection{background:var(--rosso);color:var(--carta)}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--carta);padding:.7rem 1.2rem;z-index:300;border-radius:0 0 12px 0}
.skip-link:focus{left:0}

/* ---------- texture carta ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;
  background-image:radial-gradient(rgba(120,84,30,.055) 1px,transparent 1px);
  background-size:5px 5px;
}
main,header,footer{position:relative;z-index:2}

/* ---------- utils ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,44px)}
.mono{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600}
.eyebrow{display:inline-flex;align-items:center;gap:.65rem;color:var(--rosso)}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;border-radius:2px}
.eyebrow.az{color:var(--blu)}
.sec{padding:clamp(66px,9vw,116px) 0}
.sec-title{font-size:clamp(1.9rem,4.4vw,3.1rem);margin:.55rem 0 1rem}
.lead{font-size:clamp(1.02rem,1.5vw,1.16rem);color:var(--ink-soft);max-width:62ch}
.center{text-align:center}
.center .lead{margin-inline:auto}
.center .eyebrow::before{display:none}

/* ---------- bottoni ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--f-mono);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:1.02rem 1.7rem;border-radius:999px;text-decoration:none;cursor:pointer;
  border:2px solid var(--ink);color:var(--ink);background:transparent;
  transition:transform .28s cubic-bezier(.2,.9,.3,1.4),box-shadow .28s,background .22s,color .22s;
  min-height:48px;
}
.btn:hover{transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(38,22,10,.4)}
.btn-rosso{background:var(--rosso);border-color:var(--rosso);color:var(--carta-chiara)}
.btn-rosso:hover{background:var(--rosso-scuro);border-color:var(--rosso-scuro)}
.btn-blu{background:var(--blu);border-color:var(--blu);color:#FFFDF6}
.btn-blu:hover{background:#163372;border-color:#163372}
.btn-ghost-chiaro{border-color:rgba(255,250,235,.85);color:#FFF8E7}
.btn-ghost-chiaro:hover{background:rgba(255,250,235,.14)}

/* ============================================================
   INTRO
   ============================================================ */
#intro{
  position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  background:var(--carta);flex-direction:column;gap:1.6rem;
  transition:transform .9s cubic-bezier(.76,0,.24,1);
}
#intro.escape{transform:translateY(-101%)}
.intro-logo{
  width:min(430px,74vw);height:auto;
  clip-path:inset(0 100% 0 0);
  animation:introDraw 1.5s .25s cubic-bezier(.65,0,.35,1) forwards;
}
.intro-line{
  color:var(--ink-soft);opacity:0;transform:translateY(14px);
  animation:introLine .8s 1.45s ease forwards;
  display:flex;align-items:center;gap:.9rem;
}
.intro-line i{font-style:normal;color:var(--rosso)}
.intro-line b{font-weight:600;color:var(--blu)}
.intro-bar{
  position:absolute;bottom:0;left:0;height:4px;width:100%;transform-origin:left;
  background:linear-gradient(90deg,var(--rosso) 0 50%,var(--azzurro) 50% 100%);
  transform:scaleX(0);animation:introBar 2.2s .15s cubic-bezier(.65,0,.35,1) forwards;
}
@keyframes introDraw{0%{clip-path:inset(0 100% 0 0)}100%{clip-path:inset(0 0 0 0)}}
@keyframes introLine{0%{opacity:0;transform:translateY(14px)}100%{opacity:1;transform:translateY(0)}}
@keyframes introBar{0%{transform:scaleX(0)}100%{transform:scaleX(1)}}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:120;
  background:color-mix(in srgb,var(--carta) 92%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1.5px solid rgba(38,22,10,.14);
  transition:box-shadow .3s;
}
.header.scrolled{box-shadow:0 10px 30px -16px rgba(38,22,10,.35)}
.header-in{
  max-width:1320px;margin:0 auto;padding:0 clamp(14px,3vw,34px);
  height:var(--header-h);display:flex;align-items:center;gap:1.2rem;
}
.brand{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.brand img{height:70px;width:auto;object-fit:contain}
.nav{display:flex;align-items:center;gap:1.5rem;margin-left:auto}
.nav a{
  text-decoration:none;font-weight:600;font-size:.94rem;color:var(--ink);
  position:relative;padding:.3rem 0;white-space:nowrap;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2.5px;width:0;
  background:linear-gradient(90deg,var(--rosso),var(--azzurro));border-radius:3px;transition:width .3s;
}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.header-cta{display:flex;align-items:center;gap:.7rem;margin-left:1.4rem}
.lang-btn{
  display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;
  font-family:var(--f-mono);font-weight:600;font-size:.78rem;letter-spacing:.08em;
  border:1.5px solid rgba(38,22,10,.35);border-radius:999px;padding:.5rem .95rem;
  background:transparent;color:var(--ink);transition:border-color .2s,background .2s;
  min-height:40px;
}
.lang-btn:hover{border-color:var(--ink);background:rgba(38,22,10,.05)}
.call-pill{
  display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;
  font-family:var(--f-mono);font-weight:600;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  background:var(--ink);color:var(--carta);border-radius:999px;padding:.62rem 1.15rem;
  transition:transform .25s,background .2s;min-height:40px;
}
.call-pill:hover{transform:translateY(-2px);background:var(--rosso)}
.burger{
  display:none;margin-left:auto;width:48px;height:48px;border:1.5px solid rgba(38,22,10,.35);
  border-radius:12px;background:transparent;cursor:pointer;position:relative;flex-shrink:0;
}
.burger span{position:absolute;left:12px;right:12px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s,top .3s}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:23px}
.burger span:nth-child(3){top:30px}
.burger.open span:nth-child(1){top:23px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:23px;transform:rotate(-45deg)}

/* drawer mobile */
.drawer{
  position:fixed;inset:0;z-index:110;background:var(--carta);
  display:flex;flex-direction:column;padding:calc(var(--header-h) + 22px) clamp(20px,6vw,40px) 40px;
  opacity:0;pointer-events:none;transition:opacity .35s;overflow-y:auto;
}
.drawer.show{opacity:1;pointer-events:auto}
.drawer a.dlink{
  font-family:var(--f-disp);font-size:clamp(1.7rem,6.5vw,2.4rem);text-decoration:none;color:var(--ink);
  padding:.85rem 0;border-bottom:1.5px dashed rgba(38,22,10,.2);
  display:flex;align-items:center;justify-content:space-between;
  opacity:0;transform:translateY(16px);transition:opacity .4s,transform .4s;
}
.drawer.show a.dlink{opacity:1;transform:none}
.drawer a.dlink small{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.2em;color:var(--rosso)}
.drawer-call{margin-top:1.8rem;display:grid;gap:.8rem}
.drawer-call .btn{width:100%}

/* ============================================================
   HERO SPLIT (home)
   ============================================================ */
.hero{padding:calc(var(--header-h) + clamp(40px,7vw,84px)) 0 clamp(56px,8vw,96px)}
.hero-top{text-align:center;max-width:840px;margin:0 auto clamp(34px,5vw,56px)}
.hero-top h1{font-size:clamp(2.35rem,5.6vw,4.15rem);margin:.9rem 0 1.1rem}
.hero-top h1 em{font-style:normal;color:var(--rosso)}
.hero-top h1 u{text-decoration:none;color:var(--blu)}
.hero-top .lead{margin-inline:auto}
.hero-badges{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-top:1.3rem}
.chip{
  font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  border:1.5px solid rgba(38,22,10,.3);border-radius:999px;padding:.42rem .9rem;color:var(--ink-soft);
  background:var(--carta-chiara);
}
.split{
  display:flex;gap:clamp(12px,1.6vw,20px);min-height:clamp(420px,58vh,560px);
  position:relative;
}
.pane{
  position:relative;flex:1;border-radius:26px;overflow:hidden;display:flex;
  align-items:flex-end;text-decoration:none;box-shadow:var(--shadow);
  transition:flex .55s cubic-bezier(.65,0,.35,1);will-change:flex;
}
@media(hover:hover){.split:has(.pane:hover) .pane{flex:.72}.split .pane:hover{flex:1.55}}
.pane img.ph{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 6s ease;transform:scale(1.06);
}
.pane:hover img.ph{transform:scale(1.13)}
.pane::after{content:"";position:absolute;inset:0}
.pane-piz::after{background:linear-gradient(12deg,rgba(78,10,6,.9) 0%,rgba(110,17,13,.55) 42%,rgba(148,25,19,.08) 75%)}
.pane-trat::after{background:linear-gradient(12deg,rgba(12,32,84,.9) 0%,rgba(30,66,154,.5) 45%,rgba(50,150,211,.08) 78%)}
.pane-in{position:relative;z-index:3;padding:clamp(20px,3.4vw,40px);color:#FFF8E7;width:100%}
.pane-in .mono{opacity:.92;display:block;margin-bottom:.45rem}
.pane-in h2{font-size:clamp(1.7rem,3.3vw,2.7rem);color:#FFFDF4;margin-bottom:.5rem}
.pane-in p{font-size:.98rem;line-height:1.55;max-width:44ch;opacity:.94;margin-bottom:1.1rem}
.pane-go{
  display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-mono);
  font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  border-bottom:2px solid rgba(255,248,231,.7);padding-bottom:.28rem;transition:gap .25s;
}
.pane:hover .pane-go{gap:1rem}
.pane-logo{
  position:absolute;top:clamp(14px,2.4vw,26px);left:clamp(14px,2.4vw,26px);z-index:3;
  background:rgba(255,253,246,.94);border-radius:16px;padding:.55rem .9rem;
  box-shadow:0 10px 26px -10px rgba(0,0,0,.35);
}
.pane-logo img{height:58px;width:auto}
.split-amp{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:5;
  width:64px;height:64px;border-radius:50%;background:var(--carta);color:var(--ink);
  display:flex;align-items:center;justify-content:center;font-family:var(--f-disp);
  font-size:1.7rem;box-shadow:0 12px 30px -8px rgba(38,22,10,.45);
  border:2px solid rgba(38,22,10,.12);pointer-events:none;
}

/* ============================================================
   MARQUEE
   ============================================================ */
.ribbon{overflow:clip;padding:.95rem 0;position:relative}
.ribbon-rosso{background:var(--rosso);color:#FDEFC9;transform:rotate(-1.1deg) scale(1.02)}
.ribbon-blu{background:var(--blu);color:#EAF4FF;transform:rotate(1.1deg) scale(1.02)}
.ribbon-track{
  display:flex;width:max-content;gap:0;
  animation:ribbonMove 30s linear infinite;
}
.ribbon:hover .ribbon-track{animation-play-state:paused}
.ribbon-half{display:flex;align-items:center;white-space:nowrap;font-family:var(--f-mono);font-weight:600;font-size:.8rem;letter-spacing:.24em;text-transform:uppercase}
.ribbon-half span{padding:0 1.5rem;display:inline-flex;align-items:center;gap:1.4rem}
.ribbon-half span::after{content:"✶";font-size:.9rem;opacity:.85}
@keyframes ribbonMove{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================================
   STORIA
   ============================================================ */
.storia{background:var(--carta-chiara);border-block:1.5px solid rgba(38,22,10,.12)}
.storia-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center}
.storia-txt .anno{
  font-family:var(--f-mono);font-weight:600;font-size:.78rem;letter-spacing:.2em;
  display:inline-flex;align-items:center;gap:.6rem;margin:1.25rem 0 .3rem;
}
.storia-txt .anno.a17{color:var(--rosso)}
.storia-txt .anno.a26{color:var(--blu)}
.storia-txt .anno::before{content:"";width:11px;height:11px;border-radius:50%;background:currentColor;flex-shrink:0}
.storia-txt p{margin-bottom:.9rem}
.storia-txt p.q{
  font-family:var(--f-disp);font-size:1.22rem;line-height:1.5;color:var(--ink);
  border-left:3px solid var(--arancio);padding-left:1.1rem;margin:1.3rem 0;
}
.storia-fig{position:relative}
.storia-fig .cornice{
  border-radius:24px;overflow:hidden;box-shadow:var(--shadow);
  aspect-ratio:3/4;position:relative;transform:rotate(1.6deg);
}
.storia-fig .cornice img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.storia-fig figcaption{
  position:absolute;bottom:-16px;left:-14px;background:var(--bianco);border-radius:14px;
  padding:.7rem 1.05rem;font-family:var(--f-mono);font-size:.68rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;color:var(--ink-soft);box-shadow:var(--shadow);
  transform:rotate(-2deg);max-width:86%;
}
.award-row{display:flex;gap:1rem;margin-top:2.1rem;flex-wrap:wrap}
.award{
  display:flex;align-items:center;gap:.8rem;background:var(--bianco);border:1.5px solid rgba(38,22,10,.12);
  border-radius:16px;padding:.75rem 1.1rem;box-shadow:0 10px 24px -14px rgba(38,22,10,.3);
}
.award b{font-size:.86rem;line-height:1.3;font-weight:700}
.award small{display:block;font-weight:400;color:var(--ink-soft);font-size:.78rem}
.award .medal{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--carta);font-size:1.15rem;flex-shrink:0}

/* ============================================================
   ICONICHE — tracklist + foto
   ============================================================ */
.iconiche-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:2.4rem}
.icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,24px)}
.disco{position:relative;text-decoration:none;color:var(--ink)}
.disco .sleeve{
  border-radius:20px;overflow:hidden;aspect-ratio:1/1;position:relative;
  box-shadow:var(--shadow);
}
.disco .sleeve img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.disco:hover .sleeve img{transform:scale(1.08) rotate(1.6deg)}
.disco .tno{
  position:absolute;top:12px;left:12px;z-index:2;background:var(--carta);border-radius:999px;
  font-family:var(--f-mono);font-weight:600;font-size:.7rem;letter-spacing:.12em;padding:.3rem .7rem;
  box-shadow:0 8px 18px -8px rgba(0,0,0,.4);
}
.disco .pr{
  position:absolute;top:12px;right:12px;z-index:2;background:var(--rosso);color:#FDEFC9;border-radius:999px;
  font-family:var(--f-mono);font-weight:600;font-size:.74rem;padding:.3rem .7rem;
}
.disco h3{font-size:1.18rem;margin:.95rem 0 .3rem}
.disco p{font-size:.88rem;color:var(--ink-soft);line-height:1.55}
.pino-note{
  margin-top:2.6rem;text-align:center;font-family:var(--f-disp);font-size:clamp(1.05rem,1.8vw,1.3rem);
  color:var(--ink-soft);
}
.pino-note b{color:var(--rosso);font-weight:400}

/* ============================================================
   METRO band
   ============================================================ */
.metro{background:var(--bruno);color:#F4E5BF;position:relative;overflow:clip}
.metro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.metro h2{color:#FBF0D2;font-size:clamp(2rem,4.4vw,3.2rem)}
.metro .lead{color:#D8C193}
.metro-fig{border-radius:22px;overflow:hidden;box-shadow:0 30px 70px -30px rgba(0,0,0,.7);aspect-ratio:4/5;position:relative}
.metro-fig img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.metro-prices{display:grid;gap:.55rem;margin:1.5rem 0 1.8rem}
.metro-prices .rowp{
  display:flex;align-items:baseline;gap:.8rem;font-size:.95rem;
}
.metro-prices .rowp .dots{flex:1;border-bottom:2px dotted rgba(244,229,191,.35);transform:translateY(-4px)}
.metro-prices .rowp b{font-family:var(--f-mono);font-weight:600;white-space:nowrap}

/* ============================================================
   PILASTRI
   ============================================================ */
.pilastri{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,28px);margin-top:2.6rem}
.pil{
  background:var(--bianco);border:1.5px solid rgba(38,22,10,.12);border-radius:22px;
  padding:clamp(22px,3vw,34px);position:relative;overflow:hidden;
  transition:transform .35s,box-shadow .35s;
}
.pil:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pil::before{content:"";position:absolute;top:0;left:0;right:0;height:5px}
.pil:nth-child(1)::before{background:var(--rosso)}
.pil:nth-child(2)::before{background:var(--arancio)}
.pil:nth-child(3)::before{background:var(--azzurro)}
.pil .pic{font-size:1.75rem;margin-bottom:.9rem;display:block}
.pil h3{font-size:1.28rem;margin-bottom:.55rem}
.pil p{font-size:.94rem;color:var(--ink-soft)}

/* ============================================================
   RECENSIONI marquee
   ============================================================ */
.rec{background:var(--carta-chiara);border-block:1.5px solid rgba(38,22,10,.12);overflow:clip}
.rec-head{margin-bottom:2.4rem}
.rec-strip{overflow:clip;margin-top:1rem;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.rec-track{display:flex;width:max-content;gap:clamp(14px,1.6vw,22px);animation:recMove 60s linear infinite;padding:.6rem 0 1.4rem}
.rec-strip:hover .rec-track{animation-play-state:paused}
@keyframes recMove{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.rcard{
  width:min(360px,82vw);flex-shrink:0;background:var(--bianco);border:1.5px solid rgba(38,22,10,.12);
  border-radius:20px;padding:1.5rem 1.6rem;box-shadow:0 14px 34px -20px rgba(38,22,10,.35);
  display:flex;flex-direction:column;gap:.8rem;
}
.rcard .stars{color:var(--arancio);letter-spacing:.18em;font-size:.92rem}
.rcard p{font-size:.92rem;line-height:1.6;color:var(--ink)}
.rcard .who{display:flex;align-items:center;gap:.75rem;margin-top:auto}
.rcard .who .av{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-mono);font-weight:600;font-size:.82rem;color:#FFF8E7;
}
.rcard .who b{font-size:.88rem;font-weight:700;display:block;line-height:1.25}
.rcard .who small{font-size:.74rem;color:var(--ink-soft)}
.rec-cta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-top:1.6rem}
.gstars{display:inline-flex;align-items:center;gap:.7rem;font-weight:700}
.gstars .val{font-family:var(--f-mono);font-size:1.6rem;font-weight:600}

/* ============================================================
   PAGINE LOCALE (pizzeria / trattoria)
   ============================================================ */
.loc-hero{
  position:relative;min-height:min(88vh,760px);display:flex;align-items:flex-end;
  padding:calc(var(--header-h) + 40px) 0 clamp(44px,6vw,72px);color:#FFF8E7;overflow:clip;
}
.loc-hero .bg{position:absolute;inset:0;z-index:0}
.loc-hero .bg img{width:100%;height:100%;object-fit:cover;animation:kb 16s ease-in-out infinite alternate;transform:scale(1.05)}
@keyframes kb{0%{transform:scale(1.05) translateY(0)}100%{transform:scale(1.14) translateY(-14px)}}
.loc-hero.rossa .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(8deg,rgba(52,7,4,.94) 8%,rgba(107,17,13,.62) 46%,rgba(52,7,4,.28) 100%)}
.loc-hero.blu .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(8deg,rgba(9,24,64,.94) 8%,rgba(30,66,154,.6) 46%,rgba(9,24,64,.28) 100%)}
.loc-hero .wrap{position:relative;z-index:2}
.loc-hero h1{font-size:clamp(2.4rem,6vw,4.3rem);color:#FFFDF4;max-width:14ch;margin:.9rem 0 1rem}
.loc-hero .lead{color:rgba(255,248,231,.9);max-width:56ch}
.loc-hero .mono{color:rgba(255,248,231,.85)}
.loc-hero .hero-ctas{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.7rem}
.loc-hero .badge-logo{
  background:rgba(255,253,246,.95);display:inline-flex;border-radius:18px;padding:.7rem 1.1rem;margin-bottom:1.4rem;
  box-shadow:0 14px 34px -14px rgba(0,0,0,.5);
}
.loc-hero .badge-logo img{height:64px;width:auto}
.rating-line{display:flex;align-items:center;gap:.8rem;margin-top:1.4rem;flex-wrap:wrap}
.rating-line .stars{color:#FFC94A;letter-spacing:.15em}
.rating-line b{font-family:var(--f-mono);font-weight:600}
.rating-line a{color:rgba(255,248,231,.85);font-size:.85rem}

.info-band{background:var(--bruno);color:#F4E5BF;padding:1.6rem 0}
.info-band .wrap{display:flex;gap:clamp(18px,4vw,54px);flex-wrap:wrap;align-items:center;justify-content:center}
.info-cell{display:flex;align-items:center;gap:.9rem}
.info-cell .ic{font-size:1.3rem}
.info-cell b{display:block;font-family:var(--f-mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:#CBB183;margin-bottom:.15rem}
.info-cell span{font-size:.92rem;font-weight:600}

/* ============================================================
   MENU tracklist
   ============================================================ */
.menu-hero{padding:calc(var(--header-h) + clamp(40px,6vw,70px)) 0 clamp(28px,4vw,44px)}
.menu-hero h1{font-size:clamp(2.3rem,5.4vw,3.8rem);margin:.8rem 0 .9rem}
.menu-sub{
  position:sticky;top:var(--header-h);z-index:60;background:color-mix(in srgb,var(--carta) 94%,transparent);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-block:1.5px solid rgba(38,22,10,.14);padding:.7rem 0;
}
.menu-sub .wrap{display:flex;gap:.55rem;overflow-x:auto;scrollbar-width:none}
.menu-sub .wrap::-webkit-scrollbar{display:none}
.mchip{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  border:1.5px solid rgba(38,22,10,.3);border-radius:999px;padding:.45rem 1rem;text-decoration:none;
  color:var(--ink-soft);white-space:nowrap;transition:background .2s,color .2s,border-color .2s;flex-shrink:0;
}
.mchip:hover,.mchip.on{background:var(--ink);color:var(--carta);border-color:var(--ink)}
.msec{padding:clamp(44px,6vw,72px) 0 0}
.msec:last-of-type{padding-bottom:clamp(56px,8vw,90px)}
.msec-head{display:flex;align-items:baseline;gap:1.2rem;margin-bottom:1.9rem;flex-wrap:wrap}
.msec-head .lato{font-family:var(--f-mono);font-weight:600;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;padding:.4rem .85rem;border-radius:999px}
.lato-r{background:var(--rosso);color:#FDEFC9}
.lato-b{background:var(--blu);color:#EAF4FF}
.lato-n{background:var(--bruno);color:#F4E5BF}
.msec-head h2{font-size:clamp(1.7rem,3.6vw,2.5rem)}
.msec-head .cnt{font-family:var(--f-mono);font-size:.76rem;color:var(--ink-soft);margin-left:auto}
.tracklist{display:grid;gap:0;border-top:1.5px solid rgba(38,22,10,.16)}
.trk{
  display:grid;grid-template-columns:52px 1fr auto;gap:.4rem 1.1rem;align-items:baseline;
  padding:1.05rem .4rem;border-bottom:1.5px solid rgba(38,22,10,.16);
  transition:background .2s;
}
.trk:hover{background:rgba(255,253,246,.75)}
.trk .n{font-family:var(--f-mono);font-size:.76rem;font-weight:600;color:var(--ink-soft)}
.trk h3{font-size:1.16rem;display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap}
.trk h3 .tag{
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;font-weight:600;text-transform:uppercase;
  background:var(--carta-scura);border-radius:6px;padding:.18rem .5rem;color:var(--ink-soft);
}
.trk p{grid-column:2;font-size:.88rem;color:var(--ink-soft);line-height:1.55;max-width:68ch}
.trk .pz{font-family:var(--f-mono);font-weight:600;font-size:.95rem;white-space:nowrap;text-align:right}
.trk .pz small{display:block;font-size:.68rem;color:var(--ink-soft);font-weight:400;letter-spacing:.04em}
.menu-note{
  margin-top:2.2rem;background:var(--carta-chiara);border:1.5px dashed rgba(38,22,10,.3);border-radius:16px;
  padding:1.1rem 1.4rem;font-size:.9rem;color:var(--ink-soft);display:flex;gap:.9rem;align-items:center;flex-wrap:wrap;
}
.menu-note b{color:var(--ink)}
.agg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.4rem 2rem}
.agg{display:flex;align-items:baseline;gap:.6rem;padding:.42rem 0;border-bottom:1px dotted rgba(38,22,10,.25);font-size:.9rem}
.agg .dots{flex:1;min-width:14px}
.agg b{font-family:var(--f-mono);font-weight:600;font-size:.82rem;white-space:nowrap}
.menu-dl{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.6rem}

/* ============================================================
   CONTATTI
   ============================================================ */
.due-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,3vw,34px);margin-top:2.5rem}
.loc-card{
  background:var(--bianco);border-radius:24px;overflow:hidden;border:1.5px solid rgba(38,22,10,.12);
  box-shadow:0 18px 44px -26px rgba(38,22,10,.4);display:flex;flex-direction:column;
}
.loc-card .head{padding:1.5rem 1.7rem;color:#FFF8E7;display:flex;align-items:center;gap:1rem;justify-content:space-between;flex-wrap:wrap}
.loc-card.rossa .head{background:linear-gradient(120deg,var(--rosso-scuro),var(--rosso))}
.loc-card.blu .head{background:linear-gradient(120deg,#14306E,var(--blu))}
.loc-card .head h3{color:#FFFDF4;font-size:1.4rem}
.loc-card .head .mono{font-size:.66rem;opacity:.9}
.loc-card .body{padding:1.6rem 1.7rem 1.8rem;display:grid;gap:1.15rem;flex:1}
.krow{display:grid;grid-template-columns:26px 1fr;gap:.9rem;align-items:start}
.krow .ic{font-size:1.05rem;line-height:1.6}
.krow b{display:block;font-family:var(--f-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--ink-soft);margin-bottom:.2rem}
.krow a{font-weight:700;text-decoration:none}
.krow a.tel{font-size:1.22rem;font-family:var(--f-mono);font-weight:600}
.krow a:hover{text-decoration:underline}
.krow p,.krow li{font-size:.93rem}
.krow ul{list-style:none}
.krow li{padding:.14rem 0}
.krow li b.g{display:inline;font-family:var(--f-body);font-size:.93rem;letter-spacing:0;text-transform:none;color:var(--ink);font-weight:700}
.loc-card .foot{padding:0 1.7rem 1.7rem;display:flex;gap:.8rem;flex-wrap:wrap}
.mappa-wrap{margin-top:clamp(40px,6vw,64px)}
.mappa-frame{
  border-radius:24px;overflow:hidden;border:1.5px solid rgba(38,22,10,.18);box-shadow:var(--shadow);
  aspect-ratio:16/8;min-height:340px;position:relative;background:var(--carta-chiara);
}
.mappa-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.mappa-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.2rem;align-items:center}
.come{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.4rem}
.come .cc{background:var(--carta-chiara);border:1.5px solid rgba(38,22,10,.12);border-radius:16px;padding:1rem 1.2rem;font-size:.9rem}
.come .cc b{display:block;font-family:var(--f-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.3rem}

/* FAQ */
.faq{max-width:820px;margin:2.4rem auto 0}
.faq details{
  background:var(--bianco);border:1.5px solid rgba(38,22,10,.14);border-radius:16px;
  margin-bottom:.85rem;overflow:hidden;
}
.faq summary{
  cursor:pointer;list-style:none;padding:1.15rem 1.4rem;font-weight:700;font-size:1rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:var(--f-mono);font-size:1.25rem;color:var(--rosso);
  transition:transform .3s;flex-shrink:0;line-height:1;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .fa{padding:0 1.4rem 1.25rem;color:var(--ink-soft);font-size:.95rem}

/* ============================================================
   CTA finale + FOOTER
   ============================================================ */
.finale{
  background:linear-gradient(115deg,var(--rosso-scuro) 0%,var(--rosso) 46%,var(--blu) 54%,#14306E 100%);
  color:#FFF8E7;text-align:center;
}
.finale h2{color:#FFFDF4;font-size:clamp(2rem,4.6vw,3.3rem);max-width:20ch;margin:.8rem auto 1rem}
.finale .lead{color:rgba(255,248,231,.92);margin-inline:auto}
.finale .mono{color:rgba(255,248,231,.85)}
.finale .ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}

.footer{background:var(--bruno);color:#E8D5AC;padding:clamp(52px,7vw,80px) 0 0}
.footer a{color:inherit}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:clamp(26px,4vw,48px)}
.foot-brand img{height:60px;width:auto;background:rgba(255,253,246,.96);border-radius:14px;padding:.5rem .8rem;box-shadow:0 10px 26px -12px rgba(0,0,0,.5)}
.foot-brand p{font-size:.9rem;color:#CBB183;margin-top:1.1rem;max-width:34ch}
.foot-col h4{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:#CBB183;margin-bottom:1.1rem}
.foot-col ul{list-style:none}
.foot-col li{padding:.28rem 0;font-size:.92rem}
.foot-col a{text-decoration:none}
.foot-col a:hover{text-decoration:underline}
.foot-col .tel-lab b{display:block;font-size:.72rem;font-family:var(--f-mono);letter-spacing:.14em;text-transform:uppercase;color:#CBB183;font-weight:600;margin-top:.6rem}
.foot-col .tel-lab a{font-family:var(--f-mono);font-weight:600;font-size:1.02rem}
.foot-bottom{
  margin-top:clamp(36px,5vw,56px);border-top:1px solid rgba(232,213,172,.2);
  padding:1.4rem 0 1.6rem;font-size:.78rem;color:#A8946E;
}
.foot-bottom .wrap{display:flex;gap:1rem;flex-wrap:wrap;justify-content:space-between;align-items:center}
.top-link{cursor:pointer;background:none;border:1.5px solid rgba(232,213,172,.35);color:#E8D5AC;border-radius:999px;padding:.5rem 1rem;font-family:var(--f-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.top-link:hover{background:rgba(232,213,172,.12)}

/* ============================================================
   LANG MODAL (Uniswap-style)
   ============================================================ */
.lang-overlay{
  position:fixed;inset:0;z-index:180;display:flex;align-items:center;justify-content:center;
  background:rgba(24,13,4,.45);backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);
  opacity:0;transition:opacity .3s,backdrop-filter .3s;padding:20px;
}
.lang-overlay.show{opacity:1;backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px)}
.lang-overlay:not(.show){pointer-events:none}
.lang-modal{
  width:min(430px,94vw);max-height:min(560px,86vh);background:var(--bianco);border-radius:24px;
  box-shadow:0 40px 90px -30px rgba(24,13,4,.5);display:flex;flex-direction:column;overflow:hidden;
  transform:scale(.92) translateY(16px);opacity:0;transition:transform .32s cubic-bezier(.2,.9,.3,1.2),opacity .28s;
  border:1.5px solid rgba(38,22,10,.1);
}
.lang-overlay.show .lang-modal{transform:scale(1) translateY(0);opacity:1}
.lang-head{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.4rem .9rem}
.lang-head h3{font-size:1.25rem}
.lang-x{
  width:38px;height:38px;border-radius:50%;border:1.5px solid rgba(38,22,10,.2);background:transparent;
  cursor:pointer;font-size:1.05rem;color:var(--ink);display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s;
}
.lang-x:hover{background:var(--carta);transform:rotate(90deg)}
.lang-search{padding:0 1.4rem .9rem}
.lang-search input{
  width:100%;border:1.5px solid rgba(38,22,10,.22);border-radius:14px;padding:.8rem 1.05rem;
  font-family:var(--f-body);font-size:.95rem;background:var(--carta-chiara);color:var(--ink);outline:none;
}
.lang-search input:focus{border-color:var(--blu)}
.lang-list{overflow-y:auto;padding:.3rem .7rem 1rem;flex:1}
.lang-item{
  width:100%;display:flex;align-items:center;gap:.95rem;padding:.8rem .8rem;border:0;background:transparent;
  border-radius:14px;cursor:pointer;font-family:var(--f-body);font-size:.98rem;color:var(--ink);text-align:left;
  transition:background .18s;
}
.lang-item:hover{background:var(--carta)}
.lang-item .fl{font-size:1.35rem;line-height:1;flex-shrink:0}
.lang-item .nm b{display:block;font-weight:700;line-height:1.25}
.lang-item .nm small{color:var(--ink-soft);font-size:.78rem}
.lang-item .ck{margin-left:auto;color:var(--blu);font-weight:800;opacity:0;font-size:1.05rem}
.lang-item.active .ck{opacity:1}
.lang-empty{padding:1.2rem;text-align:center;color:var(--ink-soft);font-size:.9rem}

/* ============================================================
   REVEAL
   ============================================================ */
.rv{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.3,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}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1080px){
  .nav{display:none}
  .header-cta .call-pill{display:none}
  .burger{display:block}
  .header-cta{margin-left:auto}
  .nav{margin-left:0}
}
@media(max-width:960px){
  .storia-grid,.metro-grid{grid-template-columns:1fr}
  .storia-fig{max-width:480px}
  .metro-fig{max-width:520px;margin-inline:auto}
  .icon-grid{grid-template-columns:repeat(2,1fr)}
  .pilastri{grid-template-columns:1fr}
  .due-col{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .come{grid-template-columns:1fr}
}
@media(max-width:760px){
  :root{--header-h:72px}
  .brand img{height:54px}
  .split{flex-direction:column;min-height:0}
  .pane{min-height:340px;flex:none}
  @media(hover:hover){.split:has(.pane:hover) .pane{flex:none}}
  .split-amp{width:54px;height:54px;font-size:1.4rem}
  .pane-logo img{height:46px}
  .trk{grid-template-columns:40px 1fr}
  .trk .pz{grid-column:2;text-align:left;margin-top:.15rem}
  .trk .pz small{display:inline;margin-left:.6rem}
  .agg-grid{grid-template-columns:1fr}
  .mappa-frame{aspect-ratio:4/5;min-height:400px}
}
@media(max-width:520px){
  body{font-size:15.5px}
  .icon-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .btn{width:100%}
  .hero-ctas .btn,.finale .ctas .btn,.menu-dl .btn,.rec-cta .btn{width:auto;flex:1 1 auto}
  .rcard{width:min(320px,86vw)}
  .intro-line{font-size:.62rem;letter-spacing:.16em}
}

/* ============================================================
   MOTION SAFETY
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .rv{opacity:1;transform:none}
  .loc-hero .bg img{animation:none}
  /* i nastri restano SEMPRE in movimento (regola K) */
  .ribbon-track{animation:ribbonMove 30s linear infinite!important}
  .rec-track{animation:recMove 60s linear infinite!important}
  #intro{display:none}
}
