/* ============================================================
   Syrus Precision — Main stylesheet
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  margin:0;font-family:var(--font-body);font-size:var(--fs-body);
  line-height:var(--lh-body);color:var(--c-ink);background:var(--c-bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:clip; /* contiene off-canvas/animazioni senza rompere position:sticky */
}
h1,h2,h3,h4{font-family:var(--font-display);line-height:var(--lh-tight);letter-spacing:var(--ls-tight);color:var(--c-black);margin:0 0 .5em}
p{margin:0 0 1rem}
a{color:var(--c-blue);text-decoration:none}
a:hover{color:var(--c-blue-deep)}
img{max-width:100%;height:auto;display:block}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.container--narrow{max-width:var(--container-narrow)}
.section{padding-block:clamp(2.6rem,5vw,4.5rem)}
.section-title{font-size:var(--fs-h2);margin-bottom:.6em}
.section-intro{font-size:var(--fs-lead);color:var(--c-muted);max-width:62ch;margin-bottom:2.5rem}
.eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:#0d5596;font-weight:700;margin:0 0 1rem}
.lead{font-size:var(--fs-lead);color:var(--c-muted)}
.skip-link{position:fixed;left:1rem;top:-120%;background:var(--c-blue);color:#fff;padding:.6rem 1rem;z-index:1000;border-radius:0 0 var(--r-sm) var(--r-sm);transition:top .2s var(--ease)}
.skip-link:focus{top:0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:600;border-radius:var(--r-pill);
  padding:.8rem 1.6rem;border:1px solid transparent;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s}
.btn-lg{padding:1rem 2rem;font-size:1.05rem}
.btn-primary{background:var(--grad-blue);color:#fff;box-shadow:var(--sh-blue)}
.btn-primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 22px 50px rgba(22,104,178,.36)}
.btn-ghost{background:transparent;color:var(--c-blue-deep);border-color:rgba(8,71,133,.35);font-weight:600}
.btn-ghost:hover{background:rgba(22,104,178,.06);border-color:var(--c-blue);color:var(--c-blue-deep);transform:translateY(-2px)}
.btn-ghost i{transition:transform .25s var(--ease)}
.btn-ghost:hover i{transform:translateX(3px)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:900;transition:all .35s var(--ease);padding-block:1rem}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand img{height:60px;width:auto;display:block}
.site-header.is-condensed .brand img{height:46px}
.nav-menu{display:flex;align-items:center;gap:1.8rem;list-style:none;margin:0;padding:0}
.nav-menu a{color:var(--c-ink);font-weight:500;font-size:.97rem;position:relative}
.nav-menu a[aria-current=page]{color:var(--c-blue)}
.nav-menu a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--c-blue);transition:width .3s var(--ease)}
.nav-menu a:not(.btn):hover::after{width:100%}
.nav-menu a.btn,.nav-menu a.nav-cta{color:#fff}            /* CTA sempre testo bianco */
.nav-menu a.btn:hover{color:#fff}
.nav-cta{padding:.6rem 1.2rem;box-shadow:none}
.header-actions{display:flex;align-items:center;margin-left:auto;margin-right:1.4rem}
.header-phone{display:inline-flex;align-items:center;gap:.5rem;color:var(--c-ink);font-weight:700;font-size:1.02rem;white-space:nowrap}
.header-phone i{color:var(--c-blue)}
.header-phone:hover{color:var(--c-blue)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.5rem;position:relative;z-index:1002}
.nav-toggle span{width:26px;height:2px;background:var(--c-ink);border-radius:2px;transition:transform .3s var(--ease),opacity .3s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* condensed (scrolled) */
.site-header.is-condensed{padding-block:.5rem}
.site-header.is-condensed .site-header__inner{
  background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd);border-radius:var(--r-pill);box-shadow:var(--sh-2);
  padding:.55rem .8rem .55rem 1.2rem;margin-top:.2rem}

/* ---------- Hero ---------- */
.hero{position:relative;padding-block:clamp(3rem,7vw,6rem);overflow:hidden}
.hero__bg{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,var(--c-bg) 100%),var(--grad-mesh);z-index:-1}
/* Ancora visiva: orb blu sfumato a destra (puro CSS, niente asset) */
.hero::after{content:"";position:absolute;top:50%;right:-8%;width:min(46vw,560px);aspect-ratio:1;
  transform:translateY(-50%);background:radial-gradient(circle at 50% 50%,rgba(22,104,178,.22),rgba(8,71,133,.10) 45%,transparent 70%);
  filter:blur(8px);z-index:-1;pointer-events:none}
.hero__inner{max-width:880px;position:relative}
.hero__title{font-size:var(--fs-display);margin-bottom:.35em;line-height:1.0}
.hero__text{font-size:var(--fs-lead);color:var(--c-muted);max-width:58ch;margin-bottom:2.2rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero .eyebrow{margin-bottom:1.3rem}

/* ---------- Answer box (AEO) ---------- */
.answer-box{background:var(--c-surface);border:1px solid var(--c-line);border-left:4px solid var(--c-blue);
  border-radius:var(--r-md);padding:1.5rem 1.8rem;box-shadow:var(--sh-1)}
.answer-box__label{font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--c-blue);margin:0 0 .4rem}
.answer-box__text{font-size:1.15rem;color:var(--c-ink);margin:0}

/* ---------- Trust bar ---------- */
.section--trust{padding-block:2.5rem}
.trust-title{text-align:center;color:var(--c-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-bottom:1.6rem}
.trust-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem 1.4rem;list-style:none;margin:0;padding:0}
.trust-item{display:flex;align-items:center;gap:.55rem;color:var(--c-ink);font-weight:600;font-size:.95rem;
  background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-pill);padding:.55rem 1.1rem;box-shadow:var(--sh-1);transition:.25s var(--ease)}
.trust-item:hover{border-color:rgba(22,104,178,.4);box-shadow:var(--sh-2);transform:translateY(-1px)}
.trust-item i{color:var(--c-blue);font-size:1.15rem}
@media (max-width:768px){.trust-bar{gap:.6rem}.trust-item{font-size:.85rem;padding:.45rem .9rem}}

/* ---------- Bento grid ---------- */
.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.bento-card{grid-column:span 1;background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-lg);
  padding:1.8rem;display:flex;flex-direction:column;gap:.6rem;color:var(--c-ink);
  box-shadow:var(--sh-1);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;min-height:200px}
.bento-card:hover{transform:translateY(-4px);box-shadow:var(--sh-3);border-color:transparent;color:var(--c-ink)}
.bento-card--2x2{grid-column:span 2;grid-row:span 2;background:var(--grad-blue);color:#fff;min-height:300px}
.bento-card--2x2 .bento-card__text,.bento-card--2x2 .bento-card__title{color:#fff}
.bento-card--2x1{grid-column:span 2}
.bento-card__icon{width:48px;height:48px;display:grid;place-items:center;border-radius:var(--r-sm);background:var(--c-surface-2);color:var(--c-blue);font-size:1.3rem}
.bento-card--2x2 .bento-card__icon{background:rgba(255,255,255,.18);color:#fff}
.bento-card__title{font-size:1.35rem}
.bento-card--2x2 .bento-card__title{font-size:1.7rem}
.bento-card__text{color:var(--c-muted);margin:0;flex:1;font-size:1rem}
.bento-card__more{font-weight:600;color:var(--c-blue);font-size:.95rem;margin-top:.7rem;display:inline-flex;align-items:center;gap:.4rem}
.bento-card:hover .bento-card__more{gap:.6rem}
.bento-card--2x2 .bento-card__more{color:#fff}

/* ---------- Stats ---------- */
.section--stats{background:var(--c-black);color:#fff;position:relative;overflow:hidden}
.section--stats::before{content:"";position:absolute;top:-30%;left:50%;transform:translateX(-50%);width:80%;height:160%;
  background:radial-gradient(ellipse at center,rgba(22,104,178,.22),transparent 60%);pointer-events:none}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2.5rem 2rem;text-align:center;position:relative;margin:0}
.stat__value{font-family:var(--font-mono);font-size:clamp(3rem,6vw,4.4rem);font-weight:700;color:#fff;line-height:1;letter-spacing:-.02em;text-shadow:0 0 30px rgba(22,104,178,.5)}
.stat__label{color:#aab3c2;margin:.6rem 0 0;font-size:.95rem}

/* ---------- Process timeline ---------- */
.timeline{list-style:none;margin:0;padding:0;position:relative}
.timeline::before{content:"";position:absolute;left:22px;top:6px;bottom:6px;width:2px;background:var(--c-line)}
.timeline__item{position:relative;padding-left:64px;margin-bottom:2.2rem}
.timeline__num{position:absolute;left:0;top:0;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--font-mono);font-weight:700;background:var(--c-surface);border:2px solid var(--c-blue);color:var(--c-blue);z-index:1}
.timeline__body h3{font-size:var(--fs-h3);margin-bottom:.2em}
.timeline__body p{color:var(--c-muted);margin:0}

/* ---------- Features / cards ---------- */
.feature-grid,.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem}
.feature{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);padding:1.6rem;box-shadow:var(--sh-1)}
.feature__icon{width:46px;height:46px;display:grid;place-items:center;border-radius:var(--r-sm);background:var(--c-surface-2);color:var(--c-blue);font-size:1.2rem;margin-bottom:.8rem}
.feature h3{font-size:1.15rem}
.feature p{color:var(--c-muted);margin:0}
.link-card{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-lg);padding:1.8rem;display:block;color:var(--c-ink);box-shadow:var(--sh-1);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.link-card:hover{transform:translateY(-4px);box-shadow:var(--sh-3);color:var(--c-ink)}
.link-card__icon{font-size:1.5rem;color:var(--c-blue);margin-bottom:.6rem}
.link-card p{color:var(--c-muted)}
.link-card__more{font-weight:600;color:var(--c-blue);font-size:.92rem}

/* ---------- People ---------- */
.people-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.4rem}
.person{margin:0;background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-1)}
.person img{aspect-ratio:1;object-fit:cover;width:100%}
.person figcaption{padding:1rem 1.2rem}
.person figcaption span{display:block;color:var(--c-muted);font-size:.9rem}

/* ---------- FAQ ---------- */
.faq-list{display:flex;flex-direction:column;gap:.8rem}
.faq-item{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);padding:0 1.4rem}
.faq-item summary{cursor:pointer;font-weight:600;padding:1.15rem 0;min-height:60px;list-style:none;display:flex;gap:1rem;justify-content:space-between;align-items:center;font-family:var(--font-display);font-size:1.05rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"\002B";color:var(--c-blue);font-size:1.7rem;font-weight:400;line-height:1;transition:transform .3s var(--ease);flex:none}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item__a{padding-bottom:1rem;color:var(--c-muted)}

/* ---------- Prose / legal ---------- */
.prose{font-size:1.05rem;color:var(--c-ink)}
.prose h2{font-size:var(--fs-h3);margin-top:2rem}
.prose ul{padding-left:1.2rem}
.legal-title{font-size:var(--fs-h1);margin-bottom:1.5rem}

/* ---------- CTA ---------- */
/* CTA: pannello scuro contenuto su sfondo chiaro → crea lo "stacco" prima del footer (consenso review) */
.section--cta{background:var(--c-bg);color:#fff;position:relative}
.cta-panel{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4rem);align-items:center;
  background:var(--c-black);border-radius:var(--r-xl);padding:clamp(1.8rem,4vw,3.5rem);box-shadow:var(--sh-3);overflow:hidden}
.cta-copy{align-self:center}
.cta-title{color:#fff;font-size:var(--fs-h2)}
.cta-text{color:#aeb7c6;font-size:var(--fs-lead)}
.cta-points{list-style:none;padding:0;margin:1.5rem 0 0;display:grid;gap:.7rem}
.cta-points li{color:#dfe5ee}
.cta-points i{color:var(--c-gold);margin-right:.5rem}
.cta-form{background:var(--c-surface);border-radius:var(--r-xl);padding:clamp(1.5rem,3vw,2.4rem);box-shadow:0 0 0 1px rgba(22,104,178,.4),0 30px 80px rgba(22,104,178,.25);color:var(--c-ink)}

/* ---------- Lead form ---------- */
.lead-form .form-row{margin-bottom:1rem}
.lead-form label{display:block;font-weight:600;font-size:.92rem;margin-bottom:.4rem}
.lead-form input,.lead-form select,.lead-form textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--c-line);border-radius:var(--r-sm);font:inherit;background:var(--c-bg);transition:border-color .2s,box-shadow .2s}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:none;border-color:var(--c-blue);box-shadow:0 0 0 3px rgba(22,104,178,.15)}
.lead-form .form-row--2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-check label{display:flex;gap:.6rem;align-items:flex-start;font-weight:400;font-size:.92rem}
.form-check input{width:auto;margin-top:.2rem}
.hp-field{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.btn-submit{width:100%;justify-content:center;margin-top:.5rem}
.btn-submit.is-loading{opacity:.7;pointer-events:none}
.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.form-reassure{margin-top:.8rem;font-size:.82rem;color:var(--c-muted);text-align:center}
.form-reassure i{color:var(--c-blue);margin-right:.3rem}
.form-feedback{margin-top:.6rem;font-size:.92rem;min-height:1.2em;text-align:center}
.form-feedback.is-ok{color:#1c8a4a}.form-feedback.is-err{color:#c0392b}
.field-error{border-color:#c0392b!important}

/* ---------- Partner e tecnologie ---------- */
.section--partners{padding-block:2.5rem;border-block:1px solid var(--c-line);background:var(--c-surface)}
.partners-title{text-align:center;color:var(--c-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;font-weight:600;margin-bottom:1.6rem}
.partners-grid{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2.2rem 4rem;list-style:none;margin:0;padding:0}
.partner-logo img{height:84px;width:auto;transition:transform .25s var(--ease)}
.partner-logo img:hover{transform:scale(1.05)}
@media (max-width:768px){.partners-grid{gap:2rem 2.6rem}.partner-logo img{height:60px}}

/* ---------- Recensioni Google ---------- */
.section--reviews{background:var(--c-bg)}
.reviews-head{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;align-items:flex-end;margin-bottom:2.5rem}
.reviews-rating{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}
.reviews-rating__score{font-family:var(--font-mono);font-size:2.4rem;font-weight:700;line-height:1;color:var(--c-ink)}
.reviews-stars{color:#fbbc04;letter-spacing:2px}
.reviews-rating__meta{display:flex;align-items:center;gap:.4rem;color:var(--c-muted);font-size:.9rem}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.review-card{position:relative;background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--sh-1);margin:0;display:flex;flex-direction:column;gap:.8rem}
.review-card__g{position:absolute;top:1.4rem;right:1.4rem}
.review-card blockquote{margin:0;color:var(--c-ink);font-size:.98rem;line-height:1.6;flex:1}
.review-card figcaption{display:flex;align-items:center;gap:.7rem;border-top:1px solid var(--c-line);padding-top:.9rem}
.review-card__avatar{width:38px;height:38px;border-radius:50%;background:var(--grad-blue);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.85rem;flex:none}
.review-card small{color:var(--c-muted)}
.reviews-cta{text-align:center;margin-top:2rem}
@media (max-width:900px){.reviews-grid{grid-template-columns:1fr}.reviews-head{align-items:flex-start}.reviews-rating{align-items:flex-start}}

/* ---------- Mappa + contatti ---------- */
.section--mapcontact{background:var(--c-surface);border-top:1px solid var(--c-line)}
.mapcontact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.mapcontact-lead{color:var(--c-muted);font-size:var(--fs-lead);margin-bottom:1.5rem}
.offices-list{list-style:none;padding:0;margin:0 0 1.6rem;display:grid;gap:.7rem}
.offices-list li{display:flex;gap:.6rem;align-items:baseline}
.offices-list i{color:var(--c-blue)}
.mapcontact-actions{display:flex;flex-wrap:wrap;gap:.8rem}
.leaflet-map,.gmap-embed{height:420px;width:100%;border:0;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2);z-index:1;display:block}
.leaflet-map .leaflet-control-attribution{font-size:10px}
@media (max-width:900px){.mapcontact-grid{grid-template-columns:1fr}.leaflet-map,.gmap-embed{height:340px}}

/* ---------- Sticky mobile CTA (2 azioni: WhatsApp + Form) ---------- */
.mobile-cta{display:none}
@media (max-width:820px){
  .mobile-cta{display:flex;position:fixed;left:.8rem;right:.8rem;bottom:.8rem;z-index:800;gap:.6rem;
    transform:translateY(160%);opacity:0;transition:transform .35s var(--ease),opacity .35s}
  .mobile-cta.is-shown{transform:none;opacity:1}
  .mobile-cta__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:52px;
    color:#fff;font-weight:600;font-size:.98rem;border-radius:var(--r-pill);box-shadow:var(--sh-3);padding:.8rem 1rem}
  .mobile-cta__btn i{font-size:1.15rem}
  .mobile-cta__btn--wa{background:#25D366}
  .mobile-cta__btn--wa:hover,.mobile-cta__btn--wa:active{color:#fff;background:#1ebe5b}
  .mobile-cta__btn--form{background:var(--grad-blue)}
  .mobile-cta__btn--form:hover,.mobile-cta__btn--form:active{color:#fff}
}

/* ---------- Footer ---------- */
.site-footer{background:#0e1218;color:#aab3c2;padding-block:4rem 2rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem}
.footer-claim{color:#8b95a5;font-size:.95rem;margin-top:1rem}
.footer-contact{display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;margin-top:1rem}
.footer-contact a{color:#cfd6e2;font-weight:600;font-size:.92rem}
.footer-contact a:hover{color:#fff}
.footer-contact i{color:var(--c-blue);margin-right:.35rem}
.footer-trust{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.badge-trust{font-size:.74rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#cfd6e2;padding:.3rem .6rem;border-radius:var(--r-pill)}
.site-footer h3{color:#fff;font-size:1rem;margin-bottom:1rem}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.footer-col a{color:#aab3c2}.footer-col a:hover{color:#fff}
.footer-addresses li{font-size:.85rem;margin-bottom:.5rem;white-space:nowrap}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:2.5rem;padding-top:1.5rem;font-size:.85rem;color:#7c8696}
.site-footer img{filter:brightness(0) invert(1);opacity:.9}

/* ---------- Reveal animation (solo con JS attivo: no-JS = tutto visibile, LCP safe) ---------- */
.js [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease);will-change:opacity,transform}
.js [data-reveal].is-visible{opacity:1;transform:none}
.js .reveal-item{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal-item.is-visible{opacity:1;transform:none}
/* L'hero è LCP: rendilo visibile subito anche con JS (niente attesa IO) per non penalizzare LCP. */
.js .hero [data-reveal],.js .hero .reveal-item{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:992px){
  .bento-grid{grid-template-columns:repeat(2,1fr)}
  .bento-card--2x2{grid-column:span 2;grid-row:span 1;min-height:200px}
  .cta-panel{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .nav-toggle{display:flex}
  .header-actions{margin-right:.6rem}
  /* Su mobile il telefono resta ben visibile come icona-pillola accanto all'hamburger */
  .header-phone{background:rgba(22,104,178,.1);border-radius:var(--r-pill);padding:.55rem .7rem}
  .header-phone__num{display:none}
  .header-phone i{font-size:1.15rem}
  .nav-menu{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);height:100dvh;z-index:950;flex-direction:column;align-items:flex-start;gap:1.4rem;
    background:var(--c-surface);padding:5.5rem 2rem 2rem;box-shadow:var(--sh-3);transform:translateX(100%);transition:transform .35s var(--ease);overflow-y:auto}
  .nav-menu.is-open{transform:none}
  .nav-cta{margin-top:.5rem}
  /* Mentre il menu è aperto: niente filtro sull'header (altrimenti il drawer fisso si rimpicciolisce) + scroll bloccato */
  .nav-open{overflow:hidden}
  .nav-open .site-header.is-condensed .site-header__inner{backdrop-filter:none;-webkit-backdrop-filter:none;background:transparent;box-shadow:none;border-color:transparent}
}
/* Telefoni: una sola colonna, card a larghezza piena (niente schiacciamento) */
@media (max-width:768px){
  .bento-grid{grid-template-columns:1fr;gap:1rem}
  .bento-card,.bento-card--2x2,.bento-card--2x1{grid-column:1 / -1;grid-row:auto;min-height:0}
  .bento-card{padding:1.5rem}
  .feature-grid,.card-grid{grid-template-columns:1fr}
  .lead-form .form-row--2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{justify-content:center}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  [data-reveal],.reveal-item{opacity:1;transform:none}
}

/* ---- WhatsApp widget (solo desktop; mobile usa la sticky CTA) ---- */
.wa-widget{position:fixed;right:24px;bottom:24px;z-index:1000;display:none}
@media(min-width:1024px){.wa-widget:not([hidden]){display:block}}
.wa-widget__bubble{position:relative;width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;border:none;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.25);font-size:30px;display:flex;align-items:center;justify-content:center;transition:transform .2s;animation:wa-attention 6s ease-in-out 4s infinite}
.wa-widget__bubble:hover{transform:scale(1.06);animation-play-state:paused}
@keyframes wa-attention{
  0%,84%,100%{transform:rotate(0) scale(1)}
  86%{transform:rotate(-15deg) scale(1.06)}
  88%{transform:rotate(13deg) scale(1.06)}
  90%{transform:rotate(-11deg) scale(1.05)}
  92%{transform:rotate(9deg) scale(1.05)}
  94%{transform:rotate(-5deg) scale(1.03)}
  96%{transform:rotate(0) scale(1)}
}
.wa-widget__badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:12px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.wa-widget__panel{position:absolute;right:0;bottom:74px;width:330px;max-width:80vw;background:#fff;border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.22);overflow:hidden;animation:waIn .2s ease}
@keyframes waIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.wa-widget__head{display:flex;align-items:center;gap:10px;background:#075E54;color:#fff;padding:12px 14px}
.wa-widget__avatar{width:38px;height:38px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;font-size:20px;flex:0 0 auto}
.wa-widget__id{display:flex;flex-direction:column;line-height:1.2}
.wa-widget__status{font-size:12px;opacity:.85}
.wa-widget__close{margin-left:auto;background:none;border:none;color:#fff;font-size:26px;line-height:1;cursor:pointer;width:44px;height:44px;border-radius:8px}
.wa-widget__body{background:#ECE5DD;padding:16px 14px}
.wa-widget__msg{background:#fff;border-radius:2px 12px 12px 12px;padding:10px 12px;margin:0;font-size:14px;line-height:1.5;color:#111;box-shadow:0 1px 1px rgba(0,0,0,.08)}
.wa-widget__cta{display:flex;align-items:center;justify-content:center;gap:8px;background:#25D366;color:#fff;text-decoration:none;font-weight:600;padding:14px;font-size:15px}
.wa-widget__cta:hover{background:#1da851}

/* ---- Above-the-fold landing: varianti selezionabili (?atf=form|bar) ---- */
/* Variante FORM: form a destra del testo (2 colonne). Headline a sinistra con respiro. */
.hero--atf-form .hero__inner{max-width:1180px;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(360px,415px);gap:clamp(2rem,4vw,3.4rem);align-items:center;text-align:left}
.hero--atf-form .hero__copy{min-width:0}
.hero--atf-form .hero__actions{justify-content:flex-start}
.hero__form{background:var(--c-surface,#fff);border:1px solid rgba(20,30,60,.12);border-radius:var(--r-xl,18px);padding:clamp(1.4rem,2.4vw,1.8rem);box-shadow:none;color:var(--c-ink,#14181f);text-align:left}
.hero__form-title{font-size:1.2rem;font-weight:700;margin:0 0 1.1rem}
.hero__form-sub{font-size:.92rem;color:var(--c-muted,#5b6472);margin:.18rem 0 1.1rem}
.hero__form .lead-form{margin:0}
.lead-form--compact .form-row{margin-bottom:.7rem}
.lead-form--compact .form-reassure{font-size:.78rem;margin-top:.6rem}
.lead-form--compact .btn-submit{width:100%;justify-content:center}
/* Variante BAR: striscia di contatto rapida. */
.hero__cta-bar{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.8rem}
.hero__cta-item{display:inline-flex;align-items:center;gap:.55rem;padding:.78rem 1.25rem;border-radius:999px;background:#fff;border:1px solid rgba(20,30,60,.12);font-weight:600;text-decoration:none;color:var(--c-ink,#14181f);transition:transform .15s var(--ease,ease),box-shadow .15s var(--ease,ease)}
.hero__cta-item:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(20,30,60,.14)}
.hero__cta-item--wa{background:#25D366;color:#fff;border-color:#25D366}
.hero__cta-item--primary{background:var(--grad-blue);color:#fff;border-color:transparent;box-shadow:var(--sh-blue)}
/* Hero compresso nelle varianti, così l'elemento resta above-the-fold. */
.hero--atf-form,.hero--atf-bar{padding-block:clamp(2rem,4vw,3.6rem)}
/* Variante form: sfondo identico alla home (mesh completo + orb). Il problema era l'ombra della card, ora rimossa. */
.hero--atf-bar::after{top:40%;width:min(38vw,440px)}
.hero--atf-form .hero__title{font-size:clamp(1.9rem,3.4vw,2.85rem);line-height:1.05}
.hero--atf-bar .hero__title{font-size:clamp(2rem,4.4vw,3.1rem)}
.hero--atf-form .hero__text{margin-bottom:1.4rem;max-width:46ch}
.hero--atf-bar .hero__text{margin-bottom:1.3rem;max-width:52ch}
@media(max-width:900px){
  .hero--atf-form .hero__inner{grid-template-columns:1fr;gap:1.6rem}
  .hero--atf-form .hero__form{max-width:520px}
}
@media(max-width:560px){
  .hero__cta-item{flex:1 1 100%;justify-content:center}
}

/* ---- Lead form: validazione client-side (campo errato + messaggio) ---- */
.lead-form input.is-invalid,.lead-form textarea.is-invalid{border-color:#e03131;box-shadow:0 0 0 3px rgba(224,49,49,.12)}
.lead-form input[type=checkbox].is-invalid{outline:2px solid #e03131;outline-offset:2px}
.lead-form .field-error{display:block;color:#e03131;font-size:.82rem;font-weight:500;margin-top:.35rem}
