/* ============================================================
   Pizzeria da Giuliano — Milano, dal 1969
   Stile: insegna milanese retrò "tovaglietta" · carta crema +
   rosso pomodoro + ocra mozzarella. Display Fraunces, etichette
   Bricolage Grotesque, testo Hanken Grotesk. Offline-first.
   ============================================================ */
@import url("fonts.css");

:root{
  --paper:#f4ecdc;        /* carta da pane */
  --paper-2:#ece0cb;      /* crema più calda */
  --paper-3:#e4d6bd;
  --ink:#241a12;          /* inchiostro caldo */
  --ink-soft:#5f5446;
  --red:#bf3026;          /* rosso insegna pomodoro */
  --red-deep:#8f2019;
  --gold:#d8982a;         /* ocra mozzarella/crosta */
  --gold-deep:#b87d18;
  --basil:#4d6a36;        /* verde basilico (accento minimo) */
  --char:#1d140e;         /* legno/notte calda */
  --char-2:#2a1d14;
  --cream-line:rgba(36,26,18,.16);
  --cream-line-2:rgba(36,26,18,.28);
  --shadow:0 18px 50px -22px rgba(40,22,10,.55);
  --shadow-sm:0 10px 26px -16px rgba(40,22,10,.5);
  --maxw:1200px;
  --header-h:76px;
  --r:14px;
  --ff-disp:"Fraunces",Georgia,"Times New Roman",serif;
  --ff-lab:"Bricolage Grotesque","Hanken Grotesk",system-ui,sans-serif;
  --ff-body:"Hanken Grotesk","PingFang SC","Hiragino Sans GB","Microsoft YaHei",system-ui,-apple-system,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  overflow-x:clip;
  scroll-padding-top:calc(var(--header-h) + 12px);
  scroll-behavior:auto;
}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--ff-body);
  font-size:clamp(16px,1.05vw + 13px,18px);
  line-height:1.62;
  overflow-x:clip;
  font-optical-sizing:auto;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-family:var(--ff-disp);font-weight:900;line-height:1.02;letter-spacing:-.015em;overflow-wrap:break-word}
h1,h2,h3,p,span,a,li,figcaption{overflow-wrap:break-word;word-break:normal}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}
[hidden]{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* paper grain background texture */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(120,80,40,.05) 1px,transparent 1px);
  background-size:5px 5px;
  mix-blend-mode:multiply;
}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,40px);position:relative;z-index:1}
.section{padding:clamp(54px,8vw,108px) 0;position:relative;z-index:1}
.eyebrow{
  font-family:var(--ff-lab);font-weight:700;text-transform:uppercase;
  letter-spacing:.24em;font-size:.74rem;color:var(--red);
  display:inline-flex;align-items:center;gap:.6em;margin:0 0 .9rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}
.title-xl{font-size:clamp(2.3rem,6.5vw,4.6rem)}
.title-lg{font-size:clamp(1.9rem,4.6vw,3.2rem)}
.lead{font-size:clamp(1.05rem,1.4vw,1.22rem);color:var(--ink-soft);max-width:60ch}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.accent{color:var(--red)}
.gold{color:var(--gold-deep)}

/* dotted "cut line" divider (taglio a spicchio) */
.cutline{height:0;border:0;border-top:2px dashed var(--cream-line-2);margin:0;position:relative}
.cutline::after{content:"✁";position:absolute;left:8%;top:-.85em;background:var(--paper);padding:0 .4em;color:var(--ink-soft);font-size:1.1rem}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--red);--fg:#fff7ef;
  display:inline-flex;align-items:center;gap:.55em;justify-content:center;
  font-family:var(--ff-lab);font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  font-size:.82rem;line-height:1;
  padding:.95em 1.5em;border-radius:999px;border:2px solid var(--bg);
  background:var(--bg);color:var(--fg);cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .2s,color .2s;
  box-shadow:var(--shadow-sm);
}
.btn:hover{transform:translateY(-3px);box-shadow:0 16px 30px -14px rgba(150,30,20,.6)}
.btn:active{transform:translateY(-1px)}
.btn.ghost{--bg:transparent;--fg:var(--ink);border-color:var(--cream-line-2);box-shadow:none}
.btn.ghost:hover{--fg:var(--red);border-color:var(--red)}
.btn.gold{--bg:var(--gold);--fg:#241a12}
.btn-row{display:flex;flex-wrap:wrap;gap:.8rem}
.btn-row.center{justify-content:center}

/* ---------- header / nav ---------- */
.site-head{
  position:fixed;top:0;left:0;right:0;z-index:80;
  height:var(--header-h);
  display:flex;align-items:center;
  background:rgba(244,236,220,.86);
  backdrop-filter:saturate(1.4) blur(12px);
  -webkit-backdrop-filter:saturate(1.4) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-head.scrolled{border-bottom-color:var(--cream-line);box-shadow:0 10px 30px -24px rgba(40,22,10,.7)}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,40px)}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand img{height:48px;width:auto;object-fit:contain}
.nav{display:flex;align-items:center;gap:clamp(.4rem,1.6vw,1.5rem)}
.nav a{
  font-family:var(--ff-lab);font-weight:600;font-size:.86rem;letter-spacing:.02em;
  color:var(--ink);padding:.4rem .2rem;position:relative;white-space:nowrap;
}
.nav a::after{content:"";position:absolute;left:.2rem;right:.2rem;bottom:-2px;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.nav a:hover::after,.nav a[aria-current="page"]::after{transform:scaleX(1)}
.nav a[aria-current="page"]{color:var(--red)}
.head-actions{display:flex;align-items:center;gap:.6rem}

/* language button */
.lang-btn{
  display:inline-flex;align-items:center;gap:.45em;
  font-family:var(--ff-lab);font-weight:600;font-size:.82rem;
  padding:.5em .8em;border-radius:999px;border:1.5px solid var(--cream-line-2);
  background:transparent;color:var(--ink);cursor:pointer;transition:border-color .2s,color .2s,background .2s}
.lang-btn:hover{border-color:var(--red);color:var(--red)}
.lang-btn svg{width:16px;height:16px}
.lang-btn .lcode{text-transform:uppercase;letter-spacing:.05em}

.head-cta{display:inline-flex}

/* hamburger */
.burger{display:none;width:46px;height:46px;border:1.5px solid var(--cream-line-2);border-radius:12px;background:transparent;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{display:block;width:22px;height:2px;background:var(--ink);transition:transform .3s,opacity .2s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav drawer */
.mnav{position:fixed;inset:0;z-index:79;background:rgba(29,20,14,.4);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s}
.mnav.show{opacity:1;pointer-events:auto}
.mnav-panel{position:absolute;top:0;right:0;height:100%;width:min(82vw,360px);background:var(--paper);box-shadow:var(--shadow);transform:translateX(100%);transition:transform .38s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;padding:calc(var(--header-h) + 14px) 28px 28px}
.mnav.show .mnav-panel{transform:none}
.mnav-panel a{font-family:var(--ff-disp);font-weight:600;font-size:1.5rem;padding:.7rem 0;border-bottom:1px solid var(--cream-line);color:var(--ink)}
.mnav-panel a:hover{color:var(--red)}
.mnav-panel .btn{margin-top:1.4rem}

/* ---------- intro / preloader ---------- */
.intro{position:fixed;inset:0;z-index:200;background:radial-gradient(120% 120% at 50% 30%,#2a1d12 0%,var(--char) 60%,#140d08 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;overflow:hidden}
.intro-logo{height:172px;width:auto;max-width:78vw;object-fit:contain;opacity:0;transform:translateY(14px) scale(.96);animation:introLogo 1s .25s cubic-bezier(.2,.8,.2,1) forwards}
.intro-tag{font-family:var(--ff-lab);text-transform:uppercase;letter-spacing:.4em;font-size:.72rem;color:#e9cd9a;opacity:0;animation:introTag .7s 1s ease forwards}
.intro-bar{width:min(260px,60vw);height:3px;border-radius:3px;background:rgba(233,205,154,.18);overflow:hidden;opacity:0;animation:introTag .5s .9s ease forwards}
.intro-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--red));animation:introFill 1.5s .55s cubic-bezier(.4,0,.2,1) forwards}
@keyframes introLogo{to{opacity:1;transform:none}}
@keyframes introTag{to{opacity:1}}
@keyframes introFill{to{width:100%}}
.intro.hide{animation:introOut .8s .1s cubic-bezier(.7,0,.3,1) forwards}
@keyframes introOut{to{clip-path:inset(0 0 100% 0);opacity:0;visibility:hidden}}

/* steam (used in intro + hero) */
.steam{position:absolute;pointer-events:none}
.steam span{position:absolute;bottom:0;width:10px;height:46px;border-radius:50%;background:radial-gradient(circle at 50% 100%,rgba(255,250,240,.5),rgba(255,250,240,0) 70%);filter:blur(3px);opacity:0;animation:steam 3.4s ease-in-out infinite}
@keyframes steam{0%{opacity:0;transform:translateY(8px) scale(.7)}25%{opacity:.7}100%{opacity:0;transform:translateY(-60px) scale(1.5)}}

/* ---------- hero ---------- */
.hero{position:relative;padding-top:calc(var(--header-h) + clamp(28px,5vw,60px));padding-bottom:clamp(36px,6vw,72px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,56px);align-items:center}
.hero-copy{position:relative;z-index:2}
.hero h1{font-size:clamp(2.6rem,7.4vw,5.6rem);line-height:.96}
.hero h1 .since{display:block;font-family:var(--ff-lab);font-weight:700;font-size:clamp(.7rem,1.6vw,.92rem);letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:.7rem}
.hero h1 em{font-style:italic;color:var(--red);font-weight:600}
.hero .lead{margin-top:1.3rem}
.hero .btn-row{margin-top:1.8rem}
.hero-facts{display:flex;flex-wrap:wrap;gap:1.6rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--cream-line)}
.fact{display:flex;flex-direction:column;line-height:1.1}
.fact b{font-family:var(--ff-disp);font-weight:900;font-size:1.9rem;color:var(--red)}
.fact span{font-family:var(--ff-lab);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);margin-top:.25rem}

.hero-media{position:relative}
.hero-photo{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transform:rotate(-2deg);border:8px solid #fff}
.hero-photo::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 60px rgba(40,20,8,.25)}
.hero-photo img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/9}
.hero-stamp{position:absolute;z-index:3;right:-10px;bottom:-18px;width:clamp(96px,15vw,134px);height:clamp(96px,15vw,134px);border-radius:50%;background:var(--red);color:#fff3e6;display:grid;place-items:center;text-align:center;transform:rotate(8deg);box-shadow:var(--shadow);border:2px dashed rgba(255,240,220,.5)}
.hero-stamp b{font-family:var(--ff-disp);font-weight:900;font-size:1.5rem;line-height:.9}
.hero-stamp span{font-family:var(--ff-lab);font-size:.56rem;text-transform:uppercase;letter-spacing:.18em;display:block;margin-top:.2rem}

/* marquee ribbon */
.ribbon{background:var(--red);color:#fbe7cf;overflow:hidden;border-top:2px solid var(--red-deep);border-bottom:2px solid var(--red-deep);padding:.7rem 0}
.ribbon .marquee-track{display:flex;width:max-content;animation:marq 38s linear infinite}
.ribbon:hover .marquee-track{animation-play-state:paused}
.ribbon .it{font-family:var(--ff-disp);font-style:italic;font-weight:600;font-size:1.2rem;padding:0 1.4rem;white-space:nowrap;display:inline-flex;align-items:center;gap:1.4rem}
.ribbon .it::after{content:"●";color:var(--gold);font-size:.7rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- generic media cell (riempie sempre la cella) ---------- */
.media{position:relative;border-radius:var(--r);overflow:hidden;background:var(--paper-3)}
.media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ---------- highlights grid ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px);margin-top:2.4rem}
.feat{background:var(--paper-2);border:1px solid var(--cream-line);border-radius:var(--r);padding:1.6rem;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.feat:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
.feat .ic{width:46px;height:46px;border-radius:12px;background:var(--red);color:#fff3e6;display:grid;place-items:center;margin-bottom:1rem}
.feat .ic svg{width:24px;height:24px}
.feat h3{font-size:1.3rem;margin-bottom:.5rem}
.feat p{color:var(--ink-soft);margin:0;font-size:.98rem}

/* ---------- split (storia teaser) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,60px);align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative}
.split-media .media{aspect-ratio:4/5;box-shadow:var(--shadow);border:7px solid #fff}
.split-media.tall .media{aspect-ratio:3/4}

/* ---------- menu (tovaglietta) ---------- */
.placemat{background:var(--paper);border:2px solid var(--ink);border-radius:6px;padding:clamp(22px,4vw,46px);box-shadow:var(--shadow);position:relative}
.placemat::before{content:"";position:absolute;inset:9px;border:1px solid var(--cream-line-2);border-radius:3px;pointer-events:none}
.menu-tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2.2rem}
.menu-tab{font-family:var(--ff-lab);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;padding:.6em 1.05em;border-radius:999px;border:1.5px solid var(--cream-line-2);background:transparent;color:var(--ink);cursor:pointer;transition:all .2s}
.menu-tab:hover{border-color:var(--red);color:var(--red)}
.menu-tab.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.menu-panel{display:none;animation:fadeUp .5s ease}
.menu-panel.active{display:block}
.menu-cat{margin-bottom:2.2rem}
.menu-cat:last-child{margin-bottom:0}
.menu-cat h3{font-size:1.55rem;color:var(--red);margin-bottom:.3rem;display:flex;align-items:baseline;gap:.6rem}
.menu-cat h3 small{font-family:var(--ff-lab);font-weight:600;font-size:.66rem;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-soft)}
.menu-cat .cat-note{font-size:.9rem;color:var(--ink-soft);margin:0 0 1rem}
.menu-item{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:.4rem;padding:.5rem 0;border-bottom:1px dotted var(--cream-line-2)}
.menu-item:last-child{border-bottom:0}
.mi-main{display:flex;flex-direction:column}
.mi-name{font-family:var(--ff-disp);font-weight:600;font-size:1.12rem}
.mi-desc{font-size:.86rem;color:var(--ink-soft);line-height:1.4}
.mi-price{font-family:var(--ff-lab);font-weight:700;color:var(--red);white-space:nowrap;font-size:1rem}
.mi-price .ind{font-weight:400;color:var(--ink-soft);font-size:.78rem}
.menu-foot{margin-top:1.8rem;padding-top:1.2rem;border-top:1px solid var(--cream-line);font-size:.86rem;color:var(--ink-soft);text-align:center}

/* ---------- reviews marquee ---------- */
.rev-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1.2rem;margin-bottom:2rem}
.rev-agg{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.rev-score{font-family:var(--ff-disp);font-weight:900;font-size:3.2rem;color:var(--red);line-height:1}
.rev-stars{color:var(--gold);font-size:1.1rem;letter-spacing:.05em}
.rev-meta{font-size:.86rem;color:var(--ink-soft)}
.revmarq{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.revmarq .marquee-track{display:flex;width:max-content;gap:1.2rem;animation:marq 60s linear infinite}
.revmarq:hover .marquee-track{animation-play-state:paused}
.rev-card{width:clamp(280px,80vw,360px);flex:0 0 auto;background:var(--paper-2);border:1px solid var(--cream-line);border-radius:var(--r);padding:1.5rem;display:flex;flex-direction:column;gap:.7rem}
.rev-card .rc-stars{color:var(--gold)}
.rev-card p{margin:0;font-size:.96rem;color:var(--ink);font-style:italic}
.rev-card .rc-by{font-family:var(--ff-lab);font-weight:600;font-size:.8rem;color:var(--ink-soft);display:flex;align-items:center;gap:.5rem;margin-top:auto}
.rev-card .rc-by .dot{width:6px;height:6px;border-radius:50%;background:var(--red)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--cream-line)}
.faq-q{width:100%;text-align:left;background:transparent;border:0;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 0;font-family:var(--ff-disp);font-weight:600;font-size:1.18rem;color:var(--ink)}
.faq-q:hover{color:var(--red)}
.faq-q .pm{flex:0 0 auto;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--cream-line-2);display:grid;place-items:center;transition:transform .3s,background .2s,color .2s}
.faq-q[aria-expanded="true"] .pm{background:var(--red);color:#fff;border-color:var(--red);transform:rotate(135deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding:0 0 1.3rem;color:var(--ink-soft)}
.faq-a-inner p{margin:0}

/* ---------- contatti ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,48px);align-items:start}
.contact-cards{display:flex;flex-direction:column;gap:1rem}
.ccard{display:flex;gap:1rem;align-items:flex-start;background:var(--paper-2);border:1px solid var(--cream-line);border-radius:var(--r);padding:1.2rem 1.3rem}
.ccard .ic{flex:0 0 auto;width:42px;height:42px;border-radius:11px;background:var(--red);color:#fff3e6;display:grid;place-items:center}
.ccard .ic svg{width:21px;height:21px}
.ccard h3{font-family:var(--ff-lab);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--ink-soft);margin-bottom:.2rem}
.ccard p{margin:0;font-size:1.02rem}
.ccard a{color:var(--ink);border-bottom:1px solid transparent;transition:border-color .2s,color .2s}
.ccard a:hover{color:var(--red);border-color:var(--red)}
.ccard .sub{font-size:.84rem;color:var(--ink-soft)}
.map-wrap{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:7px solid #fff;min-height:340px;background:var(--paper-3)}
.map-wrap iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:saturate(.95)}

.hours-table{width:100%;border-collapse:collapse;margin-top:.4rem}
.hours-table td{padding:.4rem 0;border-bottom:1px dotted var(--cream-line-2);font-size:.96rem}
.hours-table td:last-child{text-align:right;font-family:var(--ff-lab);font-weight:600}
.hours-table tr.closed td{color:var(--ink-soft)}
.hours-table tr.today td{color:var(--red);font-weight:700}

/* ---------- page hero (sottopagine) ---------- */
.page-hero{padding-top:calc(var(--header-h) + clamp(40px,7vw,84px));padding-bottom:clamp(28px,4vw,52px);text-align:center;position:relative}
.crumb{font-family:var(--ff-lab);font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);margin-bottom:1rem}
.crumb a:hover{color:var(--red)}

/* ---------- footer ---------- */
.site-foot{background:var(--char);color:#e7d8c3;padding:clamp(46px,6vw,76px) 0 1.6rem;position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
.foot-brand img{height:60px;width:auto;margin-bottom:1.1rem}
.foot-brand p{color:#bcab93;font-size:.95rem;max-width:38ch}
.foot-col h4{font-family:var(--ff-lab);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--gold);margin-bottom:1rem}
.foot-col a,.foot-col p{display:block;color:#d7c7b0;font-size:.95rem;padding:.22rem 0;margin:0}
.foot-col a:hover{color:#fff}
.foot-social{display:flex;gap:.7rem;margin-top:1rem}
.foot-social a{width:40px;height:40px;border-radius:11px;border:1px solid rgba(231,216,195,.2);display:grid;place-items:center;color:#e7d8c3;transition:background .2s,color .2s,border-color .2s}
.foot-social a:hover{background:var(--red);border-color:var(--red);color:#fff}
.foot-social svg{width:19px;height:19px}
.foot-bottom{margin-top:clamp(34px,5vw,56px);padding-top:1.4rem;border-top:1px solid rgba(231,216,195,.16);display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;align-items:center;font-size:.82rem;color:#a8987f}
.foot-bottom a:hover{color:#fff}

/* whatsapp / call FAB */
.fab{position:fixed;right:18px;bottom:18px;z-index:70;display:flex;flex-direction:column;gap:.7rem}
.fab a{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow);color:#fff;transition:transform .25s}
.fab a:hover{transform:scale(1.08)}
.fab .wa{background:#1faa55}
.fab .tel{background:var(--red)}
.fab svg{width:26px;height:26px}

/* ---------- language overlay (Uniswap-style) ---------- */
.lang-overlay{position:fixed;inset:0;z-index:210;display:flex;align-items:center;justify-content:center;padding:18px}
.lang-overlay .lo-back{position:absolute;inset:0;background:rgba(20,12,6,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity .3s}
.lang-overlay.show .lo-back{opacity:1}
.lo-panel{position:relative;width:min(440px,94vw);max-height:min(76vh,620px);background:var(--paper);border-radius:20px;box-shadow:0 40px 90px -30px rgba(20,10,4,.7);border:1px solid var(--cream-line);display:flex;flex-direction:column;overflow:hidden;transform:scale(.92) translateY(10px);opacity:0;transition:transform .34s cubic-bezier(.2,.9,.2,1),opacity .26s}
.lang-overlay.show .lo-panel{transform:none;opacity:1}
.lo-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.3rem .7rem}
.lo-head h3{font-size:1.3rem}
.lo-close{width:36px;height:36px;border-radius:50%;border:1px solid var(--cream-line-2);background:transparent;cursor:pointer;display:grid;place-items:center;color:var(--ink);font-size:1.1rem;transition:background .2s,color .2s}
.lo-close:hover{background:var(--red);color:#fff;border-color:var(--red)}
.lo-search{padding:0 1.3rem .8rem}
.lo-search input{width:100%;padding:.75em 1em;border-radius:12px;border:1.5px solid var(--cream-line-2);background:var(--paper-2);font-family:var(--ff-body);font-size:1rem;color:var(--ink)}
.lo-search input:focus{outline:none;border-color:var(--red)}
.lo-list{overflow-y:auto;padding:0 .7rem 1rem;display:flex;flex-direction:column;gap:2px}
.lo-opt{display:flex;align-items:center;gap:.8rem;width:100%;text-align:left;background:transparent;border:0;cursor:pointer;padding:.7em .9em;border-radius:12px;font-family:var(--ff-body);font-size:1rem;color:var(--ink);transition:background .15s}
.lo-opt:hover{background:var(--paper-2)}
.lo-opt .flag{font-size:1.3rem;line-height:1;width:1.5em;text-align:center}
.lo-opt .lname{flex:1}
.lo-opt .lnat{color:var(--ink-soft);font-size:.84rem}
.lo-opt .chk{color:var(--red);opacity:0}
.lo-opt[aria-selected="true"]{background:var(--paper-2)}
.lo-opt[aria-selected="true"] .chk{opacity:1}
.lo-empty{padding:1.4rem;text-align:center;color:var(--ink-soft);font-size:.92rem}

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

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .nav,.head-cta{display:none}
  .burger{display:flex}
}
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .hero-media{order:-1;max-width:520px}
  .split{grid-template-columns:1fr;gap:30px}
  .split.rev .split-media{order:-1}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:680px){
  .feat-grid{grid-template-columns:1fr}
  .hero-facts{gap:1.1rem}
  .fact b{font-size:1.6rem}
  .rev-head{flex-direction:column;align-items:flex-start}
  .foot-grid{grid-template-columns:1fr}
  .menu-item{grid-template-columns:1fr;gap:.1rem}
  .mi-price{margin-top:.1rem}
}
@media(max-width:400px){
  :root{--header-h:66px}
  .brand img{height:40px}
  .hero h1{font-size:2.3rem}
  .btn{width:100%}
  .btn-row .btn{flex:1 1 auto}
  .fab a{width:48px;height:48px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-delay:0ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  .intro-logo{opacity:1;transform:none}
  /* i nastri restano sempre in movimento (richiesta esplicita) */
  .ribbon .marquee-track{animation:marq 38s linear infinite!important}
  .revmarq .marquee-track{animation:marq 60s linear infinite!important}
  .steam span{animation:steam 3.4s ease-in-out infinite!important}
}
