/* ============================================================
   Donna Caterina — Ristorante di pesce siciliano · Milano
   Editoriale mediterraneo chiaro perla — Fraunces + Hanken Grotesk
   ============================================================ */

/* ---- Self-hosted fonts ---- */
@font-face{
  font-family:'Fraunces';
  src:url('assets/fonts/fraunces-normal.woff2') format('woff2');
  font-weight:300 700; font-style:normal; font-display:swap;
  font-optical-sizing:auto;
}
@font-face{
  font-family:'Fraunces';
  src:url('assets/fonts/fraunces-italic.woff2') format('woff2');
  font-weight:300 700; font-style:italic; font-display:swap;
  font-optical-sizing:auto;
}
@font-face{font-family:'Hanken';src:url('assets/fonts/hanken-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Hanken';src:url('assets/fonts/hanken-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'Hanken';src:url('assets/fonts/hanken-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:'Hanken';src:url('assets/fonts/hanken-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:'Hanken';src:url('assets/fonts/hanken-800.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap;}

/* ---- Tokens ---- */
:root{
  --perla:#FBF8F2;        /* fondo principale */
  --perla-2:#F4EEE3;      /* fondo sezioni alterne */
  --crema:#FFFDF8;
  --petrolio:#1B2A2C;     /* testo / scuro */
  --petrolio-2:#24383B;
  --inchiostro:#2C3A3C;
  --grigio:#5C6B6C;
  --hair:#E7DECF;         /* hairline */
  --arancio:#F58C36;      /* accento agrume */
  --arancio-d:#E0751F;
  --oro:#C9952F;          /* oro brand */
  --oro-d:#A87A1F;
  --mare:#2E6E73;         /* richiamo mare */
  --ombra:0 24px 60px -28px rgba(27,42,44,.32);
  --ombra-s:0 10px 30px -18px rgba(27,42,44,.28);
  --radius:18px;
  --maxw:1240px;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Hanken','Helvetica Neue',Arial,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
[hidden]{display:none!important}   /* Safari-proof: nessun overlay/intro resta visibile */
html{
  overflow-x:hidden;            /* regola Q: overflow su html, non body */
  scroll-padding-top:96px;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--inchiostro);
  background:var(--perla);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;color:var(--petrolio);margin:0 0 .5em;font-optical-sizing:auto;}
h1,h2,h3,h4,p,span,a,li{overflow-wrap:break-word;}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.serif{font-family:var(--serif)}
.italic{font-style:italic}
.smallcaps{font-variant:small-caps;letter-spacing:.18em;text-transform:lowercase}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:clamp(56px,8vw,118px) 0;position:relative}
.section--alt{background:var(--perla-2)}
.section--ink{background:var(--petrolio);color:#E8EDEC}
.section--ink h2,.section--ink h3{color:#FBF8F2}
.eyebrow{
  font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.26em;
  text-transform:uppercase;color:var(--arancio-d);display:inline-flex;align-items:center;gap:.7em;margin-bottom:1.1rem;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--oro);display:inline-block}
.section--ink .eyebrow{color:var(--oro)}
.h-display{font-size:clamp(2.3rem,5.6vw,4.3rem);letter-spacing:-.012em}
.h-2{font-size:clamp(1.9rem,4vw,3rem);letter-spacing:-.01em}
.lede{font-size:clamp(1.06rem,1.8vw,1.28rem);color:var(--grigio);max-width:60ch}
.center{text-align:center}
.muted{color:var(--grigio)}

/* note a margine / griglia editoriale */
.editorial{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.45fr);gap:clamp(28px,5vw,76px);align-items:start}
.sidenote{
  font-family:var(--serif);font-style:italic;font-size:1.15rem;color:var(--mare);
  border-left:2px solid var(--oro);padding-left:1.1rem;line-height:1.5;
}

/* ---- Buttons ---- */
.btn{
  --bg:var(--petrolio);--fg:#FBF8F2;
  display:inline-flex;align-items:center;gap:.6em;justify-content:center;
  font-family:var(--sans);font-weight:700;font-size:.96rem;letter-spacing:.01em;
  background:var(--bg);color:var(--fg);padding:.92em 1.5em;border-radius:999px;
  border:1.5px solid var(--bg);cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s,background .25s,color .25s;
  box-shadow:var(--ombra-s);
}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 36px -18px rgba(27,42,44,.5)}
.btn--accent{--bg:var(--arancio);--fg:#3A1E06;border-color:var(--arancio)}
.btn--accent:hover{--bg:var(--arancio-d)}
.btn--ghost{--bg:transparent;--fg:var(--petrolio);border-color:var(--hair)}
.btn--ghost:hover{--fg:var(--petrolio);background:var(--crema)}
.section--ink .btn--ghost{--fg:#FBF8F2;border-color:rgba(255,255,255,.28)}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.8rem}

/* ============== HEADER ============== */
.site-header{
  position:-webkit-sticky;position:sticky;top:0;z-index:80;
  background:rgba(251,248,242,.92);
  -webkit-backdrop-filter:saturate(140%) blur(12px);backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s;
}
/* iOS Safari: se backdrop-filter non è supportato, sfondo pieno (niente testo che traspare sull'hero) */
@supports not ((-webkit-backdrop-filter:blur(1px)) or (backdrop-filter:blur(1px))){
  .site-header{background:rgba(251,248,242,.98)}
}
.site-header.scrolled{border-color:var(--hair);box-shadow:0 6px 24px -20px rgba(27,42,44,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;height:78px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand__badge{
  background:var(--petrolio);border-radius:14px;padding:8px;display:grid;place-items:center;
  box-shadow:var(--ombra-s);
}
.brand__badge img{height:56px;width:auto;display:block}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--serif);font-weight:600;font-size:1.18rem;color:var(--petrolio);letter-spacing:.01em}
.brand__sub{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--oro-d);font-weight:700;margin-top:3px}
.nav__links{display:flex;align-items:center;gap:6px}
.nav__links a{
  font-weight:600;font-size:.95rem;color:var(--inchiostro);padding:.5em .8em;border-radius:999px;
  position:relative;transition:color .2s,background .2s;
}
.nav__links a:hover,.nav__links a.active{color:var(--arancio-d)}
.nav__links a.active{background:rgba(245,140,54,.1)}
.nav__right{display:flex;align-items:center;gap:10px}
.nav__cta{display:inline-flex}

/* language pill */
.lang-pill{
  display:inline-flex;align-items:center;gap:.5em;background:var(--crema);border:1px solid var(--hair);
  padding:.46em .7em;border-radius:999px;cursor:pointer;font-family:var(--sans);font-weight:700;font-size:.85rem;color:var(--petrolio);
  transition:background .2s,border-color .2s;
}
.lang-pill:hover{background:#fff;border-color:var(--oro)}
.lang-pill .flag{font-size:1.05rem;line-height:1}
.lang-pill .chev{width:11px;height:11px;opacity:.6}

/* hamburger */
.burger{display:none;background:var(--crema);border:1px solid var(--hair);border-radius:12px;width:46px;height:46px;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{width:20px;height:2px;background:var(--petrolio);border-radius:2px;transition:transform .3s,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:95;display:flex;visibility:hidden;pointer-events:none}
.drawer[hidden]{display:none!important}
.drawer__bg{position:absolute;inset:0;background:rgba(27,42,44,.46);opacity:0;transition:opacity .3s}
.drawer__panel{
  position:relative;margin-left:auto;width:min(86vw,360px);height:100%;background:var(--perla);
  padding:26px 24px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .36s var(--ease);
  box-shadow:-20px 0 60px -30px rgba(0,0,0,.5);overflow-y:auto;
}
.drawer.show{visibility:visible;pointer-events:auto}
.drawer.show .drawer__bg{opacity:1}
.drawer.show .drawer__panel{transform:translateX(0)}
.drawer__panel a{font-family:var(--serif);font-size:1.4rem;color:var(--petrolio);padding:.5em 0;border-bottom:1px solid var(--hair)}
.drawer__panel a:last-of-type{border-bottom:none}
.drawer__close{align-self:flex-end;background:none;border:none;font-size:1.7rem;color:var(--petrolio);cursor:pointer;line-height:1;margin-bottom:6px}

/* ============== INTRO / PRELOADER ============== */
.intro{
  position:fixed;inset:0;z-index:200;background:var(--petrolio);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:26px;
  transition:transform .9s var(--ease),opacity .6s ease;
}
.intro[hidden]{display:none!important}
.intro.lift{transform:translateY(-102%);opacity:.2}
.intro__logo{height:clamp(150px,30vw,200px);width:auto;filter:drop-shadow(0 10px 30px rgba(0,0,0,.4));
  opacity:0;transform:scale(.86);animation:introLogo 1.5s var(--ease) .15s forwards}
@keyframes introLogo{0%{opacity:0;transform:scale(.86)}60%{opacity:1;transform:scale(1)}100%{opacity:1;transform:scale(1)}}
.intro__wave{width:min(340px,70vw);height:30px;overflow:visible}
.intro__wave path{fill:none;stroke:var(--oro);stroke-width:2.4;stroke-dasharray:600;stroke-dashoffset:600;animation:waveDraw 1.7s var(--ease) .5s forwards}
@keyframes waveDraw{to{stroke-dashoffset:0}}
.intro__cite{font-family:var(--serif);font-style:italic;color:var(--oro);font-size:clamp(.95rem,2vw,1.18rem);opacity:0;animation:fadeUp .8s ease 1s forwards;text-align:center;padding:0 24px}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* citrus rotating signature */
.citrus{display:inline-block;animation:spin 22s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============== HERO ============== */
.hero{position:relative;background:var(--perla);overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(26px,4vw,64px);align-items:center;padding:clamp(40px,6vw,78px) 0 clamp(48px,7vw,96px)}
.hero__kicker{display:flex;align-items:center;gap:12px;margin-bottom:1.4rem}
.hero__kicker .star{color:var(--oro)}
.hero h1{font-size:clamp(2.7rem,6.6vw,5.2rem);letter-spacing:-.018em;margin-bottom:.4em}
.hero h1 .accent{color:var(--arancio);font-style:italic}
.hero__lede{font-size:clamp(1.08rem,1.9vw,1.32rem);color:var(--grigio);max-width:46ch;margin-bottom:.4rem}
.hero__media{position:relative}
.hero__photo{
  border-radius:26px;overflow:hidden;box-shadow:var(--ombra);position:relative;aspect-ratio:4/5;
  border:1px solid var(--hair);
}
.hero__photo img{width:100%;height:100%;object-fit:cover}
.hero__badge{
  position:absolute;left:-22px;bottom:26px;background:var(--crema);border:1px solid var(--hair);
  border-radius:16px;padding:14px 18px;box-shadow:var(--ombra-s);display:flex;align-items:center;gap:12px;max-width:240px;
}
.hero__badge .num{font-family:var(--serif);font-size:1.8rem;font-weight:600;color:var(--petrolio);line-height:1}
.hero__badge .lbl{font-size:.78rem;color:var(--grigio);line-height:1.25}
.hero__citrus{position:absolute;top:-26px;right:-18px;width:104px;height:104px;z-index:3}
.wavestrip{display:block;width:100%;height:34px;color:var(--mare);opacity:.6}
.wavestrip svg{width:100%;height:100%}

/* facts bar */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);border-radius:var(--radius);overflow:hidden;border:1px solid var(--hair)}
.facts div{background:var(--crema);padding:20px 18px;text-align:center}
.facts .k{font-family:var(--serif);font-size:1.5rem;color:var(--arancio-d);font-weight:600;display:block}
.facts .v{font-size:.82rem;color:var(--grigio);margin-top:3px;display:block}

/* ============== CARDS / GRID ============== */
.grid{display:grid;gap:26px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--crema);border:1px solid var(--hair);border-radius:var(--radius);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s}
.card:hover{transform:translateY(-5px);box-shadow:var(--ombra)}
.card__media{aspect-ratio:4/3;position:relative;overflow:hidden}
.card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card:hover .card__media img{transform:scale(1.06)}
.card__body{padding:22px 22px 26px}
.card__body h3{font-size:1.32rem;margin-bottom:.3em}
.card__body p{color:var(--grigio);font-size:.96rem;margin:0}
.tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mare);margin-bottom:.7em}

/* ============== MENU ============== */
.menu-tabs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:0 auto 2.6rem;max-width:880px}
.menu-tab{
  font-family:var(--sans);font-weight:700;font-size:.9rem;padding:.6em 1.15em;border-radius:999px;
  border:1px solid var(--hair);background:var(--crema);color:var(--inchiostro);cursor:pointer;transition:all .22s;
}
.menu-tab:hover{border-color:var(--oro);color:var(--oro-d)}
.menu-tab.active{background:var(--petrolio);color:#FBF8F2;border-color:var(--petrolio)}
.menu-panel{display:none}
.menu-panel.active{display:block;animation:fadeUp .5s ease}
.menu-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 56px;max-width:1040px;margin:0 auto}
.menu-item{display:flex;align-items:baseline;gap:10px;padding:14px 0;border-bottom:1px dashed var(--hair)}
.menu-item__main{flex:1;min-width:0}
.menu-item__name{font-family:var(--serif);font-size:1.16rem;font-weight:600;color:var(--petrolio);display:inline}
.menu-item__desc{font-size:.9rem;color:var(--grigio);margin-top:2px}
.menu-item__dots{flex:1;border-bottom:1px dotted var(--hair);transform:translateY(-4px);min-width:18px;margin:0 6px}
.menu-item__price{font-family:var(--serif);font-weight:600;color:var(--arancio-d);font-size:1.12rem;white-space:nowrap}
.menu-note{text-align:center;color:var(--grigio);font-style:italic;font-family:var(--serif);margin-top:2.2rem;font-size:1.05rem}

/* ============== GALLERY ============== */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;grid-auto-flow:dense}
.gallery figure{margin:0;position:relative;overflow:hidden;border-radius:14px;cursor:pointer;background:var(--perla-2);box-shadow:var(--ombra-s)}
.gallery figure::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(27,42,44,.34));opacity:0;transition:opacity .3s}
.gallery figure:hover::after{opacity:1}
.gallery img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gallery figure:hover img{transform:scale(1.07)}
.gallery figcaption{position:absolute;left:14px;bottom:12px;color:#fff;font-family:var(--serif);font-style:italic;font-size:1rem;z-index:2;opacity:0;transform:translateY(6px);transition:.3s}
.gallery figure:hover figcaption{opacity:1;transform:none}
.g-span-6{grid-column:span 6}.g-span-4{grid-column:span 4}.g-span-3{grid-column:span 3}.g-span-8{grid-column:span 8}
.g-tall{aspect-ratio:3/4}.g-wide{aspect-ratio:16/10}.g-sq{aspect-ratio:1/1}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:160;background:rgba(20,28,29,.92);display:flex;align-items:center;justify-content:center;padding:24px}
.lightbox[hidden]{display:none!important}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox__btn{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;width:52px;height:52px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:grid;place-items:center;transition:background .2s}
.lightbox__btn:hover{background:rgba(255,255,255,.25)}
.lb-close{top:22px;right:22px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}

/* ============== REVIEWS MARQUEE ============== */
.rev-aggr{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:center;margin-bottom:2.4rem}
.rev-aggr .chip{display:inline-flex;align-items:center;gap:.6em;background:var(--crema);border:1px solid var(--hair);border-radius:999px;padding:.6em 1.1em;font-weight:600;font-size:.95rem}
.rev-aggr .chip .stars{color:var(--oro);letter-spacing:.05em}
.rev-aggr .chip b{font-family:var(--serif);font-size:1.15rem;color:var(--petrolio)}
.marquee{overflow:hidden;position:relative;-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:22px;width:max-content;animation:scrollx 64s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rev-card{width:340px;flex:0 0 340px;background:var(--crema);border:1px solid var(--hair);border-radius:var(--radius);padding:24px 24px 22px;box-shadow:var(--ombra-s)}
.section--ink .rev-card{background:var(--petrolio-2);border-color:rgba(255,255,255,.1)}
.rev-card .stars{color:var(--oro);font-size:1rem;letter-spacing:.06em;margin-bottom:.6em}
.rev-card p{font-family:var(--serif);font-style:italic;font-size:1.04rem;color:var(--inchiostro);margin:0 0 1rem;line-height:1.5}
.section--ink .rev-card p{color:#E8EDEC}
.rev-card .who{display:flex;align-items:center;gap:11px}
.rev-card .av{width:38px;height:38px;border-radius:50%;background:var(--arancio);color:#3A1E06;display:grid;place-items:center;font-weight:800;font-family:var(--sans);font-size:1rem}
.rev-card .who b{display:block;font-size:.95rem;color:var(--petrolio)}
.section--ink .rev-card .who b{color:#fff}
.rev-card .who span{font-size:.8rem;color:var(--grigio)}

/* ============== CONTACT / MAP ============== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:start}
.info-list{list-style:none;padding:0;margin:0;display:grid;gap:18px}
.info-list li{display:flex;gap:14px;align-items:flex-start;min-width:0}
.info-list li>div{min-width:0;overflow-wrap:break-word;word-break:break-word}
.info-list .ic{flex-shrink:0;width:42px;height:42px;border-radius:12px;background:rgba(245,140,54,.12);display:grid;place-items:center;color:var(--arancio-d)}
.info-list .ic svg{width:20px;height:20px}
.info-list .lab{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--grigio);font-weight:700}
.info-list a,.info-list .val{font-family:var(--serif);font-size:1.18rem;color:var(--petrolio);font-weight:500;overflow-wrap:break-word;word-break:break-word}
.info-list a:hover{color:var(--arancio-d)}
.map-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--hair);box-shadow:var(--ombra-s)}
.map-card iframe{width:100%;height:380px;border:0;display:block;background:var(--perla-2)}
.map-actions{padding:14px;background:var(--crema);text-align:center}

/* form */
.form{display:grid;gap:14px}
.form label{font-size:.8rem;font-weight:700;color:var(--grigio);letter-spacing:.04em}
.form input,.form textarea,.form select{
  width:100%;font-family:var(--sans);font-size:1rem;padding:.85em 1em;border-radius:12px;
  border:1px solid var(--hair);background:var(--crema);color:var(--inchiostro);transition:border-color .2s,box-shadow .2s;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--arancio);box-shadow:0 0 0 3px rgba(245,140,54,.15)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-note{font-size:.82rem;color:var(--grigio)}
.form select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237A8483' stroke-width='2.4'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1em center;padding-right:2.6em}
.form input,.form textarea,.form select{min-height:48px}
.form textarea{min-height:96px;resize:vertical}
.form .btn{min-height:48px}
.form-err{font-size:.9rem;color:#9A2A1E;background:#FCEDEA;border:1px solid #F1C7BF;border-radius:12px;padding:.8em 1em;line-height:1.5}
.prenota-ok{text-align:center;max-width:560px;margin:0 auto;padding:2.4rem 1.2rem}
.prenota-ok__ic{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:rgba(245,140,54,.14);color:var(--arancio);margin-bottom:1.1rem}
.prenota-ok__ic svg{width:30px;height:30px}
.prenota-ok .btn-row{justify-content:center}

/* ============== FAQ ============== */
.faq{max-width:840px;margin:0 auto;display:grid;gap:12px}
.faq details{background:var(--crema);border:1px solid var(--hair);border-radius:14px;padding:4px 22px;transition:box-shadow .25s}
.faq details[open]{box-shadow:var(--ombra-s)}
.faq summary{font-family:var(--serif);font-size:1.18rem;font-weight:600;color:var(--petrolio);cursor:pointer;padding:18px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--arancio);transition:transform .3s;flex-shrink:0}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:0 0 18px;color:var(--grigio);line-height:1.6}

/* ============== STORY / split image ============== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.split--rev .split__media{order:2}
.split__media{border-radius:22px;overflow:hidden;box-shadow:var(--ombra);aspect-ratio:4/5;border:1px solid var(--hair)}
.split__media img{width:100%;height:100%;object-fit:cover}
.pullquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,3vw,2rem);color:var(--petrolio);line-height:1.32;border-left:3px solid var(--oro);padding-left:1.2rem;margin:0}

/* ============== FOOTER ============== */
.site-footer{background:var(--petrolio);color:#C9D2D1;padding:64px 0 28px}
.site-footer h4{color:#FBF8F2;font-size:1.05rem;margin-bottom:1em}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
.footer-grid a{color:#C9D2D1;font-size:.95rem;display:block;padding:3px 0;transition:color .2s}
.footer-grid a:hover{color:var(--arancio)}
.footer-brand img{height:70px;background:rgba(255,255,255,.04);border-radius:14px;padding:10px;margin-bottom:14px}
.footer-brand p{font-size:.92rem;line-height:1.55;color:#9FAEAD;max-width:34ch}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:44px;padding-top:22px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:.82rem;color:#8A9897}
.footer-bottom a{color:#8A9897}
.social-row{display:flex;gap:10px;margin-top:10px}
.social-row a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);display:grid;place-items:center;color:#C9D2D1;padding:0}
.social-row a:hover{background:var(--arancio);color:#3A1E06}
.social-row svg{width:18px;height:18px}

/* ============== FAB whatsapp ============== */
.fab{position:fixed;right:20px;bottom:20px;z-index:70;width:58px;height:58px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(37,211,102,.6);transition:transform .3s,opacity .3s}
.fab:hover{transform:scale(1.08)}
.fab svg{width:30px;height:30px;fill:#fff}
.fab.hide{opacity:0;pointer-events:none;transform:translateY(20px)}

/* ============== LANG MODAL ============== */
.lang-modal{position:fixed;inset:0;z-index:180;display:flex;align-items:center;justify-content:center;padding:20px}
.lang-modal[hidden]{display:none!important}
/* difesa in profondità: senza .show non deve intercettare i click (regola W) */
.lang-modal:not(.show),.drawer:not(.show){pointer-events:none}
.lang-modal.show,.drawer.show{pointer-events:auto}
.lang-modal__bg{position:absolute;inset:0;background:rgba(27,42,44,.4);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;transition:opacity .3s}
.lang-modal.show .lang-modal__bg{opacity:1}
.lang-modal__card{
  position:relative;background:var(--crema);border-radius:26px;width:min(420px,94vw);max-height:min(540px,86vh);
  display:flex;flex-direction:column;box-shadow:0 40px 90px -30px rgba(0,0,0,.5);border:1px solid var(--hair);
  opacity:0;transform:scale(.95);filter:blur(4px);transition:opacity .3s var(--ease),transform .3s var(--ease),filter .3s;
}
.lang-modal.show .lang-modal__card{opacity:1;transform:scale(1);filter:blur(0)}
.lang-modal__head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 14px}
.lang-modal__head h3{margin:0;font-size:1.3rem}
.lang-modal__close{background:none;border:none;font-size:1.6rem;color:var(--grigio);cursor:pointer;line-height:1}
.lang-search{margin:0 24px 12px;position:relative}
.lang-search input{width:100%;padding:.75em 1em .75em 2.4em;border-radius:12px;border:1px solid var(--hair);background:var(--perla);font-family:var(--sans);font-size:.95rem}
.lang-search input:focus{outline:none;border-color:var(--oro)}
.lang-search svg{position:absolute;left:.85em;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--grigio)}
.lang-list{overflow-y:auto;padding:4px 16px 18px;display:grid;gap:2px}
.lang-list::-webkit-scrollbar{width:7px}
.lang-list::-webkit-scrollbar-thumb{background:var(--hair);border-radius:4px}
.lang-opt{display:flex;align-items:center;gap:12px;padding:.7em .8em;border-radius:12px;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:var(--sans);font-size:1rem;color:var(--inchiostro);transition:background .15s}
.lang-opt:hover{background:var(--perla-2)}
.lang-opt.sel{background:rgba(245,140,54,.12)}
.lang-opt .flag{font-size:1.3rem}
.lang-opt .nm{flex:1}
.lang-opt .ck{color:var(--arancio-d);opacity:0}
.lang-opt.sel .ck{opacity:1}

/* ============== REVEAL ============== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}

/* ============== RESPONSIVE ============== */
@media (max-width:1080px){
  .nav__links{display:none}
  .burger{display:flex}
  .nav__cta{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .hero__grid{grid-template-columns:1fr;gap:30px}
  .hero__media{order:-1;max-width:440px;margin:0 auto}
  .editorial{grid-template-columns:1fr}
  .split,.split--rev .split__media,.contact-grid{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .grid-3{grid-template-columns:1fr 1fr}
  .menu-list{grid-template-columns:1fr;gap:0}
  .facts{grid-template-columns:1fr 1fr}
  .gallery .g-span-6,.gallery .g-span-8{grid-column:span 6}
  .gallery .g-span-4,.gallery .g-span-3{grid-column:span 6}
}
@media (max-width:560px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .facts{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery figure{grid-column:span 1!important}
  .brand__sub{display:none}
  .hero__badge{left:8px}
  .hero__citrus{width:78px;height:78px;right:0;top:-14px}
}

/* schermi piccoli (~320–430px): header compatto, niente overflow */
@media (max-width:430px){
  .nav{gap:8px;height:70px}
  .wrap{padding:0 16px}
  .brand{gap:9px;min-width:0}
  .brand__badge img{height:46px}
  .brand__name{font-size:1rem}
  .nav__right{gap:7px;flex-shrink:0}
  .lang-pill{padding:7px 9px;gap:5px}
  .lang-pill .nm{display:none}            /* lascia bandiera+freccia: piu' compatta */
  .burger{width:42px;height:42px}
}
@media (max-width:340px){
  .brand__txt{display:none}               /* resta il logo reale (badge), wordmark via */
}

/* reduced motion — ma marquee resta in moto (regola K) */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .intro{display:none!important}
  .marquee__track{animation:scrollx 64s linear infinite!important}
  .citrus{animation:spin 22s linear infinite!important}
}
