:root{--gp:#7c5cff;--ga:#b892ff;--gb:#5cc8ff}
html{scroll-behavior:smooth}
body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:-2;background:radial-gradient(900px 600px at 15% 8%,rgba(124,92,255,.22),transparent 60%),radial-gradient(700px 500px at 85% 12%,rgba(92,200,255,.14),transparent 65%),radial-gradient(800px 600px at 50% 100%,rgba(184,146,255,.14),transparent 60%);animation:aur 24s ease-in-out infinite alternate}
@keyframes aur{0%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(-2%,1%,0) scale(1.04)}100%{transform:translate3d(2%,-1%,0) scale(1)}}
.hero-v1 h1 span{background:linear-gradient(120deg,#b892ff 0%,#7c5cff 35%,#5cc8ff 70%,#b892ff 100%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:ts 9s ease-in-out infinite;filter:drop-shadow(0 6px 30px rgba(124,92,255,.25))}
@keyframes ts{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.hero-v1 h1{letter-spacing:-.02em}
a.btn-primary,.btn-primary{position:relative;overflow:hidden;box-shadow:0 10px 30px -8px rgba(124,92,255,.55),inset 0 1px 0 rgba(255,255,255,.15);transition:transform .25s ease,box-shadow .25s ease,filter .25s ease}
a.btn-primary:hover,.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(124,92,255,.7),inset 0 1px 0 rgba(255,255,255,.2);filter:brightness(1.06)}
a.btn-primary::after,.btn-primary::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);transform:translateX(-100%);transition:transform .7s ease}
a.btn-primary:hover::after,.btn-primary:hover::after{transform:translateX(100%)}
.section-axes .card,.axes .card{transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s ease,border-color .35s ease}
.section-axes .card:hover,.axes .card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -20px rgba(124,92,255,.35),0 0 0 1px rgba(184,146,255,.25) inset}
h2{position:relative}
.section-v1 h2::after,.section-axes h2::after{content:"";display:block;width:64px;height:3px;margin-top:14px;border-radius:3px;background:linear-gradient(90deg,#7c5cff,#b892ff 50%,#5cc8ff);box-shadow:0 0 16px rgba(124,92,255,.45)}
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.8,.2,1)}
[data-reveal].is-visible{opacity:1;transform:none}
.footer-v2{position:relative}
.footer-v2::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(124,92,255,.55),transparent)}
.footer-v2 a{transition:color .2s ease}
.footer-v2 a:hover{color:#b892ff}
body.light-on::before{background:radial-gradient(900px 600px at 15% 8%,rgba(124,92,255,.18),transparent 60%),radial-gradient(700px 500px at 85% 12%,rgba(92,200,255,.15),transparent 65%)}

/* ===== BLOCK REDESIGN DARK ===== */
section.section-v1,section.section-axes{background:transparent !important;background-image:none !important;box-shadow:none !important;border:none !important}
.card,[class*="card"]{background:rgba(30,22,60,.35) !important;backdrop-filter:blur(18px) saturate(140%) !important;-webkit-backdrop-filter:blur(18px) saturate(140%) !important;border:1px solid rgba(184,146,255,.12) !important;border-radius:20px !important;box-shadow:0 1px 0 rgba(255,255,255,.04) inset,0 20px 50px -20px rgba(0,0,0,.4),0 8px 24px -8px rgba(124,92,255,.15) !important}
.card:hover,[class*="card"]:hover{background:rgba(40,30,80,.45) !important;border-color:rgba(184,146,255,.3) !important;box-shadow:0 1px 0 rgba(255,255,255,.08) inset,0 30px 60px -20px rgba(124,92,255,.35),0 12px 30px -10px rgba(124,92,255,.25) !important;transform:translateY(-4px) !important}
.pstep{background:rgba(30,22,60,.35) !important;backdrop-filter:blur(16px) saturate(140%) !important;-webkit-backdrop-filter:blur(16px) saturate(140%) !important;border:1px solid rgba(184,146,255,.12) !important;border-radius:18px !important;box-shadow:0 1px 0 rgba(255,255,255,.04) inset,0 16px 40px -16px rgba(0,0,0,.35) !important}

/* ===== HERO MESH v1 ===== */
.hero-v1 .grid-bg{display:none !important}
.hero-mesh{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.hero-mesh .mesh-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;mix-blend-mode:screen;will-change:transform}
.hero-mesh .mb1{width:62vw;height:62vw;left:-18vw;top:-18vw;background:radial-gradient(closest-side,#8b5cf6,transparent 70%);animation:mbFloat1 22s ease-in-out infinite alternate}
.hero-mesh .mb2{width:52vw;height:52vw;right:-14vw;top:-10vw;background:radial-gradient(closest-side,#3b82f6,transparent 70%);animation:mbFloat2 28s ease-in-out infinite alternate;opacity:.45}
.hero-mesh .mb3{width:58vw;height:58vw;left:8vw;bottom:-22vw;background:radial-gradient(closest-side,#ec4899,transparent 70%);animation:mbFloat3 26s ease-in-out infinite alternate;opacity:.38}
.hero-mesh .mb4{width:44vw;height:44vw;right:4vw;bottom:-12vw;background:radial-gradient(closest-side,#06b6d4,transparent 70%);animation:mbFloat4 30s ease-in-out infinite alternate;opacity:.4}
@keyframes mbFloat1{0%{transform:translate(0,0) scale(1)}100%{transform:translate(6vw,4vw) scale(1.12)}}
@keyframes mbFloat2{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-4vw,6vw) scale(1.15)}}
@keyframes mbFloat3{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-5vw,-4vw) scale(1.1)}}
@keyframes mbFloat4{0%{transform:translate(0,0) scale(1)}100%{transform:translate(4vw,-5vw) scale(1.14)}}
.hero-mesh::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,transparent 35%,rgba(8,4,20,.55) 100%);pointer-events:none}
.hero-beams{position:absolute;inset:0;overflow:hidden;pointer-events:none;opacity:.35;mix-blend-mode:screen}
.hero-beams span{position:absolute;top:-20%;width:2px;height:140%;background:linear-gradient(180deg,transparent,rgba(184,146,255,.9),transparent);filter:blur(2px);transform-origin:top center;transform:rotate(14deg);animation:beamSweep 18s ease-in-out infinite}
.hero-beams span:nth-child(1){left:22%;animation-delay:0s}
.hero-beams span:nth-child(2){left:58%;animation-delay:-6s;background:linear-gradient(180deg,transparent,rgba(92,200,255,.8),transparent)}
.hero-beams span:nth-child(3){left:84%;animation-delay:-12s;background:linear-gradient(180deg,transparent,rgba(236,72,153,.7),transparent)}
@keyframes beamSweep{0%,100%{opacity:0;transform:rotate(14deg) translateX(-4vw)}50%{opacity:1;transform:rotate(14deg) translateX(4vw)}}
.hero-aurora{position:absolute;left:0;right:0;top:0;height:50%;overflow:hidden;pointer-events:none;opacity:.6;mix-blend-mode:screen}
.hero-aurora span{position:absolute;left:-10%;right:-10%;height:200px;filter:blur(40px);border-radius:50%}
.hero-aurora span:nth-child(1){top:-60px;background:linear-gradient(90deg,transparent,#7c5cff 30%,#3b82f6 60%,transparent);animation:aurWave 14s ease-in-out infinite alternate}
.hero-aurora span:nth-child(2){top:40px;background:linear-gradient(90deg,transparent,#ec4899 30%,#8b5cf6 60%,transparent);animation:aurWave2 18s ease-in-out infinite alternate;opacity:.7}
@keyframes aurWave{0%{transform:translateX(-4%) skewX(-6deg)}100%{transform:translateX(4%) skewX(6deg)}}
@keyframes aurWave2{0%{transform:translateX(3%) skewX(4deg)}100%{transform:translateX(-3%) skewX(-4deg)}}
.hero-v1 .bg-gradient{opacity:.5 !important}

/* ===== HERO FADE ===== */
.hero-v1{position:relative;border:none !important;overflow:visible !important;mask-image:linear-gradient(180deg,#000 0%,#000 78%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,#000 0%,#000 78%,transparent 100%)}
.hero-v1::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:220px;pointer-events:none;background:linear-gradient(180deg,transparent 0%,rgba(8,4,20,.35) 55%,rgba(8,4,20,0) 100%);z-index:1}
.hero-v1 + *,section.hero-v1 + section{margin-top:-120px !important;position:relative;z-index:2}
.hero-mesh{height:140% !important;bottom:-40% !important;top:auto !important}
.hero-v1{mask-image:none !important;-webkit-mask-image:none !important}
.hero-v1::after{height:300px !important;background:linear-gradient(180deg,transparent 0%,rgba(8,4,20,.6) 60%,rgba(8,4,20,.9) 100%) !important}
.hero-v1 + *,section.hero-v1 + section{margin-top:-60px !important;padding-top:80px !important}

/* ===== SCROLL FX ===== */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#7c5cff,#3b82f6 50%,#ec4899);transform-origin:left center;transform:scaleX(0);z-index:9999;box-shadow:0 0 14px rgba(124,92,255,.6)}
.scroll-indicator{position:fixed;left:50%;bottom:32px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:4px;z-index:50;opacity:1;transition:opacity .5s ease,transform .5s ease;pointer-events:none}
body.is-scrolled .scroll-indicator{opacity:0;transform:translate(-50%,20px)}
.scroll-indicator span{display:block;width:18px;height:3px;border-radius:2px;background:linear-gradient(90deg,#7c5cff,#3b82f6);opacity:.35;animation:chev 1.8s ease-in-out infinite}
.scroll-indicator span:nth-child(2){width:24px;animation-delay:.15s}
.scroll-indicator span:nth-child(3){width:12px;animation-delay:.3s}
@keyframes chev{0%,100%{opacity:.2;transform:translateY(0)}50%{opacity:1;transform:translateY(4px)}}
.scroll-counter{position:fixed;right:24px;bottom:24px;z-index:60;display:flex;align-items:baseline;gap:2px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:700;color:#b892ff;opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease;pointer-events:none;text-shadow:0 0 20px rgba(124,92,255,.5)}
body.is-scrolled .scroll-counter{opacity:.85;transform:translateY(0)}
.scroll-counter i{font-style:normal;font-size:32px;line-height:1;letter-spacing:-.04em;background:linear-gradient(135deg,#b892ff,#5cc8ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.scroll-counter em{font-style:normal;font-size:12px;opacity:.6;margin-left:2px;letter-spacing:.1em}
.fx-reveal{opacity:0;transform:translate3d(0,40px,0) scale(.98);filter:blur(8px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform 1.1s cubic-bezier(.2,.8,.2,1),filter .9s ease;transition-delay:var(--fx-delay,0ms);will-change:transform,opacity,filter}
.fx-reveal.fx-in{opacity:1;transform:translate3d(0,0,0) scale(1);filter:blur(0)}

/* ===== VEILLEUSE REDESIGN ===== */
.veilleuse-wrap{top:58px !important;left:78px !important;right:auto !important;bottom:auto !important;position:fixed !important;z-index:60 !important;transform-origin:top center !important;filter:drop-shadow(0 4px 8px rgba(0,0,0,.25))}
.veilleuse-fil{width:1.2px !important;height:34px !important;background:linear-gradient(180deg,rgba(120,120,140,.35),rgba(180,180,200,.85) 40%,rgba(90,90,110,.9)) !important;box-shadow:0 0 0 .5px rgba(0,0,0,.3),inset -.5px 0 0 rgba(255,255,255,.15) !important}
.veilleuse-culot{width:11px !important;height:5px !important;background:linear-gradient(180deg,#2a2a30 0%,#8a8a92 25%,#4a4a52 55%,#2a2a30 100%) !important;border-radius:2px 2px 3px 3px !important;box-shadow:0 1px 2px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.25),inset 0 -1px 0 rgba(0,0,0,.4) !important;position:relative !important}
.veilleuse-ampoule{width:18px !important;height:24px !important;background:radial-gradient(ellipse at 50% 40%,#5a5a62 0%,#3a3a42 45%,#1e1e24 85%) !important;border-radius:50% 50% 45% 45%/55% 55% 40% 40% !important;box-shadow:inset -2px -2px 4px rgba(0,0,0,.5),inset 2px 2px 3px rgba(255,255,255,.08),0 2px 4px rgba(0,0,0,.35) !important;position:relative !important;overflow:visible !important}
.veilleuse-ampoule::before{content:"";position:absolute !important;top:15% !important;left:22% !important;width:28% !important;height:18% !important;background:radial-gradient(ellipse,rgba(255,255,255,.35),transparent 70%) !important;border-radius:50% !important;pointer-events:none}
.veilleuse-ampoule .filament{width:8px !important;height:10px !important;top:50% !important;left:50% !important;border:none !important;background:transparent !important;box-shadow:inset 0 0 0 .8px rgba(90,90,100,.7) !important;border-radius:40% !important;opacity:.7 !important;clip-path:polygon(0% 20%,20% 0%,35% 30%,50% 0%,65% 30%,80% 0%,100% 20%,100% 80%,80% 100%,65% 70%,50% 100%,35% 70%,20% 100%,0% 80%) !important}
.veilleuse-tirette{width:6px !important;height:6px !important;background:radial-gradient(ellipse at 35% 30%,#cccdd4 0%,#6a6a72 45%,#1a1a20 100%) !important;border-radius:50% !important;margin:3px auto 0 !important;box-shadow:0 1px 2px rgba(0,0,0,.5),inset 0 .5px 0 rgba(255,255,255,.4) !important;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s ease !important}
.veilleuse-tirette:hover{transform:scale(1.35) translateY(1px) !important;box-shadow:0 2px 4px rgba(0,0,0,.5),inset 0 .5px 0 rgba(255,255,255,.5),0 0 0 3px rgba(124,92,255,.15) !important}
@keyframes swayIntro{0%{transform:translateX(0) rotate(0)}25%{transform:translateX(-1px) rotate(-2deg)}50%{transform:translateX(1px) rotate(2deg)}75%{transform:translateX(-.5px) rotate(-1deg)}100%{transform:translateX(0) rotate(0)}}
.veilleuse-wrap{animation:swayIntro 3s ease-in-out 1 !important}
@media(max-width:768px){.veilleuse-wrap{top:54px !important;left:64px !important;right:auto !important}}
