/* ===== APPLAY — Tema CINEMA (tech scuro) ===== */
:root{
  --bg:#05060d;
  --bg-2:#0a0c1a;
  --panel:rgba(255,255,255,.04);
  --panel-brd:rgba(255,255,255,.10);
  --ink:#eef2ff;
  --muted:#98a2c8;
  --cyan:#22d3ee;
  --violet:#8b5cf6;
  --pink:#f471b5;
  --grad:linear-gradient(110deg,#22d3ee 0%,#8b5cf6 50%,#f471b5 100%);
  --radius:18px;
  --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}
body{
  font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--ink);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Syne','Space Grotesk',sans-serif;line-height:1.05;letter-spacing:-.02em;font-weight:700}
.brand-name,.eyebrow,.step-n,.stat-num{font-family:'Space Grotesk',sans-serif}
a{color:inherit;text-decoration:none}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===== Sfondi ===== */
#hero-canvas{position:fixed;inset:0;z-index:-3;width:100%;height:100%;opacity:0;transition:opacity 1.2s ease}
#hero-canvas.ready{opacity:1}
.bg-glow{position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(600px 420px at 12% 8%,rgba(34,211,238,.14),transparent 60%),
    radial-gradient(720px 520px at 88% 16%,rgba(139,92,246,.16),transparent 60%),
    radial-gradient(760px 620px at 50% 108%,rgba(244,113,181,.10),transparent 60%);}
.vignette{position:fixed;inset:0;z-index:-1;pointer-events:none;
  box-shadow:inset 0 0 240px 60px rgba(0,0,0,.9);background:radial-gradient(120% 90% at 50% 40%,transparent 55%,rgba(0,0,0,.55))}
.grain{position:fixed;inset:0;z-index:9998;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='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 1.2s steps(3) infinite}
@keyframes grain{0%{transform:translate(0,0)}33%{transform:translate(-6px,4px)}66%{transform:translate(5px,-5px)}100%{transform:translate(0,0)}}

/* ===== Preloader ===== */
.preloader{position:fixed;inset:0;z-index:10000;background:#05060d;display:grid;place-items:center;overflow:hidden}
.pre-grid{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:54px 54px;mask:radial-gradient(circle at 50% 50%,#000,transparent 75%)}
.pre-center{position:relative;width:min(86vw,520px);text-align:center}
.pre-brand{display:flex;align-items:center;justify-content:center;gap:14px;font-family:'Syne';font-weight:800;font-size:clamp(2rem,7vw,3.4rem);letter-spacing:.02em;margin-bottom:30px}
.pre-name{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.pre-bar{height:2px;width:100%;background:rgba(255,255,255,.12);border-radius:2px;overflow:hidden}
.pre-bar-fill{display:block;height:100%;width:0;background:var(--grad);box-shadow:0 0 18px rgba(139,92,246,.7)}
.pre-foot{display:flex;justify-content:space-between;margin-top:14px;font-family:'Space Grotesk';font-size:.78rem;letter-spacing:.18em;color:var(--muted)}
.pre-num{color:var(--ink)}

/* ===== Cursore ===== */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:screen;will-change:transform}
.cursor-dot{width:6px;height:6px;background:var(--cyan)}
.cursor-ring{width:36px;height:36px;border:1.5px solid rgba(139,92,246,.6);transition:width .2s,height .2s,opacity .2s,background .2s}
.cursor-ring.hot{width:64px;height:64px;background:rgba(139,92,246,.10);border-color:transparent}
@media (hover:none){.cursor-dot,.cursor-ring{display:none}}

/* ===== Nav ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;
  padding:20px clamp(18px,5vw,52px);transition:background .3s,backdrop-filter .3s,padding .3s,border-color .3s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(5,6,13,.65);backdrop-filter:blur(14px);border-bottom-color:var(--panel-brd);padding-top:13px;padding-bottom:13px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.4rem;font-family:'Syne'}
.brand-mark{color:var(--cyan);filter:drop-shadow(0 0 8px var(--cyan));animation:spin 9s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.brand-logo{width:34px;height:34px;display:inline-block;filter:drop-shadow(0 0 10px rgba(139,92,246,.3))}
.pre-logo{width:58px;height:58px}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{color:var(--muted);font-size:.95rem;font-weight:500;transition:color .2s;position:relative}
.nav-links a:not(.nav-cta):hover{color:var(--ink)}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--grad);transition:width .25s}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{padding:9px 22px;border-radius:999px;background:var(--grad);color:#05060d!important;font-weight:600;box-shadow:0 6px 22px rgba(139,92,246,.4)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:999px;font-weight:600;font-size:1rem;cursor:pointer;border:none;transition:box-shadow .25s,background .25s;will-change:transform}
.btn span{transition:transform .25s}
.btn:hover span{transform:translateX(5px)}
.btn-primary{background:var(--grad);color:#05060d;box-shadow:0 8px 32px rgba(139,92,246,.45)}
.btn-primary:hover{box-shadow:0 14px 48px rgba(139,92,246,.65)}
.btn-ghost{background:var(--panel);color:var(--ink);border:1px solid var(--panel-brd)}
.btn-ghost:hover{border-color:var(--cyan);box-shadow:0 0 28px rgba(34,211,238,.28)}

/* ===== Split text (per data-split) ===== */
.line{display:block;overflow:hidden}
.line-in{display:block;will-change:transform}

/* ===== Hero ===== */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:140px clamp(18px,5vw,52px) 80px;position:relative}
.hero-inner{max-width:980px}
.eyebrow{color:var(--cyan);font-size:.88rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:24px}
.hero-title{font-size:clamp(2rem,4.8vw,3.7rem);font-weight:700;margin-bottom:26px;font-family:'Syne';letter-spacing:-.025em;line-height:1.08;max-width:880px;margin-left:auto;margin-right:auto}
.hero-sub{font-size:clamp(1.02rem,1.7vw,1.22rem);color:var(--muted);max-width:600px;margin:0 auto 40px}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--muted);font-family:'Space Grotesk';font-size:.72rem;letter-spacing:.2em}
.hero-scroll i{width:1px;height:46px;background:linear-gradient(var(--cyan),transparent);animation:scrolldown 1.8s ease-in-out infinite}
@keyframes scrolldown{0%,100%{transform:scaleY(.4);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* ===== Manifesto (aurora + mockup fluttuanti) ===== */
.manifesto{position:relative;min-height:88vh;display:grid;place-items:center;padding:120px clamp(18px,5vw,52px);overflow:hidden}
.manifesto-inner{position:relative;z-index:3;max-width:880px;margin:0 auto;text-align:center}
.manifesto-inner .eyebrow{margin-bottom:26px}
.manifesto-text{font-family:'Syne';font-weight:700;font-size:clamp(1.35rem,3.2vw,2.5rem);line-height:1.28;text-align:center;letter-spacing:-.01em}
.manifesto-text em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.manifesto-text .w{display:inline-block;will-change:transform,opacity}

/* aurora animata dietro */
.manifesto-aurora{position:absolute;inset:-10% -10% 0 -10%;z-index:1;filter:blur(70px);opacity:.55;pointer-events:none}
.manifesto-aurora::before,.manifesto-aurora::after{content:"";position:absolute;width:48vw;height:48vw;max-width:620px;max-height:620px;border-radius:50%}
.manifesto-aurora::before{top:6%;left:8%;background:radial-gradient(circle,rgba(34,211,238,.55),transparent 68%);animation:aurora1 16s ease-in-out infinite}
.manifesto-aurora::after{bottom:2%;right:6%;background:radial-gradient(circle,rgba(244,113,181,.5),transparent 68%);animation:aurora2 19s ease-in-out infinite}
@keyframes aurora1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(14vw,8vh) scale(1.25)}}
@keyframes aurora2{0%,100%{transform:translate(0,0) scale(1.1)}50%{transform:translate(-12vw,-6vh) scale(.85)}}

/* mockup che fluttuano */
.manifesto-floats{position:absolute;inset:0;z-index:2;pointer-events:none}
.mfloat{position:absolute;width:clamp(160px,18vw,250px);border-radius:14px;border:1px solid var(--panel-brd);box-shadow:0 30px 70px rgba(0,0,0,.55);opacity:.5;filter:saturate(1.05)}
.mf1{top:12%;left:3%;transform:rotate(-7deg);animation:floaty 9s ease-in-out infinite}
.mf2{bottom:10%;left:9%;width:clamp(120px,12vw,165px);transform:rotate(6deg);animation:floaty 11s ease-in-out infinite reverse}
.mf3{top:16%;right:4%;transform:rotate(8deg);animation:floaty 10s ease-in-out infinite}
@keyframes floaty{0%,100%{translate:0 0}50%{translate:0 -22px}}
@media (max-width:980px){.manifesto-floats{display:none}.manifesto-aurora{opacity:.4}}

/* ===== Marquee ===== */
.marquee-wrap{overflow:hidden;border-top:1px solid var(--panel-brd);border-bottom:1px solid var(--panel-brd);padding:20px 0;background:rgba(255,255,255,.015)}
.marquee{display:flex;gap:34px;white-space:nowrap;width:max-content;font-family:'Syne';font-weight:700;color:var(--muted);letter-spacing:.04em;font-size:clamp(1rem,2vw,1.4rem);align-items:center}
.marquee i{color:var(--violet);font-style:normal}
.marquee span:nth-child(4n+1){color:var(--ink)}

/* ===== Sections ===== */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(80px,11vw,150px) clamp(18px,5vw,52px)}
.section-head{max-width:760px;margin:0 auto 60px;text-align:center}
.section-head h2{font-size:clamp(1.9rem,4.4vw,3.4rem)}
.section-note{color:var(--muted);font-size:.82rem;font-style:italic}
.section-note.center{text-align:center;margin-top:28px}

/* ===== Cards ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px}
.card{background:var(--panel);border:1px solid var(--panel-brd);border-radius:var(--radius);padding:36px 32px;position:relative;overflow:hidden;transition:transform .35s,border-color .35s,box-shadow .35s}
.card:hover{transform:translateY(-8px);border-color:transparent;box-shadow:0 24px 60px rgba(139,92,246,.28)}
.card:hover::after{content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.card-ico{font-size:2rem;width:62px;height:62px;display:grid;place-items:center;border-radius:14px;background:linear-gradient(135deg,rgba(34,211,238,.15),rgba(139,92,246,.15));border:1px solid var(--panel-brd);margin-bottom:22px;color:var(--cyan)}
.card h3{font-size:1.35rem;margin-bottom:10px}
.card p{color:var(--muted)}
.card-idx{position:absolute;top:24px;right:26px;font-family:'Space Grotesk';font-size:.8rem;color:var(--muted);opacity:.5}

/* ===== Steps ===== */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px}
.step{background:var(--panel);border:1px solid var(--panel-brd);border-radius:var(--radius);padding:32px 28px;transition:transform .35s,border-color .35s}
.step:hover{transform:translateY(-6px);border-color:var(--violet)}
.step-n{font-size:2.6rem;font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:8px}
.step h3{font-size:1.25rem;margin-bottom:8px}
.step p{color:var(--muted);font-size:.95rem}

/* ===== Works (horizontal) ===== */
.works{position:relative}
.works-pin{min-height:100vh;display:flex;align-items:center;overflow:hidden}
.works-track{display:flex;gap:40px;padding:0 clamp(18px,6vw,90px);align-items:center;will-change:transform}
.works-intro{flex:0 0 auto;width:min(80vw,460px)}
.works-intro .eyebrow{margin-bottom:18px}
.works-title{font-size:clamp(2.2rem,5.5vw,4rem)}
.works-note{color:var(--muted);font-size:.82rem;font-style:italic;margin-top:18px}
.work-slide{flex:0 0 auto;width:min(82vw,440px);border:1px solid var(--panel-brd);border-radius:22px;overflow:hidden;background:var(--panel);transition:transform .4s,box-shadow .4s}
.work-slide:hover{transform:translateY(-8px);box-shadow:0 30px 70px rgba(34,211,238,.2)}
.work-thumb{height:300px;position:relative}
.work-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(5,6,13,.7))}
.t1{background:linear-gradient(135deg,#22d3ee,#3b82f6)}
.t2{background:linear-gradient(135deg,#8b5cf6,#6366f1)}
.t3{background:linear-gradient(135deg,#f471b5,#8b5cf6)}
.t4{background:linear-gradient(135deg,#22d3ee,#8b5cf6)}
.work-info{padding:26px}
.work-tag{display:inline-block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan);border:1px solid var(--panel-brd);padding:4px 13px;border-radius:999px;margin-bottom:14px}
.work-info h3{font-size:1.35rem;margin-bottom:6px}
.work-info p{color:var(--muted);font-size:.95rem}

/* ===== Lavori (griglia mockup interi) ===== */
.section-lead{max-width:660px;margin:18px auto 0;color:var(--muted);font-size:1.05rem;text-align:center}
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;margin-top:10px}
.work{border:1px solid var(--panel-brd);border-radius:20px;overflow:hidden;background:var(--panel);transition:transform .35s,box-shadow .35s,border-color .35s}
.work:hover{transform:translateY(-6px);border-color:rgba(139,92,246,.5);box-shadow:0 30px 70px rgba(34,211,238,.16)}
.work-shot{position:relative;line-height:0;background:#0a0c1a}
.work-shot img{width:100%;height:auto;display:block}
.work-concept{position:absolute;top:14px;left:14px;z-index:2;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:#eef2ff;background:rgba(5,6,13,.6);backdrop-filter:blur(6px);border:1px solid var(--panel-brd);padding:5px 12px;border-radius:999px}
.work-meta{display:flex;align-items:center;gap:14px;padding:20px 24px;line-height:1.4}
.work-meta .work-tag{margin-bottom:0}
.work-meta h3{font-size:1.25rem}
@media (max-width:760px){.work-grid{grid-template-columns:1fr;gap:22px}}

/* ===== Stats ===== */
.stats-sec{text-align:center}
.stats{display:flex;gap:clamp(20px,5vw,64px);justify-content:center;flex-wrap:wrap}
.stat{display:flex;flex-direction:column;gap:6px}
.stat-num{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-family:'Syne'}
.stat-lbl{color:var(--muted);font-size:.9rem}

/* ===== Split / Studio ===== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split-text h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin:10px 0 22px}
.split-text p{color:var(--muted);margin-bottom:16px}
.check-list{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:13px}
.check-list li{padding-left:34px;position:relative}
.check-list li::before{content:"✓";position:absolute;left:0;top:1px;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:var(--grad);color:#05060d;font-size:.78rem;font-weight:700}
.split-visual{position:relative;display:grid;place-items:center;min-height:360px}
.orb{position:absolute;width:300px;height:300px;border-radius:50%;background:var(--grad);filter:blur(46px);opacity:.42;animation:pulse 5.5s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.14)}}
.glass-card{position:relative;background:rgba(255,255,255,.06);backdrop-filter:blur(16px);border:1px solid var(--panel-brd);border-radius:24px;padding:44px;text-align:center;max-width:360px}
.quote{font-family:'Syne';font-size:1.5rem;font-weight:700;margin-bottom:12px}
.quote-by{color:var(--muted);font-size:.9rem}

/* ===== Contatti ===== */
.contact-box{display:grid;grid-template-columns:1fr 1fr;gap:54px;background:var(--panel);border:1px solid var(--panel-brd);border-radius:28px;padding:clamp(32px,5vw,64px)}
.contact-left h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin:10px 0 18px}
.contact-left p{color:var(--muted)}
.contact-info{list-style:none;margin-top:30px;display:flex;flex-direction:column;gap:15px}
.contact-info li{display:flex;align-items:center;gap:12px}
.contact-info span{width:36px;height:36px;display:grid;place-items:center;border-radius:10px;background:linear-gradient(135deg,rgba(34,211,238,.15),rgba(139,92,246,.15));border:1px solid var(--panel-brd);color:var(--cyan)}
.contact-form{display:flex;flex-direction:column;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.85rem;color:var(--muted)}
.field input,.field select,.field textarea{background:rgba(255,255,255,.04);border:1px solid var(--panel-brd);border-radius:12px;padding:13px 15px;color:var(--ink);font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,211,238,.15)}
.field select option{background:var(--bg-2)}
.form-note{color:var(--cyan);font-size:.9rem}

/* ===== Footer ===== */
.footer{max-width:var(--maxw);margin:0 auto;padding:40px clamp(18px,5vw,52px) 44px}
.footer-cta{font-family:'Syne';font-weight:800;font-size:clamp(2.4rem,10vw,8rem);text-align:center;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;padding:40px 0 60px;letter-spacing:-.03em}
.footer-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px;padding-top:40px;border-top:1px solid var(--panel-brd);margin-bottom:28px}
.footer-links{display:flex;gap:26px;flex-wrap:wrap}
.footer-links a{color:var(--muted);transition:color .2s}
.footer-links a:hover{color:var(--ink)}
.footer-legal{color:var(--muted);font-size:.85rem;line-height:1.8}
.footer-legal .copyright{margin-top:14px;opacity:.7}

/* ===== UI/UX enhancements ===== */
/* barra avanzamento scroll */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:300;background:var(--grad);box-shadow:0 0 14px rgba(139,92,246,.6);transition:width .08s linear;border-radius:0 2px 2px 0}
/* voce menu attiva */
.nav-links a.active:not(.nav-cta){color:var(--ink)}
.nav-links a.active:not(.nav-cta)::after{width:100%}
/* focus accessibile (tastiera) */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:8px}
/* torna su */
.to-top{position:fixed;right:24px;bottom:24px;z-index:250;width:50px;height:50px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.06);backdrop-filter:blur(10px);border:1px solid var(--panel-brd);color:var(--ink);cursor:pointer;opacity:0;transform:translateY(18px) scale(.85);pointer-events:none;transition:opacity .3s,transform .3s,border-color .3s,box-shadow .3s;font-size:1.15rem}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{border-color:var(--cyan);box-shadow:0 0 26px rgba(34,211,238,.32);transform:translateY(-2px)}
/* indice sezione (editoriale) */
.sec-index{display:block;font-family:'Space Grotesk';font-size:.78rem;letter-spacing:.22em;color:var(--muted);margin-bottom:16px;opacity:.85}
/* hero aurora viva (sfondo non più piatto) */
.bg-glow{animation:glowBreathe 14s ease-in-out infinite}
@keyframes glowBreathe{0%,100%{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}
/* contatti: due CTA */
.contact-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-call{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:999px;font-weight:600;border:1px solid var(--panel-brd);background:var(--panel);color:var(--ink);cursor:pointer;transition:border-color .25s,box-shadow .25s}
.btn-call:hover{border-color:var(--cyan);box-shadow:0 0 24px rgba(34,211,238,.25)}
/* card: micro-interazione icona */
.card:hover .card-ico{transform:translateY(-3px) scale(1.06);border-color:var(--cyan);color:var(--ink)}
.card-ico{transition:transform .35s,border-color .35s,color .35s}

/* ===== Fallback reveal (se GSAP non carica) ===== */
.no-gsap [data-reveal],.no-gsap [data-split],.no-gsap [data-words]{opacity:1!important;transform:none!important}

/* ===== Responsive ===== */
@media (max-width:860px){
  .split,.contact-box{grid-template-columns:1fr;gap:42px}
  .nav-links{position:fixed;top:0;right:0;height:100vh;width:min(78vw,320px);flex-direction:column;justify-content:center;gap:30px;background:rgba(8,10,22,.97);backdrop-filter:blur(20px);transform:translateX(100%);transition:transform .4s;border-left:1px solid var(--panel-brd)}
  .nav-links.open{transform:translateX(0)}
  .nav-toggle{display:flex;z-index:201}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){transform:translateY(-7px) rotate(-45deg)}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
