/* Il Diamante 2 — Milano · "Diamante nero, taglio & brace" */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0c0d11; --ink2:#101218; --panel:#16181f; --panel2:#1d2029;
  --line:rgba(230,238,250,.09); --line2:rgba(230,238,250,.16);
  --text:#e9e8e3; --muted:#9aa0ac;
  --gold:#e7c775; --gold2:#c9a04f; --gold-soft:#f4e2ac;
  --ice:#bfe3ff; --ice2:#8ec5f2; --garnet:#9a2b3d;
  --f-display:'Cinzel',serif; --f-serif:'Cormorant Garamond',Georgia,serif;
  --f-sans:'Outfit',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --wrap:1200px; --r:16px; --shadow:0 24px 60px -28px rgba(0,0,0,.75);
  --gold-grad:linear-gradient(135deg,#f4e2ac,#e7c775 42%,#c9a04f);
}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
body{font-family:var(--f-sans);background:var(--ink);color:var(--text);
  line-height:1.6;font-weight:300;overflow-x:clip;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(1200px 700px at 78% -8%,rgba(142,197,242,.06),transparent 60%),radial-gradient(900px 600px at -5% 12%,rgba(231,199,117,.05),transparent 55%);}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;line-height:1.12;letter-spacing:.02em}
[hidden]{display:none!important}
::selection{background:rgba(231,199,117,.28);color:#fff}
.wrap{width:min(100% - 40px,var(--wrap));margin-inline:auto}
h1,h2,h3,h4,p,span,a,li,button{overflow-wrap:break-word}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--f-sans);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  padding:.95em 1.7em;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s,background .3s,color .3s;white-space:nowrap}
.btn-gold,.btn-book{background:var(--gold-grad);color:#20180a;box-shadow:0 10px 30px -12px rgba(231,199,117,.5)}
.btn-gold:hover,.btn-book:hover{transform:translateY(-2px);box-shadow:0 16px 38px -12px rgba(231,199,117,.65)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line2)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-soft);transform:translateY(-2px)}
.btn-wide{width:100%}
.kicker{font-family:var(--f-sans);text-transform:uppercase;letter-spacing:.34em;font-size:.72rem;font-weight:600;
  color:var(--ice2);margin-bottom:.9rem}
.sec-title{font-size:clamp(1.9rem,4.4vw,3rem);color:#fff}
.sec-head{margin-bottom:2.6rem;max-width:640px}
.sec-cta{margin-top:2.6rem;display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center}
section{position:relative}

/* ---------- intro ---------- */
.intro{position:fixed;inset:0;z-index:1000;background:radial-gradient(circle at 50% 42%,#15171f,#08090c 70%);
  display:flex;align-items:center;justify-content:center;transition:opacity .7s ease,visibility .7s}
.intro.gone{opacity:0;visibility:hidden}
.intro-inner{display:flex;flex-direction:column;align-items:center;gap:1.4rem;padding:20px}
.intro-logo{width:min(72vw,440px);opacity:0;animation:introLogo 1.5s .35s cubic-bezier(.2,.7,.2,1) forwards}
.intro-gem{width:74px;height:74px;opacity:0;animation:introGem 1.3s cubic-bezier(.2,.7,.2,1) forwards}
.intro-bar{width:150px;height:2px;background:var(--line2);border-radius:2px;overflow:hidden}
.intro-bar span{display:block;height:100%;width:0;background:var(--gold-grad);animation:introBar 1.8s .3s ease forwards}
@keyframes introGem{0%{opacity:0;transform:translateY(10px) scale(.6) rotate(-30deg)}100%{opacity:1;transform:translateY(0) scale(1) rotate(0)}}
@keyframes introLogo{0%{opacity:0;transform:translateY(14px) scale(.97);filter:blur(6px)}100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}
@keyframes introBar{0%{width:0}100%{width:100%}}

/* ---------- diamond gem ---------- */
.gem{display:block;filter:drop-shadow(0 6px 16px rgba(142,197,242,.35))}
.gem-rot{transform-origin:60px 60px;animation:gemSpin 14s linear infinite}
.gem-rot polygon{transition:opacity .3s}
@keyframes gemSpin{0%{transform:rotateY(0)}100%{transform:rotateY(360deg)}}
.hero-gem{width:96px;height:96px;margin-inline:auto}
.hero-gem-wrap{position:relative;margin-bottom:1.4rem}
.hero-gem-wrap::after{content:"";position:absolute;inset:-30% 0;background:radial-gradient(closest-side,rgba(191,227,255,.25),transparent 70%);z-index:-1;animation:gemGlow 4s ease-in-out infinite}
@keyframes gemGlow{0%,100%{opacity:.5;transform:scale(.9)}50%{opacity:1;transform:scale(1.15)}}

/* ---------- header ---------- */
.site-head{position:sticky;top:0;z-index:80;background:rgba(10,11,15,.72);backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);transition:background .3s,box-shadow .3s}
.site-head.scrolled{background:rgba(9,10,14,.92);box-shadow:0 10px 30px -20px rgba(0,0,0,.9)}
.head-inner{width:min(100% - 40px,1320px);margin-inline:auto;display:flex;align-items:center;gap:1.2rem;
  min-height:78px;padding-block:.5rem}
.brand{flex-shrink:0;display:flex;align-items:center}
.brand-logo{height:52px;width:auto}
.nav-desk{display:flex;align-items:center;gap:.35rem;margin-inline:auto;flex-wrap:nowrap}
.nlink{font-size:.82rem;font-weight:500;letter-spacing:.04em;color:var(--muted);padding:.5rem .7rem;border-radius:8px;
  position:relative;transition:color .25s;white-space:nowrap}
.nlink::after{content:"";position:absolute;left:.7rem;right:.7rem;bottom:.28rem;height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .3s}
.nlink:hover{color:var(--text)}.nlink:hover::after{transform:scaleX(1)}
.nlink.is-active{color:var(--gold-soft)}.nlink.is-active::after{transform:scaleX(1)}
.head-actions{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.lang-btn{display:inline-flex;align-items:center;gap:.35rem;background:transparent;border:1px solid var(--line2);color:var(--text);
  border-radius:999px;padding:.42rem .7rem;font-family:var(--f-sans);font-size:.78rem;font-weight:600;cursor:pointer;transition:border-color .25s,color .25s}
.lang-btn:hover{border-color:var(--gold);color:var(--gold-soft)}
.head-actions .btn-book{font-size:.72rem;padding:.72em 1.3em}
.burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;background:transparent;border:1px solid var(--line2);
  border-radius:10px;cursor:pointer;align-items:center;justify-content:center}
.burger span{width:20px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.burger[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded=true] span:nth-child(2){opacity:0}
.burger[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav */
.mobile-nav{position:fixed;inset:78px 0 0;z-index:70;background:rgba(9,10,14,.98);backdrop-filter:blur(8px);
  padding:1.6rem 24px 3rem;overflow-y:auto;animation:mnav .35s ease}
@keyframes mnav{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.mnav-inner{display:flex;flex-direction:column;gap:.2rem;max-width:520px;margin-inline:auto}
.mlink{font-family:var(--f-display);font-size:1.5rem;padding:.85rem .2rem;border-bottom:1px solid var(--line);color:var(--text)}
.mlink:active{color:var(--gold)}
.mnav-cta{margin-top:1.4rem}
.mnav-info{margin-top:1.2rem;text-align:center;color:var(--muted);font-size:.9rem}
.mnav-info a{color:var(--gold-soft)}

/* ---------- lang overlay ---------- */
.lang-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}
.lang-overlay.show{}
.lang-backdrop{position:absolute;inset:0;background:rgba(6,7,10,.72);backdrop-filter:blur(6px);opacity:0;transition:opacity .3s}
.lang-overlay.show .lang-backdrop{opacity:1}
.lang-panel{position:relative;width:min(440px,100%);max-height:82vh;background:var(--panel);border:1px solid var(--line2);
  border-radius:20px;box-shadow:var(--shadow);padding:1.3rem;display:flex;flex-direction:column;
  transform:translateY(14px) scale(.94);opacity:0;transition:transform .38s cubic-bezier(.2,.8,.2,1),opacity .3s}
.lang-overlay.show .lang-panel{transform:none;opacity:1}
.lang-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.lang-top h3{font-size:1.1rem;color:#fff}
.lang-x{background:transparent;border:1px solid var(--line2);color:var(--text);width:34px;height:34px;border-radius:9px;cursor:pointer;font-size:1rem}
.lang-x:hover{border-color:var(--gold);color:var(--gold)}
.lang-search{width:100%;background:var(--ink2);border:1px solid var(--line2);color:var(--text);border-radius:11px;
  padding:.72rem .9rem;font-family:var(--f-sans);font-size:.95rem;margin-bottom:.8rem}
.lang-search:focus{outline:none;border-color:var(--gold)}
.lang-list{overflow-y:auto;display:flex;flex-direction:column;gap:.15rem;padding-right:.2rem}
.lang-opt{display:flex;align-items:center;gap:.75rem;background:transparent;border:none;color:var(--text);
  padding:.7rem .6rem;border-radius:10px;cursor:pointer;font-family:var(--f-sans);font-size:.98rem;text-align:left;transition:background .2s}
.lang-opt:hover{background:var(--panel2)}
.lang-opt .lflag{font-size:1.3rem;line-height:1}
.lang-opt .lname{flex:1}
.lang-opt .lcheck{opacity:0;color:var(--gold);font-weight:700}
.lang-opt.active .lcheck{opacity:1}
.lang-opt.active{background:rgba(231,199,117,.08)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;
  overflow:hidden;padding:120px 0 90px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .hs{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;
  transform:scale(1.08);transition:opacity 1.4s ease;animation:heroKen 18s ease-in-out infinite alternate}
.hero-bg .hs.on{opacity:1}
@keyframes heroKen{from{transform:scale(1.08)}to{transform:scale(1.18)}}
.hero-veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(8,9,12,.72),rgba(8,9,12,.55) 40%,rgba(8,9,12,.85)),
  radial-gradient(80% 60% at 50% 40%,transparent,rgba(8,9,12,.5))}
.hero-inner{position:relative;z-index:2;max-width:900px}
.hero-kicker{font-family:var(--f-sans);text-transform:uppercase;letter-spacing:.4em;font-size:.74rem;font-weight:600;color:var(--ice);margin-bottom:1rem}
.hero-title{font-size:clamp(3rem,10vw,7rem);color:#fff;line-height:.98;letter-spacing:.03em;
  text-shadow:0 6px 40px rgba(0,0,0,.6)}
.hero-title .ht-two{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-family:var(--f-serif);font-size:clamp(1.15rem,2.6vw,1.55rem);color:#e6e4dd;font-weight:500;
  max-width:640px;margin:1.4rem auto 0;line-height:1.5}
.hero-badges{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:1.7rem}
.hb{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--gold-soft);
  border:1px solid rgba(231,199,117,.35);border-radius:999px;padding:.45rem .95rem;background:rgba(231,199,117,.05)}
.hero-cta{display:flex;gap:.8rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;width:26px;height:42px;
  border:1px solid var(--line2);border-radius:14px;display:flex;justify-content:center;padding-top:8px}
.hero-scroll span{width:3px;height:8px;background:var(--gold);border-radius:2px;animation:scrolld 1.6s ease-in-out infinite}
@keyframes scrolld{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}100%{opacity:0;transform:translateY(12px)}}

/* ---------- specs ---------- */
.specs{padding:5.5rem 0}
.spec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.spec-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .4s,border-color .4s,box-shadow .4s;position:relative}
.spec-card:hover{transform:translateY(-6px);border-color:rgba(231,199,117,.4);box-shadow:var(--shadow)}
.spec-media{aspect-ratio:4/3;overflow:hidden;position:relative}
.spec-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.spec-card:hover .spec-media img{transform:scale(1.08)}
.spec-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(12,13,17,.6))}
.spec-body{padding:1.3rem 1.3rem 1.5rem;flex:1;display:flex;flex-direction:column;position:relative}
.spec-body h3{font-size:1.28rem;color:#fff;margin-bottom:.5rem}
.spec-body p{font-size:.92rem;color:var(--muted);flex:1}
.spec-arrow{color:var(--gold);margin-top:1rem;font-size:.9rem;letter-spacing:.3em;transition:letter-spacing .3s}
.spec-card:hover .spec-arrow{letter-spacing:.6em}

/* ---------- featured ---------- */
.featured{padding:5.5rem 0;background:linear-gradient(180deg,transparent,rgba(20,22,29,.5),transparent)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.dish{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  transition:transform .35s,border-color .35s,box-shadow .35s}
.dish:hover{transform:translateY(-4px);border-color:rgba(231,199,117,.35);box-shadow:var(--shadow)}
.dish .d-media{aspect-ratio:4/3;overflow:hidden}
.dish .d-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.dish:hover .d-media img{transform:scale(1.07)}
.d-body{padding:1.1rem 1.15rem 1.25rem}
.d-top{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem}
.d-name{font-family:var(--f-serif);font-weight:700;font-size:1.24rem;color:#fff;line-height:1.15;letter-spacing:0}
.d-price{font-family:var(--f-sans);font-weight:600;font-size:.98rem;color:var(--gold);white-space:nowrap}
.d-desc{font-size:.86rem;color:var(--muted);margin-top:.35rem;line-height:1.45}

/* ---------- split ---------- */
.split{padding:4.5rem 0}
.split-inner{display:grid;grid-template-columns:1.05fr 1fr;gap:3rem;align-items:center}
.split-media{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.split-media img{width:100%;aspect-ratio:4/3.4;object-fit:cover}
.split-badge{position:absolute;top:1rem;left:1rem;background:rgba(10,11,15,.8);border:1px solid rgba(231,199,117,.4);
  color:var(--gold-soft);padding:.5rem 1rem;border-radius:999px;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;font-weight:600}
.split-body h2{font-size:clamp(1.8rem,4vw,2.7rem);color:#fff;margin-bottom:1rem}
.split-body p{color:var(--muted);font-size:1.02rem;margin-bottom:1.5rem;font-family:var(--f-serif);font-weight:500;font-size:1.2rem;line-height:1.5}
.rev-order .chi-media{order:2}

/* ---------- eventi teaser ---------- */
.eventi-teaser{background-size:cover;background-position:center;background-attachment:fixed;padding:6rem 0;text-align:center;overflow:hidden}
.et-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,12,.86),rgba(8,9,12,.7))}
.et-inner{position:relative;z-index:2;max-width:660px;margin-inline:auto}
.et-inner h2{font-size:clamp(2rem,5vw,3.2rem);color:#fff;margin-bottom:1rem}
.et-inner p{color:#d9d7d0;font-family:var(--f-serif);font-size:1.25rem;margin-bottom:1.8rem}

/* ---------- reviews marquee ---------- */
.reviews{padding:5rem 0;overflow:hidden}
.rev-head{text-align:center;margin-bottom:2.4rem}
.rev-head h2{font-size:clamp(1.9rem,4.4vw,3rem);color:#fff}
.rev-agg{margin-top:1rem;color:var(--muted);font-size:.95rem}
.rev-agg b{color:var(--gold);font-size:1.15rem}
.rev-agg-stars{color:var(--gold)}
.marquee{position:relative;width:100%;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)}
.marquee-track{display:flex;gap:1.2rem;width:max-content;animation:marq 60s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rev-card{flex:0 0 358px;width:358px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.4rem 1.5rem}
.rev-stars{color:var(--gold);letter-spacing:.15em;margin-bottom:.7rem;font-size:.95rem}
.rev-txt{font-family:var(--f-serif);font-size:1.12rem;color:#e6e4dd;line-height:1.5;font-weight:500}
.rev-name{margin-top:1rem;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ice2);font-weight:600}

/* ---------- gallery teaser + grid ---------- */
.gallery-teaser{padding:5rem 0}
.gt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.gt-cell,.g-cell,.ev-cell{border:none;padding:0;cursor:pointer;overflow:hidden;border-radius:12px;position:relative;background:var(--panel)}
.gt-cell{aspect-ratio:4/3}
.gt-cell img,.g-cell img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .5s}
.gt-cell:hover img,.g-cell:hover img{transform:scale(1.07)}
.gallery-body{padding:3.5rem 0 5rem}
.g-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.g-cell{aspect-ratio:1/1}
.ev-cell{aspect-ratio:4/3}
.ev-cell img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.ev-cell:hover img{transform:scale(1.06)}
.ev-cell span{position:absolute;left:0;right:0;bottom:0;padding:1.4rem .9rem .7rem;font-size:.8rem;color:#fff;
  background:linear-gradient(transparent,rgba(8,9,12,.85));text-align:left;letter-spacing:.02em}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(6,7,10,.94);display:flex;align-items:center;justify-content:center;padding:24px}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:var(--shadow)}
.lb-x,.lb-nav{position:absolute;background:rgba(20,22,29,.7);border:1px solid var(--line2);color:#fff;cursor:pointer;
  border-radius:50%;width:48px;height:48px;font-size:1.4rem;display:flex;align-items:center;justify-content:center;transition:.2s}
.lb-x:hover,.lb-nav:hover{border-color:var(--gold);color:var(--gold)}
.lb-x{top:20px;right:20px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}

/* ---------- page hero ---------- */
.page-hero{position:relative;min-height:56vh;display:flex;align-items:flex-end;padding:120px 0 3rem;
  background-size:cover;background-position:center;overflow:hidden}
.page-hero.short{min-height:44vh}
.ph-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,12,.55),rgba(8,9,12,.9))}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-size:clamp(2.3rem,6vw,4.2rem);color:#fff}
.ph-sub{font-family:var(--f-serif);font-size:clamp(1.1rem,2.4vw,1.4rem);color:#d9d7d0;max-width:640px;margin-top:.8rem}

/* ---------- menu ---------- */
.menu-sec{padding:3.2rem 0 5rem}
.mtabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;position:sticky;top:78px;z-index:40;
  padding:1rem 0;background:rgba(10,11,15,.85);backdrop-filter:blur(10px);margin-bottom:2.4rem;border-bottom:1px solid var(--line)}
.mtab{font-family:var(--f-sans);font-weight:600;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);background:transparent;border:1px solid var(--line2);border-radius:999px;padding:.55rem 1.1rem;cursor:pointer;transition:.25s}
.mtab:hover{color:var(--text);border-color:var(--gold2)}
.mtab.is-active{background:var(--gold-grad);color:#20180a;border-color:transparent}
.msec{font-family:var(--f-display);font-size:1.15rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ice2);
  margin:2.4rem 0 1.2rem;padding-bottom:.6rem;border-bottom:1px solid var(--line);text-align:center}
.msec:first-child{margin-top:0}
.dish-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.mpanel{animation:fadeIn .5s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.menu-note{margin-top:2.5rem;color:var(--muted);font-size:.84rem;text-align:center;max-width:720px;margin-inline:auto;font-style:italic}

/* ---------- glutine strip ---------- */
.glutine-strip{padding:2.5rem 0}
.gs-inner{display:flex;align-items:center;gap:1.5rem;background:linear-gradient(120deg,rgba(142,197,242,.08),rgba(231,199,117,.06));
  border:1px solid var(--line2);border-radius:var(--r);padding:1.6rem 1.9rem;flex-wrap:wrap}
.gs-badge{font-family:var(--f-display);font-size:1.5rem;color:var(--ice);flex-shrink:0}
.gs-inner p{color:#dcdad3;font-size:1.02rem}
.gs-inner b{color:#fff}

/* ---------- pranzo ---------- */
.pranzo-sec{padding:3.5rem 0 5rem}
.formula-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.formula{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.6rem;transition:.35s}
.formula:hover{border-color:rgba(231,199,117,.4);transform:translateY(-4px)}
.f-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.6rem;gap:1rem}
.f-top h3{font-size:1.3rem;color:#fff}
.f-price{font-family:var(--f-sans);font-weight:700;font-size:1.4rem;color:var(--gold)}
.formula p{color:var(--muted);font-size:.95rem}
.pranzo-incl{margin-top:2.2rem;text-align:center;color:var(--ice2);font-family:var(--f-serif);font-size:1.15rem}

/* ---------- eventi page ---------- */
.eventi-body{padding:3.5rem 0 5rem}
.ev-features{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2.6rem}
.evf{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.6rem 1rem;text-align:center}
.evf-n{display:block;font-family:var(--f-display);font-size:2.2rem;color:var(--gold);margin-bottom:.4rem}
.evf-l{font-size:.85rem;color:var(--muted);letter-spacing:.04em}
.ev-text{max-width:760px;margin:0 auto 2.6rem;text-align:center;color:#dcdad3;font-family:var(--f-serif);font-size:1.25rem;line-height:1.55}
.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}

/* ---------- chi siamo ---------- */
.chi-body{padding:3.5rem 0 4rem}
.chi-lead{max-width:820px;margin:0 auto 3.5rem;text-align:center;font-family:var(--f-serif);font-size:clamp(1.3rem,3vw,1.8rem);color:#e6e4dd;line-height:1.5}
.chi-split{display:grid;grid-template-columns:1fr 1fr;gap:2.6rem;align-items:center;margin-bottom:3rem}
.chi-media{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.chi-media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.chi-copy h2{font-size:clamp(1.6rem,3.5vw,2.3rem);color:#fff;margin-bottom:1rem}
.chi-copy p{color:var(--muted);font-size:1.02rem;line-height:1.6}
.chi-values{display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;margin-top:1.2rem}
.chi-values span{color:var(--gold-soft);font-size:.85rem;letter-spacing:.04em}

/* ---------- contatti ---------- */
.contatti-body{padding:3.5rem 0 4.5rem}
.contatti-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:2rem;align-items:start}
.ci-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:2rem}
.ci-block{padding-block:1rem;border-bottom:1px solid var(--line)}
.ci-block:first-child{padding-top:0}.ci-block:last-of-type{border-bottom:none}
.ci-block h3{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ice2);margin-bottom:.5rem;font-family:var(--f-sans);font-weight:600}
.ci-block p,.ci-block a{color:#dcdad3;font-size:1.05rem}
.ci-block a:hover{color:var(--gold-soft)}
.ci-row{display:flex;justify-content:space-between;gap:1rem;padding:.25rem 0}
.ci-role{color:var(--muted);font-size:.9rem}
.pay-list{display:flex;flex-wrap:wrap;gap:.4rem}
.pay-chip{font-size:.74rem;border:1px solid var(--line2);border-radius:6px;padding:.3rem .6rem;color:var(--muted)}
.ci-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}
.ci-badges span{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-soft);border:1px solid rgba(231,199,117,.3);border-radius:999px;padding:.35rem .8rem}
.ci-side{display:flex;flex-direction:column;gap:1.4rem}
.map-wrap{border-radius:var(--r);overflow:hidden;border:1px solid var(--line2);position:relative}
.map-wrap iframe{width:100%;height:320px;border:0;display:block;filter:grayscale(.3) contrast(1.05)}
.map-open{position:absolute;bottom:12px;right:12px;background:rgba(10,11,15,.9)}
.ci-form{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:1.8rem}
.ci-form h3{font-size:1.3rem;color:#fff;margin-bottom:1rem}
.ci-form input,.ci-form textarea{width:100%;background:var(--ink2);border:1px solid var(--line2);color:var(--text);
  border-radius:11px;padding:.8rem 1rem;font-family:var(--f-sans);font-size:.98rem;margin-bottom:.8rem}
.ci-form input:focus,.ci-form textarea:focus{outline:none;border-color:var(--gold)}
.ci-or{margin-top:.6rem;text-align:center;color:var(--muted);font-size:.9rem}
.ci-or a{color:var(--gold-soft);font-weight:600}

/* ---------- faq ---------- */
.faq{padding:4rem 0 5rem}
.faq .sec-title{text-align:center;margin-bottom:2.4rem}
.faq-list{max-width:820px;margin-inline:auto;display:flex;flex-direction:column;gap:.7rem}
.faq-item{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:transparent;border:none;
  color:#fff;font-family:var(--f-serif);font-weight:700;font-size:1.18rem;text-align:left;padding:1.15rem 1.3rem;cursor:pointer}
.faq-ico{color:var(--gold);font-size:1.4rem;flex-shrink:0;transition:transform .3s}
.faq-item.open .faq-ico{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 1.3rem 1.2rem;color:var(--muted);font-size:.98rem;line-height:1.6}

/* ---------- footer ---------- */
.site-foot{background:var(--ink2);border-top:1px solid var(--line);padding:3.5rem 0 1.5rem;margin-top:1rem;position:relative}
.foot-grid{width:min(100% - 40px,var(--wrap));margin-inline:auto;display:grid;grid-template-columns:1.6fr 1fr 1.4fr 1fr;gap:2rem}
.foot-logo{height:46px;width:auto;margin-bottom:1rem}
.foot-tag{color:var(--muted);font-size:.92rem;max-width:320px;margin-bottom:1rem}
.foot-social{display:flex;gap:1rem}
.foot-social a{color:var(--ice2);font-size:.85rem;letter-spacing:.05em}
.foot-social a:hover{color:var(--gold-soft)}
.foot-col h4{font-family:var(--f-sans);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1rem;font-weight:600}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.foot-col a,.foot-col li{color:var(--muted);font-size:.9rem}
.foot-col a:hover{color:var(--text)}
.foot-contacts .fl-role{display:block;color:var(--ice2);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;margin-top:.3rem}
.foot-hours{color:var(--muted);font-size:.9rem}
.foot-badges{color:var(--gold-soft);font-size:.82rem;margin-top:.6rem}
.foot-bottom{width:min(100% - 40px,var(--wrap));margin:2.5rem auto 0;padding-top:1.4rem;border-top:1px solid var(--line);
  color:var(--muted);font-size:.8rem;text-align:center}
.to-top{position:fixed;right:20px;bottom:20px;z-index:60;width:46px;height:46px;border-radius:50%;background:var(--gold-grad);
  color:#20180a;display:flex;align-items:center;justify-content:center;font-size:1rem;opacity:0;pointer-events:none;
  transition:opacity .3s,transform .3s;box-shadow:0 10px 26px -10px rgba(231,199,117,.6)}
.to-top.show{opacity:1;pointer-events:auto}
.to-top:hover{transform:translateY(-3px)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .nav-desk{display:none}
  .burger{display:flex}
  .head-actions .btn-book{display:none}
  .spec-grid{grid-template-columns:repeat(2,1fr)}
  .g-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .feat-grid,.dish-grid,.formula-grid,.ev-grid,.gt-grid{grid-template-columns:repeat(2,1fr)}
  .ev-features{grid-template-columns:repeat(2,1fr)}
  .split-inner,.contatti-grid,.chi-split{grid-template-columns:1fr;gap:1.8rem}
  .rev-order .chi-media{order:0}
  .eventi-teaser{background-attachment:scroll}
  .mtabs{top:70px}
  .mobile-nav{inset-block-start:70px}
}
@media(max-width:560px){
  .wrap{width:min(100% - 32px,var(--wrap))}
  .head-inner{min-height:66px}
  .brand-logo{height:40px}
  .hero{padding:100px 0 70px}
  .spec-grid,.feat-grid,.dish-grid,.formula-grid,.ev-grid,.gt-grid,.g-grid,.ev-features{grid-template-columns:1fr}
  .g-grid{grid-template-columns:repeat(2,1fr)}
  .rev-card{flex-basis:280px;width:280px}
  .specs,.featured,.reviews,.gallery-teaser{padding:3.4rem 0}
  .ci-card,.ci-form{padding:1.4rem}
  .foot-grid{grid-template-columns:1fr 1fr}
  .btn{font-size:.76rem;padding:.9em 1.4em}
  .mtabs{top:66px}
  .mobile-nav{inset-block-start:66px}
}
@media(max-width:380px){
  .foot-grid{grid-template-columns:1fr}
  .hero-badges .hb{font-size:.66rem}
}

/* ---------- reduced motion (marquee & gem stay) ---------- */
@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}
  .hero-bg .hs{animation:none}
  .marquee-track{animation:marq 60s linear infinite!important}
  .gem-rot{animation:gemSpin 14s linear infinite!important}
  .intro-logo,.intro-gem{opacity:1!important;animation:none!important}
  .intro-bar span{width:100%!important;animation:none!important}
}
