/* ============================================================
   Pagina-servizio (/servizi/<slug>/) — estende lo stile .home-landing.
   Scoped sotto .service-page. Riusa le variabili di home.css.
   ============================================================ */

.service-page .sp-hero{position:relative;padding:64px 0 48px;overflow:hidden;text-align:left}
.service-page .sp-hero::before{content:"";position:absolute;top:-80px;right:-60px;width:420px;height:420px;
  border-radius:50%;background:radial-gradient(circle,rgba(111,108,240,.16),transparent 68%);filter:blur(10px);pointer-events:none}
.service-page .sp-crumbs{position:relative;font-size:.85rem;color:var(--muted);margin-bottom:18px}
.service-page .sp-crumbs a{color:var(--accent);font-weight:600}
.service-page .sp-crumbs a:hover{text-decoration:underline}
.service-page .sp-hero .kicker{display:inline-flex;align-items:center;font-size:.75rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:var(--soft);
  border:1px solid var(--line);padding:5px 13px;border-radius:30px;margin-bottom:18px}
.service-page .sp-hero h1{font-size:2.8rem;max-width:32ch;margin:0 0 18px;position:relative;line-height:1.12}
.service-page .sp-hero .lead{font-size:1.3rem;color:var(--ink2);max-width:62ch;margin:0 0 28px;line-height:1.5;position:relative}
.service-page .sp-hero .hero-cta{display:flex;gap:14px;flex-wrap:wrap;position:relative}

/* hero a 2 colonne: testo + mockup animato */
.service-page .sp-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.service-page .sp-hero-text{position:relative}
.service-page .sp-hero-mock{position:relative;justify-self:end;width:100%;max-width:380px}
.service-page .sp-hero-mock .ai-chip{position:absolute;top:-14px;right:18px;z-index:3}
.service-page .sp-hero-mock .mock{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:16px;box-shadow:0 40px 80px -40px rgba(16,21,31,.4)}

/* campi della prima nota: animati dal JS */
.service-page #sp-form .inp{position:relative;color:var(--ink);white-space:nowrap}
.service-page #sp-form .inp.active{border-color:var(--accent);background:#eef5fc}
.service-page #sp-form .inp.active::after{content:"";position:absolute;width:2px;height:16px;background:var(--accent);
  margin-left:1px;animation:caret .7s step-end infinite}
.service-page #sp-form .inp.done{border-color:var(--accent);background:#eef5fc}
.service-page #sp-save{opacity:.35;filter:grayscale(.6);transition:opacity .4s,filter .4s}
.service-page #sp-save.ready{opacity:1;filter:none;animation:pulse 2.4s ease-in-out infinite}
/* scansione del documento sorgente */
.service-page .sp-hero-mock .src-doc .src-scan{opacity:0;animation:none}
.service-page .sp-hero-mock .src-doc.reading .src-scan{opacity:1;animation:scanHero 1.6s ease-in-out}

.service-page .sp-cols{max-width:760px}
.service-page .sp-feats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 26px;max-width:760px}

/* mockup confidenza nell'hero */
.service-page .sp-hero-mock .doc-mock{width:100%;max-width:380px;background:#fff;border:1px solid var(--line);
  border-radius:16px;padding:18px;box-shadow:0 40px 80px -40px rgba(16,21,31,.4)}
.service-page .sp-hero-mock .conf-row .bar i{width:0;transition:width 1s cubic-bezier(.2,.7,.3,1)}
.service-page .sp-hero-mock[data-state="run"] .conf-row .bar i,
.service-page .sp-hero-mock[data-state="done"] .conf-row .bar i{width:var(--w)}
.service-page .sp-hero-mock .review{opacity:0;transform:translateY(6px);transition:opacity .5s,transform .5s}
.service-page .sp-hero-mock[data-state="done"] .review{opacity:1;transform:none}

/* FAQ */
.service-page .sp-faq{max-width:780px}
.service-page .sp-faq h2{font-size:1.9rem;margin-bottom:24px}
.service-page .sp-faq-item{border:1px solid var(--line);border-radius:12px;background:#fff;margin-bottom:12px;
  padding:0 20px;transition:.18s}
.service-page .sp-faq-item summary{cursor:pointer;font-weight:700;color:var(--ink);font-size:1.05rem;
  padding:18px 0;list-style:none;display:flex;justify-content:space-between;align-items:center}
.service-page .sp-faq-item summary::-webkit-details-marker{display:none}
.service-page .sp-faq-item summary::after{content:"+";font-size:1.4rem;color:var(--accent);font-weight:400;margin-left:14px;transition:transform .2s}
.service-page .sp-faq-item[open] summary::after{transform:rotate(45deg)}
.service-page .sp-faq-item p{color:var(--ink2);line-height:1.65;padding:0 0 18px;margin:0;max-width:64ch}
.service-page .sp-faq-item:hover{border-color:var(--accent)}
.service-page .sp-text h2{font-size:1.9rem;margin-bottom:18px;color:var(--ink)}
.service-page .sp-p{font-size:1.08rem;color:var(--ink2);line-height:1.7;margin-bottom:14px;max-width:65ch}
.service-page .sp-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.service-page .sp-feats{margin-top:22px}
.service-page .sp-visual{display:flex;justify-content:center}

.service-page .final h2{max-width:24ch}

@media(max-width:880px){
  .service-page .sp-hero-grid{grid-template-columns:1fr;gap:36px}
  .service-page .sp-hero-mock{justify-self:center;max-width:420px}
  .service-page .sp-feats-grid{grid-template-columns:1fr}
  .service-page .sp-hero h1{font-size:2.1rem}
  .service-page .sp-hero .lead{font-size:1.12rem}
  .service-page .sp-text h2{font-size:1.6rem}
}

/* ---- Altri servizi (internal linking spoke→spoke) ---- */
.service-page .sp-others h2{font-size:1.7rem;margin:0 0 28px}
.service-page .sp-others-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-page .sp-other-card{display:flex;flex-direction:column;gap:8px;padding:22px;
  background:#fff;border:1px solid var(--line);border-radius:14px;text-decoration:none;
  transition:border-color .18s,box-shadow .18s,transform .18s}
.service-page .sp-other-card:hover{border-color:var(--accent);
  box-shadow:0 18px 40px -22px rgba(0,0,0,.25);transform:translateY(-2px)}
.service-page .sp-other-label{font-weight:800;font-size:1.05rem;color:var(--ink)}
.service-page .sp-other-lead{font-size:.92rem;color:var(--muted);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.service-page .sp-other-go{margin-top:auto;font-weight:700;font-size:.9rem;color:var(--accent)}
@media(max-width:760px){.service-page .sp-others-grid{grid-template-columns:1fr}}
