/* ============================================================
   IDEA CASA · Porte e Finestre · Terzigno (NA)
   Caldo e artigianale + DNA brand (petrolio + fucsia)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --teal:#0d8a9a;
  --teal-deep:#0a6470;
  --teal-ink:#08474f;
  --fucsia:#e5357f;
  --fucsia-deep:#c81f68;

  --ink:#2b2521;          /* warm near-black */
  --ink-soft:#5f564e;     /* warm grey text */
  --line:#e4d8c8;         /* warm hairline */

  --paper:#f7f1e8;        /* warm cream bg */
  --paper-2:#efe5d6;      /* deeper cream */
  --card:#fffdf9;         /* card surface */
  --white:#fffefb;

  --wood:#8a5a36;

  --serif:'Spectral', Georgia, 'Times New Roman', serif;
  --sans:'Hanken Grotesk', system-ui, -apple-system, sans-serif;

  --maxw:1200px;
  --r:10px;
  --shadow:0 18px 50px -22px rgba(43,37,33,.45);
  --shadow-sm:0 8px 26px -16px rgba(43,37,33,.40);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:96px}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.eyebrow{
  font-family:var(--sans);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--fucsia-deep);
  display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{
  content:'';width:30px;height:2px;background:var(--fucsia);display:inline-block;
}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{
  content:'';width:30px;height:2px;background:var(--fucsia);display:inline-block;
}

h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.08;color:var(--ink);letter-spacing:-.01em}
.h-section{font-size:clamp(2.1rem,4.4vw,3.4rem);margin:1rem 0 .6rem}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:62ch}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-weight:700;font-size:.96rem;
  padding:.95rem 1.7rem;border-radius:50px;cursor:pointer;border:none;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s;
  white-space:nowrap;
}
.btn i{font-size:1.05em}
.btn-primary{background:var(--fucsia);color:#fff;box-shadow:0 12px 26px -12px rgba(229,53,127,.7)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 34px -12px rgba(229,53,127,.75);background:var(--fucsia-deep)}
.btn-wa{background:#1faf54;color:#fff;box-shadow:0 12px 26px -12px rgba(31,175,84,.6)}
.btn-wa:hover{transform:translateY(-3px);background:#179247}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-3px)}
.btn-teal{background:var(--teal);color:#fff;box-shadow:0 12px 26px -12px rgba(13,138,154,.65)}
.btn-teal:hover{transform:translateY(-3px);background:var(--teal-deep)}

/* ---------- Top bar ---------- */
.topbar{
  background:var(--teal-ink);color:#dceef0;font-size:.84rem;
  letter-spacing:.01em;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:40px;flex-wrap:wrap}
.topbar a{display:inline-flex;align-items:center;gap:.45rem;color:#dceef0;transition:color .2s}
.topbar a:hover{color:#fff}
.topbar .tb-right{display:flex;gap:1.6rem;align-items:center}
.topbar i{color:var(--fucsia);font-size:.9em}

/* ---------- Navbar ---------- */
.nav{
  position:sticky;top:0;z-index:200;
  background:rgba(247,241,232,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s, background .3s;
}
.nav.scrolled{box-shadow:0 10px 30px -20px rgba(43,37,33,.5);background:rgba(247,241,232,.96)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;min-height:74px;gap:1rem}
.brand img{height:60px;width:auto}
.menu{display:flex;gap:2rem;align-items:center}
.menu a{font-weight:600;font-size:.97rem;color:var(--ink);position:relative;padding:4px 0;transition:color .2s}
.menu a::after{content:'';position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--fucsia);transition:width .28s var(--ease)}
.menu a:hover{color:var(--teal-deep)}
.menu a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.9rem}
.hamburger{display:none;background:none;border:none;font-size:1.5rem;color:var(--teal-deep);cursor:pointer}

.mobile-menu{
  position:fixed;inset:0 0 auto 0;top:0;z-index:300;
  background:var(--paper);transform:translateY(-100%);transition:transform .4s var(--ease);
  padding:90px 28px 36px;box-shadow:var(--shadow);
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{display:block;font-family:var(--serif);font-size:1.5rem;padding:.7rem 0;border-bottom:1px solid var(--line);color:var(--ink)}
.mobile-menu .mm-actions{display:flex;flex-direction:column;gap:.8rem;margin-top:1.5rem}
.mm-close{position:absolute;top:24px;right:24px;background:none;border:none;font-size:2rem;color:var(--ink);cursor:pointer}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:slowzoom 18s ease-in-out infinite alternate}
@keyframes slowzoom{from{transform:scale(1)}to{transform:scale(1.08)}}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg, rgba(8,71,79,.82) 0%, rgba(8,71,79,.55) 42%, rgba(8,71,79,.12) 78%, rgba(8,71,79,0) 100%);
}
.hero .wrap{position:relative;z-index:2;width:100%;padding-top:5vh;padding-bottom:5vh}
.hero-inner{max-width:680px;color:#fff}
.hero .eyebrow{color:#ffd2e6}
.hero .eyebrow::before{background:var(--fucsia)}
.hero h1{
  color:#fff;font-size:clamp(2.6rem,6vw,4.6rem);line-height:1.04;margin:1.1rem 0 1.2rem;
  text-shadow:0 4px 30px rgba(0,0,0,.25);
}
.hero h1 em{font-style:italic;color:#ffd2e6}
.hero p.sub{font-size:1.2rem;color:#eef6f7;max-width:54ch;margin-bottom:2.2rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-badge{
  position:absolute;right:32px;bottom:34px;z-index:2;
  display:flex;align-items:center;gap:1rem;
  background:rgba(255,253,249,.94);backdrop-filter:blur(6px);
  padding:1rem 1.4rem;border-radius:14px;box-shadow:var(--shadow);
}
.hero-badge .yrs{font-family:var(--serif);font-size:2.8rem;font-weight:700;color:var(--teal);line-height:1}
.hero-badge .yrs small{display:block;font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:.2rem}
.hero-badge .vbar{width:1px;height:46px;background:var(--line)}
.hero-badge .txt{font-size:.92rem;color:var(--ink-soft);max-width:18ch;line-height:1.4}

/* ---------- Stats band ---------- */
.stats{background:var(--teal-ink);color:#fff;padding:0}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{padding:2.7rem 1.4rem;text-align:center;border-right:1px solid rgba(255,255,255,.1)}
.stat:last-child{border-right:none}
.stat .num{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.4rem);font-weight:700;line-height:1;color:#fff}
.stat .num span{color:var(--fucsia)}
.stat .lbl{font-size:.84rem;font-weight:600;letter-spacing:.06em;color:#bfe0e4;margin-top:.6rem;text-transform:uppercase}

/* ---------- Marquee brands ---------- */
.brands{background:var(--paper);padding:3.4rem 0 3.6rem}
.brands .kicker{text-align:center;font-size:.82rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1.8rem}
.marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.marquee-track{display:flex;align-items:center;gap:1.4rem;width:max-content;animation:scrollx 38s linear infinite}
.brands:hover .marquee-track{animation-play-state:paused}
@keyframes scrollx{to{transform:translateX(-50%)}}
.brand-logo{
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:0 18px;height:54px;
  filter:grayscale(1);opacity:.55;
  transition:filter .3s var(--ease),opacity .3s var(--ease),box-shadow .3s;
}
.brand-logo:hover{filter:grayscale(0);opacity:1;box-shadow:var(--shadow-sm)}
.brand-logo img{height:26px;width:auto;display:block}

/* ---------- Generic section ---------- */
section{position:relative}
.sec-pad{padding:6rem 0}
.sec-head{max-width:64ch}
.sec-head.center{margin:0 auto;text-align:center}

/* ---------- Storia ---------- */
.storia{background:var(--paper-2)}
.storia-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:4rem;align-items:center}
.storia-copy p{color:var(--ink-soft);margin-bottom:1.1rem;font-size:1.06rem}
.storia-media{position:relative}
.storia-media img{border-radius:var(--r);box-shadow:var(--shadow);width:100%;height:520px;object-fit:cover}
.storia-media .tag{
  position:absolute;left:-22px;bottom:34px;background:var(--card);
  border-radius:12px;padding:1.1rem 1.4rem;box-shadow:var(--shadow);
  border-left:4px solid var(--fucsia);max-width:230px;
}
.storia-media .tag b{font-family:var(--serif);color:var(--teal-deep);font-size:1.1rem}
.storia-media .tag span{display:block;font-size:.86rem;color:var(--ink-soft);margin-top:.2rem}
.values{display:flex;gap:2rem;margin-top:2rem;flex-wrap:wrap}
.value{display:flex;gap:.8rem;align-items:flex-start;max-width:230px}
.value i{color:var(--teal);font-size:1.3rem;margin-top:.25rem}
.value b{display:block;font-size:1rem;color:var(--ink)}
.value span{font-size:.9rem;color:var(--ink-soft)}

/* ---------- Servizi (categorie) ---------- */
.servizi{background:var(--paper)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:2.6rem}
.cat{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
}
.cat:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.cat-photo{width:100%;height:200px;object-fit:cover;display:block}
.cat-body{padding:1.8rem 2rem 2rem}
.cat h3{font-size:1.45rem;margin-bottom:.3rem}
.cat .cat-sub{font-size:.86rem;color:var(--fucsia-deep);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:1.2rem}
.cat ul li{
  display:flex;gap:.7rem;align-items:flex-start;padding:.55rem 0;
  border-top:1px solid var(--line);color:var(--ink-soft);font-size:.97rem;line-height:1.45;
}
.cat ul li:first-child{border-top:none}
.cat ul li i{color:var(--teal);font-size:.7rem;margin-top:.5rem}

/* ---------- Richiamo pronto intervento ---------- */
.sos-callout{
  display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;margin-top:2.4rem;
  background:var(--teal-ink);color:#fff;border-radius:var(--r);
  padding:1.5rem 1.8rem;box-shadow:var(--shadow);
  transition:transform .25s var(--ease),box-shadow .25s;
}
.sos-callout:hover{transform:translateY(-3px)}
.sos-ico{flex-shrink:0;width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);color:#ffd2e6;font-size:1.5rem}
.sos-txt{flex:1;min-width:220px}
.sos-txt b{display:block;font-family:var(--serif);font-size:1.35rem;line-height:1.2}
.sos-txt span{font-size:.95rem;color:#cfe7e9}
.sos-go{flex-shrink:0;display:inline-flex;align-items:center;gap:.5rem;font-weight:700;color:#fff;background:var(--fucsia);padding:.85rem 1.5rem;border-radius:50px;white-space:nowrap}
.sos-callout:hover .sos-go{background:var(--fucsia-deep)}

/* ---------- Soluzioni gallery ---------- */
.soluzioni{background:var(--paper-2)}
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.6rem}
.gal-card{
  position:relative;border-radius:var(--r);overflow:hidden;height:340px;
  box-shadow:var(--shadow-sm);cursor:pointer;
}
.gal-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gal-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(8,71,79,.86) 0%,rgba(8,71,79,.15) 55%,transparent 100%)}
.gal-card:hover img{transform:scale(1.07)}
.gal-info{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:1.6rem 1.5rem;color:#fff}
.gal-info .gi-k{font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#ffd2e6}
.gal-info h3{color:#fff;font-size:1.5rem;margin-top:.25rem}
.gal-info p{font-size:.9rem;color:#dff0f1;margin-top:.3rem;opacity:0;max-height:0;transition:opacity .35s,max-height .35s}
.gal-card:hover .gal-info p{opacity:1;max-height:80px}
.gal-card.tall{grid-row:span 2;height:auto}

/* ---------- Processo ---------- */
.processo{background:var(--teal-ink);color:#fff;overflow:hidden}
.processo .eyebrow{color:#ffd2e6}
.processo .h-section{color:#fff}
.processo .lead{color:#cfe7e9}
.steps{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:3rem}
.steps::before{content:"";position:absolute;top:34px;left:12.5%;right:12.5%;height:2px;background:linear-gradient(90deg,rgba(229,53,127,.15),rgba(229,53,127,.55),rgba(229,53,127,.15))}
.step{position:relative;text-align:center;padding:0 .4rem}
.step-node{position:relative;z-index:2;width:68px;height:68px;margin:0 auto 1.1rem;border-radius:50%;background:var(--teal-deep);border:2px solid var(--fucsia);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem}
.step-num{position:absolute;top:-6px;right:calc(50% - 44px);width:26px;height:26px;border-radius:50%;background:var(--fucsia);color:#fff;font-family:var(--serif);font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;z-index:3}
.step h3{color:#fff;font-size:1.2rem;margin:0 0 .5rem}
.step p{color:#bfe0e4;font-size:.92rem;line-height:1.55}
.svg-ico{width:1em;height:1em;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;display:block}

/* ---------- Contatti ---------- */
.contatti{background:var(--paper)}
.contact-single{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);padding:2.4rem;max-width:600px;margin:2.6rem auto 0;text-align:center}
.contact-single .eyebrow{justify-content:center;margin-bottom:1rem}
.contact-single h2{font-family:var(--serif);font-size:1.9rem;margin-bottom:.3rem}
.contact-single .fsub{color:var(--ink-soft);font-size:1rem;margin-bottom:1.6rem}
.contact-single .info-list{text-align:left;margin-bottom:1.4rem}
.contact-single .quick-wa .btn{width:100%;justify-content:center}
.greview{display:inline-flex;align-items:center;gap:.6rem;justify-content:center;flex-wrap:wrap;margin:0 auto 1.3rem;padding:.6rem 1.1rem;border:1px solid var(--line);border-radius:999px;background:var(--paper);text-decoration:none;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.greview:hover{border-color:var(--teal);box-shadow:var(--shadow-sm)}
.gr-stars{color:#f5a623;display:inline-flex;gap:.1rem;font-size:.95rem}
.gr-txt{font-size:.92rem;color:var(--ink-soft)}
.gr-txt b{color:var(--ink)}
.info-list li{display:flex;gap:1rem;align-items:flex-start;padding:.7rem 0;border-top:1px solid var(--line)}
.info-list li:first-child{border-top:none}
.info-list .ic{
  flex-shrink:0;width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:rgba(13,138,154,.1);color:var(--teal);font-size:1.05rem;
}
.info-list .meta small{display:block;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.info-list .meta a,.info-list .meta span{font-size:1.02rem;color:var(--ink);font-weight:600;word-break:break-word}
.info-list .meta a:hover{color:var(--teal-deep)}
.info-list .meta .map-toggle{display:flex;width:fit-content;margin-top:.9rem}
.info-list .meta .map-consent{display:block;font-size:.78rem;font-weight:400;color:var(--ink-soft);margin-top:.55rem}
.map-inline{margin-top:.9rem;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.map-inline:empty{display:none}
.map-inline iframe{display:block;width:100%;height:300px;border:0}
.quick-wa{display:flex;gap:.8rem}
.quick-wa .btn{flex:1;justify-content:center}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#c9beb2;padding:3.4rem 0 1.6rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.4rem;align-items:start}
.footer img{height:48px;margin-bottom:1rem;filter:brightness(0) invert(1);opacity:.92}
.footer .f-desc{font-size:.95rem;max-width:38ch;color:#b3a89c}
.footer h5{color:#fff;font-family:var(--sans);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1rem}
.footer ul li{padding:.3rem 0;font-size:.95rem}
.footer ul li a:hover{color:#fff}
.footer .f-contact li{display:flex;gap:.6rem;align-items:flex-start;color:#c9beb2}
.footer .f-contact i{color:var(--fucsia);margin-top:.3rem;width:16px;text-align:center}
.f-bottom{margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.84rem;color:#9b9085}
.f-bottom a{text-decoration:underline}
.f-bottom a:hover{color:#fff}
.social{display:flex;gap:.7rem}
.social a{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);color:#d8cec3;transition:all .2s}
.social a:hover{background:var(--fucsia);color:#fff;transform:translateY(-2px)}

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed;right:24px;bottom:24px;z-index:250;
  width:60px;height:60px;border-radius:50%;background:#1faf54;color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:2rem;
  box-shadow:0 10px 30px -8px rgba(31,175,84,.7);transition:transform .25s var(--ease);
  animation:pop .5s 1s both;
}
@keyframes pop{from{transform:scale(0)}to{transform:scale(1)}}
.wa-float:hover{transform:scale(1.1)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Bonus 2026 ---------- */
.bonus{background:var(--paper)}
.bonus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:2.8rem}
.imgcard{position:relative;height:360px;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s}
.imgcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.imgcard > img{width:100%;height:100%;object-fit:cover;display:block}
.imgcard-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,71,79,.92),rgba(8,71,79,.38) 45%,transparent 70%)}
.imgcard-tx{position:absolute;left:0;right:0;bottom:0;padding:24px;color:#fff}
.imgcard-tx h3{font-family:var(--serif);font-size:1.5rem;margin-bottom:.3rem;color:#fff;line-height:1.15}
.imgcard-tx p{font-size:.95rem;color:#e6f2f3}
.bonus-example{max-width:680px;margin:2.6rem auto 0;text-align:center;background:var(--teal-ink);color:#fff;border-radius:var(--r);padding:1.9rem 2rem}
.bonus-example span{display:block;font-size:.76rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#ffd2e6;margin-bottom:.7rem}
.bonus-example p{font-size:1.12rem;color:#eef6f7;line-height:1.5}
.bonus-example b{color:#fff;font-family:var(--serif);font-size:1.3rem}
.bonus-foot{text-align:center;margin-top:2.6rem;display:flex;flex-direction:column;align-items:center;gap:1.2rem}
.bonus-help{display:inline-flex;gap:.6rem;align-items:flex-start;max-width:62ch;color:var(--ink-soft);font-size:1rem;text-align:left}
.bonus-help i{color:var(--teal);margin-top:.25rem}
.bonus-note{max-width:66ch;font-size:.82rem;color:var(--ink-soft)}

/* ---------- Zone servite ---------- */
.zone{background:var(--paper-2)}
.zone-marquee{display:flex;flex-direction:column;gap:.8rem;margin-top:2.6rem}
.zone-row{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.zone-track{display:flex;gap:.7rem;width:max-content;animation:scrollx 70s linear infinite}
.zone-row.rev .zone-track{animation-direction:reverse}
.zone-marquee:hover .zone-track{animation-play-state:paused}
.zone-chip{
  flex-shrink:0;white-space:nowrap;
  background:var(--card);border:1px solid var(--line);border-radius:50px;
  padding:.5rem 1.1rem;font-size:.95rem;font-weight:600;color:var(--ink);
  transition:background .2s,color .2s,border-color .2s;
}
.zone-chip:hover{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ---------- Cilindro EVVA (focus pronto intervento) ---------- */
.evva-models{margin-top:1.6rem;display:flex;flex-direction:column;gap:.9rem}
.evva-models > div{padding-left:1rem;border-left:3px solid var(--teal)}
.evva-models b{display:block;color:var(--teal-deep);font-family:var(--serif);font-size:1.05rem}
.evva-models span{font-size:.92rem;color:var(--ink-soft)}
.evva-note{margin-top:1.1rem;font-size:.85rem;color:var(--ink-soft)}

/* ---------- FAQ ---------- */
.faq{background:var(--paper-2)}
.faq-list{max-width:800px;margin:2.4rem auto 0;display:flex;flex-direction:column;gap:1rem}
.faq-item{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem 1.7rem}
.faq-item h3{font-family:var(--serif);font-size:1.25rem;color:var(--teal-deep);margin-bottom:.5rem;line-height:1.25}
.faq-item p{color:var(--ink-soft);font-size:1rem}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .bonus-grid{grid-template-columns:1fr}
  .menu,.nav-cta .btn{display:none}
  .hamburger{display:block}
  .storia-grid{grid-template-columns:1fr;gap:2.4rem}
  .storia-media img{height:380px}
  .cat-grid{grid-template-columns:1fr}
  .gal{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:2.4rem}
  .steps::before{display:none}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
}
@media (max-width:680px){
  .wrap{padding:0 20px}
  .sec-pad{padding:4.2rem 0}
  .topbar .tb-left{display:none}
  .topbar .wrap{justify-content:center}
  .stats .wrap{grid-template-columns:1fr 1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .gal{grid-template-columns:1fr}
  .gal-card{height:300px}
  .steps{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .hero-badge{display:none}
  .hero{min-height:82vh}
  .f-bottom{flex-direction:column}
}

/* ---------- Pagine legali ---------- */
.legal-nav{background:rgba(247,241,232,.96);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:200}
.legal-nav .wrap{display:flex;align-items:center;justify-content:space-between;min-height:74px;gap:1rem}
.legal-nav .brand img{height:54px;width:auto}
.legal-nav .back{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;color:var(--teal-deep);font-size:.95rem}
.legal-nav .back:hover{color:var(--teal)}
.legal{background:var(--paper);padding:3.4rem 0 5rem}
.legal .wrap{max-width:840px}
.legal .eyebrow{margin-bottom:1rem}
.legal h1{font-size:clamp(2rem,4.4vw,2.9rem);margin-bottom:.5rem}
.legal .updated{color:var(--ink-soft);font-size:.9rem;margin-bottom:2.4rem}
.legal h2{font-size:1.5rem;margin:2.4rem 0 .7rem;color:var(--teal-deep)}
.legal h3{font-size:1.12rem;margin:1.4rem 0 .3rem;color:var(--ink)}
.legal p,.legal li{color:var(--ink-soft);font-size:1.04rem;line-height:1.75;margin-bottom:.85rem}
.legal ul{list-style:disc;padding-left:1.3rem;margin-bottom:1rem}
.legal ul li{margin-bottom:.4rem}
.legal a{color:var(--teal-deep);text-decoration:underline}
.legal a:hover{color:var(--teal)}
.legal .card-note{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--teal);border-radius:var(--r);padding:1.2rem 1.4rem;margin:1.4rem 0}
.legal .card-note p{margin-bottom:0}
.legal .back-home{display:inline-flex;align-items:center;gap:.5rem;margin-top:2.8rem;font-weight:700;color:var(--teal-deep)}

/* ---------- Cookie banner ---------- */
.cookie-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:400;
  background:var(--teal-ink);color:#eef6f7;
  padding:1.1rem 1.4rem;box-shadow:0 -10px 30px -18px rgba(0,0,0,.5);
  transform:translateY(110%);transition:transform .4s var(--ease);
}
.cookie-bar.show{transform:translateY(0)}
.cookie-bar .cb-wrap{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;justify-content:center}
.cookie-bar p{font-size:.9rem;margin:0;flex:1;min-width:240px;line-height:1.5}
.cookie-bar a{color:#ffd2e6;text-decoration:underline}
.cookie-bar .btn{padding:.7rem 1.4rem;font-size:.9rem}
