:root{
    --viola-profondo:#1A0A4B;
    --viola-brand:#5C2DD4;
    --viola-vivace:#7C3AED;
    --viola-cta:#4A00B4;
    --grigio-perla:#F4F4F6;
    --bianco:#FFFFFF;
    --lavanda-glow:rgba(140,80,240,0.18);
    --testo-soft:rgba(26,10,75,0.66);
    --linea:rgba(92,45,212,0.14);

    --r-card:20px;
    --r-pill:999px;
    --maxw:1180px;
    --shadow-card:0 18px 50px -24px rgba(26,10,75,0.28);
    --shadow-cta:0 14px 30px -10px rgba(74,0,180,0.55);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:"Poppins",system-ui,-apple-system,"Segoe UI",sans-serif;
    color:var(--viola-profondo);
    background:linear-gradient(180deg,#F8F7FC 0%,#FFFFFF 100%);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  section{position:relative}

  /* ---------- Background orb ---------- */
  .bg-orbs{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
  .bg-orbs span{
    position:absolute;border-radius:50%;
    background:radial-gradient(circle at center, var(--lavanda-glow) 0%, rgba(140,80,240,0) 62%);
  }
  .orb-1{width:120vmax;height:120vmax;top:-40vmax;left:50%;transform:translateX(-50%)}
  .orb-2{width:55vmax;height:55vmax;bottom:-15vmax;right:-15vmax;opacity:.8}

  .container{width:min(100% - 40px,var(--maxw));margin-inline:auto}

  /* ---------- Eyebrow / tagline ---------- */
  .eyebrow{
    font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
    color:var(--viola-brand);display:inline-flex;align-items:center;gap:10px;
  }

  /* ---------- Buttons ---------- */
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    font-weight:700;font-size:15px;line-height:1;
    padding:15px 26px;border-radius:var(--r-pill);
    transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
    cursor:pointer;border:none;
  }
  .btn-primary{
    background:linear-gradient(135deg,var(--viola-cta),var(--viola-vivace));
    color:#fff;box-shadow:var(--shadow-cta);
  }
  .btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 38px -10px rgba(74,0,180,0.6)}
  .btn-ghost{background:transparent;color:var(--viola-profondo);border:1.5px solid var(--linea)}
  .btn-ghost:hover{border-color:var(--viola-vivace);color:var(--viola-vivace)}
  .btn .chev{
    width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.18);
    display:grid;place-items:center;flex:none;
  }
  .btn-ghost .chev{background:var(--viola-vivace)}
  .btn-ghost .chev svg{stroke:#fff}

  /* ---------- Navbar ---------- */
  header.nav{
    position:fixed;top:0;left:0;right:0;z-index:100;
    transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
    padding:18px 0;
  }
  header.nav.scrolled{
    background:rgba(255,255,255,.82);
    backdrop-filter:blur(14px);
    box-shadow:0 1px 0 var(--linea);
    padding:11px 0;
  }
  .nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
  .nav-logo{height:44px;width:auto;display:block;transition:height .3s ease}
  header.nav.scrolled .nav-logo{height:36px}
  .nav-links{display:flex;gap:34px;align-items:center}
  .nav-links a{font-size:14px;font-weight:500;color:var(--testo-soft);transition:color .2s}
  .nav-links a:hover{color:var(--viola-profondo)}
  .nav-links a.nav-cta{font-size:14px;padding:11px 22px;color:#fff}
  .nav-links a.nav-cta:hover{color:#fff}
  .nav-toggle{display:none;background:none;border:none;cursor:pointer}

  /* ---------- Hero ---------- */
  .hero{padding:120px 0 48px;position:relative;overflow:hidden}
  .hero>.container{position:relative;z-index:2}
  .hero .container{position:relative;z-index:1}
  .cursor-glow{
    position:fixed;left:0;top:0;width:560px;height:560px;border-radius:50%;
    transform:translate(-50%,-50%);pointer-events:none;z-index:60;opacity:0;
    background:radial-gradient(circle, rgba(140,90,255,.16), rgba(140,90,255,0) 60%);
    will-change:left,top;
  }
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;text-align:left}
  .hero-copy{text-align:left;max-width:58ch}
  .hero h1{
    font-weight:700;letter-spacing:-.02em;line-height:1.1;
    font-size:clamp(34px,5vw,60px);margin:20px 0 0;max-width:15ch;
  }
  .hero h1 .accent{color:var(--viola-vivace)}
  .hero .lead{
    font-size:clamp(16px,1.5vw,19px);color:var(--testo-soft);
    max-width:52ch;margin:24px 0 34px;
  }
  .hero-actions{display:flex;gap:14px;justify-content:flex-start;flex-wrap:wrap}

  /* ---------- Hero animated visual ---------- */
  .hero-visual{
    position:relative;width:100%;aspect-ratio:1;max-width:460px;justify-self:center;
    display:grid;place-items:center;
  }
  .hv-sphere{position:relative;width:74%;aspect-ratio:1}
  /* rotating aurora glow behind the sphere */
  .hv-glow{
    position:absolute;inset:-22%;border-radius:50%;z-index:0;pointer-events:none;
    background:conic-gradient(from 0deg,
      rgba(124,80,240,0) 0deg, rgba(124,80,240,.32) 80deg,
      rgba(74,0,180,.05) 160deg, rgba(124,58,237,.34) 260deg, rgba(124,80,240,0) 360deg);
    filter:blur(34px);animation:hv-spin 20s linear infinite;
  }
  /* orbit rings — each carries a dot and spins at its own pace */
  .hv-ring{position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--linea)}
  .hv-ring::after{
    content:"";position:absolute;top:-6px;left:50%;width:12px;height:12px;border-radius:50%;
    transform:translateX(-50%);
    background:radial-gradient(circle at 35% 30%,#b79bff,var(--viola-vivace));
    box-shadow:0 0 14px 2px rgba(124,80,240,.7);
  }
  .hv-ring.r1{animation:hv-spin 14s linear infinite}
  .hv-ring.r2{inset:13%;border-style:dashed;border-color:rgba(92,45,212,.28);animation:hv-spin 22s linear infinite reverse}
  .hv-ring.r3{inset:26%;border-color:rgba(92,45,212,.18);animation:hv-spin 30s linear infinite}
  /* glowing decision core */
  .hv-core{
    position:absolute;inset:36%;border-radius:50%;z-index:2;
    background:radial-gradient(circle at 32% 28%,#9a6bff,var(--viola-cta) 68%,var(--viola-profondo));
    box-shadow:0 26px 60px -18px rgba(74,0,180,.7), inset 0 3px 12px rgba(255,255,255,.45);
    animation:hv-breathe 4.6s ease-in-out infinite;
  }
  /* drifting sparks scattered around the orbit */
  .hv-spark{position:absolute;width:7px;height:7px;border-radius:50%;background:var(--viola-vivace);opacity:.8;z-index:1}
  .hv-spark.s1{top:8%;right:18%;animation:hv-float 5s ease-in-out infinite}
  .hv-spark.s2{bottom:14%;left:10%;width:9px;height:9px;animation:hv-float 6.4s ease-in-out infinite .8s}
  .hv-spark.s3{bottom:26%;right:6%;width:5px;height:5px;animation:hv-float 4.2s ease-in-out infinite .4s}

  /* floating data chips around the sphere */
  .hv-chip{
    position:absolute;z-index:4;display:flex;align-items:center;gap:10px;
    background:var(--bianco);border:1px solid var(--linea);border-radius:14px;
    padding:12px 15px;box-shadow:var(--shadow-card);
    font-size:13px;font-weight:600;color:var(--viola-profondo);white-space:nowrap;
  }
  .hv-chip-txt{font-weight:600}
  .chip-roi{left:-6%;top:14%;flex-direction:column;align-items:flex-start;gap:8px;animation:hv-bob 6s ease-in-out infinite}
  .chip-dec{right:-8%;top:40%;animation:hv-bob 7s ease-in-out infinite 1s}
  .chip-sce{left:4%;bottom:6%;animation:hv-bob 6.6s ease-in-out infinite .5s}
  .hv-chip-lab{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--viola-brand)}
  .hv-bars{display:flex;align-items:flex-end;gap:5px;height:34px}
  .hv-bars i{
    width:9px;border-radius:3px;height:var(--h);align-self:flex-end;
    background:linear-gradient(180deg,var(--viola-vivace),var(--viola-cta));
    transform-origin:bottom;animation:hv-grow 2.6s ease-in-out infinite;
  }
  .hv-bars i:nth-child(2){animation-delay:.2s}
  .hv-bars i:nth-child(3){animation-delay:.4s}
  .hv-bars i:nth-child(4){animation-delay:.6s}
  .hv-dot{width:9px;height:9px;border-radius:50%;flex:none;background:var(--viola-vivace);box-shadow:0 0 0 4px rgba(124,58,237,.16)}
  .hv-chip-num{
    width:30px;height:30px;border-radius:50%;flex:none;display:grid;place-items:center;
    font-size:14px;font-weight:700;color:#fff;
    background:linear-gradient(135deg,var(--viola-cta),var(--viola-vivace));
  }
  @keyframes hv-spin{to{transform:rotate(360deg)}}
  @keyframes hv-breathe{0%,100%{transform:scale(.96)}50%{transform:scale(1.05)}}
  @keyframes hv-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
  @keyframes hv-float{0%,100%{transform:translateY(0);opacity:.55}50%{transform:translateY(-12px);opacity:1}}
  @keyframes hv-grow{0%,100%{transform:scaleY(.55)}50%{transform:scaleY(1)}}
  .hero-sphere{
    width:clamp(150px,26vw,260px);aspect-ratio:1;margin:54px auto 0;position:relative;
  }
  .hero-sphere .ring{
    position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--linea);
  }
  .hero-sphere .ring.r2{inset:14%;border-color:rgba(92,45,212,.22)}
  .hero-sphere .core{
    position:absolute;inset:30%;border-radius:50%;
    background:radial-gradient(circle at 32% 28%,var(--viola-vivace),var(--viola-cta) 70%,var(--viola-profondo));
    box-shadow:0 30px 60px -20px rgba(74,0,180,.6);
  }
  .hero-sphere .dot{position:absolute;width:11px;height:11px;border-radius:50%;background:var(--viola-vivace)}

  /* scroll cue */
  .scroll-cue{margin:46px auto 0;width:34px;height:34px;border-radius:50%;
    border:1.5px solid var(--linea);display:grid;place-items:center;color:var(--viola-brand)}


  /* ---------- logos marquee ---------- */
  .logos{padding:18px 0 27px;overflow:hidden}
  .logos-title{text-align:center;font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--testo-soft);margin-bottom:26px}
  .logos-marquee{
    position:relative;width:100%;overflow:hidden;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);
            mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);
  }
  .logos-track{display:flex;align-items:center;width:max-content;animation:logos-scroll 63s linear infinite;will-change:transform}
  .logos-marquee:hover .logos-track{animation-play-state:paused}
  .logo-ph{
    flex:none;display:grid;place-items:center;height:40px;margin-right:72px;
  }
  .logo-ph img{
    height:auto;width:auto;max-height:40px;max-width:120px;object-fit:contain;display:block;
    filter:grayscale(1);opacity:.62;transition:filter .25s ease,opacity .25s ease;
  }
  .logos-marquee:hover .logo-ph img,
  .logo-ph img:hover{filter:grayscale(0);opacity:1}
  @keyframes logos-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  @media (prefers-reduced-motion: reduce){ .logos-track{animation:none} }

  /* ---------- generic section heading ---------- */
  .sec-head{max-width:60ch}
  .sec-head.center{margin-inline:auto;text-align:center}
  .sec-head h2{
    font-weight:700;letter-spacing:-.02em;line-height:1.18;
    font-size:clamp(26px,3.6vw,40px);margin:16px 0 0;
  }
  .sec-head p{color:var(--testo-soft);margin-top:16px;font-size:17px}

  .pad{padding:48px 0}

  /* ---------- Promise / value pillars ---------- */
  .pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:27px}
  .pillar{
    background:var(--bianco);border-radius:var(--r-card);padding:32px 28px;
    box-shadow:var(--shadow-card);position:relative;overflow:hidden;
    border:1px solid rgba(255,255,255,.6);
  }
  .pillar::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;
    background:linear-gradient(90deg,var(--viola-cta),var(--viola-vivace))}
  .pillar .ic{
    width:50px;height:50px;border-radius:14px;display:grid;place-items:center;
    background:linear-gradient(135deg,rgba(124,58,237,.12),rgba(92,45,212,.08));
    color:var(--viola-vivace);margin-bottom:20px;
  }
  .pillar h3{font-size:20px;font-weight:700;margin-bottom:10px}
  .pillar p{color:var(--testo-soft);font-size:15px}

  /* ---------- Method (diagonal flow) ---------- */
  #metodo{background:linear-gradient(180deg,#FFFFFF,#F6F4FC)}
  .mf-line{display:none}
  /* ---- composed showcase: central case-study card + floating satellites ---- */
  .method-stage{position:relative;margin-top:40px;height:clamp(540px,52vw,600px)}

  /* central card */
  .ms-central{
    position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
    width:clamp(320px,38vw,440px);z-index:2;
    background:var(--bianco);border:1px solid var(--linea);border-radius:26px;
    padding:26px 30px 24px;box-shadow:0 50px 100px -40px rgba(26,10,75,.5);
    display:flex;flex-direction:column;align-items:center;gap:16px;
  }
  .msc-head{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;position:relative}
  .msc-dot{position:absolute;left:0;width:13px;height:13px;border-radius:50%;border:2px solid var(--linea)}
  .msc-title{font-size:14px;font-weight:600;color:var(--viola-profondo)}
  .msc-spark{position:absolute;right:0;display:grid;place-items:center}
  .msc-avatar{
    width:62px;height:62px;border-radius:50%;display:grid;place-items:center;margin-top:4px;
    background:radial-gradient(circle at 34% 30%,#9a6bff,var(--viola-cta) 70%,var(--viola-profondo));
    box-shadow:0 14px 30px -10px rgba(74,0,180,.6), inset 0 2px 8px rgba(255,255,255,.5);
  }
  .msc-prompt{font-size:14.5px;line-height:1.5;color:var(--viola-profondo);text-align:center;max-width:34ch}
  .msc-reply{
    align-self:stretch;background:linear-gradient(135deg,rgba(124,58,237,.10),rgba(74,0,180,.06));
    border:1px solid var(--linea);border-radius:14px;padding:12px 16px;
    font-size:13px;color:var(--testo-soft);text-align:center;
  }
  .msc-bar{
    align-self:stretch;display:flex;align-items:center;gap:12px;border-radius:999px;padding:5px;
    background:var(--bianco);
    box-shadow:0 0 0 2px rgba(255,255,255,.9), 0 0 0 4px transparent;
    position:relative;
  }
  .msc-bar::before{
    content:"";position:absolute;inset:-2px;border-radius:999px;z-index:-1;
    background:linear-gradient(120deg,var(--viola-vivace),#ff9a8b,var(--viola-cta));
  }
  .msc-bar-ic{
    width:34px;height:34px;border-radius:50%;display:grid;place-items:center;flex:none;color:#fff;font-size:20px;font-weight:600;line-height:1;
    background:linear-gradient(135deg,var(--viola-vivace),var(--viola-cta));
  }
  .msc-bar-ph{flex:1;font-size:13.5px;color:var(--testo-soft)}
  .msc-bar-go{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;flex:none;background:rgba(26,10,75,.12)}

  /* satellite step cards */
  .ms-card{
    position:absolute;z-index:3;width:clamp(180px,17vw,224px);opacity:1;
    background:var(--bianco);border:1px solid var(--linea);border-radius:16px;padding:16px 18px;
    box-shadow:var(--shadow-card);
  }
  .ms-card .mn-num{
    display:grid;place-items:center;width:30px;height:30px;border-radius:50%;
    background:linear-gradient(135deg,var(--viola-cta),var(--viola-vivace));color:#fff;font-weight:700;font-size:12px;margin-bottom:10px;
    box-shadow:0 8px 18px -6px rgba(124,58,237,.6);
  }
  .ms-card h4{font-size:14.5px;font-weight:700;margin-bottom:5px;letter-spacing:-.01em;line-height:1.25}
  .ms-card p{font-size:12.5px;color:var(--testo-soft);line-height:1.4}
  .ms-card.s1{left:16%;top:7%}
  .ms-card.s2{right:15%;top:1%}
  .ms-card.s3{left:17%;bottom:5%}
  .ms-card.s4{right:15%;bottom:0}

  /* decorative stat chips */
  .ms-chip{
    position:absolute;z-index:3;display:flex;flex-direction:column;gap:2px;opacity:1;
    background:var(--bianco);border:1px solid var(--linea);border-radius:14px;padding:12px 16px;
    box-shadow:var(--shadow-card);
  }
  .ms-chip .msch-k{font-size:20px;font-weight:700;color:var(--viola-vivace);letter-spacing:-.02em}
  .ms-chip .msch-l{font-size:11px;color:var(--testo-soft)}
  .ms-chip.c1{left:23%;bottom:33%}
  .ms-chip.c2{right:22%;top:35%}

  /* ---------- Services ---------- */
  .svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:26px}
  .svc{
    background:var(--bianco);border-radius:var(--r-card);padding:34px 30px;
    box-shadow:var(--shadow-card);position:relative;border:1px solid rgba(255,255,255,.6);
    display:flex;flex-direction:column;gap:14px;
  }
  .svc .tag{font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--viola-brand)}
  .svc h3{font-size:22px;font-weight:700}
  .svc p{color:var(--testo-soft);font-size:15px}
  .svc.deal{
    grid-column:1/-1;
    background:linear-gradient(135deg,var(--viola-cta),var(--viola-profondo));
    color:#fff;
  }
  .svc.deal h3,.svc.deal .tag{color:#fff}
  .svc.deal p{color:rgba(255,255,255,.78)}
  .deal-flow{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
  .deal-phase{
    flex:1 1 240px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
    border-radius:14px;padding:20px;
  }
  .deal-phase span{font-size:12px;font-weight:600;color:#C9B6FF;letter-spacing:.06em}
  .deal-phase h4{font-size:17px;font-weight:700;margin:6px 0}
  .deal-phase p{font-size:13.5px}

  /* ---------- Proof / case study ---------- */
  .proof-section{background:linear-gradient(180deg,#F6F4FC,#FFFFFF)}
  .cs{position:relative;padding:30px 0 48px}
  .cs-head{max-width:66ch;margin:0 auto 30px;text-align:center}
  .cs-head h2{font-weight:700;letter-spacing:-.02em;line-height:1.18;font-size:clamp(26px,3.6vw,40px);margin:16px 0 0}
  .cs-head p{color:var(--testo-soft);margin-top:16px;font-size:17px}
  .cs-inner{display:grid;grid-template-columns:.82fr 1.18fr;gap:48px;align-items:start}
  .cs-side{align-self:start;position:sticky;top:96px}
  .cs-kicker{font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--viola-brand)}
  .cs-steps{list-style:none;display:flex;flex-direction:column;gap:13px;margin:24px 0 0}
  .cs-steps li{
    display:flex;align-items:center;gap:14px;font-size:16px;font-weight:600;color:var(--viola-profondo);
    opacity:.45;cursor:pointer;user-select:none;border-radius:10px;padding:4px 6px;margin-left:-6px;
    transition:opacity .35s ease, transform .35s ease, background .25s ease;
  }
  .cs-steps li:hover{opacity:.85;background:rgba(124,58,237,.06)}
  .cs-steps li:focus-visible{outline:2px solid var(--viola-vivace);outline-offset:2px}
  .cs-steps li.active{opacity:1;transform:translateX(5px)}
  .cs-steps li .si{
    width:34px;height:34px;border-radius:50%;flex:none;display:grid;place-items:center;
    font-size:12px;font-weight:700;background:var(--grigio-perla);color:var(--viola-brand);
    transition:background .35s ease, color .35s ease;
  }
  .cs-steps li.active .si{background:var(--viola-vivace);color:#fff}
  .cs-progress{height:3px;background:var(--linea);border-radius:2px;margin-top:28px;overflow:hidden;max-width:320px}
  .cs-progress span{display:block;height:100%;width:0%;background:linear-gradient(90deg,var(--viola-cta),var(--viola-vivace));transition:width .4s ease}
  .cs-hint{font-size:12.5px;color:var(--testo-soft);margin-top:18px;max-width:34ch}

  /* mini-report paper card — scrolls internally; the page stays put while
     the cursor is over it (overscroll-behavior:contain) */
  .cs-stage{
    position:relative;border-radius:18px;padding:0 52px 34px;color:var(--viola-profondo);
    background:linear-gradient(180deg,#FFFFFF 0%,#FBFAFE 100%);
    border:1px solid var(--linea);
    box-shadow:0 40px 90px -40px rgba(26,10,75,.4);
    height:clamp(440px,64vh,580px);overflow-y:auto;overscroll-behavior:contain;
    scroll-behavior:smooth;
  }
  .cs-stage::-webkit-scrollbar{width:8px}
  .cs-stage::-webkit-scrollbar-thumb{background:rgba(92,45,212,.28);border-radius:8px}
  .cs-stage::-webkit-scrollbar-track{background:transparent}
  .cs-stage{scrollbar-width:thin;scrollbar-color:rgba(92,45,212,.28) transparent}
  /* a thin brand accent down the left edge, like a report margin */
  .cs-stage::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--viola-cta),var(--viola-vivace))}
  .report-head{
    display:flex;align-items:center;justify-content:space-between;gap:16px;
    padding-bottom:16px;border-bottom:1.5px solid var(--viola-profondo);
  }
  .report-head .rh-logo{height:30px;width:auto}
  .report-head .rh-title{font-size:13.5px;font-style:italic;color:var(--viola-profondo);font-weight:500;text-align:right}
  .report-head .rh-title em{font-style:italic;color:var(--testo-soft);font-weight:400}
  .report-foot{
    display:flex;align-items:center;justify-content:space-between;gap:16px;
    margin-top:18px;padding-top:14px;border-top:1px solid var(--linea);
    font-size:11.5px;letter-spacing:.04em;color:var(--testo-soft);
  }
  .report-foot .rf-page{font-variant-numeric:tabular-nums;font-weight:600;color:var(--viola-brand)}
  .cs-ghost{display:none}
  /* on desktop the wrapper is transparent: slides flow exactly as before */
  .cs-track{display:contents}
  .cs-slide{position:relative;z-index:1;display:flex;flex-direction:column;gap:13px}
  .cs-slide + .cs-slide{margin-top:30px;padding-top:30px;border-top:1px solid var(--linea)}
  .cs-slide .lab{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--viola-brand)}
  .cs-slide .big{font-size:clamp(36px,5.5vw,60px);font-weight:700;line-height:1;letter-spacing:-.02em;color:var(--viola-vivace)}
  .cs-slide .big-sub{font-size:15px;font-weight:500;color:var(--testo-soft);letter-spacing:0;margin-left:6px;white-space:nowrap}
  .cs-slide h3{font-size:clamp(20px,2.4vw,26px);font-weight:700;max-width:24ch;letter-spacing:-.01em;color:var(--viola-profondo)}
  .cs-slide h3.quote{font-size:clamp(21px,2.8vw,30px);max-width:26ch;line-height:1.32;font-style:italic}
  .cs-slide p{font-size:15px;color:var(--testo-soft);max-width:50ch}

  /* keep the report header visible while the phases scroll beneath it;
     the top spacing lives inside the header so it sticks flush to the top
     and no phase text can peek above it */
  .report-head{position:sticky;top:0;z-index:5;padding:34px 0 16px;background:var(--bianco)}

  /* ---------- Audience ---------- */
  .aud-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:25px}
  .aud{
    background:var(--bianco);border-radius:16px;padding:26px 26px;border:1px solid var(--linea);
    display:flex;gap:16px;align-items:flex-start;
  }
  .aud .ck{width:30px;height:30px;border-radius:50%;flex:none;display:grid;place-items:center;
    background:rgba(124,58,237,.12);color:var(--viola-vivace)}
  .aud h4{font-size:16px;font-weight:700;margin-bottom:4px}
  .aud p{font-size:14px;color:var(--testo-soft)}

  /* ---------- Mission ---------- */
  #mission{text-align:center}
  .mission-q{
    font-size:clamp(24px,3.6vw,40px);font-weight:700;letter-spacing:-.02em;
    line-height:1.3;max-width:22ch;margin:24px auto 0;
  }
  .mission-q em{color:var(--viola-vivace);font-style:normal}

  /* ---------- CTA ---------- */
  .cta-band{
    background:linear-gradient(135deg,var(--viola-profondo),var(--viola-cta));
    border-radius:32px;padding:64px 48px;text-align:center;color:#fff;position:relative;overflow:hidden;
  }
  .cta-band::before{content:"";position:absolute;width:60vmax;height:60vmax;border-radius:50%;
    top:-40vmax;left:50%;transform:translateX(-50%);
    background:radial-gradient(circle,var(--lavanda-glow),transparent 60%)}
  .cta-band h2{font-size:clamp(26px,4vw,42px);font-weight:700;letter-spacing:-.02em;max-width:20ch;margin:0 auto 14px;position:relative}
  .cta-band p{color:rgba(255,255,255,.82);max-width:50ch;margin:0 auto 32px;position:relative}
  .cta-band .btn{position:relative;background:#fff;color:var(--viola-cta)}
  .cta-band .btn .chev{background:var(--viola-vivace)}

  /* ---------- Contact form ---------- */
  .contact-wrap{
    display:grid;grid-template-columns:.85fr 1.15fr;
    border-radius:28px;overflow:hidden;background:var(--bianco);
    box-shadow:0 40px 90px -40px rgba(26,10,75,.4);border:1px solid rgba(255,255,255,.6);
  }
  .contact-aside{
    background:linear-gradient(155deg,var(--viola-profondo),var(--viola-cta));
    color:#fff;padding:50px 44px;position:relative;overflow:hidden;
  }
  .contact-aside::before{
    content:"";position:absolute;width:60vmax;height:60vmax;border-radius:50%;
    top:-30vmax;left:-20vmax;background:radial-gradient(circle,var(--lavanda-glow),transparent 60%);pointer-events:none;
  }
  .contact-aside>*{position:relative;z-index:1}
  .contact-aside .eyebrow{color:#E6DBFF}
  .contact-aside .eyebrow::before{background:#E6DBFF}
  .contact-aside h2{font-size:clamp(24px,3vw,32px);font-weight:700;letter-spacing:-.02em;margin:16px 0 12px;line-height:1.2}
  .contact-aside p{color:rgba(255,255,255,.82);font-size:15px}
  .contact-points{list-style:none;margin:28px 0 0;display:flex;flex-direction:column;gap:14px}
  .contact-point{display:flex;align-items:center;gap:12px;font-size:14.5px;font-weight:500}
  .cp-ic{width:26px;height:26px;border-radius:50%;flex:none;display:grid;place-items:center;background:rgba(255,255,255,.14);color:#fff}
  .contact-mail{display:inline-block;margin-top:34px;font-size:14px;font-weight:600;color:#fff;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:2px}

  .contact-form-panel{padding:48px 44px}
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
  .field{display:flex;flex-direction:column;gap:7px}
  .field.full{grid-column:1/-1}
  .field label{font-size:13px;font-weight:600;color:var(--viola-profondo)}
  .field label .req{color:var(--viola-vivace)}
  .field input,.field select,.field textarea{
    font-family:inherit;font-size:15px;color:var(--viola-profondo);
    padding:13px 15px;border:1px solid var(--linea);border-radius:12px;background:var(--bianco);
    width:100%;transition:border-color .2s ease, box-shadow .2s ease;
  }
  .field input::placeholder,.field textarea::placeholder{color:rgba(26,10,75,.4)}
  .field input:focus,.field select:focus,.field textarea:focus{
    outline:none;border-color:var(--viola-vivace);box-shadow:0 0 0 3px rgba(124,58,237,.15);
  }
  .field textarea{resize:vertical;min-height:120px;line-height:1.5}
  .field select{
    appearance:none;-webkit-appearance:none;cursor:pointer;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235C2DD4' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 14px center;padding-right:42px;
  }
  .form-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:22px}
  .form-note{font-size:12.5px;color:var(--testo-soft);max-width:36ch;margin:0}
  .form-success{text-align:center;padding:30px 10px}
  .form-success .fs-ic{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;background:rgba(124,58,237,.12);color:var(--viola-vivace)}
  .form-success h3{font-size:22px;font-weight:700;margin-bottom:10px}
  .form-success p{font-size:15px;color:var(--testo-soft);max-width:42ch;margin:0 auto}
  .form-success a{color:var(--viola-vivace);font-weight:600}

  /* ---------- Footer ---------- */
  footer{padding:32px 0 24px}
  .foot-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;flex-wrap:wrap}
  .foot-logo{height:36px;width:auto;margin-bottom:14px}
  footer p{font-size:14px;color:var(--testo-soft);max-width:34ch}
  .foot-links{display:flex;gap:40px;flex-wrap:wrap}
  .foot-col h5{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--viola-brand);margin-bottom:14px}
  .foot-col a{display:block;font-size:14px;color:var(--testo-soft);margin-bottom:9px;transition:color .2s}
  .foot-col a:hover{color:var(--viola-profondo)}
  .foot-bottom{margin-top:24px;padding-top:24px;border-top:1px solid var(--linea);
    display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--testo-soft)}
  .foot-legal{display:flex;gap:20px;flex-wrap:wrap}
  .foot-legal a{color:var(--testo-soft);transition:color .2s}
  .foot-legal a:hover{color:var(--viola-vivace)}

  /* ---------- Hero quick chips ---------- */
  .hero-chips{display:flex;gap:12px;justify-content:flex-start;flex-wrap:wrap;margin-top:30px}
  .hchip{
    display:inline-flex;align-items:center;gap:9px;padding:10px 16px;border-radius:var(--r-pill);
    background:var(--bianco);border:1px solid var(--linea);font-size:13.5px;font-weight:500;
    color:var(--viola-profondo);cursor:pointer;
    transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
  }
  .hchip:hover{transform:translateY(-2px);border-color:var(--viola-vivace);box-shadow:var(--shadow-card)}
  .hchip .d{width:7px;height:7px;border-radius:50%;background:var(--viola-vivace);flex:none}

  /* ---------- Hero interactive orbit ---------- */
  .hero-orbit{position:relative;width:100%;max-width:520px;aspect-ratio:1;margin:0 auto;justify-self:center}
  .orbit-glow{
    position:absolute;inset:-14%;border-radius:50%;z-index:0;pointer-events:none;
    background:conic-gradient(from 0deg,
      rgba(124,80,240,0) 0deg, rgba(124,80,240,.30) 70deg,
      rgba(74,0,180,.06) 150deg, rgba(124,58,237,.30) 250deg, rgba(124,80,240,0) 360deg);
    filter:blur(36px);opacity:.75;
  }
  .core-halo{
    position:absolute;left:50%;top:50%;width:58%;aspect-ratio:1;border-radius:50%;
    transform:translate(-50%,-50%) scale(1);z-index:1;pointer-events:none;
    background:radial-gradient(circle, rgba(124,80,240,.55), rgba(124,80,240,0) 68%);
    filter:blur(20px);animation:halo-breathe 4.2s ease-in-out infinite;
  }
  @keyframes halo-breathe{
    0%,100%{opacity:.42;transform:translate(-50%,-50%) scale(.9)}
    50%{opacity:.85;transform:translate(-50%,-50%) scale(1.12)}
  }
  .orbit-ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--linea);z-index:2}
  .orbit-ring.ring-b{inset:15%;border-style:dashed;border-color:rgba(92,45,212,.22)}
  /* ---------- Animated wireframe sphere (dark purple, lit for depth) ---------- */
  :root{
    --sph-primary:74,0,180;     /* viola scuro — wireframe (palette viola-cta) */
    --sph-rot-dur:240s;
    --sph-wire-op:.62;
  }
  .sphere-stage{
    position:absolute;left:50%;top:50%;width:340px;height:340px;
    transform:translate(-50%,-52%);perspective:1200px;z-index:1;pointer-events:none;
    opacity:.9;
  }
  /* soft purple portal behind the sphere */
  .sphere-stage::before{
    content:"";position:absolute;inset:-30%;border-radius:50%;z-index:-1;
    background:radial-gradient(circle at 50% 50%,
      rgba(74,0,180,.42) 0%,
      rgba(92,45,212,.30) 26%,
      rgba(124,58,237,.18) 46%,
      rgba(124,58,237,.08) 64%,
      rgba(124,58,237,0) 84%);
    filter:blur(22px);
  }
  /* fixed light source (top-left): illuminated side + highlight */
  .sphere-light{
    position:absolute;left:50%;top:50%;width:92%;height:92%;transform:translate(-50%,-50%);
    border-radius:50%;z-index:0;
    background:radial-gradient(circle at 34% 29%,
      rgba(255,255,255,.95) 0%, rgba(221,212,255,.55) 18%,
      rgba(124,58,237,.16) 42%, rgba(124,58,237,0) 66%);
    filter:blur(5px);
    animation:sphereBreathe 9s ease-in-out infinite;
  }
  /* gaussian blur keeps the sphere decorative, not the hero protagonist */
  .sphere-blur{
    position:absolute;inset:0;filter:blur(5px);
  }
  .sphere-rot{
    position:absolute;inset:0;transform-style:preserve-3d;z-index:2;
    animation:sphereRotate var(--sph-rot-dur) linear infinite;
  }
  .wireframe-line{
    position:absolute;inset:0;border-radius:50%;transform-style:preserve-3d;
    border:1px solid rgba(var(--sph-primary),var(--sph-wire-op));
    box-shadow:0 0 14px rgba(var(--sph-primary),.18);
  }
  /* shaded side (bottom-right) — gives volume, multiplies over the dark mesh */
  .sphere-shade{
    position:absolute;left:50%;top:50%;width:98%;height:98%;transform:translate(-50%,-50%);
    border-radius:50%;z-index:3;pointer-events:none;mix-blend-mode:multiply;
    background:radial-gradient(circle at 70% 74%,
      rgba(26,10,75,.55) 0%, rgba(26,10,75,.22) 30%, rgba(26,10,75,0) 56%);
  }
  /* soft ambient halo so the sphere sits in the scene, not pasted-on */
  .sphere-stage::after{
    content:"";position:absolute;left:50%;top:50%;width:120%;height:120%;
    transform:translate(-50%,-50%);border-radius:50%;z-index:-1;pointer-events:none;
    background:radial-gradient(circle, rgba(124,58,237,.14) 0%, rgba(124,58,237,.05) 40%, transparent 64%);
    filter:blur(18px);
  }
  @keyframes sphereRotate{
    from{transform:rotateY(0deg) rotateX(0deg)}
    to{transform:rotateY(360deg) rotateX(360deg)}
  }
  @keyframes sphereBreathe{
    0%,100%{opacity:.85}
    50%{opacity:1}
  }
  /* selecting a pill energises the (blurred) sphere */
  .sphere-stage.is-active .sphere-rot{animation-duration:60s}
  .sphere-stage.is-active::before{filter:blur(20px);background:radial-gradient(circle at 50% 50%,rgba(74,0,180,.55) 0%,rgba(124,58,237,.26) 40%,rgba(124,58,237,0) 82%)}

  /* central label, sits above the blurred sphere */
  .orbit-core{
    position:absolute;left:50%;top:50%;transform:translate(-50%,-52%);
    width:185px;aspect-ratio:1;border-radius:50%;padding:5%;
    display:grid;place-content:center;text-align:center;gap:5px;
    color:#fff;cursor:pointer;transition:transform .3s ease;z-index:5;
    text-shadow:0 2px 16px rgba(40,10,90,.85),0 1px 4px rgba(40,10,90,.7);
  }
  .orbit-core:hover{transform:translate(-50%,-52%) scale(1.05)}
  .orbit-core .oc-k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#c4b5fd}
  .orbit-core .oc-label{font-size:clamp(18px,2.3vw,24px);font-weight:700;line-height:1.12;color:#fff}
  .orbit-core .oc-sub{font-size:12px;color:rgba(255,255,255,.78);line-height:1.32}
  .onode{
    position:absolute;transform:translate(-50%,-50%);
    background:var(--bianco);border:1px solid var(--linea);border-radius:var(--r-pill);
    padding:11px 16px;font-size:13px;font-weight:600;color:var(--viola-profondo);
    cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-card);
    display:flex;align-items:center;gap:8px;z-index:4;
    transition:border-color .25s ease,background .25s ease,color .25s ease,box-shadow .25s ease;
  }
  .onode .od{width:6px;height:6px;border-radius:50%;background:var(--viola-vivace);flex:none;transition:background .25s}
  .onode:hover{border-color:var(--viola-vivace)}
  .onode.active{background:linear-gradient(135deg,var(--viola-cta),var(--viola-vivace));color:#fff;border-color:transparent;box-shadow:var(--shadow-cta), 0 0 26px -2px rgba(124,80,240,.75)}
  .onode.active .od{background:#fff}

  /* ---------- Bridge / role ---------- */
  .bridge{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch;margin-top:27px}
  .bnode{
    background:var(--bianco);border:1px solid var(--linea);border-radius:var(--r-card);
    padding:32px 28px;text-align:center;box-shadow:var(--shadow-card);
  }
  .bnode .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--viola-brand);font-weight:500}
  .bnode h4{font-size:20px;font-weight:700;margin:12px 0 10px;letter-spacing:-.01em}
  .bnode p{font-size:14px;color:var(--testo-soft)}
  .bnode.mid{background:linear-gradient(135deg,var(--viola-cta),var(--viola-vivace));color:#fff;border:none;box-shadow:var(--shadow-cta);transform:translateY(-8px)}
  .bnode.mid .k{color:#E6DBFF}
  .bnode.mid p{color:rgba(255,255,255,.84)}
  .bconn{display:grid;place-items:center;padding:0 10px}
  .bconn .chev{width:36px;height:36px;border-radius:50%;background:var(--viola-vivace);display:grid;place-items:center;box-shadow:0 8px 18px -6px rgba(124,58,237,.6)}

  /* ---------- Strategies ---------- */
  .strat-block{margin-top:24px}
  .strat-block .sub-h{
    font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--viola-brand);
    font-weight:500;padding-bottom:18px;margin-bottom:26px;border-bottom:1px solid var(--linea);
    display:flex;align-items:center;justify-content:space-between;gap:14px;
  }
  .strat-block .sub-h em{font-style:normal;color:var(--testo-soft);text-transform:none;letter-spacing:0;font-size:14px}
  .strat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .strat{
    display:flex;gap:16px;align-items:flex-start;background:var(--bianco);
    border:1px solid var(--linea);border-radius:16px;padding:24px;
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s;
  }
  .strat:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);border-color:transparent}
  .strat .n{
    font-size:12px;font-weight:700;color:var(--viola-vivace);flex:none;
    font-variant-numeric:tabular-nums;width:26px;height:26px;border-radius:50%;
    display:grid;place-items:center;background:rgba(124,58,237,.1);
  }
  .strat h4{font-size:16px;font-weight:700;margin-bottom:5px}
  .strat p{font-size:13.5px;color:var(--testo-soft)}

  /* ---------- reveal base ---------- */
  .reveal{opacity:0;transform:translateY(30px)}

  /* ---------- responsive ---------- */
  @media (max-width:880px){
    .pillars,.svc-grid,.aud-grid,.stats,.strat-grid{grid-template-columns:1fr}
    .bridge{grid-template-columns:1fr}
    .bnode.mid{transform:none}
    .bconn{padding:8px 0}
    .bconn .chev{transform:rotate(90deg)}
    .method-stage{height:auto;display:flex;flex-direction:column;align-items:stretch;gap:16px}
    .ms-central{position:relative;left:auto;top:auto;transform:none;width:auto;order:-1}
    .ms-card,.ms-chip{position:relative;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto}
    .ms-chip{align-items:flex-start}
    .mf-line{display:none}
    .nav-links{
      position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:#fff;
      flex-direction:column;justify-content:center;gap:26px;padding:40px;
      transform:translateX(100%);transition:transform .35s ease;box-shadow:-20px 0 60px -30px rgba(26,10,75,.4);
    }
    .nav-links.open{transform:translateX(0)}
    .nav-links a{font-size:18px}
    .nav-toggle{display:block;z-index:101}
    .pad{padding:36px 0}
    .proof-card,.cta-band{padding:40px 26px}
    .proof-card .ghost-num{font-size:140px}
    .hero{padding:104px 0 36px}
    .hero-grid{grid-template-columns:1fr;gap:30px}
    .hero-copy{text-align:left;max-width:none}
    .hero h1{max-width:18ch}
    .hero-actions,.hero-chips{justify-content:flex-start}
    .hero-actions .btn{flex:1 1 auto;justify-content:center}
    .hero-visual{order:2;max-width:320px;margin:6px auto 0}
    /* pull the floating chips inside the frame so they don't clip on narrow screens */
    .chip-roi{left:0;top:10%}
    .chip-dec{right:0;top:42%}
    .chip-sce{left:2%;bottom:2%}
    .hero-orbit{width:min(92vw,420px);margin-top:44px}
    .sphere-stage{transform:translate(-50%,-52%) scale(.86)}
    .onode{padding:8px 12px;font-size:11.5px}
    .cs-inner{grid-template-columns:1fr;gap:22px;min-width:0}
    /* mobile: niente lista fasi, solo le card sfogliabili */
    .cs-side{display:none}
    /* report = deck di card larghe quanto lo schermo, altezza naturale */
    .cs-stage{padding:20px 18px;height:auto;overflow:hidden;min-width:0}
    .report-head{position:static;margin:0;padding:0 0 14px}
    .cs-track{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scrollbar-width:none;margin-top:4px;max-width:100%}
    .cs-track::-webkit-scrollbar{display:none}
    .cs-slide{flex:0 0 100%;width:100%;min-width:0;scroll-snap-align:center}
    .cs-slide + .cs-slide{margin-top:0;padding-top:0;border-top:none}
    .cs-slide h3{max-width:none}
    .cs-slide p{max-width:none}
    .cs-slide .big{font-size:clamp(30px,8vw,42px)}
    .contact-wrap{grid-template-columns:1fr}
    .contact-aside{padding:40px 28px}
    .contact-form-panel{padding:34px 28px}
    .form-grid{grid-template-columns:1fr}
    .form-foot .btn{width:100%;justify-content:center}
    /* footer legal row stacks neatly */
    .foot-bottom{flex-direction:column;align-items:flex-start;gap:12px}
    .foot-legal{gap:18px}
    .foot-links{gap:28px}
  }
  @media (max-width:430px){
    .onode{padding:7px 10px;font-size:10.5px;gap:6px}
    .onode .od{width:5px;height:5px}
    .hero{padding:96px 0 30px}
    .hero .lead{font-size:16px}
    .hero-visual{max-width:268px}
    .hv-chip{font-size:11px;padding:9px 11px;gap:8px}
    .hv-bars{height:26px}
    .hv-chip-num{width:26px;height:26px;font-size:13px}
    .sec-head h2,.cs-head h2{font-size:25px}
    .cs-stage{padding:22px}
    .cs-slide h3{font-size:20px}
    .logo-ph{margin-right:46px}
    .contact-aside,.contact-form-panel{padding:30px 22px}
  }

  @media (prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
    .reveal{opacity:1!important;transform:none!important}
    .cs-steps li{opacity:1}
  }

/* ---------- Blog ---------- */
.page-top{padding:120px 0 20px}
.blog-hero{max-width:62ch}
.blog-hero h1{font-size:clamp(32px,5vw,52px);font-weight:700;letter-spacing:-.02em;line-height:1.1;margin:18px 0 0}
.blog-hero p{color:var(--testo-soft);font-size:18px;margin-top:18px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:14px}
.post-card{
  display:flex;flex-direction:column;gap:12px;background:var(--bianco);border:1px solid rgba(255,255,255,.6);
  border-radius:var(--r-card);padding:28px 26px;box-shadow:var(--shadow-card);position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;color:inherit;
}
.post-card::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--viola-cta),var(--viola-vivace));transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.post-card:hover{transform:translateY(-4px);box-shadow:0 26px 60px -28px rgba(26,10,75,.4)}
.post-card:hover::after{transform:scaleX(1)}
.post-tag{align-self:flex-start;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--viola-brand);background:rgba(124,58,237,.1);padding:6px 12px;border-radius:var(--r-pill)}
.post-card h3{font-size:20px;font-weight:700;letter-spacing:-.01em;line-height:1.25}
.post-card p{font-size:14.5px;color:var(--testo-soft);flex:1}
.post-meta{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--testo-soft);margin-top:4px}
.post-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--viola-vivace)}
.post-readmore{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--viola-vivace);margin-top:2px}

/* ---------- Article ---------- */
.article{max-width:760px;margin-inline:auto}
.back-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--viola-brand);margin-bottom:26px}
.back-link:hover{color:var(--viola-vivace)}
.article-head .post-meta{margin-top:16px}
.article h1{font-size:clamp(28px,4.4vw,46px);font-weight:700;letter-spacing:-.02em;line-height:1.12;margin-top:14px}
.article-lead{font-size:19px;color:var(--testo-soft);line-height:1.6;margin-top:20px}
.article-rule{height:1px;background:var(--linea);margin:34px 0}
.post-body p{font-size:16.5px;line-height:1.75;color:var(--viola-profondo);margin-bottom:20px}
.post-body h2{font-size:24px;font-weight:700;letter-spacing:-.01em;margin:36px 0 14px}
.post-body strong{font-weight:700}
.post-body ul{margin:0 0 20px;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.post-body ul li{position:relative;padding-left:30px;font-size:16.5px;line-height:1.65;color:var(--viola-profondo)}
.post-body ul li::before{content:"";position:absolute;left:6px;top:10px;width:8px;height:8px;border-radius:50%;background:var(--viola-vivace)}
.post-quote{
  border-left:4px solid var(--viola-vivace);background:linear-gradient(135deg,rgba(124,58,237,.06),rgba(92,45,212,.03));
  padding:22px 26px;border-radius:0 14px 14px 0;margin:30px 0;font-size:18px;font-style:italic;color:var(--viola-profondo);
}
.article-cta{margin-top:44px;padding-top:30px;border-top:1px solid var(--linea);text-align:center}
.article-cta p{color:var(--testo-soft);margin-bottom:18px}

@media (max-width:880px){
  .blog-grid{grid-template-columns:1fr}
  .page-top{padding:100px 0 16px}
}
