*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
    :root{
      --navy:#04090f;
      --navy2:#07111e;
      --navy3:#0c1929;
      --c:#00e5ff;
      --m:#d400ff;
      --g:#00ff9d;
      --w:#dff0ff;
      --mu:rgba(223,240,255,0.4);
      --b:rgba(0,229,255,0.08);
    }
    html{scroll-behavior:smooth;}
    body{
      background:var(--navy);
      color:var(--w);
      font-family:'DM Sans',sans-serif;
      font-size:17px;
      line-height:1.6;
      overflow-x:hidden;
      cursor:default;text-decoration:none;display:inline-block;
    }
 
    /* ── CANVAS BG ── */
    #bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;}
 
    /* ── SCANLINES ── */
    #scan{position:fixed;inset:0;z-index:9996;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.04) 3px,rgba(0,0,0,.04) 4px);}
 
    /* ── NAV ── */
    nav{
      position:fixed;top:0;left:0;right:0;z-index:500;
      height:70px;padding:0 5%;
      display:flex;align-items:center;justify-content:space-between;
      background:rgba(4,9,15,.6);
      backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
      border-bottom:1px solid var(--b);
      transition:height .3s,background .3s;
    }
    .nav-line{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--c),transparent);animation:navLine 4s linear infinite;}
    @keyframes navLine{0%{background-position:-200% 0;}100%{background-position:200% 0;}}
 
    .nav-logo{
      font-family:'Syne',sans-serif;font-size:22px;font-weight:800;
      color:var(--w);text-decoration:none;display:flex;align-items:center;gap:1px;
      position:relative;
    }
    .logo-dot{color:var(--c);display:inline-block;animation:dotPulse 2s ease-in-out infinite;}
    @keyframes dotPulse{0%,100%{text-shadow:0 0 6px var(--c);}50%{text-shadow:0 0 18px var(--c),0 0 36px var(--c);}}
 
    .nav-links{display:flex;gap:36px;list-style:none;}
    .nav-links a{
      text-decoration:none;color:var(--mu);font-size:12px;
      letter-spacing:.12em;text-transform:uppercase;
      position:relative;transition:color .2s;
    }
    .nav-links a::before{
      content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;
      background:var(--c);transform:scaleX(0);transform-origin:left;
      transition:transform .25s;
    }
    .nav-links a:hover{color:var(--c);}
    .nav-links a:hover::before{transform:scaleX(1);}
 
    .nav-cta{
      border:1px solid var(--c);color:var(--c);
      padding:8px 22px;border-radius:3px;
      font-size:11px;letter-spacing:.14em;text-transform:uppercase;
      text-decoration:none;position:relative;overflow:hidden;
      transition:color .25s,box-shadow .25s;
    }
    .nav-cta::before{
      content:'';position:absolute;inset:0;background:var(--c);
      transform:scaleX(0);transform-origin:left;transition:transform .25s;z-index:-1;
    }
    .nav-cta:hover{color:var(--navy);box-shadow:0 0 24px rgba(0,229,255,.45);}
    .nav-cta:hover::before{transform:scaleX(1);}
 
    /* ── HAMBURGER ── */
    .hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:8px;z-index:600;}
    .hamburger span{display:block;width:24px;height:1.5px;background:var(--w);border-radius:2px;transition:transform .3s,opacity .3s;transform-origin:center;}
    .hamburger.active span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
    .hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0);}
    .hamburger.active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
    .mobile-menu{
      position:fixed;inset:0;z-index:400;
      background:rgba(4,9,15,.98);backdrop-filter:blur(24px);
      display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
      visibility:hidden;opacity:0;pointer-events:none;
      transition:opacity .3s,visibility .3s;
    }
    .mobile-menu.open{visibility:visible;opacity:1;pointer-events:all;}
    .mobile-menu a{font-family:'Syne',sans-serif;font-size:36px;font-weight:800;color:var(--w);text-decoration:none;letter-spacing:-1px;transition:color .2s;}
    .mobile-menu a:hover{color:var(--c);}
    .mobile-menu .mcta{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:500;color:var(--navy)!important;background:var(--c);padding:14px 44px;border-radius:3px;margin-top:8px;}
 
    /* ── HERO ── */
    #hero{
      min-height:100vh;display:flex;align-items:center;
      padding:120px 5% 80px;overflow:hidden;position:relative;z-index:1;
    }
    .hero-inner{max-width:800px;position:relative;z-index:2;width:100%;}
 
    /* SCRAMBLE TITLE */
    h1{
      font-family:'Syne',sans-serif;
      font-size:clamp(52px,8.5vw,100px);
      font-weight:800;line-height:.97;
      letter-spacing:-2.5px;
      margin-bottom:32px;
      opacity:0;animation:fadeUp .9s .2s forwards;
    }
    h1 .line{display:block;}
    h1 .cx{color:var(--c);text-shadow:0 0 40px rgba(0,229,255,.4);}
    h1 .mx{color:var(--m);text-shadow:0 0 40px rgba(212,0,255,.4);}
 
    /* GLITCH */
    .glitch{position:relative;display:inline-block;}
    .glitch::before,.glitch::after{content:attr(data-t);position:absolute;top:0;left:0;opacity:0;}
    .glitch::before{color:var(--c);animation:g1 5s infinite;}
    .glitch::after{color:var(--m);animation:g2 5s infinite;}
    @keyframes g1{0%,88%,100%{opacity:0;transform:translate(0);}89%{opacity:.9;transform:translate(-4px,1px);clip-path:polygon(0 0,100% 0,100% 30%,0 30%);}91%{opacity:0;}93%{opacity:.8;transform:translate(4px,-2px);clip-path:polygon(0 60%,100% 60%,100% 100%,0 100%);}95%{opacity:0;}}
    @keyframes g2{0%,90%,100%{opacity:0;transform:translate(0);}91%{opacity:.8;transform:translate(4px,2px);clip-path:polygon(0 40%,100% 40%,100% 70%,0 70%);}93%{opacity:0;}95%{opacity:.7;transform:translate(-4px,-1px);clip-path:polygon(0 10%,100% 10%,100% 45%,0 45%);}97%{opacity:0;}}
 
    .hero-desc{
      font-size:18px;color:var(--mu);max-width:520px;
      margin-bottom:52px;font-weight:300;
      opacity:0;animation:fadeUp .9s .4s forwards;
    }
    .hero-ctas{
      display:flex;gap:16px;flex-wrap:wrap;
      opacity:0;animation:fadeUp .9s .55s forwards;
    }
 
    /* TYPED BADGE */
    .hero-badge{
      display:inline-flex;align-items:center;gap:10px;
      border:1px solid rgba(0,229,255,.2);border-radius:4px;
      padding:8px 16px;margin-bottom:28px;font-size:12px;
      letter-spacing:.1em;text-transform:uppercase;color:var(--mu);
      opacity:0;animation:fadeUp .9s .1s forwards;
    }
    .badge-dot{width:6px;height:6px;border-radius:50%;background:var(--g);animation:blinkDot 1.5s step-end infinite;}
    @keyframes blinkDot{0%,100%{opacity:1;}50%{opacity:0;}}
 
    /* HERO TERMINAL */
    .hero-visual{
      position:absolute;right:5%;top:50%;
      transform:translateY(-50%);
      width:min(440px,38vw);
      opacity:0;animation:fadeIn 1.2s .8s forwards;
      z-index:2;
    }
 
    /* BUTTONS */
    .btn-p{
      background:transparent;color:var(--c);
      border:1px solid var(--c);
      padding:14px 34px;border-radius:3px;
      font-family:'DM Sans',sans-serif;font-size:13px;
      font-weight:500;letter-spacing:.1em;text-transform:uppercase;
      cursor:pointer;text-decoration:none;display:inline-block;
      position:relative;overflow:hidden;transition:color .3s,box-shadow .3s;
    }
    .btn-p::before{content:'';position:absolute;inset:0;background:var(--c);transform:scaleX(0);transform-origin:left;transition:transform .3s;z-index:-1;}
    .btn-p:hover{color:var(--navy);box-shadow:0 0 30px rgba(0,229,255,.45);}
    .btn-p:hover::before{transform:scaleX(1);}
    .btn-g{
      background:transparent;color:var(--mu);
      border:1px solid rgba(223,240,255,.15);
      padding:14px 34px;border-radius:3px;
      font-family:'DM Sans',sans-serif;font-size:13px;
      letter-spacing:.1em;text-transform:uppercase;
      cursor:pointer;transition:border-color .2s,color .2s;
      text-decoration:none;display:inline-block;
    }
    .btn-g:hover{border-color:rgba(223,240,255,.4);color:var(--w);}
 
    /* ── TERMINAL ── */
    .term-win{
      background:rgba(4,9,15,.92);
      border:1px solid rgba(0,229,255,.18);
      border-radius:12px;overflow:hidden;
      box-shadow:0 0 80px rgba(0,229,255,.1),0 0 160px rgba(212,0,255,.05),inset 0 1px 0 rgba(0,229,255,.1);
    }
    .term-hd{
      background:var(--navy3);padding:12px 16px;
      display:flex;align-items:center;gap:8px;
      border-bottom:1px solid rgba(0,229,255,.08);
    }
    .td{width:10px;height:10px;border-radius:50%;}
    .tdr{background:#ff5f56;}.tdy{background:#ffbd2e;}.tdg{background:#27c93f;}
    .term-t{font-size:11px;color:var(--mu);margin-left:8px;letter-spacing:.1em;}
    .term-body{padding:20px;font-family:'Courier New',monospace;font-size:13px;line-height:1.9;min-height:160px;}
    .tp{color:var(--g);}.tc{color:var(--w);}.to{color:rgba(0,229,255,.7);padding-left:16px;}
    .t-cur{display:inline-block;width:8px;height:14px;background:var(--c);vertical-align:middle;animation:blink 1s step-end infinite;}
    @keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}
 
    .term-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;}
    .ts{
      background:var(--navy3);border:1px solid rgba(0,229,255,.1);
      border-radius:8px;padding:12px;text-align:center;position:relative;overflow:hidden;
    }
    .ts::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--c),transparent);}
    .ts-n{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;color:var(--c);}
    .ts-l{font-size:10px;color:var(--mu);margin-top:2px;}
 
    .fbadge{
      position:absolute;background:rgba(4,9,15,.9);
      border:1px solid rgba(212,0,255,.3);border-radius:10px;
      padding:10px 16px;display:flex;align-items:center;gap:10px;
      font-size:12px;backdrop-filter:blur(12px);
    }
    .fbadge .fi{width:30px;height:30px;border-radius:8px;background:rgba(212,0,255,.15);display:flex;align-items:center;justify-content:center;font-size:14px;}
    .fb1{left:-50px;top:-24px;animation:fbFloat 4s ease-in-out infinite;}
    .fb2{right:-24px;bottom:8px;border-color:rgba(0,229,255,.3);animation:fbFloat 4s ease-in-out infinite;animation-delay:-2s;}
    .fb2 .fi{background:rgba(0,229,255,.15);}
    @keyframes fbFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
 
    /* ── SECTIONS COMMON ── */
    section{position:relative;z-index:1;}
    h2{font-family:'Syne',sans-serif;font-size:clamp(34px,5vw,62px);font-weight:800;line-height:1.05;letter-spacing:-1.5px;margin-bottom:52px;}
    h2 em{font-style:normal;color:var(--c);}
    .slabel{
      display:inline-flex;align-items:center;gap:8px;
      font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--c);
      margin-bottom:18px;
    }
    .slabel::before{content:'';width:24px;height:1px;background:var(--c);}
 
    /* ── SERVIZI ── */
    #servizi{padding:140px 5%;}
    .sgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
 
    .scard{
      background:rgba(7,17,30,.7);border:1px solid rgba(0,229,255,.07);
      border-radius:12px;padding:30px 22px;
      position:relative;overflow:hidden;
      transition:border-color .3s,transform .4s,box-shadow .4s;
    }
    /* animated border beam */
    .scard::before{
      content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
      background:conic-gradient(transparent,var(--c),transparent 30%);
      animation:rotateBorder 4s linear infinite;opacity:0;
      transition:opacity .4s;
    }
    .scard-inner{position:relative;z-index:1;background:rgba(7,17,30,.85);border-radius:10px;padding:2px;}
    .scard:hover{transform:translateY(-8px);box-shadow:0 24px 70px rgba(0,0,0,.5),0 0 40px rgba(0,229,255,.1);}
    .scard:hover::before{opacity:1;}
    @keyframes rotateBorder{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
 
    .snum{font-family:'Syne',sans-serif;font-size:11px;color:var(--c);letter-spacing:.2em;margin-bottom:18px;}
    .sicon{font-size:28px;margin-bottom:14px;display:block;
      filter:drop-shadow(0 0 8px currentColor);
      animation:iconFloat 3s ease-in-out infinite;
    }
    .scard:nth-child(1) .sicon{animation-delay:0s;}
    .scard:nth-child(2) .sicon{animation-delay:-.6s;}
    .scard:nth-child(3) .sicon{animation-delay:-1.2s;}
    .scard:nth-child(4) .sicon{animation-delay:-1.8s;}
    .scard:nth-child(5) .sicon{animation-delay:-2.4s;}
    @keyframes iconFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
 
    .stitle{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;margin-bottom:10px;}
    .sdesc{font-size:13px;color:var(--mu);line-height:1.7;}
 
    /* ── CHI SIAMO ── */
    #chi-siamo{padding:120px 5%;}
    .tgrid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:920px;}
 
    .tcard{
      background:rgba(7,17,30,.7);border:1px solid rgba(0,229,255,.07);
      border-radius:16px;padding:36px;
      display:flex;gap:24px;align-items:flex-start;
      position:relative;overflow:hidden;cursor:none;
      transition:border-color .3s,box-shadow .3s;
    }
    .tcard::after{
      content:'';position:absolute;top:0;left:0;right:0;height:1px;
      background:linear-gradient(90deg,transparent,var(--c),var(--m),transparent);
      opacity:0;transition:opacity .4s;
    }
    .tcard:hover{border-color:rgba(0,229,255,.2);box-shadow:0 0 50px rgba(0,229,255,.07);}
    .tcard:hover::after{opacity:1;}
 
    .tphoto{
      width:88px;height:88px;border-radius:50%;overflow:hidden;flex-shrink:0;
      border:1px solid rgba(0,229,255,.2);position:relative;
    }
    .tphoto::after{content:'';position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,rgba(0,229,255,.1),rgba(212,0,255,.1));}
    .tphoto img{width:100%;height:100%;object-fit:cover;}
    .tname{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;margin-bottom:4px;}
    .trole{font-size:11px;color:var(--c);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px;}
    .tbio{font-size:14px;color:var(--mu);line-height:1.7;}
 
    /* ── PORTFOLIO ── */
    #portfolio{padding:120px 5%;}
    .pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
 
    .pitem{
      border-radius:12px;overflow:hidden;aspect-ratio:4/3;
      position:relative;background:var(--navy3);
      border:1px solid rgba(0,229,255,.07);
      transition:transform .5s cubic-bezier(.23,1,.32,1),box-shadow .5s;
      cursor:none;display:block;text-decoration:none;color:inherit;
    }
    .pitem.p1{grid-column:span 2;aspect-ratio:16/9;}
    .pitem:hover{transform:scale(.97);box-shadow:0 0 60px rgba(0,229,255,.14);}
 
    .pbg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .7s cubic-bezier(.23,1,.32,1);}
    .pitem:hover .pbg{transform:scale(1.08);}
 
    .pov{
      position:absolute;inset:0;display:flex;flex-direction:column;
      justify-content:flex-end;padding:28px;
      background:linear-gradient(transparent 20%,rgba(4,9,15,.92));
    }
    /* scanline on hover */
    .pov::before{
      content:'';position:absolute;inset:0;
      background:repeating-linear-gradient(0deg,transparent,transparent 4px,rgba(0,229,255,.02) 4px,rgba(0,229,255,.02) 5px);
      opacity:0;transition:opacity .3s;
    }
    .pitem:hover .pov::before{opacity:1;}
    .pov::after{content:'↗';position:absolute;top:20px;right:20px;font-size:18px;color:var(--c);opacity:0;transition:opacity .3s,transform .3s;}
    .pitem:hover .pov::after{opacity:1;transform:translate(4px,-4px);}
 
    .ptag{display:inline-block;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--c);margin-bottom:8px;border:1px solid rgba(0,229,255,.3);padding:3px 10px;border-radius:3px;}
    .ptitle{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;}
 
    /* ── CONTATTI ── */
    #contatti{padding:140px 5%;text-align:center;position:relative;}
    #contatti::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:800px;height:500px;background:radial-gradient(ellipse,rgba(0,229,255,.05),transparent 70%);pointer-events:none;}
    .cinner{max-width:640px;margin:0 auto;position:relative;}
    .csub{font-size:18px;color:var(--mu);font-weight:300;margin-bottom:48px;}
    .cform{display:flex;flex-direction:column;gap:12px;max-width:480px;margin:0 auto;}
    .cform input,.cform textarea{
      background:rgba(7,17,30,.85);border:1px solid rgba(0,229,255,.1);
      border-radius:4px;padding:15px 20px;
      color:var(--w);font-family:'DM Sans',sans-serif;font-size:15px;
      outline:none;transition:border-color .2s,box-shadow .2s;
    }
    .cform input:focus,.cform textarea:focus{border-color:var(--c);box-shadow:0 0 20px rgba(0,229,255,.1);}
    .cform input::placeholder,.cform textarea::placeholder{color:var(--mu);}
    .cform textarea{border-radius:4px;resize:vertical;min-height:120px;}
    .cform button.btn-p{width:100%;border:1px solid var(--c);cursor:pointer;}
 
    /* ── FOOTER ── */
    footer{
      border-top:1px solid rgba(0,229,255,.07);
      padding:40px 5%;display:flex;justify-content:space-between;
      align-items:center;flex-wrap:wrap;gap:16px;position:relative;z-index:1;
    }
    footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(0,229,255,.3),transparent);}
    .flogo{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:var(--w);text-decoration:none;}
    .flogo span{color:var(--c);}
    .fcopy{font-size:13px;color:var(--mu);}
    .flinks{display:flex;gap:20px;}
    .flinks a{color:var(--mu);font-size:13px;text-decoration:none;transition:color .2s;}
    .flinks a:hover{color:var(--c);}
 
    /* ── REVEAL ── */
    .reveal{opacity:0;transform:translateY(32px);transition:opacity .8s,transform .8s;}
    .reveal.vis{opacity:1;transform:none;}
 
    /* ── KEYFRAMES ── */
    @keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:none;}}
    @keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
 
    /* ── RESPONSIVE ── */
    @media(max-width:1024px){.hero-visual{width:min(380px,36vw);}}
    @media(max-width:900px){.hero-visual{display:none;}h1{font-size:clamp(36px,7vw,64px);}
      .sgrid{grid-template-columns:repeat(2,1fr);}
      .pitem.p1{grid-column:span 1;aspect-ratio:4/3;}
      #servizi,#portfolio{padding:80px 5%;}
    }
    @media(max-width:768px){h2{font-size:clamp(28px,7vw,44px);margin-bottom:36px;}
      .pgrid{grid-template-columns:1fr 1fr;gap:14px;}
      .tgrid{grid-template-columns:1fr;}
    }
    @media(max-width:640px){
      #cur,#cur2,#cur3{display:none;}
      .nav-links,.nav-cta{display:none!important;}
      .hamburger{display:flex!important;}
      nav{padding:0 4%;}
      /* Fix spazio vuoto hero su mobile */
      #hero{min-height:auto;padding:100px 5% 48px;text-align:center;}
      /* Fix overflow orizzontale */
      html,body{overflow-x:hidden;max-width:100vw;}
      #bg-canvas{width:100vw!important;max-width:100vw;}
      .hero-visual{display:none!important;}
      h1{font-size:32px!important;letter-spacing:-.5px;line-height:1.1;margin-bottom:16px;}
      /* Fix colore bisogno */
      h2 em{color:var(--c);}
      .hero-desc{font-size:15px;max-width:100%;margin-bottom:28px;}
      .hero-ctas{flex-direction:column;align-items:stretch;gap:10px;}
      .btn-p,.btn-g{width:100%;text-align:center;padding:14px 20px;font-size:14px;}
      #servizi,#portfolio{padding:56px 4%;}
      #contatti{padding:72px 4%;}
      .sgrid{grid-template-columns:1fr;}
      .pgrid{grid-template-columns:1fr;gap:14px;}
      .pitem{aspect-ratio:16/9!important;}
      footer{flex-direction:column;align-items:center;text-align:center;}
    }
    @media(max-width:380px){h1{font-size:28px!important;}h2{font-size:24px!important;}}
 
    /* ── EXTRA FX ── */
    /* morphing border on hover for team cards */
    @property --border-angle{syntax:'<angle>';initial-value:0deg;inherits:false;}
 
    /* NOISE TEXTURE */
    #noise{position:fixed;inset:0;z-index:9995;pointer-events:none;opacity:.025;
      background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    }
 
    /* LOADING SCREEN */
    #loader{
      position:fixed;inset:0;z-index:9000;background:var(--navy);
      display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;
      transition:opacity .6s,visibility .6s;
    }
    #loader.done{opacity:0;visibility:hidden;}
    .loader-logo{font-family:'Syne',sans-serif;font-size:36px;font-weight:800;color:var(--w);letter-spacing:-1px;}
    .loader-logo span{color:var(--c);}
    .loader-bar-wrap{width:200px;height:1px;background:rgba(0,229,255,.15);border-radius:1px;overflow:hidden;}
    .loader-bar{height:100%;background:linear-gradient(90deg,var(--c),var(--m));width:0%;transition:width .05s linear;}
    .loader-pct{font-size:12px;color:var(--mu);letter-spacing:.2em;}
 
    /* MAGNETIC BUTTONS */
    .mag{display:inline-block;transition:transform .2s;}
 
    /* REVEAL STAGGER for individual elements */
    [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .7s var(--delay,0s),transform .7s var(--delay,0s);}
    [data-reveal].vis{opacity:1;transform:none;}

    /* ── COME LAVORIAMO ── */
#come-lavoriamo{padding:120px 5%;}
.wgrid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:24px;max-width:860px;
}
.wcard{
  background:rgba(7,17,30,.7);
  border:1px solid rgba(0,229,255,.07);
  border-radius:16px;padding:40px 36px;
  position:relative;overflow:hidden;
  transition:border-color .3s,box-shadow .3s;
}
.wcard::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--c),transparent);
  opacity:0;transition:opacity .4s;
}
.wcard:hover{border-color:rgba(0,229,255,.2);box-shadow:0 0 50px rgba(0,229,255,.07);}
.wcard:hover::before{opacity:1;}
.wicon{font-size:32px;margin-bottom:18px;display:block;}
.wtitle{font-family:'Syne',sans-serif;font-size:22px;font-weight:700;margin-bottom:12px;}
.wdesc{font-size:14px;color:var(--mu);line-height:1.8;}

@media(max-width:640px){
  #come-lavoriamo{padding:56px 4%;}
  .wgrid{grid-template-columns:1fr;}
}