:root{
  --cream:#FBF7F1;
  --cream-deep:#F4ECE0;
  --surface:#FFFFFF;
  --paper:#FCF8F2;
  --ink:#33291F;
  --ink-soft:#5c4e40;
  --ink-soft2:#8a7a6a;
  --border:#E9DFD2;
  --border-strong:#DDCFBD;
  --terra-bg:#F5E3D8; --terra-fg:#9C4A22;
  --olive-bg:#E9EEDB; --olive-fg:#56712B;
  --gold:#C08A2E;
  --serif:'Lora',serif;
  --sans:'Karla',-apple-system,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --shadow-card:0 1px 2px rgba(51,41,31,.04), 0 12px 32px -18px rgba(51,41,31,.22);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream); color:var(--ink); font-family:var(--sans);
  font-size:16px; line-height:1.65; -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
/* Paper grain — leggerissima, tattile, no immagini */
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(156,74,34,.03), transparent 45%),
    radial-gradient(circle at 85% 20%, rgba(86,113,43,.03), transparent 40%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%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='120' height='120' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
  background-size:auto, auto, 120px 120px;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.wrap{max-width:1040px; margin:0 auto; padding:0 24px}

.nav{position:sticky; top:0; z-index:50; background:rgba(251,247,241,.82); backdrop-filter:saturate(1.4) blur(12px); -webkit-backdrop-filter:saturate(1.4) blur(12px); border-bottom:1px solid transparent; transition:border-color .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease)}
.nav.is-scrolled{border-bottom-color:var(--border); box-shadow:0 6px 24px -18px rgba(51,41,31,.4)}
.nav-inner{max-width:1040px; margin:0 auto; padding:16px 24px; display:flex; align-items:center; justify-content:space-between}
.logo{font-family:var(--serif); font-weight:600; font-style:italic; font-size:22px; letter-spacing:-.01em}
.logo:hover{color:var(--terra-fg)}
.nav-links{display:flex; gap:30px; font-size:14px; color:var(--ink-soft2)}
.nav-links a{position:relative; padding:4px 0; transition:color .2s}
.nav-links a::after{content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1.5px; background:var(--terra-fg); transition:right .3s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:40%}
.nav-links a.is-active{color:var(--ink)}
.nav-links a.is-active::after{right:0}

.btn-dark{background:#33291F; color:#fff; font-size:13.5px; font-weight:500; padding:10px 20px; border-radius:6px; display:inline-block; transition:background .2s, transform .15s}
.btn-dark:hover{background:#4a3a2a}
.btn-dark:active{transform:scale(.98)}
.btn-ghost{font-size:13.5px; font-weight:500; padding:10px 18px; border-radius:6px; border:1px solid var(--border); display:inline-block; transition:border-color .2s, background .2s}
.btn-ghost:hover{border-color:#cbb89e; background:#fff}

.hero{position:relative; padding:88px 0 84px}
.hero-grid{display:grid; grid-template-columns:1.25fr .75fr; gap:56px; align-items:center}
.tag{display:inline-flex; align-items:center; gap:8px; font-size:11.5px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; padding:7px 15px; border-radius:9999px; margin-bottom:26px; background:var(--terra-bg); color:var(--terra-fg)}
.tag-dot{width:6px; height:6px; border-radius:50%; background:currentColor; box-shadow:0 0 0 0 currentColor; animation:tagPulse 2.6s var(--ease) infinite}
@keyframes tagPulse{0%{box-shadow:0 0 0 0 rgba(156,74,34,.5)}70%,100%{box-shadow:0 0 0 7px rgba(156,74,34,0)}}
.hero h1{font-family:var(--serif); font-weight:600; font-size:54px; line-height:1.08; letter-spacing:-.02em; max-width:660px}
.hero h1 em{font-style:italic; color:var(--terra-fg); font-weight:500}
.hero-sub{margin-top:22px; max-width:460px; color:var(--ink-soft); font-size:17px}
.hero-cta{margin-top:32px; display:flex; gap:12px; flex-wrap:wrap}
.hero-meta{margin-top:26px; display:inline-flex; align-items:center; gap:9px; font-size:13.5px; color:var(--ink-soft2)}
.hero-meta .dot{width:8px; height:8px; border-radius:50%; background:var(--ink-soft2); flex-shrink:0; position:relative}
.hero-meta.is-open .dot{background:#4e8a3c}
.hero-meta.is-open .dot::after{content:""; position:absolute; inset:0; border-radius:50%; background:#4e8a3c; animation:tagPulse 2.4s var(--ease) infinite}
.hero-meta.is-open .hero-meta-text{color:var(--olive-fg); font-weight:600}
.hero-meta.is-closed .dot{background:#b0705a}

/* Piatto della domenica — card-illustrazione (niente foto) */
.hero-card{position:relative; background:var(--surface); border:1px solid var(--border); border-radius:18px; padding:30px 28px 26px; box-shadow:var(--shadow-card); overflow:hidden}
.hero-card::before{content:""; position:absolute; inset:0; background:radial-gradient(120% 80% at 50% -10%, rgba(245,227,216,.7), transparent 60%); pointer-events:none}
.hero-plate{position:relative; width:100%; aspect-ratio:1; max-width:210px; margin:0 auto 18px; color:var(--terra-fg)}
.hero-plate svg{width:100%; height:100%; animation:plateSpin 60s linear infinite}
@keyframes plateSpin{to{transform:rotate(360deg)}}
.hero-card-body{position:relative; text-align:center; display:flex; flex-direction:column; gap:4px}
.hero-card-eyebrow{font-size:11px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--terra-fg)}
.hero-card-title{font-family:var(--serif); font-style:italic; font-size:24px; font-weight:600}
.hero-card-note{font-size:13px; color:var(--ink-soft2)}

.hero-scroll{position:absolute; z-index:1; left:50%; bottom:22px; transform:translateX(-50%); width:22px; height:34px; border:1.5px solid var(--border-strong); border-radius:12px; display:flex; justify-content:center; padding-top:6px; opacity:.7}
.hero-scroll span{width:3px; height:7px; border-radius:2px; background:var(--ink-soft2); animation:scrollCue 1.8s var(--ease) infinite}
@keyframes scrollCue{0%{opacity:0; transform:translateY(-2px)}40%{opacity:1}80%,100%{opacity:0; transform:translateY(8px)}}
@media(prefers-reduced-motion:reduce){.tag-dot,.hero-plate svg,.hero-scroll span,.hero-meta .dot::after{animation:none}}

.strip{border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--surface)}
.strip-grid{display:grid; grid-template-columns:repeat(3,1fr); padding:44px 24px; gap:24px}
.strip-item{display:flex; flex-direction:column; gap:6px; text-align:center; padding:0 8px; position:relative}
.strip-item + .strip-item::before{content:""; position:absolute; left:0; top:8px; bottom:8px; width:1px; background:var(--border)}
.strip-item .num{font-family:var(--serif); font-size:38px; font-weight:600; color:var(--terra-fg); letter-spacing:-.01em; line-height:1}
.strip-item .label{font-size:13px; color:var(--ink-soft2); max-width:200px; margin:0 auto}

.section{padding:88px 0}
.section-alt{background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.eyebrow{display:inline-flex; align-items:center; gap:9px; font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--terra-fg)}
.eyebrow::before{content:""; width:22px; height:1.5px; background:currentColor; opacity:.6}
.section h2{font-family:var(--serif); font-weight:600; font-size:36px; letter-spacing:-.015em; line-height:1.12; margin-top:14px; margin-bottom:38px}
.section-head{display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:36px}
.section-head h2{margin-bottom:0}

.chi-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:48px; align-items:start}
.chi-text h2{margin-bottom:18px}
.chi-text p{color:var(--ink-soft2); margin-bottom:14px; max-width:480px}
.chi-cards{display:flex; flex-direction:column; gap:16px}
.mini-card{background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:24px; box-shadow:var(--shadow-card); transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s}
.mini-card:hover{transform:translateY(-3px); box-shadow:0 1px 2px rgba(51,41,31,.05), 0 20px 40px -22px rgba(51,41,31,.3); border-color:var(--border-strong)}
.mini-icon{width:42px; height:42px; border-radius:10px; display:flex; align-items:center; justify-content:center; margin-bottom:14px}
.mini-icon svg{width:18px; height:18px}
.mini-card h3{font-size:15px; font-weight:600; margin-bottom:4px}
.mini-card p{font-size:13.5px; color:var(--ink-soft2)}
.pastel-terra{background:var(--terra-bg); color:var(--terra-fg)}
.pastel-olive{background:var(--olive-bg); color:var(--olive-fg)}

/* ── Menù: layout carta stampata + pannello QR ── */
.menu-layout{display:grid; grid-template-columns:1.55fr .95fr; gap:28px; align-items:start}

.menu-card{position:relative; background:var(--paper); border:1px solid var(--border-strong); border-radius:16px; padding:38px 40px 30px; box-shadow:var(--shadow-card)}
/* bordo interno "carta menù" */
.menu-card::after{content:""; position:absolute; inset:12px; border:1px solid var(--border); border-radius:9px; pointer-events:none}
.menu-card-head{position:relative; text-align:center; margin-bottom:30px}
.menu-card-mark{display:block; font-family:var(--serif); font-style:italic; font-weight:600; font-size:30px; letter-spacing:.01em; color:var(--ink)}
.menu-card-sub{display:block; margin-top:6px; font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft2)}
.menu-card-rule{display:block; width:56px; height:2px; margin:16px auto 0; background:var(--terra-fg); opacity:.6; position:relative}
.menu-card-rule::before,.menu-card-rule::after{content:""; position:absolute; top:50%; width:5px; height:5px; border-radius:50%; background:var(--terra-fg); transform:translateY(-50%)}
.menu-card-rule::before{left:-12px}.menu-card-rule::after{right:-12px}

.menu-cols{display:grid; grid-template-columns:repeat(3,1fr); gap:14px 34px; position:relative}
.menu-group{position:relative}
.menu-cat{font-family:var(--serif); font-style:italic; font-size:19px; font-weight:600; margin-bottom:16px; color:var(--terra-fg); display:flex; align-items:center; gap:10px}
.menu-cat::after{content:""; flex:1; height:1px; background:var(--border)}
.menu-list{display:flex; flex-direction:column; gap:15px}
.menu-list li{display:flex; align-items:baseline; gap:6px; font-size:15px; line-height:1.4}
.menu-list .dish{flex-shrink:1}
.menu-list .dots{flex:1; align-self:center; border-bottom:1px dotted var(--border-strong); min-width:8px; transform:translateY(-2px)}
.menu-list .price{color:var(--terra-fg); font-weight:600; flex-shrink:0; font-variant-numeric:tabular-nums}
.menu-list li.is-star .dish{position:relative}
.menu-list li.is-star .dish::after{content:"★"; margin-left:7px; font-size:11px; color:var(--gold); vertical-align:middle}
.veg{display:inline-grid; place-items:center; width:15px; height:15px; margin-left:5px; border-radius:50%; background:var(--olive-bg); color:var(--olive-fg); font-style:normal; font-size:9px; font-weight:700; text-transform:uppercase; vertical-align:baseline}
.menu-card-foot{position:relative; margin-top:30px; padding-top:18px; border-top:1px solid var(--border); display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; font-size:12px; color:var(--ink-soft2)}
.veg-key{display:inline-flex; align-items:center; gap:7px}

/* Pannello QR — invito reale a scansionare */
.qr-panel{position:relative; background:linear-gradient(170deg, #3a2f23, #2c231a); color:#F3E7D9; border-radius:16px; padding:34px 30px 30px; box-shadow:var(--shadow-card); overflow:hidden; text-align:center}
.qr-panel::before{content:""; position:absolute; inset:0; opacity:.5; background:radial-gradient(90% 60% at 50% 0%, rgba(192,138,46,.25), transparent 70%); pointer-events:none}
.qr-panel-eyebrow{position:relative; font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--gold)}
.qr-panel-title{position:relative; font-family:var(--serif); font-weight:600; font-size:23px; line-height:1.22; margin:10px 0 12px}
.qr-panel-text{position:relative; font-size:13.5px; line-height:1.6; color:rgba(243,231,217,.72); max-width:260px; margin:0 auto 22px}
.qr-frame{position:relative; width:150px; height:150px; margin:0 auto 16px; background:var(--cream); border-radius:14px; padding:16px; box-shadow:0 14px 30px -12px rgba(0,0,0,.6)}
.qr-frame::after{content:""; position:absolute; inset:8px; border:1.5px solid rgba(51,41,31,.12); border-radius:8px; pointer-events:none}
.qr-graphic{position:relative; width:100%; height:100%; color:var(--ink); overflow:hidden}
.qr-graphic svg{width:100%; height:100%; display:block}
.qr-scan{position:absolute; left:0; right:0; top:0; height:26%; background:linear-gradient(180deg, rgba(192,138,46,0), rgba(192,138,46,.35)); border-bottom:1.5px solid rgba(192,138,46,.9); border-radius:6px; animation:qrScan 2.6s var(--ease) infinite}
@keyframes qrScan{0%{transform:translateY(-10%)}50%{transform:translateY(300%)}100%{transform:translateY(-10%)}}
.qr-panel-hint{position:relative; display:inline-flex; align-items:center; gap:7px; font-size:12px; letter-spacing:.04em; color:rgba(243,231,217,.85)}
.qr-panel-hint::before{content:""; width:14px; height:14px; border:1.5px solid currentColor; border-radius:3px; opacity:.7}
@media(prefers-reduced-motion:reduce){.qr-scan{animation:none; opacity:.35}}

.dove-grid{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center}
.info-list{display:flex; flex-direction:column; gap:18px; margin-top:8px}
.info-list li{display:flex; flex-direction:column; gap:2px; border-bottom:1px solid var(--border); padding-bottom:14px}
.info-list strong{font-size:13px; color:var(--ink-soft2); font-weight:600}
.info-list span{font-size:15.5px}
.map-card{position:relative; display:block; background:var(--cream-deep); border:1px solid var(--border); border-radius:16px; height:260px; overflow:hidden; box-shadow:var(--shadow-card); transition:transform .3s var(--ease), box-shadow .3s var(--ease)}
.map-card:hover{transform:translateY(-3px); box-shadow:0 1px 2px rgba(51,41,31,.05), 0 24px 44px -22px rgba(51,41,31,.35)}
.map-lines{position:absolute; inset:0; color:#cdbca4}
.map-lines svg{width:100%; height:100%}
.map-pin{position:absolute; left:50%; top:44%; transform:translate(-50%,-100%); width:40px; height:40px; border-radius:50%; background:var(--terra-fg); color:#fff; display:grid; place-items:center; box-shadow:0 10px 22px -8px rgba(156,74,34,.8)}
.map-pin::after{content:""; position:absolute; left:50%; top:52%; width:34px; height:34px; border-radius:50%; background:var(--terra-fg); opacity:.25; transform:translate(-50%,-50%); animation:pinPulse 2.4s var(--ease) infinite}
.map-pin svg{width:20px; height:20px; position:relative}
@keyframes pinPulse{0%{transform:translate(-50%,-50%) scale(.6); opacity:.4}80%,100%{transform:translate(-50%,-50%) scale(2.4); opacity:0}}
.map-label{position:absolute; left:14px; right:14px; bottom:14px; display:flex; flex-direction:column; gap:2px; background:rgba(252,248,242,.94); backdrop-filter:blur(6px); border:1px solid var(--border); border-radius:10px; padding:12px 14px; font-size:12.5px; color:var(--ink-soft2)}
.map-label strong{font-size:14.5px; color:var(--ink); font-weight:600}
@media(prefers-reduced-motion:reduce){.map-pin::after{animation:none}}

.section-cta{padding-top:40px; padding-bottom:96px}
.cta-box{position:relative; background:linear-gradient(165deg, #3a2f23, #2b221a); color:#F3E7D9; border:1px solid rgba(0,0,0,.2); border-radius:22px; padding:64px 40px; text-align:center; overflow:hidden; box-shadow:var(--shadow-card)}
.cta-box::before{content:""; position:absolute; inset:0; opacity:.6; background:radial-gradient(80% 60% at 50% -10%, rgba(192,138,46,.22), transparent 65%); pointer-events:none}
.cta-box .eyebrow{color:var(--gold)}
.cta-box .eyebrow::before{background:var(--gold)}
.cta-box h2{position:relative; margin-bottom:10px; max-width:600px; margin-left:auto; margin-right:auto}
.cta-box p{position:relative; color:rgba(243,231,217,.72); margin-bottom:28px}
.cta-box .hero-cta{position:relative; justify-content:center}
.cta-box .btn-dark{background:var(--cream); color:var(--ink)}
.cta-box .btn-dark:hover{background:#fff}

.footer{border-top:1px solid var(--border); padding:28px 0}
.footer-inner{display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; font-size:13px; color:var(--ink-soft2)}
.footer-credit a{color:var(--ink); border-bottom:1px solid var(--border)}
.footer-credit a:hover{border-color:var(--ink)}

.reveal{opacity:0; transform:translateY(12px); transition:opacity .6s var(--ease), transform .6s var(--ease)}
.reveal.in{opacity:1; transform:translateY(0)}

/* entrance */
.entrance{
  position:fixed; inset:0; z-index:300; background:var(--cream);
  pointer-events:none;
  animation:entranceFade .8s var(--ease) forwards;
}
@keyframes entranceFade{
  0%, 40%{ opacity:1 }
  100%{ opacity:0 }
}
@media(prefers-reduced-motion:reduce){
  .entrance{ display:none }
}

@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr; gap:36px}
  .hero-card{max-width:380px}
  .menu-layout{grid-template-columns:1fr; gap:20px}
  .qr-panel{display:grid; grid-template-columns:1fr auto; align-items:center; column-gap:30px; row-gap:14px; text-align:left; padding:30px 32px}
  .qr-panel-copy{grid-column:1}
  .qr-panel-title br{display:none}
  .qr-panel-text{margin-bottom:0; max-width:none}
  .qr-frame{grid-column:2; grid-row:1 / span 2; margin:0}
  .qr-panel-hint{grid-column:1; justify-self:start}
}
@media(max-width:860px){
  .hero h1{font-size:40px}
  .chi-grid, .dove-grid{grid-template-columns:1fr; gap:32px}
  .menu-cols{grid-template-columns:1fr; gap:22px 28px}
  .menu-card{padding:30px 26px 26px}
  .strip-grid{grid-template-columns:1fr; gap:28px}
  .strip-item + .strip-item::before{display:none}
  .strip-item + .strip-item{border-top:1px solid var(--border); padding-top:24px}
  .section-head{flex-direction:column; align-items:flex-start}
}
@media(max-width:560px){
  .nav-links{display:none}
  .nav .btn-dark{display:none}
  .hero{padding:56px 0 60px}
  .hero h1{font-size:32px}
  .hero-scroll{display:none}
  .section{padding:60px 0}
  .section h2{font-size:29px}
  .menu-card{padding:26px 20px 22px}
  .menu-card::after{inset:8px}
  .menu-card-mark{font-size:26px}
  .qr-panel{grid-template-columns:1fr; text-align:center; justify-items:center; row-gap:0}
  .qr-frame{grid-column:1; grid-row:auto; margin:8px auto 14px}
  .qr-panel-hint{grid-column:1; justify-self:center}
  .cta-box{padding:44px 24px}
}

/* accessibilità */
.skip-link{
  position:fixed; top:-100%; left:50%; transform:translateX(-50%); z-index:500;
  padding:10px 22px; background:var(--ink); color:var(--cream);
  font-size:13px; font-weight:600; letter-spacing:.03em;
  border-radius:0 0 10px 10px; transition:top .25s var(--ease);
}
.skip-link:focus{ top:0 }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--terra-fg); outline-offset:2px; border-radius:4px;
}
h1, h2, h3{ text-wrap:balance }

/* burger + mobile menu */
.burger{display:none; width:38px; height:38px; border-radius:50%; background:rgba(0,0,0,.04); position:relative; align-items:center; justify-content:center}
.burger span{position:absolute; width:16px; height:1.5px; background:var(--ink); transition:transform .28s var(--ease)}
.burger span:nth-child(1){transform:translateY(-4px)}
.burger span:nth-child(2){transform:translateY(4px)}
.burger.open span:nth-child(1){transform:translateY(0) rotate(45deg)}
.burger.open span:nth-child(2){transform:translateY(0) rotate(-45deg)}
.mobile-menu{
  position:fixed; inset:0; z-index:400; background:rgba(251,247,241,.98); backdrop-filter:blur(10px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:26px;
  opacity:0; pointer-events:none; transition:opacity .3s var(--ease);
}
.mobile-menu.open{ opacity:1; pointer-events:auto }
.mobile-menu a{
  font-family:var(--serif); font-style:italic; font-size:26px; color:var(--ink);
  opacity:0; transform:translateY(14px); transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.mobile-menu.open a{ opacity:1; transform:translateY(0) }
.mobile-menu.open a:nth-child(1){transition-delay:.06s}
.mobile-menu.open a:nth-child(2){transition-delay:.11s}
.mobile-menu.open a:nth-child(3){transition-delay:.16s}
.mobile-menu.open a:nth-child(4){transition-delay:.21s}
.mobile-menu.open a:nth-child(5){transition-delay:.26s}
.mobile-menu.open a:nth-child(6){transition-delay:.31s}
.mobile-menu-call{margin-top:14px; font-family:var(--sans)!important; font-style:normal!important; font-size:15px!important; font-weight:600; background:var(--ink); color:var(--cream)!important; padding:14px 26px; border-radius:9999px;}
@media(max-width:560px){
  .burger{display:flex}
}


/* ── JS spring motion (progressive enhancement) ── */
.reveal{ opacity:1; transform:none; filter:none; transition:none; }
.mm-on .reveal{ opacity:0; will-change:transform,opacity; }
@media (prefers-reduced-motion: reduce){
  .mm-on .reveal{ opacity:1 !important; transform:none !important; filter:none !important; }
}


/* -- Capsula flottante "Torna a NZ Agency" -- */
.nz-return{
  position:fixed; z-index:45;
  left:max(16px, env(safe-area-inset-left));
  bottom:max(16px, env(safe-area-inset-bottom));
  display:inline-flex; align-items:center; gap:0;
  padding:7px; border-radius:9999px; white-space:nowrap;
  text-decoration:none; font-size:13px; font-weight:600; letter-spacing:.01em;
  background:rgba(251,247,241,.86); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border:1px solid var(--border); color:var(--ink);
  box-shadow:0 10px 30px rgba(0,0,0,.16);
  transition:gap .35s cubic-bezier(.16,1,.3,1), padding .35s cubic-bezier(.16,1,.3,1), transform .25s, box-shadow .25s;
}
.nz-return-ic{ width:32px; height:32px; flex-shrink:0; border-radius:50%; background:#33291F; color:#fff; display:grid; place-items:center; transition:transform .3s; }
.nz-return-ic svg{ width:15px; height:15px; }
.nz-return-tx{ max-width:0; opacity:0; overflow:hidden; transition:max-width .35s cubic-bezier(.16,1,.3,1), opacity .25s; }
.nz-return-tx strong{ font-weight:700; }
.nz-return:hover, .nz-return:focus-visible{ gap:10px; padding-right:18px; transform:translateY(-3px); box-shadow:0 16px 40px rgba(0,0,0,.24); }
.nz-return:hover .nz-return-ic, .nz-return:focus-visible .nz-return-ic{ transform:translateX(-2px); }
.nz-return:hover .nz-return-tx, .nz-return:focus-visible .nz-return-tx{ max-width:200px; opacity:1; }
@media(prefers-reduced-motion:reduce){ .nz-return, .nz-return-tx, .nz-return-ic{ transition:none } }
.nz-return.nz-intro{ gap:10px; padding-right:18px; }
.nz-return.nz-intro .nz-return-tx{ max-width:200px; opacity:1; }
/* capsula sempre espansa: capibile subito all'ingresso */
.nz-return{ gap:10px; padding-right:18px; }
.nz-return .nz-return-tx{ max-width:200px; opacity:1; }

/* ── ambient shader hero ── */
.ambient-canvas{ position:absolute; inset:0; z-index:0; width:100%; height:100%; pointer-events:none; }
.hero{ position:relative; overflow:hidden; }
.hero > .wrap{ position:relative; z-index:1; }

/* ── Specialità ── */
.spec-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.spec-card{ position:relative; background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:32px 28px; box-shadow:var(--shadow-card); overflow:hidden; }
.spec-card::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--terra-fg); transform:scaleY(0); transform-origin:top; transition:transform .4s var(--ease); }
.spec-card:hover::before{ transform:scaleY(1); }
.spec-tag{ display:inline-block; font-size:11px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:var(--terra-fg); background:var(--terra-bg); padding:5px 12px; border-radius:9999px; margin-bottom:16px; }
.spec-card h3{ font-family:var(--serif); font-style:italic; font-size:25px; font-weight:600; margin-bottom:10px; letter-spacing:-.01em; }
.spec-card p{ font-size:14.5px; color:var(--ink-soft); }

/* ── Recensioni ── */
.reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.review-card{ position:relative; background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:30px 28px; margin:0; box-shadow:var(--shadow-card); transition:transform .3s var(--ease), box-shadow .3s var(--ease); }
.review-card:hover{ transform:translateY(-3px); box-shadow:0 1px 2px rgba(51,41,31,.05), 0 22px 42px -22px rgba(51,41,31,.32); }
.review-card::before{ content:"\201C"; position:absolute; top:14px; right:22px; font-family:var(--serif); font-size:60px; line-height:1; color:var(--terra-bg); }
.review-card .stars{ color:var(--gold); letter-spacing:3px; font-size:14px; margin-bottom:14px; }
.review-card blockquote{ position:relative; font-family:var(--serif); font-size:18px; line-height:1.55; margin:0 0 16px; }
.review-card figcaption{ font-size:13px; color:var(--ink-soft2); font-weight:600; }

/* ── Eventi ── */
.eventi-grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.eventi-grid .hero-sub{ margin:14px 0 26px; }
.eventi-list{ display:flex; flex-direction:column; }
.eventi-list li{ display:flex; flex-direction:column; gap:3px; border-top:1px solid var(--border); padding:18px 14px 18px 0; position:relative; transition:padding-left .3s var(--ease); }
.eventi-list li:last-child{ border-bottom:1px solid var(--border); }
.eventi-list li::before{ content:""; position:absolute; left:0; top:31px; width:0; height:6px; border-radius:3px; background:var(--terra-fg); transition:width .3s var(--ease); }
.eventi-list li:hover{ padding-left:18px; }
.eventi-list li:hover::before{ width:6px; }
.eventi-list strong{ font-family:var(--serif); font-size:18px; font-weight:600; }
.eventi-list span{ font-size:14px; color:var(--ink-soft2); }

@media(max-width:860px){
  .spec-grid{ grid-template-columns:1fr; }
  .reviews-grid{ grid-template-columns:1fr; }
  .eventi-grid{ grid-template-columns:1fr; gap:28px; }
}
