/* ==========================================================================
   Osteria del Centenate — heritage editoriale "almanacco d'osteria"
   Carta avorio invecchiata · bordeaux vino · verde bottiglia · ottone
   ========================================================================== */

/* ---- Fonts (self-hosted, offline-first) --------------------------------- */
@font-face{font-family:'Fraunces';src:url('fonts/fraunces-300700-normal.woff2') format('woff2');
  font-weight:300 700;font-style:normal;font-display:swap;}
@font-face{font-family:'Fraunces';src:url('fonts/fraunces-300700-italic.woff2') format('woff2');
  font-weight:300 700;font-style:italic;font-display:swap;}
@font-face{font-family:'Spectral';src:url('fonts/spectral-400-normal.woff2') format('woff2');
  font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Spectral';src:url('fonts/spectral-400-italic.woff2') format('woff2');
  font-weight:400;font-style:italic;font-display:swap;}
@font-face{font-family:'Spectral';src:url('fonts/spectral-500-normal.woff2') format('woff2');
  font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'Spectral';src:url('fonts/spectral-600-normal.woff2') format('woff2');
  font-weight:600;font-style:normal;font-display:swap;}

/* ---- Tokens ------------------------------------------------------------- */
:root{
  --paper:#f2ebdc;         /* aged cream paper */
  --paper-2:#ece3cf;        /* deeper cream */
  --paper-3:#e5d9be;        /* card wash */
  --ink:#2a2018;            /* sepia-black text */
  --ink-soft:#6a5b49;       /* muted */
  --ink-faint:#8b7a63;
  --wine:#6f1d26;           /* bordeaux primary */
  --wine-deep:#521720;
  --wine-bright:#8a2531;
  --bottle:#31432f;         /* bottle green secondary */
  --bottle-deep:#20301f;
  --gold:#a9853b;           /* brass tertiary */
  --gold-soft:#c2a15f;
  --line:rgba(42,32,24,.16);
  --line-strong:rgba(42,32,24,.30);
  --shadow:0 18px 40px -24px rgba(42,32,24,.55);
  --shadow-sm:0 8px 22px -16px rgba(42,32,24,.5);
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --body:'Spectral',Georgia,'Times New Roman',serif;
  --maxw:1180px;
  --head-h:76px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---- Reset / base ------------------------------------------------------- */
*{margin:0;padding:0;box-sizing:border-box}
html{
  overflow-x:clip;
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--head-h) + 12px);
  -webkit-text-size-adjust:100%;
}
body{
  overflow-x:clip;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.62;
  font-size:clamp(16px,1.05vw,17.5px);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
}
/* paper grain */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.28'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{
  font-family:var(--serif);font-weight:600;line-height:1.06;
  font-variation-settings:"SOFT" 30,"WONK" 0,"opsz" 90;
  letter-spacing:-.01em;overflow-wrap:break-word;
}
h1,h2,h3,h4,p,span,a,li,figcaption,dd,dt{overflow-wrap:break-word}
p{color:var(--ink)}
::selection{background:var(--wine);color:#f7efdc}
:focus-visible{outline:2.5px solid var(--wine);outline-offset:3px;border-radius:3px}

/* ---- Layout helpers ----------------------------------------------------- */
.wrap{width:min(92%,var(--maxw));margin-inline:auto;position:relative;z-index:1}
.section{padding:clamp(64px,9vw,120px) 0;position:relative;z-index:1}
.section--tight{padding:clamp(44px,6vw,72px) 0}
.center{text-align:center}
.eyebrow{
  font-family:var(--body);font-weight:600;text-transform:uppercase;
  letter-spacing:.34em;font-size:.72rem;color:var(--wine);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before,.eyebrow.two::after{content:"";width:26px;height:1px;background:var(--gold)}
.eyebrow--gold{color:var(--gold)}
.title{
  font-size:clamp(2rem,5.2vw,3.7rem);margin:.32em 0 .5em;
  font-variation-settings:"SOFT" 40,"WONK" 0,"opsz" 130;
}
.title em{font-style:italic;color:var(--wine)}
.lead{font-size:clamp(1.06rem,1.5vw,1.24rem);color:var(--ink-soft);max-width:60ch}
.center .lead{margin-inline:auto}
.ornament{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--gold);margin:0 auto}
.ornament::before,.ornament::after{content:"";height:1px;width:min(90px,18vw);background:linear-gradient(90deg,transparent,var(--gold-soft))}
.ornament::after{background:linear-gradient(90deg,var(--gold-soft),transparent)}
.ornament svg{width:26px;height:26px;flex:none}

/* ---- Buttons ------------------------------------------------------------ */
.btn{
  --bg:var(--wine);--fg:#f6edd8;
  display:inline-flex;align-items:center;gap:.55em;justify-content:center;
  font-family:var(--body);font-weight:600;font-size:.98rem;letter-spacing:.02em;
  padding:.86em 1.6em;border-radius:2px;cursor:pointer;border:1px solid transparent;
  background:var(--bg);color:var(--fg);transition:transform .3s var(--ease),box-shadow .3s,background .3s;
  box-shadow:var(--shadow-sm);position:relative;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line-strong);box-shadow:none}
.btn--ghost:hover{background:var(--ink);--fg:var(--paper);border-color:var(--ink)}
.btn--gold{--bg:var(--gold);--fg:#241a0a}
.btn--sm{padding:.6em 1.05em;font-size:.86rem}
.btn svg{width:1.05em;height:1.05em}

/* ---- Header ------------------------------------------------------------- */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:60;height:var(--head-h);
  display:flex;align-items:center;
  background:rgba(242,235,220,.82);backdrop-filter:blur(12px) saturate(1.1);
  border-bottom:1px solid transparent;transition:border-color .4s,background .4s,box-shadow .4s;
}
.hdr.scrolled{border-color:var(--line);box-shadow:0 6px 24px -22px rgba(42,32,24,.9);background:rgba(242,235,220,.94)}
.hdr__in{display:flex;align-items:center;justify-content:space-between;gap:18px;width:min(94%,1260px);margin-inline:auto}
.brand{display:flex;align-items:center;gap:12px;flex:none}
.brand img{height:56px;width:auto;object-fit:contain;filter:drop-shadow(0 1px 0 rgba(255,255,255,.4))}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__txt b{font-family:var(--serif);font-weight:600;font-size:1.06rem;font-variation-settings:"SOFT" 40;letter-spacing:.01em}
.brand__txt span{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--wine);margin-top:3px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  font-family:var(--body);font-weight:500;font-size:.96rem;color:var(--ink);
  padding:.5em .8em;border-radius:2px;position:relative;transition:color .25s;
}
.nav a::after{content:"";position:absolute;left:.8em;right:.8em;bottom:.28em;height:1.5px;background:var(--wine);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav a:hover::after,.nav a[aria-current="page"]::after{transform:scaleX(1)}
.nav a[aria-current="page"]{color:var(--wine)}
.hdr__actions{display:flex;align-items:center;gap:10px;flex:none}

/* language button */
.lang-btn{
  display:inline-flex;align-items:center;gap:.45em;background:transparent;border:1px solid var(--line-strong);
  color:var(--ink);font-family:var(--body);font-weight:500;font-size:.88rem;
  padding:.5em .8em;border-radius:2px;cursor:pointer;transition:background .25s,border-color .25s;
}
.lang-btn:hover{background:rgba(111,29,38,.08);border-color:var(--wine)}
.lang-btn svg{width:1.05em;height:1.05em}
.lang-btn .cur{text-transform:uppercase;letter-spacing:.06em}

/* hamburger */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;flex:none}
.burger span{width:24px;height:2px;background:var(--ink);transition:transform .35s var(--ease),opacity .3s}
.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 drawer */
.drawer{
  position:fixed;inset:0;z-index:55;background:linear-gradient(160deg,var(--paper),var(--paper-2));
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  transform:translateY(-100%);transition:transform .5s var(--ease);
}
.drawer.open{transform:translateY(0)}
.drawer a{font-family:var(--serif);font-size:1.8rem;font-weight:500;padding:.35em;color:var(--ink);opacity:0;transform:translateY(14px);transition:opacity .4s,transform .4s,color .25s}
.drawer.open a{opacity:1;transform:none}
.drawer a:hover{color:var(--wine)}
.drawer.open a:nth-child(1){transition-delay:.08s}
.drawer.open a:nth-child(2){transition-delay:.14s}
.drawer.open a:nth-child(3){transition-delay:.20s}
.drawer.open a:nth-child(4){transition-delay:.26s}
.drawer.open a:nth-child(5){transition-delay:.32s}
.drawer.open a:nth-child(6){transition-delay:.38s}
.drawer__deco{margin-top:26px;color:var(--gold)}

/* ---- Intro / macchina del tempo ---------------------------------------- */
.intro{position:fixed;inset:0;z-index:120;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:radial-gradient(120% 100% at 50% 20%,#f6efe0,#e7dcc3 70%,#ded0b2);overflow:hidden}
.intro[hidden]{display:none!important}
.intro::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");mix-blend-mode:multiply;opacity:.5}
.intro__clock{position:relative;width:min(240px,52vw);aspect-ratio:1;margin-bottom:14px}
.intro__clock svg{width:100%;height:100%;overflow:visible}
.intro__logo{width:min(300px,68vw);opacity:0;transform:scale(.9);filter:drop-shadow(0 6px 14px rgba(42,32,24,.25))}
.intro__tag{font-family:var(--body);text-transform:uppercase;letter-spacing:.4em;font-size:.72rem;color:var(--wine);margin-top:18px;opacity:0}
.intro__years{font-family:var(--serif);font-style:italic;color:var(--ink-soft);font-size:.98rem;margin-top:6px;opacity:0}
.intro.play .intro__logo{animation:logoReveal 1.5s .5s var(--ease) forwards}
.intro.play .intro__tag{animation:fadeUp .8s 1.5s var(--ease) forwards}
.intro.play .intro__years{animation:fadeUp .8s 1.7s var(--ease) forwards}
.intro.leaving{animation:introWipe 1s var(--ease) forwards}
@keyframes logoReveal{0%{opacity:0;transform:scale(.9)}60%{opacity:1}100%{opacity:1;transform:scale(1)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes introWipe{to{clip-path:inset(0 0 100% 0);opacity:1}}
.hand{transform-origin:100px 100px}
.intro.play .hand-h{animation:spinBack 3s var(--ease) forwards}
.intro.play .hand-m{animation:spinBackM 3s var(--ease) forwards}
@keyframes spinBack{from{transform:rotate(220deg)}to{transform:rotate(-140deg)}}
@keyframes spinBackM{from{transform:rotate(560deg)}to{transform:rotate(-220deg)}}

/* ---- Hero --------------------------------------------------------------- */
.hero{position:relative;padding-top:calc(var(--head-h) + clamp(30px,6vw,66px));padding-bottom:clamp(50px,8vw,96px);overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.hero__kicker{margin-bottom:14px}
.hero h1{font-size:clamp(2.7rem,7.6vw,5.6rem);line-height:.98;margin:.06em 0 .34em;font-variation-settings:"SOFT" 50,"opsz" 144,"WONK" 1}
.hero h1 .l1{display:block;color:var(--ink)}
.hero h1 .l2{display:block;font-style:italic;color:var(--wine);font-weight:500}
.hero__sub{font-size:clamp(1.08rem,1.6vw,1.32rem);color:var(--ink-soft);max-width:44ch;margin-bottom:12px}
.hero__meta{display:flex;flex-wrap:wrap;gap:8px 20px;margin:20px 0 26px;font-size:.9rem;color:var(--ink-soft)}
.hero__meta b{color:var(--wine);font-weight:600}
.hero__meta span{display:inline-flex;align-items:center;gap:.5em}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px}
.hero__figure{position:relative}
.hero__figure .frame{
  position:relative;border-radius:3px;overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--line-strong);transform:rotate(-1.4deg);
}
.hero__figure .frame::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 8px rgba(242,235,220,.9),inset 0 0 0 9px var(--line);pointer-events:none}
.hero__figure img{width:100%;height:clamp(340px,52vw,560px);object-fit:cover;display:block}
.hero__stamp{
  position:absolute;bottom:-22px;left:-22px;width:120px;height:120px;border-radius:50%;
  background:var(--wine);color:#f2e6cf;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;box-shadow:var(--shadow);transform:rotate(-8deg);border:2px dashed rgba(242,230,207,.5);
}
.hero__stamp b{font-family:var(--serif);font-size:1.5rem;line-height:1;font-style:italic}
.hero__stamp span{font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;margin-top:4px;max-width:80%}
.hero__scroll{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--ink-faint);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase}
.hero__scroll i{width:1px;height:34px;background:var(--gold);animation:scrollPulse 2.2s var(--ease) infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1}}

/* steam */
.steam{position:absolute;top:0;left:50%;width:6px;height:60px;pointer-events:none}
.steam i{position:absolute;bottom:0;left:0;width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5);filter:blur(2px);animation:steam 3.2s ease-in infinite}
.steam i:nth-child(2){animation-delay:1s;left:6px}
.steam i:nth-child(3){animation-delay:2s;left:-4px}
@keyframes steam{0%{opacity:0;transform:translateY(0) scale(.6)}30%{opacity:.7}100%{opacity:0;transform:translateY(-56px) scale(2)}}

/* ---- Ribbon marquee ----------------------------------------------------- */
.ribbon{background:var(--wine);color:#efe0c4;border-block:1px solid var(--wine-deep);overflow:hidden;padding:14px 0}
.ribbon--green{background:var(--bottle);color:#e6ddc4;border-color:var(--bottle-deep)}
.marquee{display:flex;width:max-content;animation:marq 38s linear infinite}
.marquee:hover{animation-play-state:paused}
.marquee__set{display:flex;flex:none}
.marquee span{font-family:var(--serif);font-style:italic;font-size:1.14rem;padding:0 26px;white-space:nowrap;display:inline-flex;align-items:center;gap:26px}
.marquee span::after{content:"✦";color:var(--gold-soft);font-style:normal;font-size:.7rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---- Story teaser ------------------------------------------------------- */
.story{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,70px);align-items:center}
.story__media{position:relative}
.story__media img{width:100%;height:clamp(320px,42vw,480px);object-fit:cover;border-radius:3px;box-shadow:var(--shadow);border:1px solid var(--line-strong)}
.story__media .cap{position:absolute;bottom:12px;left:12px;right:12px;background:rgba(42,32,24,.78);color:#f2e6cf;font-size:.8rem;padding:.5em .8em;border-radius:2px;font-style:italic}
.dropcap::first-letter{font-family:var(--serif);float:left;font-size:3.6em;line-height:.72;padding:.06em .12em 0 0;color:var(--wine);font-weight:600;font-style:italic}
.story p{margin-bottom:1.1em;color:var(--ink-soft);font-size:1.06rem}
.story .quote{font-family:var(--serif);font-style:italic;font-size:1.24rem;color:var(--ink);border-left:3px solid var(--gold);padding-left:1em;margin:1.4em 0}

/* ---- Dish cards --------------------------------------------------------- */
.dishes{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}
.dish{
  background:linear-gradient(180deg,var(--paper),var(--paper-2));border:1px solid var(--line);
  border-radius:3px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  transition:transform .4s var(--ease),box-shadow .4s;position:relative;
}
.dish:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.dish__img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--paper-3)}
.dish__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.dish:hover .dish__img img{transform:scale(1.06)}
.dish__noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--gold);opacity:.5}
.dish__noimg svg{width:56px;height:56px}
.dish__body{padding:20px 20px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.dish__dialect{font-family:var(--serif);font-style:italic;color:var(--wine);font-size:1.28rem;font-weight:500;line-height:1.1}
.dish__it{font-size:.94rem;color:var(--ink-soft);flex:1}
.dish__foot{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-top:6px;border-top:1px dotted var(--line-strong);padding-top:12px}
.dish__price{font-family:var(--serif);font-weight:600;font-size:1.15rem;color:var(--ink)}
.dish__tag{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);border:1px solid var(--line-strong);padding:.25em .6em;border-radius:2px}

/* ---- Degustazione panel ------------------------------------------------- */
.degu{background:linear-gradient(150deg,var(--bottle),var(--bottle-deep));color:#ece2c8;border-radius:4px;overflow:hidden;position:relative;box-shadow:var(--shadow)}
.degu::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");opacity:.14;mix-blend-mode:overlay}
.degu__in{position:relative;padding:clamp(30px,5vw,56px)}
.degu__head{text-align:center;margin-bottom:34px}
.degu__head .eyebrow{color:var(--gold-soft)}
.degu__head h2{color:#f4ead0;font-size:clamp(1.7rem,3.6vw,2.6rem);margin-top:.3em}
.degu__head p{color:#cdc2a3;max-width:56ch;margin:.6em auto 0}
.degu__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}
.degu__card{background:rgba(246,238,214,.06);border:1px solid rgba(246,238,214,.2);border-radius:3px;padding:26px 22px;display:flex;flex-direction:column;gap:12px;transition:background .35s,transform .35s}
.degu__card:hover{background:rgba(246,238,214,.12);transform:translateY(-4px)}
.degu__card h3{color:#f4ead0;font-size:1.24rem}
.degu__card .price{font-family:var(--serif);font-size:2.1rem;font-weight:600;color:var(--gold-soft)}
.degu__card .price small{font-size:.9rem;color:#bdb193;font-weight:400}
.degu__card ul{list-style:none;display:flex;flex-direction:column;gap:7px;font-size:.9rem;color:#d9cfb1}
.degu__card li{padding-left:1.2em;position:relative}
.degu__card li::before{content:"—";position:absolute;left:0;color:var(--gold-soft)}
.degu__note{text-align:center;margin-top:24px;font-size:.82rem;color:#bdb193;font-style:italic}

/* ---- Reviews ------------------------------------------------------------ */
.reviews{overflow:hidden;position:relative}
.reviews__track{display:flex;width:max-content;gap:22px;animation:marq 60s linear infinite}
.reviews__track:hover{animation-play-state:paused}
.rev{width:340px;flex:none;background:linear-gradient(180deg,var(--paper),var(--paper-2));border:1px solid var(--line);border-radius:3px;padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}
.rev__stars{color:var(--gold);letter-spacing:2px;font-size:.9rem}
.rev__txt{font-size:.95rem;color:var(--ink);font-style:italic;line-height:1.55;flex:1}
.rev__who{display:flex;align-items:center;gap:10px;border-top:1px dotted var(--line-strong);padding-top:12px}
.rev__av{width:36px;height:36px;border-radius:50%;background:var(--wine);color:#f2e6cf;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;flex:none}
.rev__who b{font-size:.92rem}
.rev__who>div span{font-size:.72rem;color:var(--ink-faint);display:block}
.reviews__agg{display:flex;flex-wrap:wrap;justify-content:center;gap:18px 34px;margin-top:34px;text-align:center}
.reviews__agg .a{display:flex;flex-direction:column;gap:2px}
.reviews__agg .a b{font-family:var(--serif);font-size:1.8rem;color:var(--wine);font-weight:600}
.reviews__agg .a span{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}

/* ---- Stats counters ----------------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat b{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.4rem);color:var(--wine);font-weight:600;font-variation-settings:"opsz" 144;display:block;line-height:1}
.stat span{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:8px;display:block}

/* ---- FAQ ---------------------------------------------------------------- */
.faq{max-width:820px;margin-inline:auto;display:flex;flex-direction:column;gap:12px}
.faq__item{border:1px solid var(--line);border-radius:3px;background:linear-gradient(180deg,var(--paper),var(--paper-2));overflow:hidden;transition:border-color .3s}
.faq__item[open]{border-color:var(--wine)}
.faq__q{list-style:none;cursor:pointer;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--serif);font-size:1.12rem;font-weight:500;color:var(--ink)}
.faq__q::-webkit-details-marker{display:none}
.faq__q .ic{flex:none;width:22px;height:22px;position:relative;transition:transform .35s var(--ease)}
.faq__q .ic::before,.faq__q .ic::after{content:"";position:absolute;background:var(--wine);border-radius:2px}
.faq__q .ic::before{top:10px;left:2px;right:2px;height:2px}
.faq__q .ic::after{left:10px;top:2px;bottom:2px;width:2px;transition:transform .35s var(--ease)}
.faq__item[open] .faq__q .ic::after{transform:scaleY(0)}
.faq__a{padding:0 22px 20px;color:var(--ink-soft);font-size:.98rem}

/* ---- Contatti / info ---------------------------------------------------- */
.info{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,54px);align-items:start}
.info__list{display:flex;flex-direction:column;gap:22px}
.info__row{display:flex;gap:16px;align-items:flex-start}
.info__row .ic{flex:none;width:44px;height:44px;border-radius:50%;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:var(--wine);background:var(--paper)}
.info__row .ic svg{width:20px;height:20px}
.info__row h4{font-size:1.06rem;margin-bottom:3px}
.info__row p,.info__row a{color:var(--ink-soft);font-size:.98rem}
.info__row a:hover{color:var(--wine)}
.info__row .lbl{font-weight:600;color:var(--ink)}
.hours{list-style:none;font-size:.96rem;color:var(--ink-soft)}
.hours li{display:flex;justify-content:space-between;gap:16px;padding:5px 0;border-bottom:1px dotted var(--line)}
.hours li:last-child{border:0}
.hours .closed{color:var(--wine);font-weight:600}
.map{border-radius:4px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:var(--shadow-sm);height:100%;min-height:360px;position:relative}
.map iframe{width:100%;height:100%;min-height:360px;border:0;display:block;filter:sepia(.12) saturate(1.05)}

/* prenota banner */
.prenota{position:relative;overflow:hidden;border-radius:4px;box-shadow:var(--shadow)}
.prenota img{width:100%;height:clamp(260px,34vw,360px);object-fit:cover;display:block;filter:brightness(.62) sepia(.18)}
.prenota__in{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;padding:24px;color:#f4ead0}
.prenota__in h2{color:#f6ecd4;font-size:clamp(1.8rem,4vw,3rem)}
.prenota__in p{color:#e2d6bb;max-width:46ch}
.prenota__cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

/* ---- Footer ------------------------------------------------------------- */
.foot{background:linear-gradient(180deg,var(--wine-deep),#3d1119);color:#e7d8bb;position:relative;z-index:1}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:clamp(50px,7vw,84px) 0 44px}
.foot__brand .badge{background:var(--paper);border-radius:6px;padding:12px 16px;display:inline-block;box-shadow:var(--shadow)}
.foot__brand .badge img{height:66px;width:auto}
.foot__brand p{margin-top:18px;color:#cbb99a;max-width:34ch;font-size:.95rem}
.foot__soc{display:flex;gap:12px;margin-top:20px}
.foot__soc a{width:40px;height:40px;border:1px solid rgba(231,216,187,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#e7d8bb;transition:background .25s,transform .25s}
.foot__soc a:hover{background:rgba(231,216,187,.14);transform:translateY(-3px)}
.foot__soc svg{width:18px;height:18px}
.foot h5{font-family:var(--serif);font-size:1.1rem;color:#f4ead0;margin-bottom:16px;font-weight:600}
.foot__col a,.foot__col p{display:block;color:#cbb99a;font-size:.95rem;padding:4px 0;transition:color .25s}
.foot__col a:hover{color:#f4ead0}
.foot__bar{border-top:1px solid rgba(231,216,187,.18);padding:20px 0;display:flex;flex-wrap:wrap;gap:10px 20px;justify-content:space-between;align-items:center;font-size:.82rem;color:#b7a382}
.foot__bar a{color:#cbb99a}.foot__bar a:hover{color:#f4ead0}

/* ---- Language modal (Uniswap-style) ------------------------------------ */
.lang-modal{position:fixed;inset:0;z-index:130;display:flex;align-items:center;justify-content:center;padding:20px}
.lang-modal[hidden]{display:none!important}
.lang-modal__bd{position:absolute;inset:0;background:rgba(42,32,24,.5);backdrop-filter:blur(6px);opacity:0;transition:opacity .3s}
.lang-modal.show .lang-modal__bd{opacity:1}
.lang-modal__panel{
  position:relative;width:min(440px,100%);max-height:min(560px,86vh);background:var(--paper);
  border:1px solid var(--line-strong);border-radius:8px;box-shadow:0 30px 70px -20px rgba(42,32,24,.7);
  display:flex;flex-direction:column;overflow:hidden;transform:scale(.94) translateY(8px);opacity:0;
  transition:transform .32s var(--ease),opacity .32s;
}
.lang-modal.show .lang-modal__panel{transform:none;opacity:1}
.lang-modal__head{padding:20px 22px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.lang-modal__head h3{font-size:1.24rem}
.lang-modal__x{background:none;border:0;cursor:pointer;color:var(--ink-soft);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lang-modal__x:hover{background:rgba(42,32,24,.08);color:var(--ink)}
.lang-search{padding:14px 22px}
.lang-search input{width:100%;padding:.7em 1em;border:1px solid var(--line-strong);border-radius:4px;background:var(--paper-2);font-family:var(--body);font-size:.98rem;color:var(--ink)}
.lang-search input:focus{outline:none;border-color:var(--wine)}
.lang-list{overflow-y:auto;padding:6px 12px 16px;display:flex;flex-direction:column;gap:2px}
.lang-list button{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:.7em .8em;border-radius:5px;font-family:var(--body);font-size:1rem;color:var(--ink);transition:background .2s}
.lang-list button:hover{background:rgba(111,29,38,.08)}
.lang-list button[aria-selected="true"]{background:rgba(111,29,38,.12);font-weight:600}
.lang-list .flag{font-size:1.3rem;flex:none;width:1.5em;text-align:center}
.lang-list .nm{flex:1}
.lang-list .ck{color:var(--wine);opacity:0}
.lang-list button[aria-selected="true"] .ck{opacity:1}
.lang-list .empty{padding:20px;text-align:center;color:var(--ink-faint);font-style:italic}

/* ---- Page hero (inner pages) ------------------------------------------- */
.phero{padding-top:calc(var(--head-h) + clamp(40px,6vw,72px));padding-bottom:clamp(30px,5vw,54px);text-align:center;position:relative;border-bottom:1px solid var(--line)}
.phero h1{font-size:clamp(2.3rem,6vw,4.2rem);margin:.24em 0 .3em;font-variation-settings:"SOFT" 50,"opsz" 144}
.phero h1 em{font-style:italic;color:var(--wine)}
.crumbs{font-size:.82rem;color:var(--ink-faint);letter-spacing:.04em}
.crumbs a:hover{color:var(--wine)}

/* ---- Menu page ---------------------------------------------------------- */
.mtabs{position:sticky;top:var(--head-h);z-index:40;background:rgba(242,235,220,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:12px 0}
.mtabs__in{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;justify-content:flex-start}
.mtabs__in::-webkit-scrollbar{display:none}
.mtab{flex:none;background:none;border:1px solid var(--line-strong);color:var(--ink-soft);font-family:var(--body);font-weight:500;font-size:.9rem;padding:.55em 1.1em;border-radius:2px;cursor:pointer;white-space:nowrap;transition:all .25s}
.mtab:hover{border-color:var(--wine);color:var(--wine)}
.mtab.active{background:var(--wine);color:#f4ead0;border-color:var(--wine)}
.mcat{scroll-margin-top:calc(var(--head-h) + 68px)}
.mcat__head{text-align:center;margin-bottom:34px}
.mcat__head h2{font-size:clamp(1.8rem,4vw,2.8rem)}
.mcat__head h2 em{font-style:italic;color:var(--wine)}
.mcat__head p{color:var(--ink-soft);max-width:52ch;margin:.5em auto 0;font-size:.98rem}
.mlist{max-width:860px;margin-inline:auto;display:flex;flex-direction:column}
.mitem{display:flex;gap:14px;align-items:baseline;padding:18px 0;border-bottom:1px dotted var(--line-strong)}
.mitem:last-child{border-bottom:0}
.mitem__main{flex:1}
.mitem__name{font-family:var(--serif);font-style:italic;font-weight:500;font-size:1.2rem;color:var(--wine);line-height:1.2}
.mitem__desc{font-size:.95rem;color:var(--ink-soft);margin-top:4px}
.mitem__al{font-size:.7rem;letter-spacing:.08em;color:var(--ink-faint);margin-top:5px;text-transform:uppercase}
.mitem__dots{flex:1;border-bottom:1px dotted var(--line-strong);align-self:flex-end;margin-bottom:6px;min-width:14px}
.mitem__price{font-family:var(--serif);font-weight:600;font-size:1.15rem;color:var(--ink);white-space:nowrap}
.mitem__price small{font-size:.7rem;color:var(--ink-faint);font-weight:400;display:block;text-align:right}
.mnote{max-width:860px;margin:30px auto 0;font-size:.86rem;color:var(--ink-faint);font-style:italic;text-align:center;border-top:1px solid var(--line);padding-top:20px}
.allerg{max-width:860px;margin:14px auto 0;font-size:.78rem;color:var(--ink-faint);text-align:center;line-height:1.7}

/* ---- Wine page ---------------------------------------------------------- */
.wcols{display:grid;grid-template-columns:1fr;gap:clamp(30px,5vw,54px)}
.wcard{background:linear-gradient(180deg,var(--paper),var(--paper-2));border:1px solid var(--line);border-radius:4px;padding:clamp(24px,4vw,40px);box-shadow:var(--shadow-sm)}
.wcard h2{font-size:clamp(1.6rem,3.4vw,2.4rem);margin-bottom:6px}
.wcard h2 em{font-style:italic;color:var(--wine)}
.wcard>p{color:var(--ink-soft);margin-bottom:22px;font-size:.96rem}
.wlist{columns:2;column-gap:40px}
.witem{break-inside:avoid;display:flex;justify-content:space-between;gap:12px;align-items:baseline;padding:12px 0;border-bottom:1px dotted var(--line-strong)}
.witem__n{font-family:var(--serif);font-weight:500;font-size:1.04rem;color:var(--ink)}
.witem__n span{display:block;font-family:var(--body);font-style:italic;font-size:.78rem;color:var(--ink-faint)}
.witem__p{font-family:var(--serif);font-weight:600;color:var(--wine);white-space:nowrap}
.witem__p small{font-size:.68rem;color:var(--ink-faint);font-weight:400;display:block;text-align:right}

/* ---- Reveal ------------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

/* ---- Gallery / lightbox ------------------------------------------------- */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.gcell{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:3px;cursor:pointer;border:1px solid var(--line-strong);box-shadow:var(--shadow-sm)}
.gcell img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.gcell:hover img{transform:scale(1.07)}
.gcell figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(42,32,24,.82));color:#f2e6cf;font-size:.82rem;padding:22px 12px 10px;font-style:italic}
.lightbox{position:fixed;inset:0;z-index:135;background:rgba(28,20,14,.92);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .3s}
.lightbox[hidden]{display:none!important}
.lightbox.show{opacity:1}
.lightbox img{max-width:min(1000px,94vw);max-height:86vh;border-radius:3px;box-shadow:0 30px 80px -20px #000}
.lightbox__x{position:absolute;top:20px;right:24px;background:none;border:0;color:#f2e6cf;font-size:2rem;cursor:pointer;line-height:1}

/* ---- Back to top -------------------------------------------------------- */
.totop{position:fixed;right:20px;bottom:20px;z-index:50;width:46px;height:46px;border-radius:50%;background:var(--wine);color:#f2e6cf;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);opacity:0;transform:translateY(14px) scale(.85);pointer-events:none;transition:opacity .35s,transform .35s}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop svg{width:20px;height:20px}
/* Phone FAB (compare dopo lo scroll, così non copre l'hero) */
.wa-fab{position:fixed;left:20px;bottom:20px;z-index:50;width:54px;height:54px;border-radius:50%;background:var(--wine);color:#f2e6cf;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);opacity:0;transform:translateY(14px) scale(.85);pointer-events:none;transition:opacity .35s,transform .35s}
.wa-fab.show{opacity:1;transform:none;pointer-events:auto}
.wa-fab:hover{transform:scale(1.08)}
.wa-fab svg{width:26px;height:26px}

/* ---- Responsive --------------------------------------------------------- */
@media(max-width:960px){
  .hero__grid{grid-template-columns:1fr;gap:34px}
  .hero__figure{order:-1;max-width:480px;margin-inline:auto}
  .hero__figure img{height:clamp(300px,60vw,420px)}
  .story{grid-template-columns:1fr;gap:30px}
  .story__media{max-width:520px;margin-inline:auto;width:100%}
  .info{grid-template-columns:1fr}
  .map{min-height:320px}
  .foot__top{grid-template-columns:1fr 1fr}
  .foot__brand{grid-column:1/-1}
}
@media(max-width:820px){
  :root{--head-h:66px}
  .nav{display:none}
  .burger{display:flex}
  .brand img{height:46px}
  .brand__txt b{font-size:.98rem}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px 20px}
  .wlist{columns:1}
}
@media(max-width:560px){
  .hdr__actions .lang-btn .cur{display:none}
  .lang-btn{padding:.5em .6em}
  .hero h1{font-size:clamp(2.5rem,12vw,3.4rem)}
  .hero__stamp{width:96px;height:96px;left:auto;right:-10px;bottom:-16px}
  .hero__stamp b{font-size:1.2rem}
  .foot__top{grid-template-columns:1fr;gap:30px}
  .rev{width:280px}
  .prenota img{height:300px}
  .btn{padding:.8em 1.3em}
  .hero__cta .btn,.prenota__cta .btn{flex:1 1 auto}
}
@media(max-width:380px){
  .brand__txt{display:none}
  .title{font-size:1.8rem}
}

/* ---- Reduced motion ----------------------------------------------------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .marquee,.reviews__track{animation:marq 60s linear infinite!important}
  .hero__scroll i,.steam i{animation:none!important}
}
[hidden]{display:none!important}
