/* ============== DESIGN TOKENS ============== */
:root{
  /* brand palette (derivata dal logo + post) */
  --bordeaux:#7A1B3C;
  --bordeaux-deep:#5C1430;
  --coral:#EF8276;
  --coral-bright:#F2685B;
  --accent-ink:#C42E4D; /* accento per TESTO su fondo chiaro (contrasto AA ~5:1) */
  --strawberry:#E2342B;
  --cocoa:#6B4A2B;
  --cocoa-light:#A9794B;
  --leaf:#6FAE5A;
  --leaf-deep:#4E8C3F;

  /* superfici */
  --cream:#FFF8F4;
  --pink-mist:#FBE3EA;
  --pink-wash:#FCEAF0;
  --pink-soft:#F8D2DD;
  --peach:#FBE0D2;
  --white:#ffffff;

  /* testo */
  --ink:#3A2730;
  --muted:#7C5C68;

  /* tipografia */
  --font-display:"Playfair Display","Georgia",serif;
  --font-script:"Caveat","Segoe Script",cursive;
  --font-brand:"Yellowtail","Brush Script MT",cursive;
  --font-body:"Nunito",system-ui,-apple-system,sans-serif;

  /* misure */
  --nav-h:78px;
  --maxw:1200px;
  --cut:2.1vw; /* inclinazione del taglio diagonale (~1.2°, costante a ogni larghezza) come il marquee */
  --radius:4px;
  --radius-sm:4px;
  --shadow:0 22px 50px -24px rgba(122,27,60,.34);
  --shadow-soft:0 14px 34px -20px rgba(122,27,60,.28);
  --ring:0 0 0 4px rgba(239,130,118,.28);
}

/* ============== RESET / BASE ============== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
section{position:relative}
::selection{background:var(--coral);color:#fff}

/* grana sottile su tutta la pagina */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{width:min(100% - 40px,var(--maxw));margin-inline:auto}
/* skip-link accessibilità: visibile solo al focus da tastiera */
.skip-link{position:absolute;left:12px;top:-60px;z-index:100;background:var(--bordeaux);color:#fff;
  padding:.7rem 1.1rem;border-radius:0 0 4px 4px;font-weight:800;transition:top .2s}
.skip-link:focus{top:0;outline:3px solid var(--coral)}
main:focus{outline:none}
.eyebrow{
  font-family:var(--font-script);font-size:1.6rem;color:var(--accent-ink);
  font-weight:700;line-height:1;display:inline-block;transform:rotate(-3deg);
}
h1,h2,h3{font-family:var(--font-display);color:var(--bordeaux);line-height:1.04;margin:0;font-weight:600}
.section-title{font-size:clamp(2rem,4.4vw,3.2rem);letter-spacing:-.5px}
/* highlight in stile logo: script a pennello (Yellowtail) invece del corsivo serif */
.section-title em,
.hero-copy h1 .ital,
.page-hero h1 em{
  font-family:var(--font-script);font-style:normal;font-weight:700;
  color:var(--accent-ink);font-size:1.3em;line-height:1;
  padding-right:.06em;
}
/* su fondo scuro l'accento torna chiaro (leggibile sul bordeaux) */
.contact .section-title em,.contact h2 em{color:var(--coral-bright)}
.lead{color:var(--muted);font-size:1.08rem;max-width:54ch}

/* burst corallo (i trattini del logo) */
.spark{display:inline-block;vertical-align:middle}
.spark line{stroke:var(--coral);stroke-width:3.4;stroke-linecap:round}

/* ============== BOTTONI ============== */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;font-weight:800;font-size:1rem;
  padding:.92rem 1.6rem;border-radius:4px;border:0;transition:.28s cubic-bezier(.2,.7,.3,1);
  position:relative;letter-spacing:.2px;
}
.btn--primary{background:var(--strawberry);color:#fff;box-shadow:0 14px 26px -12px rgba(226,52,43,.6)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 20px 32px -12px rgba(226,52,43,.7);background:#d22b22}
.btn--ghost{background:transparent;color:var(--bordeaux);border:2px solid var(--bordeaux)}
.btn--ghost:hover{background:var(--bordeaux);color:#fff;transform:translateY(-3px)}
.btn--cream{background:#fff;color:var(--bordeaux);box-shadow:var(--shadow-soft)}
.btn--cream:hover{transform:translateY(-3px)}
.btn svg{width:18px;height:18px}

/* ============== BADGE PREZZO (motivo brand) ============== */
.price-badge{
  position:relative;width:84px;height:84px;border-radius:50%;background:#fff;
  display:grid;place-items:center;box-shadow:0 16px 30px -14px rgba(122,27,60,.45);
  border:2.5px solid var(--coral);transition:.3s;
}
.price-badge::after{content:"";position:absolute;inset:5px;border-radius:50%;border:1.5px dashed rgba(239,130,118,.55)}
.price-badge b{font-family:var(--font-display);font-weight:600;color:var(--bordeaux);font-size:1.8rem;line-height:.8}
.price-badge b small{font-size:.85rem;font-weight:600}
.price-badge .spark{position:absolute;top:-12px;right:-12px;width:34px;height:34px}
.price-badge:hover{transform:rotate(-8deg) scale(1.06)}

/* blob acquerello */
.blob{position:absolute;border-radius:50%;filter:blur(58px);opacity:.55;z-index:0;pointer-events:none}

/* ============== NAV ============== */
.nav{
  position:sticky;top:0;z-index:50;height:var(--nav-h);display:flex;align-items:center;
  background:rgba(255,248,244,.78);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(122,27,60,.08);transition:.3s;
}
.nav.scrolled{box-shadow:0 10px 30px -22px rgba(122,27,60,.5);background:rgba(255,248,244,.92)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:min(100% - 40px,var(--maxw))}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--font-brand);font-size:1.85rem;color:var(--bordeaux);line-height:1}
.brand .amp{color:var(--coral-bright)}
.brand .mark{width:42px;height:42px;flex:0 0 auto}
.nav-links{display:flex;align-items:center;gap:1.55rem;list-style:none;margin:0;padding:0}
.nav-links a{font-weight:700;font-size:.96rem;color:var(--ink);position:relative;padding:.25rem 0;transition:.2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2.5px;width:0;background:var(--coral);border-radius:2px;transition:.28s}
.nav-links a:hover,.nav-links a.active{color:var(--bordeaux)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.burger{display:none;background:none;border:0;padding:6px;width:42px;height:42px}
.burger span{display:block;height:2.6px;width:24px;margin:5px auto;background:var(--bordeaux);border-radius:3px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7.6px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.6px) rotate(-45deg)}
/* il pannello mobile resta nascosto sopra il breakpoint (evita il menu duplicato) */
.nav-mobile{display:none}
/* logo ufficiale tondo nella nav */
.brand .logo{width:54px;height:54px;border-radius:50%;display:block;box-shadow:0 6px 16px -8px rgba(122,27,60,.5)}


.nav-specials{position:relative;display:flex;align-items:center}
.nav-specials__trigger{
  display:inline-flex;align-items:center;gap:.35rem;border:0;background:transparent;color:var(--ink);
  font-weight:800;font-size:.96rem;padding:.38rem 0;transition:.2s;
}
.nav-specials__trigger svg{width:15px;height:15px;transition:.2s;color:var(--coral-bright)}
.nav-specials:hover .nav-specials__trigger,
.nav-specials:focus-within .nav-specials__trigger{color:var(--bordeaux)}
.nav-specials:hover .nav-specials__trigger svg,
.nav-specials:focus-within .nav-specials__trigger svg{transform:rotate(180deg)}
.nav-specials__menu{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translate(-50%,8px);
  min-width:250px;background:#fff;border:1px solid rgba(122,27,60,.1);border-radius:4px;
  box-shadow:0 22px 54px -26px rgba(122,27,60,.42);padding:.55rem;opacity:0;visibility:hidden;
  pointer-events:none;transition:.22s cubic-bezier(.2,.7,.3,1);z-index:80;
}
.nav-specials__menu::before{content:"";position:absolute;left:0;right:0;top:-16px;height:16px}
.nav-specials:hover .nav-specials__menu,
.nav-specials:focus-within .nav-specials__menu{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0)}
.nav-specials__menu a{
  display:grid;gap:.12rem;padding:.78rem .9rem;border-radius:4px;color:var(--bordeaux);transition:.2s;
}
.nav-specials__menu a::after{display:none}
.nav-specials__menu a span{font-family:var(--font-script);font-size:1.15rem;color:var(--coral-bright);line-height:1}
.nav-specials__menu a strong{font-family:var(--font-display);font-size:1.06rem;line-height:1.15;color:var(--bordeaux)}
.nav-specials__menu a:hover{background:var(--pink-wash);transform:translateX(2px)}
.nav-mobile__group{
  margin-top:.6rem;font-family:var(--font-script);font-size:1.25rem;font-weight:800;color:var(--coral-bright);
}

/* ============== HERO ============== */
.hero{position:relative;overflow:hidden;background:var(--cream);display:flex;align-items:center;min-height:clamp(440px,58vh,560px)}
/* foto a destra con bordo sinistro tagliato in diagonale (richiama l'inclinazione del marquee) */
.hero-photo{
  position:absolute;top:0;right:0;bottom:0;width:46%;z-index:0;
  background:url("../images/banner1.webp") center/cover no-repeat;
  /* bordo sinistro diagonale + bordo inferiore inclinato ~ -1.2° come il marquee
     (angolo sinistro più in basso, destro più in alto) */
  clip-path:polygon(14% 0, 100% 0, 100% 97.5%, 2% 100%);
  /* ingresso "painting": pennellata morbida che rivela + messa a fuoco.
     Stato base = rivelato, così con prefers-reduced-motion (animation:none) l'immagine resta visibile. */
  -webkit-mask-image:linear-gradient(105deg, #000 50%, rgba(0,0,0,0) 82%);
  mask-image:linear-gradient(105deg, #000 50%, rgba(0,0,0,0) 82%);
  -webkit-mask-size:230% 100%; mask-size:230% 100%;
  -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat;
  -webkit-mask-position:0 0; mask-position:0 0;
  animation:heroPaint 1.6s cubic-bezier(.4,0,.2,1) both;
}
@keyframes heroPaint{
  0%{
    -webkit-mask-position:100% 0; mask-position:100% 0;
    filter:blur(14px) saturate(.6) contrast(.96);
    transform:scale(1.06);
  }
  60%{ filter:blur(3px) saturate(.85) contrast(1); }
  100%{
    -webkit-mask-position:0 0; mask-position:0 0;
    filter:blur(0) saturate(1) contrast(1);
    transform:none;
  }
}
.hero .wrap{position:relative;z-index:2;padding-block:clamp(2.5rem,6vw,4.5rem)}
.hero-copy{max-width:460px}
.hero-tag{font-family:var(--font-script);font-size:clamp(1.7rem,3.4vw,2.4rem);color:var(--bordeaux);font-weight:700;display:flex;align-items:center;gap:.5rem}
.hero-tag .heart{width:24px;height:24px;color:var(--coral)}
.hero-copy h1{font-size:clamp(2.3rem,5vw,3.8rem);letter-spacing:-1px;margin:.4rem 0 1rem;line-height:1.03}
.hero-copy h1 .ital{color:var(--coral-bright)}
.hero-copy p.lead{margin:0 0 1.8rem;font-size:1.1rem;max-width:40ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}

@media (max-width:980px){
  .hero{display:block;min-height:0}
  .hero-photo{position:relative;width:100%;height:clamp(190px,40vw,280px);
    clip-path:polygon(0 0, 100% 0, 100% 90%, 0 100%)}
  .hero .wrap{padding-block:clamp(1.6rem,5vw,2.4rem) clamp(2.6rem,7vw,3.6rem)}
  .hero-copy{max-width:none}
}

/* ============== MARQUEE ============== */
.marquee{background:var(--bordeaux);color:#fff;padding:.85rem 0;overflow:hidden;transform:rotate(-1.2deg);margin:0 0 1.2rem;position:relative;z-index:3}
.marquee__track{display:flex;gap:2.2rem;white-space:nowrap;width:max-content;animation:slide 26s linear infinite}
.marquee span{font-family:var(--font-display);font-style:italic;font-size:1.25rem;letter-spacing:.5px;display:flex;align-items:center;gap:2.2rem}
.marquee .dot{color:var(--coral)}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============== ABOUT ============== */
.about{padding:clamp(3.5rem,8vw,6.5rem) 0}
.about .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.about-photo{position:relative}
.about-photo .photo{aspect-ratio:4/5;border-radius:var(--radius)}
.about-photo .price-badge{position:absolute;left:-26px;bottom:34px;z-index:3}
.about-copy .eyebrow{margin-bottom:.4rem}
.about-copy h2{margin:.2rem 0 1.1rem}
.promises{list-style:none;padding:0;margin:1.8rem 0 0;display:grid;gap:1rem}
.promises li{display:flex;gap:.95rem;align-items:flex-start}
.promises .ic{flex:0 0 auto;width:46px;height:46px;border-radius:4px;display:grid;place-items:center;background:var(--pink-wash);color:var(--bordeaux)}
.promises .ic svg{width:24px;height:24px}
.promises b{display:block;color:var(--bordeaux);font-size:1.05rem}
.promises p{margin:.1rem 0 0;color:var(--muted);font-size:.96rem;line-height:1.5}

/* ============== MENU ============== */
.menu{padding:clamp(3.5rem,8vw,6rem) 0;background:linear-gradient(180deg,transparent,var(--pink-wash) 18%,var(--pink-wash) 82%,transparent)}
.head-center{text-align:center;max-width:640px;margin:0 auto clamp(2rem,4vw,3rem)}
.head-center .lead{margin:1rem auto 0}
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.dish{
  background:#fff;border-radius:var(--radius);padding:1.4rem;position:relative;overflow:hidden;
  box-shadow:var(--shadow-soft);transition:.32s cubic-bezier(.2,.7,.3,1);border:1px solid rgba(122,27,60,.05);
}
.dish:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.dish-art{height:160px;border-radius:var(--radius-sm);background:radial-gradient(circle at 50% 38%,#fff,var(--pink-wash));display:grid;place-items:center;margin-bottom:1rem;position:relative}
.dish-art.is-lightboxable{cursor:zoom-in}
.dish-art.is-lightboxable:focus-visible{outline:3px solid var(--coral);outline-offset:3px}
#menu .dish-art{aspect-ratio:16/9;height:auto;overflow:hidden}
.dish-art svg{height:128px;width:auto;transition:.4s}
.dish-art .dish-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:var(--radius-sm);transition:.4s}
.dish:hover .dish-art .dish-photo{transform:scale(1.05)}
.dish-art .dish-placeholder{display:grid;place-items:center;color:rgba(122,27,60,.3)}
.dish-art .dish-placeholder svg{width:40px;height:40px}
.dish:hover .dish-art svg{transform:scale(1.08) rotate(-3deg)}
.dish .price-badge{position:absolute;top:-18px;right:-10px;width:70px;height:70px;z-index:3}
/* catalogo: il badge prezzo fuoriesce esteticamente dalla card */
.menu--pop .dish{overflow:visible}
.menu--pop .dish .price-badge{top:-22px;right:-16px;z-index:5}
.dish .price-badge b{font-size:1.45rem}
.dish h3{font-size:1.4rem;margin-bottom:.35rem}
.dish p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.5}
.dish .tag{display:inline-block;margin-top:.8rem;font-size:.78rem;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--coral-bright);background:rgba(239,130,118,.12);padding:.28rem .7rem;border-radius:4px}
.menu-note{text-align:center;margin-top:2.2rem;color:var(--muted);font-family:var(--font-script);font-size:1.4rem}
/* blocchi per categoria nel catalogo */
.cat-block{margin-top:clamp(2rem,4vw,3rem)}
.cat-block:first-of-type{margin-top:0}
.cat-head{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem;padding-bottom:.7rem;border-bottom:2px dashed rgba(122,27,60,.16)}
.cat-title{font-size:clamp(1.5rem,3vw,2rem);color:var(--bordeaux)}
.cat-desc{margin:0;color:var(--muted);font-size:.98rem}

/* ============== PAGE HERO (sottopagine) ============== */
.page-hero{padding:clamp(2.6rem,6vw,4.5rem) 0 clamp(1.5rem,3vw,2.5rem);text-align:center;position:relative;overflow:hidden}
.page-hero .blob{width:420px;height:420px;background:var(--pink-soft);top:-160px;left:50%;transform:translateX(-50%);opacity:.5}
.page-hero h1{font-size:clamp(2.4rem,5.4vw,3.6rem);letter-spacing:-.5px;margin:.3rem 0 .8rem;position:relative;z-index:2}
.page-hero h1 em{color:var(--coral-bright)}
.page-hero .lead{margin:0 auto;position:relative;z-index:2}
.page-hero .eyebrow{position:relative;z-index:2}

/* ============== COVER HERO (articolo blog + catalogo): FULL-WIDTH + TAGLIO DIAGONALE ============== */
.cover-hero{
  position:relative;display:flex;align-items:flex-end;overflow:hidden;
  min-height:clamp(360px,54vh,560px);background:var(--bordeaux-deep);color:#fff;
  /* taglio verso il body in diagonale come il marquee (angolo sx più in basso) */
  clip-path:polygon(0 0, 100% 0, 100% calc(100% - var(--cut)), 0 100%);
  padding-bottom:calc(var(--cut) + clamp(1.6rem,3.5vw,2.8rem));
}
.cover-hero__photo{position:absolute;inset:0;z-index:0;background:var(--hero-image) center/cover no-repeat;transform:scale(1.02)}
.cover-hero::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(20,4,12,.12) 0%,rgba(24,4,15,.36) 42%,rgba(40,8,22,.76) 76%,rgba(48,10,26,.92) 100%);
}
.cover-hero .wrap{position:relative;z-index:2;padding-top:clamp(4rem,9vw,6.5rem)}
.cover-hero__copy{max-width:780px}
.cover-hero .eyebrow{color:#FFE5DD}
.cover-hero h1{font-size:clamp(2.2rem,5.4vw,4rem);color:#fff;letter-spacing:-.5px;line-height:1.06;margin:.4rem 0 .9rem;text-wrap:balance}
.cover-hero h1 em{color:#FFE0D6}
.cover-hero .lead{font-size:clamp(1.05rem,1.9vw,1.32rem);color:rgba(255,248,244,.92);max-width:62ch;margin:0}
.cover-hero__meta{margin:1.3rem 0 0;color:rgba(255,248,244,.8);font-weight:700;font-size:.86rem;text-transform:uppercase;letter-spacing:.08em}

/* ============== ARTICOLO BLOG (body) ============== */
.article-body{max-width:760px;margin:0 auto;padding:clamp(2.4rem,5vw,3.4rem) 0 clamp(3rem,7vw,5rem)}
.article-prose{font-size:1.1rem;line-height:1.75;color:var(--ink)}
.article-prose h2{font-size:1.7rem;margin:2rem 0 .8rem}
.article-prose h3{font-size:1.35rem;margin:1.6rem 0 .6rem}
.article-prose p{margin:0 0 1.1rem}
.article-prose ul,.article-prose ol{margin:0 0 1.1rem;padding-left:1.3rem;display:grid;gap:.45rem}
.article-prose a{color:var(--coral-bright);font-weight:700;text-decoration:underline}
.article-prose strong{color:var(--bordeaux)}
.article-prose blockquote{margin:1.4rem 0;padding:.6rem 1.2rem;border-left:4px solid var(--coral);background:var(--pink-wash);border-radius:0 4px 4px 0;color:var(--muted)}
.article-back{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:.6rem}
.event-meta{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;color:var(--muted);font-weight:700;position:relative;z-index:2;margin:.4rem 0 0}
.event-meta-loc{display:inline-flex;align-items:center;gap:.35rem}
.event-meta-loc svg{width:16px;height:16px;color:var(--coral)}
.event-meta-sep{color:var(--coral)}
.event-thumb{flex:0 0 auto;width:84px;height:84px;border-radius:4px;object-fit:cover}

/* ============== SU RICHIESTA (catalogo) ============== */
.on-request{padding:clamp(3rem,7vw,5rem) 0 clamp(3.5rem,8vw,6rem)}
.request-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.request-card{
  background:#fff;border-radius:var(--radius);padding:1.8rem 1.4rem;text-align:center;
  box-shadow:var(--shadow-soft);border:1px solid rgba(122,27,60,.05);transition:.32s cubic-bezier(.2,.7,.3,1);
}
.request-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.request-card .ic{
  width:62px;height:62px;border-radius:4px;display:grid;place-items:center;margin:0 auto 1rem;
  background:var(--pink-wash);color:var(--bordeaux);
}
.request-card .ic svg{width:30px;height:30px}
.request-card h3{font-size:1.2rem;margin-bottom:.4rem}
.request-card p{margin:0;color:var(--muted);font-size:.94rem;line-height:1.5}

/* ============== EVENTS ============== */
.events{padding:clamp(3.5rem,8vw,6rem) 0}
.events .head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:2.4rem}
.events-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
.event{display:flex;gap:1.3rem;background:#fff;border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow-soft);transition:.3s;align-items:center}
.event:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.event .date{flex:0 0 auto;width:84px;height:84px;border-radius:4px;background:var(--bordeaux);color:#fff;display:grid;place-content:center;text-align:center;line-height:1}
.event .date .d{font-family:var(--font-display);font-size:2.1rem;font-weight:600}
.event .date .m{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;margin-top:.2rem;color:var(--coral)}
.event h3{font-size:1.3rem;margin-bottom:.25rem}
.event .where{display:flex;align-items:center;gap:.4rem;color:var(--muted);font-weight:700;font-size:.9rem}
.event .where svg{width:16px;height:16px;color:var(--coral)}
.event p{margin:.5rem 0 0;color:var(--muted);font-size:.92rem;line-height:1.45}
.event h3{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.past-badge{font-family:var(--font-body);font-size:.66rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;
  color:var(--bordeaux);background:var(--pink-wash);border:1px solid rgba(122,27,60,.18);
  padding:.18rem .5rem;border-radius:4px;line-height:1}
.event.is-past .date{background:var(--cocoa-light)}
.event.is-past{opacity:.92}

/* ============== GALLERY ============== */
.gallery{padding:clamp(3.5rem,8vw,6rem) 0;background:linear-gradient(180deg,transparent,var(--peach) 30%,var(--pink-wash) 100%)}
/* masonry: gestisce orientamenti misti e qualsiasi numero di foto */
.gallery-grid{column-count:4;column-gap:1rem}
.gallery .photo{break-inside:avoid;margin:0 0 1rem;display:block;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;position:relative}
.gallery .photo img{width:100%;height:auto;display:block;transition:.5s cubic-bezier(.2,.7,.3,1)}
.gallery .photo:hover img{transform:scale(1.05)}
/* i segnaposto (gallery vuota) mantengono un'altezza */
.gallery .photo:not(.has-image){aspect-ratio:4/3}

/* ============== BLOG ============== */
.blog{padding:clamp(3.5rem,8vw,6rem) 0}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin-top:2.6rem}
.post{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);transition:.32s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.post .photo{aspect-ratio:16/10;border-radius:0}
.post .post-cover{aspect-ratio:16/10;object-fit:cover;width:100%}
.post-body{padding:1.4rem 1.5rem 1.7rem}
.post .cat{font-family:var(--font-script);font-size:1.35rem;color:var(--coral-bright);font-weight:700}
.post h3{font-size:1.32rem;margin:.2rem 0 .6rem;line-height:1.15}
.post p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.5}
.post .more{margin-top:1rem;font-weight:800;color:var(--bordeaux);display:inline-flex;align-items:center;gap:.4rem;font-size:.92rem}
.post .more svg{width:16px;height:16px;transition:.25s}
.post:hover .more svg{transform:translateX(4px)}
.post h3 a{transition:.2s}
.post h3 a:hover{color:var(--coral-bright)}
.pager{display:flex;align-items:center;justify-content:center;gap:1.2rem;flex-wrap:wrap;margin-top:3rem}
.pager-info{color:var(--muted);font-weight:700;font-size:.92rem}
.btn.is-disabled{opacity:.4;pointer-events:none}

/* ============== CONTACT ============== */
.contact{padding:calc(clamp(3.5rem,8vw,6.5rem) + var(--cut)) 0 clamp(3.5rem,8vw,6.5rem);background:var(--bordeaux);color:#fff;position:relative;overflow:hidden;clip-path:polygon(0 var(--cut), 100% 0, 100% 100%, 0 100%)}
.contact h2{color:#fff}
.contact .eyebrow{color:#FBE0D2}
.contact .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start;position:relative;z-index:2}
.contact .lead{color:rgba(255,248,244,.82)}
.contact-info{margin-top:2rem;display:grid;gap:1.1rem}
.contact-info a,.contact-info div{display:flex;gap:.85rem;align-items:center;font-weight:700;color:#fff}
.contact-info .ic{width:44px;height:44px;border-radius:4px;background:rgba(255,255,255,.12);display:grid;place-items:center;flex:0 0 auto}
.contact-info .ic svg{width:21px;height:21px;color:var(--peach)}
.contact-info small{display:block;font-weight:600;color:rgba(255,248,244,.6);font-size:.78rem;letter-spacing:.4px}
.form-card{background:var(--cream);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:0 40px 70px -30px rgba(0,0,0,.5);color:var(--ink)}
.contact-map{margin-top:clamp(2rem,4vw,3rem);border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 60px -30px rgba(0,0,0,.5);line-height:0}
.contact-map iframe{display:block;width:100%}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1.05rem;display:flex;flex-direction:column;min-width:0}
.field label{font-weight:800;font-size:.85rem;color:var(--bordeaux);margin-bottom:.4rem;letter-spacing:.2px}
.field input,.field textarea{
  font-family:inherit;font-size:1rem;padding:.85rem 1rem;border-radius:4px;border:2px solid #f0d9e0;
  background:#fff;color:var(--ink);transition:.22s;width:100%;min-width:0;max-width:100%;
}
/* iOS: i date input hanno larghezza intrinseca che sborda — forziamo il contenimento */
.field input[type="date"]{-webkit-appearance:none;appearance:none}
.field textarea{resize:vertical;min-height:110px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--coral);box-shadow:var(--ring)}
.field .err{color:var(--strawberry);font-size:.8rem;font-weight:700;margin-top:.35rem}
/* honeypot: fuori schermo, invisibile agli umani ma compilato dai bot */
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-card .btn{width:100%;justify-content:center;margin-top:.4rem}
.form-success{display:none;text-align:center;padding:2rem 1rem}
.form-success.show{display:block;animation:pop .5s cubic-bezier(.2,.8,.3,1.3)}
.form-success svg{width:64px;height:64px;color:var(--coral);margin-bottom:.6rem}
.form-success h3{font-size:1.7rem;margin-bottom:.4rem}
.form-success p{color:var(--muted);margin:0}
@keyframes pop{from{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}

/* ============== FOOTER ============== */
.footer{background:var(--bordeaux-deep);color:rgba(255,248,244,.78);padding:clamp(3rem,6vw,4.5rem) 0 2rem}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer .brand{color:#fff;margin-bottom:.8rem}
.footer .footer-logo{width:96px;height:96px;border-radius:50%;display:block;margin-bottom:1rem;box-shadow:0 10px 24px -10px rgba(0,0,0,.5)}
.footer p{max-width:36ch;font-size:.95rem;line-height:1.6;margin:0}
.footer h4{font-family:var(--font-body);color:#fff;font-size:.85rem;letter-spacing:1.5px;text-transform:uppercase;margin:0 0 1rem}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.footer ul a{font-size:.95rem;transition:.2s}
.footer ul a:hover{color:var(--peach);padding-left:4px}
.socials{display:flex;gap:.7rem;margin-top:1.2rem}
.socials a{width:42px;height:42px;border-radius:4px;background:rgba(255,255,255,.1);display:grid;place-items:center;transition:.25s}
.socials a:hover{background:var(--coral);transform:translateY(-3px)}
.socials svg{width:20px;height:20px;color:#fff}
.footer .legal-links{display:flex;gap:1.4rem;flex-wrap:wrap;padding-top:1.6rem;margin-top:.4rem}
.footer .legal-links a{font-size:.85rem;font-weight:700;color:rgba(255,248,244,.8);transition:.2s}
.footer .legal-links a:hover{color:var(--peach)}
.footer .bottom{padding-top:1.2rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:rgba(255,248,244,.55)}
.footer .bottom .heart{color:var(--coral)}
.footer .bottom .agency-link{color:rgba(255,248,244,.8);font-weight:700;text-decoration:underline}
.footer .bottom .agency-link:hover{color:var(--peach)}

/* ============== PHOTO PLACEHOLDER ============== */
.photo{
  background:
    repeating-linear-gradient(45deg,rgba(239,130,118,.05) 0 14px,transparent 14px 28px),
    radial-gradient(circle at 40% 35%,var(--pink-mist),var(--pink-soft));
  border:1.5px dashed rgba(122,27,60,.18);
  display:grid;place-items:center;color:var(--bordeaux);position:relative;overflow:hidden;
}
.photo.has-image{border:0}
.photo > img{width:100%;height:100%;object-fit:cover}
.photo::after{content:attr(data-label);position:absolute;bottom:12px;font-family:var(--font-script);font-size:1.05rem;color:rgba(122,27,60,.5)}
.photo.has-image::after{content:none}
.photo .cam{width:38px;height:38px;color:rgba(122,27,60,.32)}

/* ============== LIGHTBOX GALLERY ============== */
.lightbox{
  position:fixed;inset:0;z-index:90;display:grid;
  grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(.4rem,2vw,1.4rem);
  padding:clamp(.8rem,3vw,2rem);
  background:rgba(60,12,28,.86);backdrop-filter:blur(10px);
  opacity:0;transition:opacity .28s ease;
}
.lightbox.open{opacity:1}
.lightbox[hidden]{display:none}
.lb-stage{margin:0;display:grid;place-items:center;min-width:0;height:100%}
.lb-img{
  max-width:100%;max-height:88vh;border-radius:var(--radius-sm);
  box-shadow:0 40px 90px -30px rgba(0,0,0,.8);background:var(--cream);
  transform:scale(.96);transition:transform .28s cubic-bezier(.2,.7,.3,1);
}
.lb-html{
  width:min(760px,90vw);max-height:88vh;aspect-ratio:16/9;border-radius:var(--radius-sm);
  background:radial-gradient(circle at 50% 38%,#fff,var(--pink-wash));box-shadow:0 40px 90px -30px rgba(0,0,0,.8);
  display:grid;place-items:center;transform:scale(.96);transition:transform .28s cubic-bezier(.2,.7,.3,1);overflow:hidden;
}
.lb-html[hidden]{display:none}
.lb-html svg{width:min(520px,70vw);height:auto;max-height:72vh}
.lb-html img{width:100%;height:100%;object-fit:cover;border-radius:inherit}
.lightbox.open .lb-img,.lightbox.open .lb-html{transform:scale(1)}
.lb-btn{
  background:rgba(255,255,255,.12);border:0;color:#fff;border-radius:50%;
  width:clamp(44px,7vw,58px);height:clamp(44px,7vw,58px);display:grid;place-items:center;
  transition:.22s;flex:0 0 auto;
}
.lb-btn svg{width:50%;height:50%}
.lb-btn:hover{background:var(--coral);transform:scale(1.08)}
.lb-close{position:absolute;top:clamp(.8rem,3vw,1.4rem);right:clamp(.8rem,3vw,1.4rem);z-index:2}
.lb-counter{
  position:absolute;bottom:clamp(.8rem,3vw,1.6rem);left:50%;transform:translateX(-50%);
  color:#fff;font-weight:800;font-size:.9rem;letter-spacing:.5px;
  background:rgba(0,0,0,.35);padding:.35rem .9rem;border-radius:4px;
}
@media (max-width:680px){
  .lightbox{grid-template-columns:1fr}
  .lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);z-index:2}
  .lb-prev{left:.6rem}.lb-next{right:.6rem}
  .lb-prev:hover,.lb-next:hover{transform:translateY(-50%) scale(1.08)}
}

/* ============== COOKIE BANNER ============== */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:60;padding:1rem;pointer-events:none}
.cookie-inner{
  max-width:760px;margin:0 auto;background:var(--cream);border:1px solid rgba(122,27,60,.12);
  border-radius:var(--radius);box-shadow:0 30px 60px -24px rgba(122,27,60,.5);
  padding:1.2rem 1.4rem;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  transform:translateY(140%);opacity:0;transition:.4s cubic-bezier(.2,.7,.3,1);pointer-events:auto;
}
.cookie-banner.show .cookie-inner{transform:translateY(0);opacity:1}
.cookie-inner p{margin:0;flex:1 1 320px;color:var(--ink);font-size:.92rem;line-height:1.5}
.cookie-inner a{color:var(--coral-bright);font-weight:700;text-decoration:underline}
.cookie-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.cookie-actions .btn{padding:.6rem 1.1rem;font-size:.9rem}
.cookie-actions .btn--ghost{text-decoration:none}

/* ============== REVEAL ============== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ============== RESPONSIVE ============== */
@media (max-width:920px){
  .hero .wrap,.about .wrap,.contact .wrap{grid-template-columns:1fr}
  .hero-visual{order:-1;min-height:340px}
  .menu-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .request-grid{grid-template-columns:repeat(2,1fr)}
  .events-grid{grid-template-columns:1fr}
  .gallery-grid{column-count:3}
  .about-photo{max-width:420px;margin-inline:auto}
}
@media (max-width:680px){
  .nav-links,.nav-cta .btn{display:none}
  .burger{display:block}
  .nav-mobile{display:block;position:fixed;inset:var(--nav-h) 0 auto;background:var(--cream);
    padding:1.4rem 20px 2rem;box-shadow:0 24px 40px -20px rgba(122,27,60,.4);
    transform:translateY(-130%);transition:transform .38s cubic-bezier(.2,.7,.3,1);z-index:40;border-bottom:1px solid rgba(122,27,60,.1);
    max-height:calc(100vh - var(--nav-h));max-height:calc(100dvh - var(--nav-h));
    overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
  .nav-mobile.open{transform:translateY(0)}
  .nav-mobile ul{list-style:none;padding:0;margin:0;display:grid;gap:.4rem}
  .nav-mobile ul a{display:block;font-weight:800;font-size:1.15rem;color:var(--bordeaux);padding:.7rem 0;border-bottom:1px solid rgba(122,27,60,.08)}
  .nav-mobile .btn{margin-top:1rem;width:100%;justify-content:center}
  .menu-grid,.blog-grid{grid-template-columns:1fr}
  .request-grid{grid-template-columns:1fr}
  .gallery-grid{column-count:2}
  .form-row{grid-template-columns:1fr}
  .footer .top{grid-template-columns:1fr}
  .hero-copy h1{font-size:clamp(2.4rem,9vw,3rem)}
  .marquee span{font-size:1.05rem}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
}


/* ============== PAGINE TEMATICHE / STAGIONALI ============== */
.nav-theme-link{
  color:var(--bordeaux)!important;
  background:linear-gradient(135deg,rgba(239,130,118,.16),rgba(251,224,210,.65));
  border:1px solid rgba(239,130,118,.28);
  border-radius:4px;
  padding:.38rem .78rem!important;
}
.nav-theme-link::after{display:none}

.theme-teaser{padding:clamp(2rem,5vw,3.6rem) 0;background:linear-gradient(180deg,var(--cream),var(--pink-wash));overflow:hidden}
.theme-teaser__inner{
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  min-height:230px;border-radius:var(--radius);padding:clamp(1.4rem,4vw,2.4rem);
  background:
    linear-gradient(90deg,rgba(45,10,27,.96) 0%,rgba(92,20,48,.88) 38%,rgba(122,27,60,.52) 68%,rgba(122,27,60,.14) 100%),
    var(--theme-image) center/cover no-repeat;
  color:#fff;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.theme-teaser__inner::after{
  content:"";position:absolute;right:-60px;bottom:-80px;width:220px;height:220px;border-radius:50%;
  border:42px solid color-mix(in srgb,var(--theme-accent,#EF8276) 52%,transparent);opacity:.7;pointer-events:none;
}
.theme-teaser__copy{position:relative;z-index:2;max-width:620px}
.theme-teaser .eyebrow{color:#FFE5DD}
.theme-teaser h2{color:#fff;margin:.35rem 0 .6rem}
.theme-teaser .lead{color:rgba(255,248,244,.9);margin:0}
.theme-teaser__meta{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}
.theme-teaser__meta span{
  display:inline-flex;align-items:center;border-radius:4px;padding:.36rem .72rem;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);
  font-weight:800;font-size:.84rem;color:#fff;
}
.theme-teaser .btn{position:relative;z-index:2;flex:0 0 auto}

.theme-hero{
  position:relative;min-height:clamp(520px,72vh,720px);display:flex;align-items:center;overflow:hidden;
  background:var(--bordeaux);color:#fff;
  /* stesso taglio diagonale della cover hero, verso la sezione successiva */
  clip-path:polygon(0 0, 100% 0, 100% calc(100% - var(--cut)), 0 100%);
  padding-bottom:var(--cut);
}
.theme-hero::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,rgba(24,4,15,.98) 0%,rgba(48,8,25,.96) 32%,rgba(92,20,48,.78) 62%,rgba(122,27,60,.22) 100%);
}
.theme-hero__photo{position:absolute;inset:0;background:var(--theme-image) center/cover no-repeat;z-index:0;transform:scale(1.01)}
.theme-hero .wrap{position:relative;z-index:2;padding-block:clamp(4rem,9vw,7rem)}
.theme-hero__copy{max-width:680px}
.theme-hero .eyebrow{color:#FFE5DD}
.theme-hero h1{font-size:clamp(3rem,8vw,6.4rem);color:#fff;letter-spacing:-1px;margin:.35rem 0 1rem;text-wrap:balance}
.theme-hero .lead{font-size:clamp(1.08rem,2vw,1.35rem);color:rgba(255,248,244,.9);max-width:50ch;margin:0}
.theme-hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}

.theme-intro{padding:clamp(3rem,7vw,5rem) 0;background:var(--cream)}
.theme-intro__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
.theme-intro__text .section-title{margin:.3rem 0 1rem}
.theme-note{background:#fff;border-radius:var(--radius);padding:clamp(1.3rem,3vw,2rem);box-shadow:var(--shadow-soft);border:1px solid rgba(122,27,60,.07)}
.theme-note b{display:block;color:var(--bordeaux);font-family:var(--font-display);font-size:1.35rem;line-height:1.15;margin-bottom:.5rem}
.theme-note p{margin:0;color:var(--muted)}

.theme-products{background:linear-gradient(180deg,var(--pink-wash),var(--cream) 92%)}
.theme-dish .tag{background:color-mix(in srgb,var(--theme-accent,#EF8276) 18%,#fff);color:var(--bordeaux)}
.theme-cta{
  margin-top:clamp(2.4rem,5vw,4rem);display:flex;align-items:center;justify-content:space-between;gap:2rem;
  background:#fff;border-radius:var(--radius);padding:clamp(1.5rem,4vw,2.4rem);box-shadow:var(--shadow-soft);
  border:1px solid rgba(122,27,60,.07);
}
.theme-cta .section-title{margin:.3rem 0 .6rem;font-size:clamp(1.9rem,3.8vw,2.9rem)}
.theme-cta .lead{margin:0}
.theme-cta .btn{flex:0 0 auto}

@media (max-width:900px){
  .theme-teaser__inner,.theme-cta{align-items:flex-start;flex-direction:column}
  .theme-intro__grid{grid-template-columns:1fr}
  .theme-hero{min-height:0}
  .theme-hero::before{background:linear-gradient(180deg,rgba(38,8,24,.96),rgba(68,12,34,.84),rgba(122,27,60,.36))}
  .theme-hero .wrap{padding-top:clamp(9rem,28vw,13rem);padding-bottom:3.5rem}
}

/* ============== CONTATTI RAPIDI (FAB) ============== */
.contact-fab{
  position:fixed;right:clamp(1rem,3vw,2rem);bottom:clamp(1rem,3vw,2rem);left:auto;z-index:55;
  pointer-events:none;visibility:hidden;opacity:0;transform:translateY(14px);
  transition:opacity .3s ease,transform .3s cubic-bezier(.2,.7,.3,1),visibility .3s,bottom .3s ease;
}
.contact-fab.is-visible{visibility:visible;opacity:1;transform:none}
/* anello focus a due toni: lo scuro stacca su fondo chiaro/verde, il bianco sul fondo bordeaux */
.contact-fab a:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px var(--bordeaux-deep),0 0 0 5px #fff}

/* desktop: pill chiamata (con numero) + bottone WhatsApp tondo */
.contact-fab__bar{display:none}
.contact-fab__dock{display:flex;flex-direction:column;align-items:flex-end;gap:.7rem;pointer-events:auto}
.contact-fab__btn{
  display:flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:50%;
  color:#fff;box-shadow:var(--shadow);transition:transform .2s cubic-bezier(.2,.7,.3,1),box-shadow .2s,background .2s;
}
.contact-fab__btn:hover{transform:translateY(-3px);box-shadow:0 24px 40px -18px rgba(122,27,60,.6)}
.contact-fab__btn svg{width:26px;height:26px}
.contact-fab__btn--wa{background:#25D366}
.contact-fab__btn--wa:hover{background:#1FB855}
.contact-fab__pill{
  display:inline-flex;align-items:center;gap:.7rem;padding:.62rem 1.25rem .62rem 1.05rem;border-radius:999px;
  background:var(--bordeaux);color:#fff;text-decoration:none;box-shadow:var(--shadow);
  transition:transform .2s cubic-bezier(.2,.7,.3,1),box-shadow .2s,background .2s;
}
.contact-fab__pill:hover{transform:translateY(-3px);background:var(--bordeaux-deep);box-shadow:0 24px 40px -18px rgba(122,27,60,.6)}
.contact-fab__pill svg{width:24px;height:24px;flex:0 0 auto}
.contact-fab__pill-text{display:flex;flex-direction:column;line-height:1;text-align:left}
.contact-fab__pill-eyebrow{font-family:var(--font-body);font-weight:700;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;opacity:.85}
.contact-fab__pill-num{font-family:var(--font-body);font-weight:800;font-size:1.05rem;letter-spacing:.3px;margin-top:.15rem}

/* mobile: barra a tutta larghezza ancorata in basso (stesso breakpoint della navbar: 680px) */
@media (max-width:680px){
  .contact-fab{right:0;bottom:0;left:0;transform:translateY(100%)}
  .contact-fab.is-visible{transform:none}
  .contact-fab__dock{display:none}
  .contact-fab__bar{display:flex;box-shadow:0 -10px 30px -16px rgba(122,27,60,.5)}
  .contact-fab__bar a{
    flex:1;min-width:0;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
    padding:.95rem .6rem;color:#fff;text-decoration:none;
    font-family:var(--font-body);font-weight:800;font-size:1rem;letter-spacing:.2px;
  }
  .contact-fab__bar a:active{filter:brightness(.92)}
  .contact-fab__bar svg{width:21px;height:21px;flex:0 0 auto}
  .contact-fab__num{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.96rem}
  .contact-fab__call{background:var(--bordeaux)}
  .contact-fab__wa{background:#25D366}
  /* mentre il banner cookie è visibile, solleva la barra sopra di esso (no overlap) */
  body.cookie-active .contact-fab{bottom:calc(var(--cookie-h, 0px) + .6rem)}
}

@media (prefers-reduced-motion:reduce){
  .contact-fab{transition:opacity .2s ease}
  .contact-fab,.contact-fab.is-visible{transform:none}
}
