:root{
  --bg:#0E0B09;
  --bg-2:#161210;
  --surface:#1A1512;
  --surface-2:#211B16;
  --cream2:#F4ECE0;
  --ink-soft:#B8AA98;
  --ink-faint:#7d7164;
  --gold:#C9974B;
  --gold-soft:#E3C383;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --serif:'Cormorant', serif;
  --sans:'Manrope', -apple-system, sans-serif;
  --ease-out: cubic-bezier(.23,1,.32,1);
  --ease-drawer: cubic-bezier(.32,.72,0,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--cream2); font-family:var(--sans);
  font-size:16.5px; line-height:1.65; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit; background:none; border:none; color:inherit; cursor:pointer}
.wrap{max-width:1180px; margin:0 auto; padding:0 28px}

/* grain overlay */
.grain{position:fixed; inset:0; z-index:40; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ambient glow */
.glow{position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden}
.glow span{position:absolute; border-radius:50%; filter:blur(80px); opacity:.18}
.glow .g1{width:560px; height:560px; background:var(--gold); top:-6%; left:-8%}
.glow .g2{width:420px; height:420px; background:#8a5a2b; bottom:-15%; right:-5%}

/* floating nav */
.nav{position:sticky; top:16px; z-index:50; display:flex; justify-content:center; padding:0 20px}
.nav-inner{
  width:100%; max-width:920px; margin:0 auto;
  background:rgba(26,21,18,.7); backdrop-filter:blur(18px);
  border:1px solid var(--line-2); border-radius:9999px;
  padding:10px 10px 10px 22px; display:flex; align-items:center; justify-content:space-between;
}
.logo{font-family:var(--serif); font-size:21px; letter-spacing:.04em; color:var(--cream2)}
.logo em{color:var(--gold); font-style:italic}
.nav-links{display:flex; gap:30px; font-size:14px; color:var(--ink-soft)}
.nav-links a[aria-current]{color:var(--cream2)}
.nav-links a:hover{color:var(--cream2)}

.btn-gold{
  display:inline-flex; align-items:center; gap:10px;
  background:var(--gold); color:#1a1310; font-size:13.5px; font-weight:600;
  padding:8px 8px 8px 20px; border-radius:9999px;
  transition:transform 160ms var(--ease-out), background 200ms;
}
.btn-gold .arrow{width:30px; height:30px; border-radius:50%; background:rgba(26,19,16,.18); display:flex; align-items:center; justify-content:center; transition:transform 200ms var(--ease-out)}
.btn-gold:hover .arrow{transform:translate(2px,-2px) scale(1.05)}
.btn-gold:active{transform:scale(.97)}

.btn-ghost{
  display:inline-flex; align-items:center; gap:8px; font-size:13.5px; font-weight:500;
  padding:11px 22px; border:1px solid var(--line-2); border-radius:9999px; color:var(--cream2);
  transition:border-color 200ms, background 200ms, transform 160ms var(--ease-out);
}
.btn-ghost:hover{border-color:var(--gold-soft); background:rgba(201,151,75,.06)}
.btn-ghost:active{transform:scale(.97)}

/* hamburger */
.burger{display:none; width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,.06); position:relative; align-items:center; justify-content:center}
.burger span{position:absolute; width:16px; height:1.5px; background:var(--cream2); transition:transform 280ms var(--ease-drawer), opacity 280ms}
.burger span:nth-child(1){transform:translateY(-4px)}
.burger span:nth-child(2){transform:translateY(4px)}
.burger.open span:nth-child(1){transform:rotate(45deg)}
.burger.open span:nth-child(2){transform:rotate(-45deg) translateY(0)}
.burger.open span:nth-child(1){transform:translateY(0) rotate(45deg)}

.mobile-menu{
  position:fixed; inset:0; z-index:49; background:rgba(10,8,7,.92); backdrop-filter:blur(24px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:28px;
  opacity:0; pointer-events:none; transition:opacity 300ms var(--ease-out);
}
.mobile-menu.open{opacity:1; pointer-events:auto}
.mobile-menu a{font-family:var(--serif); font-size:30px; color:var(--cream2); opacity:0; transform:translateY(16px); transition:opacity 400ms var(--ease-out), transform 400ms var(--ease-out)}
.mobile-menu.open a{opacity:1; transform:translateY(0)}
.mobile-menu.open a:nth-child(1){transition-delay:80ms}
.mobile-menu.open a:nth-child(2){transition-delay:140ms}
.mobile-menu.open a:nth-child(3){transition-delay:200ms}
.mobile-menu.open a:nth-child(4){transition-delay:260ms}
.mobile-menu.open a:nth-child(5){transition-delay:320ms}

/* hero */
.hero{position:relative; margin-top:-68px; padding:188px 0 96px; z-index:1}
.tag{display:inline-flex; align-items:center; gap:8px; font-size:11px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); padding:7px 16px; border:1px solid var(--line-2); border-radius:9999px; margin-bottom:28px}
.hero h1{font-family:var(--serif); font-weight:500; font-size:68px; line-height:1.04; letter-spacing:-.01em; max-width:760px; color:var(--cream2)}
.hero h1 em{color:var(--gold); font-style:italic}
.hero-sub{margin-top:24px; max-width:480px; color:var(--ink-soft); font-size:17px}
.hero-cta{margin-top:40px; display:flex; gap:16px; flex-wrap:wrap}

/* strip */
.strip{position:relative; z-index:1; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.strip-grid{display:grid; grid-template-columns:repeat(4,1fr)}
.strip-item{padding:36px 28px; border-right:1px solid var(--line); text-align:center}
.strip-item:last-child{border-right:none}
.strip-item .num{font-family:var(--serif); font-size:32px; color:var(--gold-soft); display:block; margin-bottom:6px}
.strip-item .label{font-size:12.5px; color:var(--ink-soft); letter-spacing:.03em}

/* sections */
.section{position:relative; z-index:1; padding:104px 0}
.eyebrow{font-size:11.5px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-soft)}
.section-head{display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:52px}
.section h2{font-family:var(--serif); font-weight:500; font-size:42px; letter-spacing:-.01em; margin-top:12px; color:var(--cream2)}
.section-sub{color:var(--ink-soft); margin-top:14px; max-width:520px}

/* double bezel dish cards */
.dish-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.shell{padding:7px; border-radius:28px; background:rgba(255,255,255,.03); border:1px solid var(--line)}
.core{
  background:linear-gradient(160deg, var(--surface), var(--surface-2));
  border-radius:21px; padding:30px 26px; height:100%;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.06);
  transition:transform 280ms var(--ease-out);
}
.shell:hover .core{transform:translateY(-4px)}
.dish-tex{height:150px; border-radius:14px; margin-bottom:22px; position:relative; overflow:hidden}
.dish-tex::after{content:''; position:absolute; inset:0; background-image:repeating-linear-gradient(120deg, rgba(255,255,255,.04) 0 1px, transparent 1px 22px)}
.tex-a{background:linear-gradient(135deg, #4a3318, #1d140a)}
.tex-b{background:linear-gradient(135deg, #3a2a1a, #16100a)}
.tex-c{background:linear-gradient(135deg, #553a1c, #20150a)}
.core .ptag{font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faint)}
.core h3{font-family:var(--serif); font-size:23px; margin-top:8px; color:var(--cream2); font-weight:500}
.core p{font-size:14px; color:var(--ink-soft); margin-top:10px}
.core .price{display:block; margin-top:16px; color:var(--gold-soft); font-size:14px; font-weight:600}

/* storia teaser */
.phil{display:grid; grid-template-columns:.9fr 1.1fr; gap:64px; align-items:center}
.phil-frame{aspect-ratio:4/5; border-radius:24px; background:linear-gradient(155deg, #3a2a1a, #120e0a); position:relative; overflow:hidden}
.phil-frame::after{content:''; position:absolute; inset:0; background-image:repeating-linear-gradient(115deg, rgba(255,255,255,.04) 0 1px, transparent 1px 30px)}
.phil-text p{color:var(--ink-soft); margin-bottom:16px; max-width:480px}
.phil-text p:first-of-type{font-size:23px; color:var(--cream2); font-family:var(--serif); line-height:1.4; font-style:italic}

/* form (prenotazioni) */
.form{display:flex; flex-direction:column; gap:22px}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.field{display:flex; flex-direction:column; gap:8px}
.field label{font-size:12.5px; color:var(--ink-soft); letter-spacing:.03em}
.field input, .field textarea, .field select{
  background:var(--surface); border:1px solid var(--line-2); border-radius:10px;
  padding:13px 16px; font-family:var(--sans); font-size:15.5px; color:var(--cream2); resize:none;
  transition:border-color 200ms;
}
.field input:focus, .field textarea:focus, .field select:focus{outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,151,75,.2)}
.field select option{background:var(--surface)}

/* contatti / dove */
.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:3px; border-bottom:1px solid var(--line); padding-bottom:14px}
.info-list strong{font-size:12.5px; color:var(--ink-soft); letter-spacing:.04em; text-transform:uppercase}
.info-list span, .info-list a{font-size:16px}
.map-placeholder{background:var(--surface); border:1px solid var(--line); border-radius:18px; height:260px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; color:var(--ink-soft); font-size:13px}
.map-placeholder svg{width:30px; height:30px; opacity:.6; color:var(--gold-soft)}

/* menu */
.menu-cols{display:grid; grid-template-columns:repeat(2,1fr); gap:48px}
.menu-cat{font-family:var(--serif); font-style:italic; font-size:24px; font-weight:500; margin-bottom:20px; color:var(--gold-soft)}
.menu-list{display:flex; flex-direction:column; gap:16px; margin-bottom:40px}
.menu-list li{display:flex; justify-content:space-between; gap:14px; border-bottom:1px solid var(--line); padding-bottom:12px; font-size:15.5px; color:var(--cream2)}
.menu-list .price{color:var(--gold-soft); font-weight:600; flex-shrink:0}
.menu-note{font-size:14px; color:var(--ink-soft)}

/* page hero */
.page-hero{position:relative; z-index:1; padding:96px 0 64px; border-bottom:1px solid var(--line)}
.page-hero h1{font-family:var(--serif); font-weight:500; font-size:50px; letter-spacing:-.01em; max-width:680px; color:var(--cream2); margin-top:14px}
.page-hero p{margin-top:18px; color:var(--ink-soft); max-width:540px}

/* cta finale */
.cta-final{position:relative; z-index:1; padding:104px 0; text-align:center; border-top:1px solid var(--line)}
.cta-final h2{font-family:var(--serif); font-weight:500; font-size:44px; margin-top:14px; color:var(--cream2)}
.cta-final p{color:var(--ink-soft); margin-top:14px; max-width:480px; margin-left:auto; margin-right:auto}
.cta-final .hero-cta{justify-content:center; margin-top:36px}

/* footer */
.footer{position:relative; z-index:1; border-top:1px solid var(--line); padding:36px 0}
.footer-inner{display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:13px; color:var(--ink-soft)}
.footer-credit a{color:var(--cream2); border-bottom:1px solid var(--line)}
.footer-credit a:hover{border-color:var(--gold-soft)}

/* reveal */
.reveal{opacity:0; transform:translateY(22px) scale(.98); filter:blur(6px); transition:opacity .9s var(--ease-out), transform .9s var(--ease-out), filter .9s var(--ease-out)}
.reveal.in{opacity:1; transform:translateY(0) scale(1); filter:blur(0)}
.reveal.d1.in{transition-delay:60ms}
.reveal.d2.in{transition-delay:120ms}
.reveal.d3.in{transition-delay:180ms}

@media(hover:hover) and (pointer:fine){
  .shell:hover{border-color:var(--line-2)}
}
@media(max-width:920px){
  .hero h1{font-size:46px}
  .strip-grid{grid-template-columns:repeat(2,1fr)}
  .strip-item:nth-child(2n){border-right:none}
  .dish-grid{grid-template-columns:1fr 1fr}
  .phil, .dove-grid{grid-template-columns:1fr; gap:36px}
  .menu-cols{grid-template-columns:1fr; gap:8px}
}
@media(max-width:680px){
  .nav-links{display:none}
  .burger{display:flex}
  .hero{padding:156px 0 64px}
  .hero h1{font-size:34px}
  .page-hero h1{font-size:32px}
  .section{padding:72px 0}
  .dish-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .strip-grid{grid-template-columns:1fr}
  .strip-item{border-right:none; border-bottom:1px solid var(--line)}
}
@media(prefers-reduced-motion:reduce){
  .reveal{transition:opacity .4s ease; transform:none; filter:none}
  .reveal.in{transform:none; filter:none}
}

/* entrance */
.entrance{
  position:fixed; inset:0; z-index:300; background:var(--bg);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px;
  pointer-events:none;
  animation:entranceOut .5s var(--ease-out) 1.1s forwards;
}
.entrance-word{
  font-family:var(--serif); font-size:32px; letter-spacing:.06em; color:var(--cream2);
  opacity:0; transform:translateY(8px);
  animation:entranceWord .6s var(--ease-out) .15s forwards;
}
.entrance-word em{ color:var(--gold); font-style:italic }
.entrance-line{
  width:0; height:1px; background:var(--gold);
  animation:entranceLine .6s var(--ease-out) .5s forwards;
}
@keyframes entranceWord{ to{ opacity:1; transform:translateY(0) } }
@keyframes entranceLine{ to{ width:120px } }
@keyframes entranceOut{ to{ opacity:0; visibility:hidden } }
@media(prefers-reduced-motion:reduce){
  .entrance{ display:none }
}

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


/* ── 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; }
}

/* hero deep-sea caustics canvas (WebGL) dietro al contenuto */
.sea-canvas{ position:absolute; inset:0; z-index:0; width:100%; height:100%; pointer-events:none; }
.hero > .wrap{ position:relative; z-index:1; }

/* ── L'ESPERIENZA (menu degustazione raccontato) ── */
.exp-grid{display:grid; grid-template-columns:.85fr 1.15fr; gap:64px; align-items:start}
.exp-intro h2{font-family:var(--serif); font-weight:500; font-size:40px; letter-spacing:-.01em; margin:12px 0 18px; color:var(--cream2)}
.exp-intro .section-sub{margin-bottom:28px}
.exp-steps{display:flex; flex-direction:column}
.exp-steps li{display:grid; grid-template-columns:64px 1fr; gap:22px; align-items:baseline; padding:26px 0; border-top:1px solid var(--line)}
.exp-steps li:last-child{border-bottom:1px solid var(--line)}
.exp-n{font-family:var(--serif); font-size:22px; font-style:italic; color:var(--gold)}
.exp-steps h3{font-family:var(--serif); font-size:23px; font-weight:500; color:var(--cream2); margin-bottom:4px}
.exp-steps p{font-size:14.5px; color:var(--ink-soft); max-width:460px}

/* ── RICONOSCIMENTI (press) ── */
.press-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.press-grid figure{margin:0}
.press-grid .core{display:flex; flex-direction:column; justify-content:space-between; gap:24px; min-height:240px}
.press-grid blockquote{margin:0}
.press-grid .core p{font-family:var(--serif); font-style:italic; font-size:20px; line-height:1.5; color:var(--cream2)}
.press-grid figcaption{font-size:12.5px; font-weight:600; letter-spacing:.04em; color:var(--gold-soft); text-transform:uppercase}
.press-grid figcaption span{display:block; margin-top:4px; font-weight:400; letter-spacing:.02em; text-transform:none; color:var(--ink-faint)}

@media(max-width:920px){
  .exp-grid{grid-template-columns:1fr; gap:36px}
  .press-grid{grid-template-columns:1fr}
}


/* -- 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(26,21,18,.72); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border:1px solid var(--line-2); color:var(--cream2);
  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:var(--gold); color:#1a1310; 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; }


/* ════════════════════════════════════════════════════════════════
   ELEVAZIONE CRAFT — livello di rifinitura (award-quality)
   Aggiunte non distruttive: tipografia fluida, interazioni, ritmo,
   e rifiniture per pagina. Segue le stesse variabili/tema.
════════════════════════════════════════════════════════════════ */

/* Fallback quando sea.js si auto-disattiva: intensifica il glow oro
   dell'hero così non resta un'area piatta. */
.hero.sea-fallback::before{
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 90% at 78% 30%, rgba(201,151,75,.20), transparent 60%),
    radial-gradient(90% 80% at 12% 80%, rgba(138,90,43,.16), transparent 62%);
  -webkit-mask-image:linear-gradient(#000,rgba(0,0,0,.6)); mask-image:linear-gradient(#000,rgba(0,0,0,.6));
}

/* — Tipografia fluida degli headline: scala meglio tra i breakpoint — */
.hero h1{ font-size:clamp(38px, 6.4vw, 72px); }
.page-hero h1{ font-size:clamp(31px, 4.6vw, 54px); }
.section h2, .cta-final h2{ font-size:clamp(30px, 3.6vw, 46px); }
.exp-intro h2{ font-size:clamp(28px, 3.2vw, 42px); }
.hero h1 em{ font-style:italic; position:relative; }

/* — Nav: sottolineatura oro animata + attivo — */
.nav-links a{ position:relative; padding:4px 0; transition:color .25s var(--ease-out); }
.nav-links a::after{
  content:''; position:absolute; left:0; right:100%; bottom:-2px; height:1px;
  background:var(--gold-soft); transition:right .34s var(--ease-out); opacity:.9;
}
.nav-links a:hover::after{ right:0; }
.nav-links a[aria-current]::after{ right:0; opacity:1; }
.nav-inner{ transition:box-shadow .4s var(--ease-out), border-color .4s var(--ease-out); }
.nav.is-scrolled .nav-inner{ box-shadow:0 14px 40px -18px rgba(0,0,0,.7); border-color:rgba(255,255,255,.2); }

/* — Bottone oro: brillio interno leggero al hover — */
.btn-gold{ position:relative; overflow:hidden; box-shadow:0 8px 24px -12px rgba(201,151,75,.6); }
.btn-gold::before{
  content:''; position:absolute; inset:0; background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.35) 50%, transparent 70%);
  transform:translateX(-120%); transition:transform .7s var(--ease-out);
}
.btn-gold:hover::before{ transform:translateX(120%); }
.btn-gold:hover{ background:var(--gold-soft); }

/* — Strip stats: numeri più vivi, hover sottile — */
.strip-item{ transition:background .3s var(--ease-out); }
.strip-item:hover{ background:rgba(201,151,75,.045); }
.strip-item .num{ font-size:clamp(28px,3.2vw,36px); letter-spacing:-.01em; }

/* — Eyebrow: piccola tacca oro davanti — */
.eyebrow{ display:inline-flex; align-items:center; gap:10px; }
.eyebrow::before{ content:''; width:22px; height:1px; background:var(--gold); opacity:.75; }
.cta-final .eyebrow, .exp-intro .eyebrow, .page-hero .eyebrow{ }
.cta-final .eyebrow::before{ display:none; }

/* — Card piatti: cornice più ricca, texture con leggero moto al hover — */
.core{ position:relative; }
.dish-tex::before{
  content:''; position:absolute; inset:0; z-index:1;
  background:radial-gradient(120% 100% at 20% 0%, rgba(255,255,255,.10), transparent 55%);
}
.dish-tex{ transition:transform .6s var(--ease-out); }
.shell:hover .dish-tex{ transform:scale(1.04); }
.core .price{ display:inline-flex; align-items:center; gap:8px; }
.core .price::before{ content:''; width:14px; height:1px; background:var(--gold); opacity:.7; }
.ptag{ display:inline-block; padding:3px 10px; border:1px solid var(--line); border-radius:9999px; }

/* — Sezione storia (phil): cornice con texture "acqua" e didascalia — */
.phil-frame{ box-shadow:inset 0 0 0 1px rgba(255,255,255,.04), 0 30px 60px -30px rgba(0,0,0,.6); }
.phil-frame::before{
  content:'“Il mare, ogni mattina.”'; position:absolute; left:24px; bottom:22px; z-index:2;
  font-family:var(--serif); font-style:italic; font-size:19px; color:var(--gold-soft);
  max-width:70%; text-shadow:0 2px 12px rgba(0,0,0,.5);
}

/* — Esperienza: numeri con linea di connessione verticale — */
.exp-steps li{ transition:border-color .3s; }
.exp-steps li:hover .exp-n{ color:var(--gold-soft); }
.exp-n{ transition:color .3s; }

/* — Press: virgolette decorative — */
.press-grid .core{ position:relative; }
.press-grid .core::before{
  content:'”'; position:absolute; top:6px; right:20px; font-family:var(--serif);
  font-size:76px; line-height:1; color:var(--gold); opacity:.14;
}

/* ── MENU: da lista piatta a carta editoriale ─────────────────── */
.menu-cols{ gap:clamp(40px,7vw,88px); }
.menu-cat{ display:flex; align-items:baseline; gap:14px; }
.menu-cat::after{ content:''; flex:1; height:1px; background:var(--line); }
.menu-list li{
  align-items:baseline; border-bottom:none; padding-bottom:0;
  position:relative; gap:0; padding-top:2px;
}
.menu-list li > span:first-child{ position:relative; padding-right:8px; background:var(--bg); }
/* leader dots tra piatto e prezzo */
.menu-list li::after{
  content:''; position:absolute; left:0; right:0; bottom:6px; z-index:-1;
  border-bottom:1px dotted rgba(255,255,255,.16);
}
.menu-list li .price{ background:var(--bg); padding-left:8px; }
.menu-list li:hover > span:first-child{ color:var(--gold-soft); transition:color .2s; }
.menu-note{ border-top:1px solid var(--line); padding-top:18px; font-style:italic; }

/* ── FORM prenotazioni: più tattile, stato di successo curato ──── */
.form-row, .field{ }
.field input, .field textarea, .field select{
  background:var(--surface); transition:border-color .2s, box-shadow .25s, background .2s;
}
.field input:hover, .field textarea:hover, .field select:hover{ border-color:rgba(255,255,255,.24); }
.form .btn-gold{ margin-top:6px; }
.booking-ok{
  display:none; align-items:center; gap:14px; margin-top:4px;
  padding:18px 20px; border-radius:14px; border:1px solid rgba(201,151,75,.4);
  background:linear-gradient(160deg, rgba(201,151,75,.10), rgba(201,151,75,.03));
}
.booking-ok.show{ display:flex; animation:okIn .5s var(--ease-out); }
.booking-ok .ok-ic{ width:34px; height:34px; flex-shrink:0; border-radius:50%; background:var(--gold); color:#1a1310; display:grid; place-items:center; }
.booking-ok .ok-ic svg{ width:18px; height:18px; }
.booking-ok p{ font-size:14px; color:var(--gold-soft); margin:0; }
@keyframes okIn{ from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none} }

/* ── CONTATTI: mappa placeholder più evocativa (griglia porto) ── */
.map-placeholder{
  height:300px; position:relative; overflow:hidden;
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(201,151,75,.10), transparent 55%),
    var(--surface);
}
.map-placeholder::before{
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:34px 34px; -webkit-mask-image:radial-gradient(circle at 50% 45%, #000, transparent 75%); mask-image:radial-gradient(circle at 50% 45%, #000, transparent 75%);
}
.map-placeholder svg, .map-placeholder span{ position:relative; z-index:1; }
.map-placeholder span{ font-weight:600; letter-spacing:.02em; color:var(--cream2); }
.info-list li{ transition:border-color .3s; }
.info-list li:hover{ border-color:var(--line-2); }
.info-list a{ color:var(--gold-soft); transition:color .2s; }
.info-list a:hover{ color:var(--cream2); }

/* — CTA finale: alone caldo dietro il titolo — */
.cta-final{ overflow:hidden; }
.cta-final::before{
  content:''; position:absolute; z-index:-1; left:50%; top:40%; transform:translate(-50%,-50%);
  width:min(680px,80vw); aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, rgba(201,151,75,.12), transparent 65%);
}

/* — Footer: allineamento più raffinato su desktop — */
.footer{ padding:44px 0; }

/* — Reveal: sostituisce lo scale che può causare shift su blocchi larghi — */

/* — Micro rifinitura scrollbar (webkit) — */
::selection{ background:rgba(201,151,75,.32); color:var(--cream2); }

/* — Breakpoint extra: telefoni molto stretti — */
@media(max-width:420px){
  .wrap{ padding:0 20px; }
  .nav{ top:10px; }
  .phil-frame::before{ font-size:16px; left:18px; bottom:16px; }
}

/* — Riduci intensità entrance su schermi piccoli già veloci — */
@media(max-width:680px){
  .press-grid .core::before{ font-size:60px; }
  .cta-final h2{ font-size:30px; }
}
