:root{
    --bg:#0A0A0A;
    --bg-2:#121212;
    --bg-3:#171717;
    --fg:#EFEDE9;
    --muted:#8C8C8C;
    --muted-2:#5E5E5E;
    --line:rgba(255,255,255,.12);
    --line-2:rgba(255,255,255,.06);
    --display:'Syne', sans-serif;
    --sans:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --maxw:1280px;
    --gutter:clamp(20px, 5vw, 80px);
    --ease:cubic-bezier(.16,1,.3,1);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--sans);background:var(--bg);color:var(--fg);
    line-height:1.55;font-weight:300;-webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  body.loading{overflow:hidden;height:100vh}

  h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1;letter-spacing:-0.02em}
  p{color:var(--muted)}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  ::selection{background:var(--fg);color:var(--bg)}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
  .eyebrow{
    font-family:var(--sans);font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;
    color:var(--muted);font-weight:500;margin-bottom:1.8rem;display:flex;align-items:center;gap:.7rem;
  }
  .eyebrow::before{content:"";width:28px;height:1px;background:currentColor}

  /* ---------- Grain overlay ---------- */
  .grain{position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

  /* ---------- Intro loader ---------- */
  #intro{position:fixed;inset:0;z-index:10000;background:var(--bg);overflow:hidden;transition:opacity .8s var(--ease),transform 1s var(--ease)}
  #intro.done{opacity:0;transform:translateY(-101%);pointer-events:none}
  #intro .intro-fx{position:absolute;inset:0;width:100%;height:100%;display:block}
  .intro-center{position:absolute;left:0;right:0;bottom:clamp(30px,8vh,76px);display:flex;flex-direction:column;align-items:center;gap:.9rem;text-align:center;padding:0 24px;z-index:2}
  .intro-word{font-family:var(--display);font-weight:800;font-size:clamp(2rem,7vw,4.2rem);letter-spacing:-0.04em;color:var(--fg);line-height:1}
  .intro-tag{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
  .intro-bar{width:min(240px,58vw);height:2px;background:var(--line);border-radius:2px;overflow:hidden;margin-top:.2rem}
  .intro-bar span{display:block;height:100%;width:0;background:var(--fg)}
  @media(max-width:600px){
    .intro-center{bottom:clamp(22px,6vh,46px);gap:.7rem;padding:0 18px}
    .intro-word{font-size:clamp(1.7rem,9vw,2.6rem)}
    .intro-tag{font-size:.6rem;letter-spacing:.12em;max-width:92vw;line-height:1.5}
    .intro-bar{width:min(220px,66vw)}
  }

  /* ---------- Custom cursor ---------- */
  .cursor{position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;background:var(--fg);z-index:9500;pointer-events:none;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s,opacity .3s;mix-blend-mode:difference}
  .cursor.hover{width:54px;height:54px;background:var(--fg)}
  @media (hover:none){.cursor{display:none}}

  /* ---------- Buttons ---------- */
  .btn{
    position:relative;display:inline-flex;align-items:center;gap:.7rem;font-family:var(--sans);
    font-size:.82rem;letter-spacing:.02em;font-weight:500;padding:1.1em 2.1em;
    border:1px solid var(--fg);background:var(--fg);color:var(--bg);cursor:pointer;border-radius:100px;
    transition:background .4s var(--ease),color .4s var(--ease);overflow:hidden;will-change:transform;
  }
  .btn span{position:relative;z-index:1}
  .btn:hover{background:transparent;color:var(--fg)}
  .btn--ghost{background:transparent;color:var(--fg)}
  .btn--ghost:hover{background:var(--fg);color:var(--bg)}
  .btn--lg{padding:1.25em 2.6em;font-size:.9rem}
  .btn .arrow{display:inline-block;transition:transform .4s var(--ease)}
  .btn:hover .arrow{transform:translateX(5px)}

  /* ---------- Nav ---------- */
  header.nav{position:fixed;top:0;left:0;right:0;z-index:8000;transition:background .5s,backdrop-filter .5s,border-color .5s;border-bottom:1px solid transparent}
  header.nav.scrolled{background:rgba(10,10,10,.6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom-color:var(--line-2)}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:84px}
  .logo{font-family:var(--display);font-size:1.4rem;font-weight:800;letter-spacing:-0.04em}
  .logo .dot{color:var(--muted)}
  .nav-links{display:flex;gap:2.6rem;align-items:center}
  .nav-links a.link{font-size:.82rem;color:var(--fg);position:relative;transition:color .3s;font-weight:400}
  .nav-links a.link::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--fg);transition:width .35s var(--ease)}
  .nav-links a.link:hover{color:var(--fg)}
  .nav-links a.link:hover::after{width:100%}
  .nav-cta{font-size:.78rem;padding:.85em 1.6em}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
  .burger span{width:24px;height:1.5px;background:var(--fg);transition:.3s}
  .nav-right{display:flex;align-items:center;gap:1.5rem}
  .lang-switch{font-size:.72rem;letter-spacing:.06em;font-weight:500;color:var(--fg);border:1px solid var(--line);border-radius:999px;padding:.5em 1em;transition:border-color .3s,background .3s,color .3s;white-space:nowrap}
  .lang-switch:hover{border-color:var(--fg);background:var(--fg);color:var(--bg)}

  /* ---------- Reveal ---------- */
  .reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  .reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}
  .line-mask{overflow:hidden;display:block}
  .line-mask>span{display:block;transform:translateY(105%);transition:transform 1s var(--ease)}
  .in .line-mask>span,.line-mask.in>span{transform:translateY(0)}

  /* ---------- Placeholder media ---------- */
  .ph{position:relative;background:var(--bg-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted-2);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;overflow:hidden}
  .ph::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 18px,rgba(255,255,255,.02) 18px,rgba(255,255,255,.02) 36px)}
  .ph .ph-label{position:relative;z-index:1;padding:0 1rem;line-height:2.1;font-weight:500}
  .ph .ph-label svg{display:block;margin:0 auto .8rem;opacity:.5}
  .ph img.media,.media{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.92);transition:filter .25s linear,transform 1.4s var(--ease);will-change:filter}
  .ph:has(img.media){background:none}
  .ph:has(img.media)::after{display:none}

  /* ---------- Hero ---------- */
  .hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px 0 80px;overflow:hidden}
  .hero-media{position:absolute;inset:-9% 0;z-index:0;overflow:hidden;will-change:transform}
  .hero-media img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(1.05) brightness(.92)}
  .hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(10,10,10,.92) 0%,rgba(10,10,10,.72) 38%,rgba(10,10,10,.34) 72%,rgba(10,10,10,.5) 100%)}
  .hero-overlay::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,10,10,.88) 0%,transparent 38%)}
  .hero .wrap{position:relative;z-index:2;width:100%}
  .hero-inner{max-width:20ch}
  .hero h1{font-size:clamp(3rem,9vw,8rem);font-weight:800;letter-spacing:-0.045em;margin-bottom:2rem;line-height:.92}
  .hero .lead{font-size:clamp(1rem,1.4vw,1.18rem);max-width:42ch;margin-bottom:2.8rem;color:var(--muted)}
  .hero-cta-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-bottom:3rem}
  .reassure{font-size:.78rem;color:var(--muted-2);letter-spacing:.02em;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
  .reassure .sep{opacity:.6}
  .scroll-hint{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted-2);display:flex;flex-direction:column;align-items:center;gap:.8rem}
  .scroll-hint .bar{width:1px;height:42px;background:linear-gradient(var(--muted),transparent);position:relative;overflow:hidden}
  .scroll-hint .bar::after{content:"";position:absolute;top:-40%;left:0;width:100%;height:40%;background:var(--fg);animation:scrolldot 2s var(--ease) infinite}
  @keyframes scrolldot{0%{top:-40%}60%,100%{top:100%}}

  /* ---------- Marquee ---------- */
  .marquee{border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);padding:1.7rem 0;overflow:hidden;white-space:nowrap;background:var(--bg)}
  .marquee-track{display:inline-flex;gap:3rem;animation:marq 26s linear infinite;will-change:transform}
  .marquee:hover .marquee-track{animation-play-state:paused}
  .marquee span{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-0.02em;color:var(--fg);display:inline-flex;align-items:center;gap:3rem}
  .marquee span::after{content:"✦";color:var(--muted-2);font-size:1rem}
  @keyframes marq{to{transform:translateX(-50%)}}

  /* ---------- Sections ---------- */
  section{position:relative;padding:clamp(80px,11vw,170px) 0}
  .section-head{max-width:24ch;margin-bottom:4rem}
  .section-head.wide{max-width:34ch}
  .section-head h2{font-size:clamp(2.4rem,5.5vw,4.6rem);font-weight:800;margin-bottom:1.4rem;letter-spacing:-0.035em;line-height:.98}
  .section-head p.sub{font-size:1.05rem;max-width:46ch;font-family:var(--sans)}
  .num-index{position:absolute;top:clamp(80px,11vw,170px);right:var(--gutter);font-family:var(--display);font-size:.8rem;color:var(--muted-2);letter-spacing:.1em}

  /* ---------- Problema ---------- */
  .problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:center}
  .problem-list{list-style:none}
  .problem-list li{display:flex;gap:1.6rem;align-items:flex-start;padding:2rem 0;border-top:1px solid var(--line)}
  .problem-list li:last-child{border-bottom:1px solid var(--line)}
  .problem-list .num{font-family:var(--display);font-size:.9rem;font-weight:700;color:var(--fg);flex-shrink:0;min-width:2.4em}
  .problem-list li p{font-size:1.05rem;color:var(--muted)}
  .problem-close{margin-top:2.8rem;font-family:var(--display);font-size:clamp(1.6rem,2.8vw,2.3rem);color:var(--fg);line-height:1.2;font-weight:700;letter-spacing:-0.03em}
  .problem-close em{color:var(--muted-2);font-style:normal}
  .problem-media{aspect-ratio:3/4;min-height:480px;will-change:transform}

  /* ---------- Cards ---------- */
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
  .card{position:relative;background:var(--bg-2);border:1px solid var(--line);padding:2.8rem 2.2rem;border-radius:6px;overflow:hidden;transition:transform .5s var(--ease),border-color .5s}
  .card::before{content:"";position:absolute;inset:0;background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),rgba(255,255,255,.06),transparent 60%);opacity:0;transition:opacity .4s}
  .card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.28)}
  .card:hover::before{opacity:1}
  .card .icon{width:30px;height:30px;color:var(--fg);margin-bottom:1.8rem;position:relative}
  .card h3{font-size:1.5rem;margin-bottom:.8rem;letter-spacing:-0.02em;position:relative}
  .card p{font-size:.96rem;position:relative}

  /* ---------- Video ---------- */
  .video-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:2.8rem}
  .video-head h2{font-size:clamp(2rem,4.4vw,3.6rem);font-weight:800;letter-spacing:-0.03em}
  .video-frame{position:relative;aspect-ratio:16/9;width:100%;background:var(--bg-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;border-radius:6px}
  .video-frame::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 18px,rgba(255,255,255,.02) 18px,rgba(255,255,255,.02) 36px)}
  .play{position:relative;z-index:1;width:96px;height:96px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);transition:transform .4s var(--ease),background .4s}
  .video-frame:hover .play{transform:scale(1.12);background:rgba(255,255,255,.12)}
  .play svg{margin-left:5px}
  .video-cap{position:absolute;z-index:1;bottom:20px;left:22px;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2)}
  .video-meta{position:absolute;z-index:1;bottom:20px;right:22px;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2)}

  /* ---------- Come funziona ---------- */
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
  .step{background:var(--bg);padding:clamp(2rem,2.6vw,2.6rem);min-height:320px;display:flex;flex-direction:column;transition:background .5s}
  .step:hover{background:var(--bg-2)}
  .step .step-n{font-size:.74rem;font-weight:500;letter-spacing:.12em;color:var(--muted-2);margin-bottom:auto;font-family:var(--sans)}
  .step h3{font-size:1.4rem;margin:1.8rem 0 .8rem;letter-spacing:-0.02em}
  .step p{font-size:.92rem}

  /* ---------- Risultati ---------- */
  .results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
  .result{padding:3rem 2rem 3rem 0;border-bottom:1px solid var(--line)}
  .result .big{font-family:var(--display);font-size:clamp(3rem,6vw,5.2rem);color:var(--fg);line-height:.9;margin-bottom:1rem;font-weight:800;letter-spacing:-0.05em}
  .result .label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);margin-bottom:1.1rem;font-weight:500}
  .result p{font-size:.95rem}
  .results-note{margin-top:3rem;font-size:.9rem;color:var(--muted-2)}

  /* ---------- Garanzia ---------- */
  .guarantee{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(36px,6vw,90px);align-items:center}
  .guarantee-card{background:var(--bg-2);border:1px solid var(--line);padding:clamp(2.6rem,4vw,3.6rem);border-radius:6px}
  .guarantee-card .seal{width:46px;height:46px;color:var(--fg);margin-bottom:2rem}
  .guarantee-card p.body{font-size:1.08rem;color:var(--muted);margin-bottom:1.5rem}
  .guarantee-card .note{font-size:.88rem;color:var(--muted-2);border-top:1px solid var(--line);padding-top:1.4rem}

  /* ---------- FAQ ---------- */
  .faq-wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(40px,6vw,100px);align-items:start}
  .faq-item{border-bottom:1px solid var(--line)}
  .faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:1.9rem 2.6rem 1.9rem 0;font-family:var(--display);font-size:1.25rem;color:var(--fg);position:relative;line-height:1.25;font-weight:700;letter-spacing:-0.02em}
  .faq-q::after{content:"";position:absolute;right:2px;top:50%;width:13px;height:13px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath d='M7 0v14M0 7h14' stroke='%23EFEDE9' stroke-width='1.4'/%3E%3C/svg%3E") center/contain no-repeat;transform:translateY(-50%);transition:transform .4s var(--ease)}
  .faq-item.open .faq-q::after{transform:translateY(-50%) rotate(135deg)}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
  .faq-a p{padding:0 0 1.9rem;font-size:1rem;max-width:56ch}

  /* ---------- Final CTA ---------- */
  .final-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
  .final-copy h2{font-size:clamp(2.6rem,5.5vw,5rem);font-weight:800;margin-bottom:1.6rem;letter-spacing:-0.035em;line-height:.96}
  .final-copy p.sub{font-size:1.06rem;margin-bottom:2.4rem;max-width:42ch;color:var(--muted)}
  .final-media{aspect-ratio:16/11;min-height:240px;margin-bottom:1.8rem;will-change:transform}
  .final-meta{font-size:.88rem;color:var(--muted-2);display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
  .final-meta a{color:var(--fg);border-bottom:1px solid var(--line);transition:border-color .3s}
  .final-meta a:hover{border-bottom-color:var(--fg)}
  form{display:grid;gap:1rem;background:var(--bg-2);padding:clamp(1.8rem,3vw,2.8rem);border:1px solid var(--line);border-radius:6px}
  .field{display:flex;flex-direction:column;gap:.45rem}
  .row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  label{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);font-weight:500}
  input,select,textarea{font-family:var(--sans);font-size:.95rem;font-weight:300;padding:.95em 1.1em;background:var(--bg);border:1px solid var(--line);color:var(--fg);border-radius:4px;transition:border-color .3s;width:100%}
  input::placeholder,textarea::placeholder{color:var(--muted-2)}
  input:focus,select:focus,textarea:focus{outline:none;border-color:var(--fg)}
  textarea{resize:vertical;min-height:90px}
  select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23EFEDE9' stroke-width='1.4' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1em center}
  form .btn{width:100%;justify-content:center;margin-top:.4rem}
  .form-done{text-align:center;padding:1.4rem .4rem}
  .form-done h3{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--fg);margin-bottom:.7rem;letter-spacing:-0.02em}
  .form-done p{color:var(--muted);font-size:.95rem;max-width:30ch;margin:0 auto}

  /* ---------- Pricing ---------- */
  .price-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;max-width:900px;margin:2.6rem auto 0}
  .price-card{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:2.1rem 1.9rem;display:flex;flex-direction:column;gap:.5rem;transition:border-color .3s,transform .4s var(--ease)}
  .price-card:hover{border-color:rgba(255,255,255,.22);transform:translateY(-4px)}
  .price-region{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);font-weight:500}
  .price-old{font-family:var(--display);font-weight:700;font-size:1.2rem;color:var(--muted-2);text-decoration:line-through;text-decoration-thickness:2px}
  .price-old span{font-family:var(--sans);font-size:.78rem;font-weight:400}
  .price-now{font-family:var(--display);font-weight:800;font-size:clamp(2.3rem,5.5vw,3.1rem);color:var(--fg);letter-spacing:-0.03em;line-height:1;margin-top:.1rem;display:flex;align-items:baseline;gap:.3rem;flex-wrap:wrap}
  .price-now span{font-family:var(--sans);font-size:1rem;font-weight:400;color:var(--muted);letter-spacing:0}
  .price-note{font-size:.82rem;color:var(--muted);margin-top:.25rem}
  .price-foot{max-width:660px;margin:2.2rem auto 0;text-align:center;color:var(--muted);font-size:.96rem}
  .price-cta{text-align:center;margin-top:2rem}
  @media(max-width:680px){.price-grid{grid-template-columns:1fr}}

  /* ---------- Interactive flow (how we work) ---------- */
  .flow{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(1.4rem,4vw,3.4rem);align-items:start;margin:3rem auto 0;max-width:1040px}
  .flow-rail{display:flex;flex-direction:column;gap:.25rem}
  .flow-tab{display:flex;align-items:center;gap:1rem;width:100%;text-align:left;background:none;border:none;border-left:2px solid var(--line-2);cursor:pointer;padding:.95rem .9rem;border-radius:0 8px 8px 0;color:var(--muted);transition:background .3s,border-color .3s,color .3s}
  .flow-tab:hover{background:var(--bg-2);color:var(--fg)}
  .flow-tab.active{background:var(--bg-2);border-left-color:var(--fg);color:var(--fg)}
  .flow-tab .ft-n{font-family:var(--display);font-weight:700;font-size:.8rem;color:var(--muted-2);min-width:1.8em;transition:color .3s}
  .flow-tab.active .ft-n,.flow-tab:hover .ft-n{color:var(--fg)}
  .flow-tab .ft-t{font-size:.92rem;font-weight:500;line-height:1.3}
  .flow-stage{position:relative;min-height:300px}
  .flow-panel{position:absolute;inset:0;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:clamp(1.8rem,3vw,2.6rem);opacity:0;transform:translateY(16px);transition:opacity .5s var(--ease),transform .5s var(--ease);pointer-events:none;display:flex;flex-direction:column;justify-content:center}
  .flow-panel.active{position:relative;opacity:1;transform:none;pointer-events:auto}
  .flow-panel .fp-n{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,6vw,4rem);line-height:1;letter-spacing:-.04em;color:rgba(255,255,255,.1)}
  .flow-panel h3{font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2.4vw,1.7rem);color:var(--fg);margin:.3rem 0 .7rem;letter-spacing:-.01em}
  .flow-panel p{color:var(--muted);font-size:1rem;line-height:1.65}
  @media(max-width:780px){
    .flow{grid-template-columns:1fr;gap:1rem}
    .flow-rail{flex-direction:row;overflow-x:auto;gap:.5rem;padding-bottom:.6rem;-webkit-overflow-scrolling:touch}
    .flow-tab{flex:0 0 auto;flex-direction:column;align-items:flex-start;gap:.3rem;border-left:none;border-bottom:2px solid var(--line-2);border-radius:8px 8px 0 0;min-width:150px}
    .flow-tab.active{border-bottom-color:var(--fg)}
    .flow-stage{min-height:240px}
    .flow-panel{position:relative}
    .flow-panel:not(.active){display:none}
  }

  /* ---------- Floating AI assistants ---------- */
  .ai-orbit{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;align-items:center;margin-top:2.6rem}
  .ai-orbit .ao-label{width:100%;text-align:center;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.4rem}
  .ai-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.6em 1.05em;border:1px solid var(--line);border-radius:999px;background:var(--bg-2);font-size:.86rem;color:var(--fg);white-space:nowrap;animation:ai-float 5.5s ease-in-out infinite;will-change:transform}
  .ai-chip svg{width:15px;height:15px;color:var(--fg)}
  .ai-chip:nth-child(3){animation-delay:-1.1s}.ai-chip:nth-child(4){animation-delay:-2.2s}.ai-chip:nth-child(5){animation-delay:-3.3s}.ai-chip:nth-child(6){animation-delay:-4.2s}
  @keyframes ai-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

  /* ---------- Guarantee 3D card stack ---------- */
  .guarantee-stack{position:relative;max-width:660px;margin:2.6rem auto 0;perspective:1600px;padding:0 54px}
  .gs-viewport{position:relative;transform-style:preserve-3d}
  .gs-card{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:1.7rem 1.9rem;display:flex;flex-direction:column;overflow:hidden;transition:transform .65s var(--ease),opacity .65s var(--ease),filter .65s var(--ease);backface-visibility:hidden}
  .gs-card.front{position:relative;transform:none;opacity:1;z-index:2}
  .gs-card.back{position:absolute;inset:0;transform-origin:center right;transform:translate(40px,-26px) scale(.93) rotateY(-13deg);opacity:.5;z-index:1;filter:blur(.6px);pointer-events:none}
  .gs-card .seal{width:30px;height:30px;color:var(--fg);margin-bottom:.7rem}
  .gs-card .eyebrow{margin-bottom:.35rem}
  .gs-card h3{font-family:var(--display);font-weight:700;font-size:clamp(1.25rem,2.3vw,1.6rem);color:var(--fg);letter-spacing:-.02em;margin:.1rem 0 .55rem;line-height:1.12}
  .gs-card .gs-sub{color:var(--muted);font-size:.92rem;line-height:1.5;margin-bottom:.45rem}
  .gs-points{list-style:none;margin:.85rem 0 0;display:flex;flex-direction:column;gap:.5rem}
  .gs-points li{font-size:.85rem;color:var(--muted);line-height:1.45;padding-left:.85rem;border-left:2px solid var(--line)}
  .gs-points b{color:var(--fg);font-weight:600}
  .gs-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:999px;border:1px solid var(--line);background:var(--bg);color:var(--fg);cursor:pointer;font-size:1.2rem;line-height:1;z-index:5;transition:border-color .3s,background .3s,color .3s}
  .gs-arrow.gs-prev{left:0}
  .gs-arrow.gs-next{right:0}
  .gs-arrow:hover{border-color:var(--fg);background:var(--fg);color:var(--bg)}
  .gs-hint{display:block;text-align:center;margin-top:1.2rem;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2)}
  @media(max-width:680px){.guarantee-stack{perspective:none;padding:0 42px}.gs-card{padding:1.4rem 1.3rem}.gs-card.front{transform:none;opacity:1;filter:none}.gs-card.back{display:none}}
  @media(prefers-reduced-motion:reduce){.ai-chip{animation:none}.gs-card{transition:opacity .3s}.gs-card.back{transform:translateZ(0);opacity:0}}

  /* ---------- Responsive tables (guides) ---------- */
  .table-scroll{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .table-scroll .prose-table{margin:0}

  /* ---------- Footer ---------- */
  footer{padding:80px 0 46px;border-top:1px solid var(--line)}
  .footer-big{font-family:var(--display);font-weight:800;font-size:clamp(2.4rem,8vw,7rem);letter-spacing:-0.04em;line-height:.9;margin-bottom:3rem;color:var(--fg)}
  .footer-inner{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
  .footer-tag{font-size:.9rem;max-width:32ch;color:var(--muted)}
  .footer-meta{font-size:.8rem;color:var(--muted-2);text-align:right;line-height:2}
  .footer-meta a{color:var(--fg)}
  .footer-bottom{margin-top:2.8rem;padding-top:1.6rem;border-top:1px solid var(--line-2);font-size:.74rem;color:var(--muted-2);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem}

  /* ---------- Responsive ---------- */
  @media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:880px){
    .nav-links{position:fixed;top:84px;left:0;right:0;background:var(--bg);flex-direction:column;align-items:flex-start;gap:1.6rem;padding:2rem var(--gutter);border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .5s var(--ease);height:auto}
    .nav-links.open{transform:translateY(0)}
    .burger{display:flex}
    .nav-right{gap:1rem}
    .hero-inner{max-width:none}
    .problem-grid,.guarantee,.faq-wrap,.final-grid{grid-template-columns:1fr}
    .problem-media{aspect-ratio:16/10;min-height:260px;order:-1}
    .cards,.results-grid{grid-template-columns:1fr}
    .result{padding:2.2rem 0}
    .num-index{display:none}
  }
  @media (max-width:480px){.row2{grid-template-columns:1fr}.hero-cta-row{flex-direction:column;align-items:stretch}.hero-cta-row .btn{justify-content:center}.steps{grid-template-columns:1fr}.hero-fx{display:none}}
  @media (prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}.line-mask>span{transform:none}}

  /* ---------- Scroll progress bar ---------- */
  .scroll-progress{position:fixed;top:0;left:0;height:2px;width:100%;background:var(--fg);transform:scaleX(0);transform-origin:0 50%;z-index:8500;opacity:.8;pointer-events:none}

  /* ---------- Hero 3D accent ---------- */
  .hero-fx{position:absolute;top:0;right:0;width:min(58vw,720px);height:100%;z-index:1;opacity:.5;pointer-events:none}
  @media(max-width:880px){.hero-fx{opacity:.26;width:100%}}

  /* ---------- 3D globe band ---------- */
  .globe-band{position:relative;overflow:hidden;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
  .globe-wrap{position:relative;height:clamp(400px,50vw,660px);overflow:hidden}
  .aurora{position:absolute;inset:0;z-index:0;pointer-events:none}
  .aurora::before,.aurora::after{content:"";position:absolute;border-radius:50%;filter:blur(72px);mix-blend-mode:screen}
  .aurora::before{width:48vw;height:48vw;left:-6vw;top:-12vw;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);animation:drift1 22s var(--ease) infinite alternate}
  .aurora::after{width:42vw;height:42vw;right:-6vw;bottom:-14vw;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);animation:drift2 27s var(--ease) infinite alternate}
  @keyframes drift1{to{transform:translate(7vw,6vh) scale(1.15)}}
  @keyframes drift2{to{transform:translate(-6vw,-5vh) scale(1.12)}}
  .globe-fx{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
  .globe-copy{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 var(--gutter);pointer-events:none}
  .globe-copy .eyebrow{justify-content:center}
  .globe-copy h2{font-family:var(--display);font-weight:800;font-size:clamp(2rem,4.8vw,3.8rem);letter-spacing:-0.035em;line-height:1;max-width:18ch}
  .globe-copy .gb-sub{margin-top:1.1rem;font-size:.95rem;letter-spacing:.04em;color:var(--muted)}

  @media (prefers-reduced-motion:reduce){.media{filter:grayscale(0) contrast(1) brightness(1)}.aurora::before,.aurora::after{animation:none}}

/* ---------- Footer sitemap columns ---------- */
.footer-cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;padding:.5rem 0 0}
.fcol{display:flex;flex-direction:column;gap:.55rem}
.fcol .fhead{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.5rem;font-weight:500}
.fcol a{font-size:.9rem;color:var(--muted);transition:color .3s;width:fit-content}
.fcol a:hover{color:var(--fg)}
@media(max-width:760px){.footer-cols{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.footer-cols{grid-template-columns:1fr}}

/* ---------- Sub-page hero ---------- */
.page-hero{padding:clamp(150px,18vh,240px) 0 clamp(50px,7vw,90px);position:relative}
.page-hero .crumbs{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);margin-bottom:1.2rem}
.page-hero .crumbs a{color:var(--muted)}
.page-hero .crumbs a:hover{color:var(--fg)}
.page-hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,6vw,5rem);letter-spacing:-0.04em;line-height:1;margin:0 0 1.3rem;max-width:20ch}
.page-hero .lead{font-size:1.12rem;max-width:48ch;color:var(--muted);margin-bottom:2.2rem}

/* ---------- Prose (guide/articoli) ---------- */
.prose{max-width:74ch}
.prose>p{font-size:1.06rem;color:var(--muted);margin-bottom:1.35rem}
.prose h2{font-family:var(--display);font-weight:700;font-size:clamp(1.7rem,3.2vw,2.5rem);letter-spacing:-0.025em;line-height:1.05;margin:2.8rem 0 1rem;color:var(--fg)}
.prose h3{font-size:1.32rem;letter-spacing:-0.02em;margin:1.8rem 0 .6rem;color:var(--fg)}
.prose ul,.prose ol{margin:0 0 1.4rem 1.2rem;color:var(--muted)}
.prose li{margin-bottom:.55rem;font-size:1.02rem}
.prose a{color:var(--fg);border-bottom:1px solid var(--line);transition:border-color .3s}
.prose a:hover{border-bottom-color:var(--fg)}
.prose strong{color:var(--fg);font-weight:500}
.prose blockquote{border-left:2px solid var(--line);padding-left:1.4rem;margin:1.8rem 0;font-family:var(--display);font-size:1.3rem;color:var(--fg)}
.prose-table{width:100%;border-collapse:collapse;margin:1.6rem 0;font-size:.95rem}
.prose-table th,.prose-table td{text-align:left;padding:.8rem 1rem;border-bottom:1px solid var(--line)}
.prose-table th{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-weight:500}
.prose-table td{color:var(--muted)}
.toc{border:1px solid var(--line);border-radius:6px;padding:1.4rem 1.6rem;margin-bottom:2.4rem;background:var(--bg-2)}
.toc .fhead{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.7rem;display:block}
.toc a{display:block;color:var(--muted);font-size:.96rem;padding:.25rem 0;border:none}
.toc a:hover{color:var(--fg)}
.article-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:920px){.article-grid{grid-template-columns:.85fr 2.15fr;gap:clamp(2rem,5vw,5rem);align-items:start}.article-grid .toc{position:sticky;top:110px}}

/* ============ REVISIONE HOME — componenti & tuning responsive ============ */

/* --- titoli più corti/responsive --- */
.hero h1{font-size:clamp(2.5rem,7.2vw,5rem);line-height:.96}
.section-head h2{font-size:clamp(1.9rem,4vw,3.3rem)}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.8rem)}
.final-copy h2{font-size:clamp(2rem,4.2vw,3.4rem)}
.h2-display{font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,4vw,3.3rem);letter-spacing:-0.035em;line-height:1.02;margin:0 0 1rem}

/* --- fascia foto full-bleed --- */
.photo-band{position:relative;min-height:60vh;display:flex;align-items:flex-end;overflow:hidden}
.photo-band-media{position:absolute;inset:-8% 0;z-index:0;will-change:transform}
.photo-band-media img{width:100%;height:100%;object-fit:cover}
.photo-band-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(10,10,10,.86) 0%,rgba(10,10,10,.18) 52%,rgba(10,10,10,.5) 100%)}
.photo-band .wrap{position:relative;z-index:2;width:100%;padding-top:9vh;padding-bottom:7vh}
.photo-band h2{font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,4.2vw,3.4rem);letter-spacing:-0.035em;line-height:1.04;max-width:20ch}
.photo-band p{max-width:46ch;margin-top:1rem}

/* --- roadmap / gantt --- */
.gantt{margin-top:1rem}
.gantt-timeline{display:flex;gap:8px;margin-bottom:8px}
.gt-seg{flex-grow:1;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);padding-bottom:.55rem;border-bottom:1px solid var(--line)}
.gt-seg.gt-ongoing{color:var(--fg);border-bottom-color:var(--fg)}
.gantt-bars{display:flex;gap:8px;margin-bottom:2.4rem}
.gt-bar{flex-grow:1;height:10px;border-radius:5px;background:rgba(255,255,255,.16)}
.gt-bar.gt-ongoing-bar{background:linear-gradient(90deg,rgba(255,255,255,.55),rgba(255,255,255,.06))}
.roadmap-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.rc{background:var(--bg);padding:clamp(1.5rem,2.4vw,2.2rem);transition:background .4s}
.rc:hover{background:var(--bg-2)}
.rc-n{font-family:var(--display);font-weight:700;font-size:1.25rem;color:var(--fg);display:block}
.rc-when{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);display:block;margin:.4rem 0 1.2rem}
.rc ul{list-style:none;display:flex;flex-direction:column;gap:.65rem;margin:0}
.rc li{font-size:.92rem;color:var(--muted);padding-left:1.1rem;position:relative;line-height:1.4}
.rc li::before{content:"";position:absolute;left:0;top:.5em;width:5px;height:5px;border-radius:50%;background:var(--muted-2)}
@media(max-width:760px){.gantt-timeline,.gantt-bars{display:none}.roadmap-cards{grid-template-columns:1fr}}

/* --- mockup area cliente (dashboard) --- */
.mockup{max-width:1000px;margin:0 auto;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg-2);box-shadow:0 50px 90px -50px rgba(0,0,0,.7)}
.mockup-bar{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.1rem;border-bottom:1px solid var(--line);background:var(--bg-3)}
.mockup-bar .mdot{width:11px;height:11px;border-radius:50%;background:var(--line-2);border:1px solid var(--line)}
.mockup-url{margin-left:1rem;font-size:.72rem;color:var(--muted-2);background:var(--bg);padding:.32rem .9rem;border-radius:100px;border:1px solid var(--line)}
.mockup-body{display:grid;grid-template-columns:210px 1fr;min-height:400px}
.mockup-side{border-right:1px solid var(--line);padding:1.2rem .8rem;display:flex;flex-direction:column;gap:.25rem}
.ms-brand{font-family:var(--display);font-weight:700;font-size:1rem;padding:.3rem .7rem 1.1rem;color:var(--fg)}
.ms-brand .dot{color:var(--muted-2)}
.mockup-side a{font-size:.86rem;color:var(--muted);padding:.58rem .7rem;border-radius:7px;display:flex;align-items:center;gap:.6rem;transition:background .25s,color .25s}
.mockup-side a:hover{color:var(--fg)}
.mockup-side a.active{background:var(--bg);color:var(--fg)}
.ms-ico{width:7px;height:7px;border-radius:2px;background:currentColor;opacity:.55}
.mockup-main{padding:1.4rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-content:start;background:var(--bg-2)}
.mk-card{background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:1.15rem 1.2rem}
.mk-card.wide{grid-column:1 / -1}
.mk-h{font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.85rem;display:flex;justify-content:space-between;align-items:center}
.mk-badge{background:var(--fg);color:var(--bg);font-size:.64rem;padding:.16rem .55rem;border-radius:100px;letter-spacing:.04em;font-weight:500}
.mk-progress{height:8px;border-radius:4px;background:var(--line);overflow:hidden;margin:.2rem 0 .7rem}
.mk-progress span{display:block;height:100%;background:var(--fg)}
.mk-progmeta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--muted)}
.mk-row{display:flex;justify-content:space-between;align-items:center;font-size:.86rem;color:var(--muted);padding:.5rem 0;border-bottom:1px solid var(--line-2);gap:.8rem}
.mk-row:last-child{border-bottom:none}
.mk-row b{color:var(--fg);font-weight:500}
.mk-pill{font-size:.64rem;padding:.14rem .55rem;border-radius:100px;border:1px solid var(--line);color:var(--muted-2);white-space:nowrap}
.mk-pill.go{border-color:rgba(255,255,255,.5);color:var(--fg)}
@media(max-width:680px){.mockup-body{grid-template-columns:1fr}.mockup-side{flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--line);gap:.3rem}.ms-brand{width:100%;padding-bottom:.5rem}.mockup-main{grid-template-columns:1fr}}

/* --- fix hero: colonna più larga, H1 più contenuto (responsive) --- */
.hero-inner{max-width:min(760px,94vw)}
.hero h1{font-size:clamp(2.5rem,6vw,4.4rem);line-height:1;margin-bottom:1.6rem}
.hero .lead{max-width:44ch}
@media(max-width:560px){.hero h1{font-size:clamp(2.3rem,9vw,3rem)}.hero-inner{max-width:100%}}

/* --- fix larghezza section-head (era in ch sul font piccolo -> troppo stretto) --- */
.section-head{max-width:40rem}
.section-head.wide{max-width:52rem}
.photo-band h2{max-width:18ch}
.globe-copy h2{max-width:20ch}

/* ============ REVISIONE 2 — contrasto foto, 3D lettering, casi, filosofia ============ */

/* --- contrasto testi sulle fasce-foto --- */
.photo-band-overlay{background:linear-gradient(0deg,rgba(8,8,8,.92) 0%,rgba(8,8,8,.34) 56%,rgba(8,8,8,.62) 100%)}
.photo-band h2{text-shadow:0 2px 30px rgba(0,0,0,.55)}
.photo-band p{color:rgba(239,237,233,.92);text-shadow:0 1px 16px rgba(0,0,0,.6)}
.photo-band .eyebrow{color:rgba(239,237,233,.85)}

/* --- sezione "cliente giusto" con 3D lettering rotante --- */
.client-fit{position:relative;text-align:center;overflow:hidden;padding:clamp(90px,13vw,170px) 0}
.lettering3d{perspective:1000px;margin:0 auto 2.4rem}
.lettering3d .l3d{display:inline-block;font-family:var(--display);font-weight:800;letter-spacing:-0.03em;line-height:.92;font-size:clamp(3rem,11vw,9rem);color:var(--fg);transform-style:preserve-3d;animation:l3dspin 9s ease-in-out infinite;text-shadow:1px 1px 0 rgba(255,255,255,.12),2px 2px 0 rgba(255,255,255,.09),3px 3px 0 rgba(255,255,255,.06),4px 4px 0 rgba(0,0,0,.5),10px 12px 26px rgba(0,0,0,.55)}
@keyframes l3dspin{0%,100%{transform:rotateY(-24deg) rotateX(7deg)}50%{transform:rotateY(24deg) rotateX(-5deg)}}
.client-fit .cf-copy{max-width:54ch;margin:0 auto}
.client-fit .cf-copy p{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--fg)}
.client-fit .cf-copy .muted{color:var(--muted)}
@media (prefers-reduced-motion:reduce){.lettering3d .l3d{animation:none;transform:rotateY(-12deg)}}

/* --- casi studio --- */
.cases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.4rem}
.case-card{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:transform .5s var(--ease),border-color .5s;display:flex;flex-direction:column}
.case-card:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.26)}
.case-img{aspect-ratio:4/3;overflow:hidden}
.case-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.case-loc{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.case-card h3{font-size:1.35rem;letter-spacing:-0.02em}
.case-card .case-res{font-size:.95rem;color:var(--muted);margin-bottom:.4rem}
.case-metrics{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto;padding-top:.8rem;border-top:1px solid var(--line-2)}
.case-metric{display:flex;flex-direction:column;gap:.1rem}
.case-metric b{font-family:var(--display);font-weight:700;font-size:1.15rem;color:var(--fg);line-height:1}
.case-metric span{font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2)}
.case-metric+.case-metric{padding-left:.9rem;border-left:1px solid var(--line-2)}
.cases-note{margin-top:2.4rem;font-size:.86rem;color:var(--muted-2)}

/* --- sezione filosofia "cosa aspettarti" --- */
.philo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.philo .philo-lead{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,2.8vw,2.3rem);letter-spacing:-0.03em;line-height:1.18;color:var(--fg)}
.philo .philo-body p{font-size:1.05rem;margin-bottom:1.1rem}
@media(max-width:880px){.philo{grid-template-columns:1fr}}

/* --- honeypot anti-bot --- */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* --- garanzia prominente --- */
.guarantee-prom{max-width:940px;margin:0 auto;text-align:center;border:1px solid rgba(255,255,255,.24);border-radius:16px;padding:clamp(2.4rem,5vw,4.2rem);background:linear-gradient(180deg,var(--bg-2),var(--bg));box-shadow:0 50px 100px -55px rgba(0,0,0,.75);position:relative}
.guarantee-prom .seal{width:52px;height:52px;color:var(--fg);margin:0 auto 1.4rem}
.guarantee-prom .eyebrow{justify-content:center}
.guar-headline{font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,3.9vw,3.2rem);letter-spacing:-0.03em;line-height:1.1;margin:.4rem auto 1.5rem;max-width:24ch;color:var(--muted)}
.guar-headline .hl{color:var(--fg)}
.guar-sub{font-size:1.04rem;color:var(--muted);max-width:60ch;margin:0 auto 1rem}
.guar-note{font-size:.88rem;color:var(--muted-2);max-width:58ch;margin:0 auto}
@media(max-width:560px){.guar-headline{font-size:1.55rem}}

/* --- sezione Brand & AI (canali -> presenza LLM) --- */
.channels-flow{display:grid;grid-template-columns:1fr auto 1fr;gap:clamp(1.4rem,4vw,3rem);align-items:center;margin-top:1.5rem}
.ch-nodes{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:flex-end}
.ch-nodes span{border:1px solid var(--line);border-radius:100px;padding:.6rem 1.15rem;font-size:.85rem;color:var(--muted);background:var(--bg-2);transition:color .3s,border-color .3s}
.ch-nodes span:hover{color:var(--fg);border-color:rgba(255,255,255,.3)}
.ch-arrow{font-size:2rem;color:var(--muted-2);text-align:center}
.ch-out{border:1px solid rgba(255,255,255,.24);border-radius:14px;padding:1.7rem 1.9rem;background:linear-gradient(180deg,var(--bg-2),var(--bg));text-align:center;box-shadow:0 40px 80px -50px rgba(0,0,0,.7)}
.ch-out strong{display:block;font-family:var(--display);font-weight:800;font-size:1.7rem;letter-spacing:-0.02em;color:var(--fg);margin-bottom:.5rem}
.ch-out span{font-size:.9rem;color:var(--muted);line-height:1.5;display:block}
@media(max-width:760px){.channels-flow{grid-template-columns:1fr;gap:1rem}.ch-nodes{justify-content:center}.ch-arrow{transform:rotate(90deg)}}

/* --- sezione approccio integrato (discipline unite) --- */
.disciplines{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.3rem 0;max-width:840px;margin:1.4rem auto 0;border:1px solid rgba(255,255,255,.2);border-radius:18px;padding:clamp(1.5rem,3.2vw,2.2rem) clamp(1.6rem,4vw,2.8rem);background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.disciplines span{font-family:var(--display);font-weight:700;font-size:clamp(1.05rem,1.8vw,1.5rem);letter-spacing:-0.02em;color:var(--fg);display:inline-flex;align-items:center}
.disciplines span:not(:last-child)::after{content:"·";margin:0 .85rem;color:var(--muted-2);font-weight:400}
