:root{
  --bg:        #03060f;
  --bg-2:      #0a1226;
  --bg-3:      #121b35;
  --ink:       #e9eefb;
  --ink-dim:   #8b95b2;
  --jedi:      #4cd2ff;          /* sabre bleu */
  --sith:      #ff3b3b;          /* sabre rouge */
  --gold:      #ffe27a;          /* hologramme / Tatooine */
  --green:     #6dffb3;          /* sabre vert */
  --line:      rgba(76,210,255,.22);
  --line-dim:  rgba(233,238,251,.10);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; overflow-x:hidden; overscroll-behavior-x:none; }
html,body{ background:var(--bg); color:var(--ink); font-family:'Inter',sans-serif; -webkit-font-smoothing:antialiased; max-width:100%; }
body{ overflow-x:hidden; position:relative; width:100%; }
img{ max-width:100%; }

/* — typography — */
.display{ font-family:'Orbitron',sans-serif; font-weight:900; letter-spacing:0.04em; line-height:0.95; text-transform:uppercase; }
.display em{ font-style:normal; color:var(--jedi); text-shadow: 0 0 18px rgba(76,210,255,.55); }
.display em.red{ color:var(--sith); text-shadow: 0 0 18px rgba(255,59,59,.55); }
.display em.gold{ color:var(--gold); text-shadow: 0 0 18px rgba(255,226,122,.45); }
.mono{ font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-dim); }
.label{ font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color:var(--jedi); }
h2.display{ font-size: clamp(40px, 7vw, 96px); }

/* — global star background — */
.stars{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  transform:translateZ(0); will-change:transform; backface-visibility:hidden;
  background:
    radial-gradient(2px 2px at 20% 30%, #fff 99%, transparent),
    radial-gradient(1px 1px at 70% 60%, #fff 99%, transparent),
    radial-gradient(1px 1px at 40% 80%, #fff 99%, transparent),
    radial-gradient(2px 2px at 85% 15%, #fff 99%, transparent),
    radial-gradient(1px 1px at 12% 70%, #fff 99%, transparent),
    radial-gradient(1px 1px at 55% 25%, #fff 99%, transparent),
    radial-gradient(1px 1px at 92% 50%, #fff 99%, transparent),
    radial-gradient(1.5px 1.5px at 30% 50%, #fff 99%, transparent),
    radial-gradient(1px 1px at 65% 90%, #fff 99%, transparent),
    radial-gradient(1px 1px at 5% 10%, #fff 99%, transparent),
    radial-gradient(1px 1px at 78% 35%, #fff 99%, transparent),
    radial-gradient(1px 1px at 22% 92%, #fff 99%, transparent),
    radial-gradient(circle at 80% 10%, rgba(76,210,255,.12), transparent 40%),
    radial-gradient(circle at 10% 90%, rgba(255,59,59,.08), transparent 50%),
    var(--bg);
  background-size: 600px 600px, 600px 600px, 600px 600px, 800px 800px, 600px 600px, 600px 600px, 600px 600px, 700px 700px, 600px 600px, 600px 600px, 600px 600px, 600px 600px, 100% 100%, 100% 100%;
  animation: drift 240s linear infinite;
}
@keyframes drift{ to{ background-position: -600px -300px, -600px -300px, -600px -300px, -800px -400px, -600px -300px, -600px -300px, -600px -300px, -700px -350px, -600px -300px, -600px -300px, -600px -300px, -600px -300px, 0 0, 0 0; } }

/* shooting stars */
.shooting{ position:fixed; inset:0; z-index:-1; pointer-events:none; overflow:hidden; transform:translateZ(0); }
.shooting span{ position:absolute; width:140px; height:1px; background: linear-gradient(90deg, transparent, #fff, transparent); transform: rotate(-25deg); animation: shoot 8s linear infinite; opacity:0; }
.shooting span:nth-child(1){ top:15%; left:-20%; animation-delay: 0s; }
.shooting span:nth-child(2){ top:35%; left:-20%; animation-delay: 2.4s; }
.shooting span:nth-child(3){ top:55%; left:-20%; animation-delay: 5.1s; }
.shooting span:nth-child(4){ top:75%; left:-20%; animation-delay: 7s; }
@keyframes shoot{ 0%{ transform: translate(0,0) rotate(-25deg); opacity:0; } 10%{ opacity:1; } 100%{ transform: translate(140vw, 60vh) rotate(-25deg); opacity:0; } }

/* GPU-isolate content blocks so they always repaint during scroll */
header.hero, .marquee, .counters, section.s, .crawl-wrap, footer.site, .page-hero{ transform:translateZ(0); }

/* — scanline / CRT — */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1000;
  background: repeating-linear-gradient(0deg, rgba(120,200,255,.05) 0 1px, transparent 1px 4px);
  opacity:.5;
}
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1001;
  box-shadow: inset 0 0 200px rgba(0,0,0,.7);
}

/* — nav — */
nav.top{ position:fixed; inset:0 0 auto 0; z-index:100; padding:18px 32px; display:flex; align-items:center; justify-content:space-between; background:rgba(3,6,15,.6); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--line); }
nav .logo{ display:flex; align-items:center; gap:14px; font-family:'Orbitron',sans-serif; font-weight:900; font-size:18px; letter-spacing:.16em; color:#fff; text-decoration:none; }
nav .logo .saber{ position:relative; width:5px; height:26px; border-radius:3px; background: linear-gradient(180deg, #eafaff, #fff 50%, #eafaff); box-shadow: 0 0 3px #fff, 0 0 7px var(--jedi), 0 0 14px var(--jedi), 0 0 26px rgba(76,210,255,.7); animation: hum 2.4s ease-in-out infinite; }
@keyframes hum{ 0%,100%{ box-shadow: 0 0 3px #fff, 0 0 7px var(--jedi), 0 0 14px var(--jedi), 0 0 26px rgba(76,210,255,.6);} 48%{ box-shadow: 0 0 3px #fff, 0 0 9px var(--jedi), 0 0 18px var(--jedi), 0 0 34px rgba(76,210,255,.85);} 52%{ box-shadow: 0 0 2px #fff, 0 0 6px var(--jedi), 0 0 12px var(--jedi), 0 0 22px rgba(76,210,255,.55);} }
nav ul{ display:flex; gap:28px; list-style:none; }
nav ul a{ color:var(--ink); text-decoration:none; font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.18em; text-transform:uppercase; transition: color .3s, text-shadow .3s; }
nav ul a:hover{ color:var(--jedi); text-shadow: 0 0 12px var(--jedi); }
nav ul a.active{ color:var(--jedi); text-shadow: 0 0 12px var(--jedi); }
nav ul a.active::after{ content:""; display:block; height:1px; margin-top:5px; background:var(--jedi); box-shadow:0 0 8px var(--jedi); }
nav .cta{ display:flex; align-items:center; gap:10px; font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--green); text-decoration:none; }
nav .cta .pulse{ width:8px; height:8px; background:var(--green); border-radius:50%; box-shadow:0 0 0 0 var(--green); animation:pulse 2s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(109,255,179,.6);} 70%{box-shadow:0 0 0 14px rgba(109,255,179,0);} 100%{box-shadow:0 0 0 0 rgba(109,255,179,0);} }

/* — burger / menu mobile — */
.nav-toggle{ display:none; width:46px; height:40px; flex-direction:column; align-items:center; justify-content:center; gap:5px; padding:0; background:rgba(10,18,38,.5); border:1px solid var(--line); border-radius:8px; cursor:pointer; }
.nav-toggle span{ display:block; width:22px; height:2px; border-radius:2px; background:var(--ink); transition: transform .3s, opacity .25s; }
nav.top.nav-open .nav-toggle span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
nav.top.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
nav.top.nav-open .nav-toggle span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* — hero — */
.hero{ position:relative; min-height:100vh; padding:140px 32px 60px; overflow:hidden; }
.hero canvas#warp{ position:absolute; inset:0; width:100%; height:100%; z-index:0; pointer-events:none; }
.hero-grid{ position:relative; z-index:5; max-width:1480px; margin:0 auto; }
.hero .meta{ display:flex; justify-content:space-between; align-items:flex-end; padding-bottom:30px; border-bottom:1px solid var(--line); }
.hero h1{ font-size: clamp(56px, 11vw, 180px); margin:50px 0 30px; }
.hero h1 .word{ display:block; overflow:hidden; }
.hero h1 .word span{ display:inline-block; transform:translateY(110%); animation: rise 1.1s cubic-bezier(.2,.9,.2,1) forwards; }
.hero h1 .word:nth-child(2) span{ animation-delay:.15s; }
.hero h1 .word:nth-child(3) span{ animation-delay:.30s; }
@keyframes rise{ to{ transform:translateY(0); } }

.hero .sub{ font-family:'JetBrains Mono',monospace; font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-dim); margin-bottom:30px; max-width:600px; line-height:1.7; }
.hero .sub .typing{ color:var(--jedi); }
.hero .sub .typing::after{ content:'_'; animation: blink 1s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:0; } }

.hero .lower{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:40px; align-items:end; padding-top:24px; border-top:1px solid var(--line); }
.hero .lower p{ font-size:15px; line-height:1.55; color:var(--ink-dim); max-width:42ch; }
.hero .lower .stack{ display:flex; flex-direction:column; gap:6px; }
.hero .lower .stack b{ font-family:'Orbitron',sans-serif; font-weight:700; font-size:24px; color:var(--ink); letter-spacing:.04em; }
.hero .lower .stack .label{ color:var(--gold); }

/* — page hero (sous-pages) — */
.page-hero{ position:relative; min-height:62vh; padding:160px 32px 70px; overflow:hidden; display:flex; align-items:flex-end; border-bottom:1px solid var(--line); }
.page-hero .ph-inner{ position:relative; z-index:5; max-width:1480px; margin:0 auto; width:100%; }
.page-hero .crumb{ display:flex; gap:10px; align-items:center; font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-dim); margin-bottom:26px; }
.page-hero .crumb a{ color:var(--ink-dim); text-decoration:none; }
.page-hero .crumb a:hover{ color:var(--jedi); }
.page-hero .crumb .sep{ color:var(--jedi); }
.page-hero .crumb b{ color:var(--jedi); font-weight:400; }
.page-hero h1{ font-size: clamp(48px, 9vw, 140px); margin-bottom:24px; }
.page-hero .lead{ font-size:18px; line-height:1.6; color:var(--ink-dim); max-width:60ch; font-weight:300; }
.page-hero .lead em{ font-style:normal; color:var(--ink); }

/* — planets — */
.planet{
  position:absolute; right:-180px; top:60px; width:520px; height:520px; border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%, #2a3550 0%, #0a1226 40%, #03060f 70%),
    radial-gradient(circle at 65% 50%, transparent 25px, rgba(0,0,0,.6) 26px, transparent 38px),
    radial-gradient(circle at 30% 70%, transparent 14px, rgba(0,0,0,.4) 15px, transparent 22px),
    radial-gradient(circle at 75% 25%, transparent 8px, rgba(0,0,0,.4) 9px, transparent 14px);
  box-shadow:
    inset -60px -60px 120px rgba(0,0,0,.85),
    inset 30px 30px 100px rgba(76,210,255,.06),
    0 0 90px rgba(76,210,255,.18);
  animation: rot 120s linear infinite;
  z-index:1;
}
.planet::before{ content:""; position:absolute; inset:48% 0 48% 0; background: rgba(0,0,0,.5); border-top:1px solid rgba(0,0,0,.7); border-bottom:1px solid rgba(0,0,0,.7); }
@keyframes rot{ to{ transform: rotate(360deg); } }

.planet.warm{
  background:
    radial-gradient(circle at 32% 30%, #5a3a2a 0%, #2a1810 42%, #120a06 72%),
    radial-gradient(circle at 60% 55%, transparent 30px, rgba(0,0,0,.45) 31px, transparent 46px);
  box-shadow: inset -60px -60px 120px rgba(0,0,0,.85), inset 30px 30px 100px rgba(255,154,60,.08), 0 0 90px rgba(255,154,60,.16);
}

.planet-ring{
  position:absolute; right:-300px; top:120px; width:760px; height:760px; border-radius:50%;
  border:1px dashed rgba(76,210,255,.18);
  animation: rot 200s linear infinite reverse;
  z-index:0; pointer-events:none;
}
.planet-ring::before{ content:""; position:absolute; left:-6px; top:50%; width:12px; height:12px; border-radius:50%; background:var(--jedi); box-shadow:0 0 16px var(--jedi); }

/* twin sun */
.twin-sun{ position:absolute; left:8%; top:18%; z-index:0; }
.twin-sun .s1, .twin-sun .s2{ position:absolute; border-radius:50%; }
.twin-sun .s1{ width:90px; height:90px; background: radial-gradient(circle, #fff5c8, #ff9a3c 60%, transparent 75%); box-shadow:0 0 80px rgba(255,154,60,.4); animation: pulse-s 5s ease-in-out infinite; }
.twin-sun .s2{ width:60px; height:60px; left:80px; top:50px; background: radial-gradient(circle, #ffe9a8, #ff6b3c 60%, transparent 75%); box-shadow:0 0 60px rgba(255,107,60,.4); animation: pulse-s 7s ease-in-out infinite; }
@keyframes pulse-s{ 0%,100%{ transform: scale(1); opacity:.95; } 50%{ transform: scale(1.06); opacity:1; } }

/* — ships — */
.ship{ position:absolute; z-index:2; font-family:monospace; color:var(--ink-dim); white-space:pre; font-size:10px; line-height:1; animation: fly 22s linear infinite; }
.ship.tie{ top:30%; right:-100px; animation-duration: 28s; }
.ship.tie::before{ content: "─◧─"; font-size:24px; color:var(--ink); filter: drop-shadow(0 0 8px var(--ink)); }
.ship.xwing{ top:65%; left:-100px; animation-name: fly-r; animation-duration: 32s; }
.ship.xwing::before{ content: "≻═◇═≺"; font-size:20px; color:var(--jedi); filter: drop-shadow(0 0 8px var(--jedi)); }
@keyframes fly{ from{ transform: translateX(0); } to{ transform: translateX(-110vw); } }
@keyframes fly-r{ from{ transform: translateX(0); } to{ transform: translateX(110vw); } }

/* — marquee — */
.marquee{ overflow:hidden; padding:18px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background: rgba(10,18,38,.5); position:relative; z-index:5; }
.marquee-track{ display:flex; gap:40px; white-space:nowrap; animation: scroll 40s linear infinite; }
.marquee span{ font-family:'Orbitron',sans-serif; font-weight:700; font-size:36px; color:var(--ink); letter-spacing:.08em; text-transform:uppercase; }
.marquee span em{ color:var(--jedi); font-style:normal; text-shadow:0 0 16px rgba(76,210,255,.6); }
.marquee .dot{ width:12px; height:12px; border-radius:50%; background:var(--gold); align-self:center; flex:none; box-shadow:0 0 14px var(--gold); }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* — section base — */
section.s{ padding:120px 32px; position:relative; z-index:5; }
.s-inner{ max-width:1480px; margin:0 auto; }
.s-head{ display:grid; grid-template-columns: 120px 1fr; gap:30px; align-items:start; margin-bottom:60px; }
.s-head .num{ font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--jedi); padding-top:16px; letter-spacing:.18em; }
.s-head .num::before{ content:"//"; color:var(--ink-dim); margin-right:8px; }
.s-head .tagline{ margin-top:16px; color:var(--ink-dim); max-width:55ch; line-height:1.6; font-size:15px; }

.reveal{ opacity:0; transform:translateY(40px); transition: opacity .9s cubic-bezier(.2,.9,.2,1), transform .9s cubic-bezier(.2,.9,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* — about — */
.about{ display:grid; grid-template-columns: 1fr 1.2fr; gap:60px; align-items:start; }
.holo-frame{ position:relative; aspect-ratio: 4/5; border-radius:4px; overflow:hidden; border:1px solid var(--jedi); box-shadow: 0 0 40px rgba(76,210,255,.25), inset 0 0 60px rgba(76,210,255,.12); }
.holo-frame img{ width:100%; height:100%; object-fit:cover; filter: saturate(.92) contrast(1.04) brightness(.94); opacity:1; }
.holo-frame::before{ content:""; position:absolute; inset:0; pointer-events:none; background: repeating-linear-gradient(0deg, rgba(76,210,255,.06) 0 2px, transparent 2px 5px); }
.holo-frame::after{ content:""; position:absolute; inset:0; pointer-events:none; background: linear-gradient(180deg, transparent 0%, rgba(76,210,255,.10) 50%, transparent 100%); height:30%; animation: sweep 6s linear infinite; }
@keyframes sweep{ 0%{ transform: translateY(-100%); } 100%{ transform: translateY(400%); } }
.holo-meta{ position:absolute; left:14px; bottom:12px; font-family:'JetBrains Mono',monospace; font-size:10px; color:var(--jedi); letter-spacing:.2em; text-shadow:0 0 8px var(--jedi); z-index:2; }
.holo-meta b{ display:block; font-weight:700; }
.holo-corners span{ position:absolute; width:18px; height:18px; border:1px solid var(--jedi); }
.holo-corners span:nth-child(1){ top:8px; left:8px; border-right:none; border-bottom:none; }
.holo-corners span:nth-child(2){ top:8px; right:8px; border-left:none; border-bottom:none; }
.holo-corners span:nth-child(3){ bottom:8px; left:8px; border-right:none; border-top:none; }
.holo-corners span:nth-child(4){ bottom:8px; right:8px; border-left:none; border-top:none; }

.about .text p{ font-size:18px; line-height:1.6; color:var(--ink); font-family:'Inter',sans-serif; font-weight:300; margin-bottom:22px; }
.about .text p em{ font-style:normal; color:var(--jedi); }
.about .text .quote{ font-family:'Orbitron',sans-serif; font-weight:500; font-size:24px; line-height:1.3; color:var(--gold); border-left:2px solid var(--gold); padding-left:20px; margin: 30px 0; text-transform:uppercase; letter-spacing:.04em; }
.about .pills{ display:flex; flex-wrap:wrap; gap:8px; margin-top:24px; }
.about .pills span{ padding:7px 14px; border:1px solid var(--line); border-radius:0; font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.14em; color:var(--jedi); text-transform:uppercase; background: rgba(76,210,255,.05); }

/* — services grid — */
.services{ display:grid; grid-template-columns: repeat(3, 1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.svc{ background:var(--bg-2); padding:36px 28px; min-height:240px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden; transition: background .5s; text-decoration:none; color:inherit; }
.svc::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--jedi); transform: scaleY(0); transform-origin:top; transition: transform .5s; }
.svc:hover{ background:var(--bg-3); }
.svc:hover::before{ transform: scaleY(1); }
.svc:hover h3{ color:var(--jedi); text-shadow:0 0 14px rgba(76,210,255,.5); }
.svc .num{ font-family:'JetBrains Mono',monospace; font-size:10px; color:var(--gold); letter-spacing:.2em; }
.svc h3{ font-family:'Orbitron',sans-serif; font-weight:700; font-size:24px; line-height:1.1; margin:14px 0 14px; letter-spacing:.04em; text-transform:uppercase; transition: color .4s, text-shadow .4s; }
.svc p{ color:var(--ink-dim); font-size:13px; line-height:1.55; max-width:38ch; }
.svc .arrow{ position:absolute; top:36px; right:28px; font-size:18px; color:var(--ink-dim); transition: transform .5s, color .4s; }
.svc:hover .arrow{ transform: translate(6px,-6px); color:var(--jedi); }

/* — feature rows (sous-pages) — */
.feat{ display:grid; grid-template-columns: 1fr 1.1fr; gap:60px; align-items:center; margin-bottom:90px; }
.feat:last-child{ margin-bottom:0; }
.feat.flip .feat-media{ order:2; }
.feat-text .label{ margin-bottom:18px; }
.feat-text h3{ font-family:'Orbitron',sans-serif; font-weight:700; font-size: clamp(28px,4vw,44px); line-height:1.05; letter-spacing:.03em; text-transform:uppercase; margin-bottom:22px; }
.feat-text h3 em{ font-style:normal; color:var(--jedi); text-shadow:0 0 16px rgba(76,210,255,.45); }
.feat-text p{ font-size:17px; line-height:1.65; color:var(--ink-dim); font-weight:300; margin-bottom:18px; max-width:52ch; }
.feat-text p em{ font-style:normal; color:var(--ink); }
.feat-list{ list-style:none; margin-top:8px; display:flex; flex-direction:column; gap:2px; }
.feat-list li{ display:flex; gap:14px; align-items:baseline; padding:11px 0; border-bottom:1px solid var(--line-dim); font-size:15px; color:var(--ink); }
.feat-list li::before{ content:"▸"; color:var(--jedi); font-size:12px; flex:none; }
.feat-media{ position:relative; aspect-ratio: 4/3; border:1px solid var(--line); overflow:hidden; }
.feat-media img{ width:100%; height:100%; object-fit:cover; filter: saturate(.78) contrast(1.08) brightness(.86); transition: transform 1.2s cubic-bezier(.2,.8,.2,1), filter .8s; }
.feat-media:hover img{ transform:scale(1.05); filter: saturate(1) contrast(1.08) brightness(.96); }
.feat-media::before{ content:""; position:absolute; inset:0; pointer-events:none; z-index:2; background: repeating-linear-gradient(0deg, rgba(76,210,255,.05) 0 2px, transparent 2px 5px); }
.feat-media .tag{ position:absolute; left:14px; top:14px; z-index:3; font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:var(--jedi); background:rgba(3,6,15,.7); border:1px solid var(--line); padding:6px 10px; }

/* — placeholder media — */
.ph-media{ position:relative; aspect-ratio:4/3; border:1px solid var(--line); overflow:hidden; background:
    repeating-linear-gradient(45deg, rgba(76,210,255,.05) 0 12px, transparent 12px 24px), var(--bg-2); display:flex; align-items:center; justify-content:center; }
.ph-media span{ font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-dim); text-align:center; padding:0 20px; }

/* — process steps — */
.steps{ display:grid; grid-template-columns: repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.step{ background:var(--bg-2); padding:32px 26px; position:relative; min-height:200px; }
.step .n{ font-family:'Orbitron',sans-serif; font-weight:900; font-size:46px; color:var(--jedi); opacity:.5; line-height:1; text-shadow:0 0 18px rgba(76,210,255,.35); }
.step h3{ font-family:'Orbitron',sans-serif; font-weight:700; font-size:17px; letter-spacing:.04em; text-transform:uppercase; margin:16px 0 10px; }
.step p{ font-size:13px; line-height:1.55; color:var(--ink-dim); }

/* — partner callout — */
.partner{ display:grid; grid-template-columns: 1fr 1.4fr; gap:50px; align-items:center; border:1px solid var(--line); background: linear-gradient(180deg, rgba(10,18,38,.8), rgba(3,6,15,.5)); padding:50px; position:relative; overflow:hidden; }
.partner::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background: linear-gradient(180deg, var(--green), var(--jedi)); box-shadow:0 0 20px var(--green); }
.partner .badge{ display:inline-flex; align-items:center; gap:8px; font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--green); border:1px solid rgba(109,255,179,.35); padding:7px 12px; margin-bottom:20px; background:rgba(109,255,179,.05); }
.partner .badge .pulse{ width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); }
.partner h3{ font-family:'Orbitron',sans-serif; font-weight:700; font-size: clamp(26px,3.4vw,38px); line-height:1.05; letter-spacing:.03em; text-transform:uppercase; margin-bottom:10px; }
.partner h3 em{ font-style:normal; color:var(--green); text-shadow:0 0 16px rgba(109,255,179,.45); }
.partner .role{ font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.partner p{ font-size:16px; line-height:1.65; color:var(--ink-dim); font-weight:300; margin-bottom:20px; max-width:54ch; }
.partner p em{ font-style:normal; color:var(--ink); }
.partner .ptags{ display:flex; flex-wrap:wrap; gap:8px; }
.partner .ptags span{ padding:7px 14px; border:1px solid rgba(109,255,179,.3); font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.14em; color:var(--green); text-transform:uppercase; background:rgba(109,255,179,.05); }

/* — counters — */
.counters{ display:grid; grid-template-columns: repeat(4, 1fr); gap:0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); position:relative; z-index:5; background: rgba(10,18,38,.4); }
.ct{ padding:60px 30px; border-left:1px solid var(--line); position:relative; }
.ct:first-child{ border-left:none; }
.ct .n{ font-family:'Orbitron',sans-serif; font-weight:900; font-size: clamp(54px, 7vw, 110px); line-height:1; color:var(--jedi); letter-spacing:-0.02em; text-shadow:0 0 24px rgba(76,210,255,.4); }
.ct .l{ margin-top:14px; font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--ink-dim); letter-spacing:.18em; text-transform:uppercase; }
.ct::before{ content:""; position:absolute; left:0; top:0; height:2px; width:0; background:var(--jedi); transition: width 1.5s; }
.ct.in::before{ width:100%; }

/* — gallery — */
.gal{ display:grid; grid-template-columns: repeat(12, 1fr); gap:14px; }
.gal .item{ position:relative; overflow:hidden; aspect-ratio: 4/5; border:1px solid var(--line); }
.gal .item.wide{ grid-column: span 7; aspect-ratio: 16/10; }
.gal .item.tall{ grid-column: span 5; }
.gal .item.med{ grid-column: span 4; aspect-ratio: 4/5; }
.gal .item.lrg{ grid-column: span 8; aspect-ratio: 16/10; }
.gal .item img{ width:100%; height:100%; object-fit:cover; transition: transform 1.2s cubic-bezier(.2,.8,.2,1), filter .8s; filter: saturate(.7) contrast(1.1) brightness(.85); }
.gal .item:hover img{ transform: scale(1.06); filter: saturate(1) contrast(1.1) brightness(.95); }
.gal .item .cap{ position:absolute; inset:auto 0 0 0; padding:14px 18px; background: linear-gradient(transparent, rgba(3,6,15,.92)); display:flex; justify-content:space-between; font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink); }
.gal .item .cap b{ font-weight:700; color:var(--jedi); }
.gal .item::before{ content:""; position:absolute; inset:0; border:1px solid transparent; transition: border-color .4s, box-shadow .4s; pointer-events:none; z-index:2; }
.gal .item:hover::before{ border-color: var(--jedi); box-shadow: inset 0 0 24px rgba(76,210,255,.3); }

/* — testimonials — */
.testi{ display:grid; grid-template-columns: repeat(3, 1fr); gap:20px; }
.testi .q{ padding:30px 26px; border:1px solid var(--line); background: linear-gradient(180deg, rgba(10,18,38,.8), rgba(3,6,15,.6)); position:relative; }
.testi .q::before{ content:""; position:absolute; top:-1px; left:-1px; right:-1px; height:2px; background: linear-gradient(90deg, transparent, var(--jedi), transparent); }
.testi .q .rate{ color:var(--gold); font-size:13px; letter-spacing:3px; margin-bottom:16px; text-shadow:0 0 8px var(--gold); }
.testi .q p{ font-family:'Inter',sans-serif; font-weight:300; font-size:16px; line-height:1.55; margin-bottom:22px; color:var(--ink); }
.testi .q footer{ display:flex; align-items:center; gap:12px; font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--ink-dim); letter-spacing:.1em; text-transform:uppercase; }
.testi .q footer .av{ width:36px; height:36px; border-radius:50%; background: linear-gradient(135deg, var(--jedi), var(--gold)); border:1px solid var(--jedi); box-shadow:0 0 12px rgba(76,210,255,.4); }
.testi .q footer b{ display:block; color:var(--jedi); font-weight:700; font-size:11px; }

/* — zone — */
.zone{ display:grid; grid-template-columns: 1fr 1.3fr; gap:50px; align-items:center; }
.zone .map{ position:relative; aspect-ratio: 1.2/1; background: radial-gradient(ellipse at 60% 45%, rgba(76,210,255,.15) 0%, transparent 60%), radial-gradient(circle at 30% 70%, rgba(255,226,122,.08) 0%, transparent 50%), var(--bg-2); border:1px solid var(--line); overflow:hidden; }
.zone .map svg{ width:100%; height:100%; }
.zone ul{ list-style:none; columns:2; gap:30px; }
.zone ul li{ padding:12px 0; border-bottom:1px solid var(--line-dim); font-family:'Orbitron',sans-serif; font-weight:500; font-size:18px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink); }
.zone ul li small{ display:block; font-family:'JetBrains Mono',monospace; font-size:9px; color:var(--ink-dim); letter-spacing:.2em; margin-top:4px; text-transform:uppercase; }
.zone ul li:hover{ color:var(--jedi); text-shadow:0 0 12px rgba(76,210,255,.5); }

/* — contact — */
.contact{ display:grid; grid-template-columns: 1fr 1fr; gap:60px; align-items:start; }
.contact-cta{ display:flex; flex-direction:column; gap:12px; }
.contact-cta a{ display:flex; align-items:center; justify-content:space-between; padding:24px 28px; border:1px solid var(--line); text-decoration:none; color:var(--ink); transition: all .4s cubic-bezier(.2,.9,.2,1); background: rgba(10,18,38,.5); position:relative; overflow:hidden; }
.contact-cta a::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--jedi); transition: width .4s; opacity:.1; }
.contact-cta a:hover{ border-color:var(--jedi); transform: translateX(6px); box-shadow: 0 0 30px rgba(76,210,255,.2); }
.contact-cta a:hover::before{ width:100%; }
.contact-cta a .left b{ display:block; font-family:'Orbitron',sans-serif; font-weight:700; font-size:22px; letter-spacing:.04em; }
.contact-cta a .left small{ display:block; font-family:'JetBrains Mono',monospace; font-size:10px; color:var(--gold); margin-bottom:4px; letter-spacing:.18em; text-transform:uppercase; }
.contact-cta a .arr{ font-size:20px; color:var(--jedi); transition: transform .5s; }
.contact-cta a:hover .arr{ transform: translateX(8px); }

form.devis{ display:flex; flex-direction:column; gap:16px; padding:28px; border:1px solid var(--line); background: rgba(10,18,38,.5); }
form.devis .row{ display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
form.devis label{ font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.18em; color:var(--gold); display:block; margin-bottom:8px; text-transform:uppercase; }
form.devis input, form.devis select, form.devis textarea{
  width:100%; background:transparent; border:none; border-bottom:1px solid var(--line);
  color:var(--ink); padding:8px 0; font-family:'JetBrains Mono',monospace; font-size:14px;
  transition: border-color .3s, box-shadow .3s; outline:none;
}
form.devis textarea{ resize:vertical; min-height:80px; }
form.devis input:focus, form.devis select:focus, form.devis textarea:focus{ border-color:var(--jedi); box-shadow: 0 1px 0 0 var(--jedi); }
form.devis option{ background:var(--bg-2); color:var(--ink); }
form.devis button{
  margin-top:10px; align-self:flex-start; padding:14px 30px;
  background: transparent; color:var(--jedi); border:1px solid var(--jedi);
  font-family:'Orbitron',sans-serif; font-weight:700; font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  cursor:pointer; transition: all .3s; position:relative; overflow:hidden;
}
form.devis button:hover{ background:var(--jedi); color:var(--bg); box-shadow:0 0 30px rgba(76,210,255,.5); }
form.devis .head{ font-family:'Orbitron',sans-serif; font-weight:700; font-size:22px; line-height:1.2; letter-spacing:.04em; text-transform:uppercase; margin-bottom:6px; color:var(--ink); }
form.devis .head em{ font-style:normal; color:var(--jedi); }
form.devis button:disabled{ cursor:default; opacity:.85; }
/* honeypot anti-spam : hors écran, jamais visible ni focusable visuellement */
.hp-field{ position:absolute !important; left:-9999px !important; top:auto; width:1px; height:1px; overflow:hidden; }
/* message de statut sous le bouton */
form.devis .form-status{ font-family:'JetBrains Mono',monospace; font-size:12px; letter-spacing:.04em; line-height:1.5; margin:0; min-height:0; transition: color .3s; }
form.devis .form-status:empty{ display:none; }
form.devis .form-status.sending{ color:var(--ink-dim); }
form.devis .form-status.ok{ color:var(--green); }
form.devis .form-status.error{ color:var(--sith); }

/* — FAQ — */
.faq{ max-width:920px; margin:0 auto; }
.faq details{ border-bottom:1px solid var(--line); padding:24px 0; }
.faq details:first-child{ border-top:1px solid var(--line); }
.faq summary{ font-family:'Orbitron',sans-serif; font-weight:500; font-size:20px; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; transition: color .3s; letter-spacing:.04em; text-transform:uppercase; }
.faq summary:hover{ color:var(--jedi); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .plus{ width:32px; height:32px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; transition: all .4s; flex:none; color:var(--jedi); }
.faq details[open] summary .plus{ background:var(--jedi); border-color:var(--jedi); color:var(--bg); transform:rotate(45deg); }
.faq details p{ margin-top:14px; color:var(--ink-dim); font-size:14px; line-height:1.6; max-width:65ch; }

/* — footer — */
footer.site{ padding:60px 32px 30px; border-top:1px solid var(--line); background:rgba(10,18,38,.6); position:relative; z-index:5; }
footer.site .row{ max-width:1480px; margin:0 auto; display:grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid var(--line-dim); }
footer.site h4{ font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.2em; color:var(--gold); margin-bottom:16px; text-transform:uppercase; }
footer.site .big{ font-family:'Orbitron',sans-serif; font-weight:900; font-size:42px; line-height:1; letter-spacing:.04em; text-transform:uppercase; }
footer.site .big em{ font-style:normal; color:var(--jedi); }
footer.site ul{ list-style:none; }
footer.site ul li{ padding:5px 0; }
footer.site ul a{ color:var(--ink); text-decoration:none; font-size:13px; font-family:'JetBrains Mono',monospace; letter-spacing:.06em; }
footer.site ul a:hover{ color:var(--jedi); }
footer.site .bot{ max-width:1480px; margin:0 auto; padding-top:20px; display:flex; justify-content:space-between; font-family:'JetBrains Mono',monospace; font-size:10px; color:var(--ink-dim); letter-spacing:.16em; text-transform:uppercase; }

/* — lightsaber divider — */
.saber-divider{ position:relative; z-index:5; padding:50px 32px; display:flex; justify-content:center; }
.saber-divider .saber-full{ position:relative; display:flex; align-items:center; width:100%; max-width:1200px; }
.saber-divider .hilt{ position:relative; flex:none; width:140px; height:38px; border-radius:4px; background: linear-gradient(180deg, #2a2f38 0%, #15181d 50%, #2a2f38 100%); border:1px solid #3a4150; box-shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 4px 12px rgba(0,0,0,.6); }
.saber-divider .hilt::before{ content:""; position:absolute; left:8px; top:50%; transform:translateY(-50%); width:118px; height:6px; background: repeating-linear-gradient(90deg, #3a4150 0 4px, #15181d 4px 8px); border-radius:2px; }
.saber-divider .hilt::after{ content:""; position:absolute; right:-2px; top:8px; bottom:8px; width:8px; background: linear-gradient(180deg, #6dffb3, #fff, #6dffb3); border-radius:2px; box-shadow: 0 0 14px var(--green); }
.saber-divider .blade{ position:relative; flex:1; height:22px; border-radius:11px; background: linear-gradient(90deg, #fff 0%, #eafff3 3%, var(--green) 16%, var(--green) 100%); box-shadow: 0 0 4px #fff, 0 0 9px rgba(255,255,255,.85), 0 0 20px var(--green), 0 0 38px var(--green), 0 0 70px rgba(109,255,179,.5); transform-origin: left center; animation: saber-ignite 1.6s cubic-bezier(.2,.9,.2,1) both, blade-hum 3s ease-in-out infinite 1.6s; }
/* white-hot inner core */
.saber-divider .blade::before{ content:""; position:absolute; inset:5px 6px 5px 0; border-radius:6px; background: linear-gradient(90deg, #fff 0%, rgba(255,255,255,.95) 10%, rgba(255,255,255,.55) 40%, rgba(255,255,255,.35) 100%); }
/* soft wide bloom */
.saber-divider .blade::after{ content:""; position:absolute; left:-4px; right:-6px; top:50%; transform:translateY(-50%); height:56px; border-radius:50%; background: radial-gradient(ellipse 100% 50% at 50% 50%, rgba(109,255,179,.4), rgba(109,255,179,0) 72%); filter: blur(9px); pointer-events:none; z-index:-1; }
@keyframes saber-ignite{ 0%{ transform: scaleX(0); opacity:0; } 20%{ opacity:1; } 100%{ transform: scaleX(1); opacity:1; } }
@keyframes blade-hum{ 0%,100%{ box-shadow: 0 0 4px #fff, 0 0 9px rgba(255,255,255,.85), 0 0 20px var(--green), 0 0 38px var(--green), 0 0 70px rgba(109,255,179,.5); } 48%{ box-shadow: 0 0 5px #fff, 0 0 12px rgba(255,255,255,.95), 0 0 26px var(--green), 0 0 48px var(--green), 0 0 88px rgba(109,255,179,.65); } 52%{ box-shadow: 0 0 3px #fff, 0 0 8px rgba(255,255,255,.8), 0 0 18px var(--green), 0 0 34px var(--green), 0 0 62px rgba(109,255,179,.45); } }
.saber-divider .saber-label{ position:absolute; left:50%; top:-26px; transform:translateX(-50%); font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:.3em; color:var(--green); text-transform:uppercase; text-shadow: 0 0 10px var(--green); }

@media (max-width: 980px){
  nav.top{ padding:12px 16px; }
  nav.top .logo{ position:relative; z-index:101; }
  .nav-toggle{ display:flex; position:relative; z-index:101; }
  nav.top .cta{ display:none; }
  nav.top ul{
    position:fixed; left:0; right:0; top:0; align-items:stretch;
    flex-direction:column; gap:0; margin:0; padding:76px 22px 26px;
    background:rgba(3,6,15,.98); -webkit-backdrop-filter:blur(16px); backdrop-filter:blur(16px);
    border-bottom:1px solid var(--line); box-shadow:0 30px 60px rgba(0,0,0,.6);
    transform:translateY(-105%); transition:transform .38s cubic-bezier(.4,0,.2,1); z-index:99;
  }
  nav.top.nav-open ul{ transform:translateY(0); }
  nav.top ul li{ width:100%; }
  nav.top ul a{ display:block; padding:17px 4px; font-size:14px; letter-spacing:.16em; border-bottom:1px solid var(--line-dim); }
  nav.top ul a.active::after{ display:none; }
  body.nav-open{ overflow:hidden; }
  .hero{ padding:100px 18px 50px; }
  .hero .meta{ flex-direction:column; align-items:flex-start; gap:8px; }
  .hero h1{ font-size:clamp(34px, 8.5vw, 62px); margin:26px 0 22px; }
  .hero h1 .word, .hero h1 .word span{ display:inline; overflow:visible; }
  .hero .sub{ font-size:12px; }
  .page-hero h1{ font-size:clamp(34px, 9vw, 60px); }
  .hero .lower{ grid-template-columns: 1fr; gap:24px; }
  .page-hero{ padding:120px 18px 50px; min-height:auto; }
  .planet, .planet-ring, .twin-sun{ display:none; }
  section.s{ padding:80px 18px; }
  .s-head{ grid-template-columns: 1fr; gap:14px; margin-bottom:40px; }
  .about{ grid-template-columns: 1fr; gap:30px; }
  .services{ grid-template-columns: 1fr; }
  .feat, .feat.flip{ grid-template-columns: 1fr; gap:28px; }
  .feat.flip .feat-media{ order:0; }
  .steps{ grid-template-columns: 1fr 1fr; }
  .partner{ grid-template-columns: 1fr; gap:28px; padding:30px; }
  .counters{ grid-template-columns: repeat(2,1fr); }
  .ct{ padding:40px 20px; }
  .ct:nth-child(2){ border-left:1px solid var(--line); }
  .ct:nth-child(3), .ct:nth-child(4){ border-top:1px solid var(--line); }
  .ct:nth-child(3){ border-left:none; }
  .gal{ grid-template-columns: repeat(2,1fr); gap:8px; }
  .gal .item, .gal .item.wide, .gal .item.tall, .gal .item.med, .gal .item.lrg{ grid-column: span 2; aspect-ratio:4/3; }
  .testi{ grid-template-columns: 1fr; }
  .zone{ grid-template-columns: 1fr; }
  .contact{ grid-template-columns: 1fr; gap:30px; }
  footer.site .row{ grid-template-columns: 1fr 1fr; gap:24px; }
  footer.site .big{ font-size:28px; }
  .marquee span{ font-size:24px; }
}

/* — lightbox (agrandissement des photos) — */
.zoomable{ cursor: zoom-in; }
.lb{ position:fixed; inset:0; z-index:2000; display:none; align-items:center; justify-content:center;
  background:rgba(3,6,15,.93); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.lb.open{ display:flex; }
.lb img{ max-width:92vw; max-height:84vh; border-radius:6px; box-shadow:0 30px 90px rgba(0,0,0,.65);
  border:1px solid rgba(76,210,255,.28); }
.lb .lb-cap{ position:absolute; bottom:22px; left:0; right:0; text-align:center; color:#e9eefb;
  font-family:'JetBrains Mono',monospace; font-size:13px; letter-spacing:.08em; text-transform:uppercase; padding:0 16px; }
.lb .lb-cap b{ color:#4cd2ff; font-weight:500; }
.lb button{ position:absolute; background:rgba(233,238,251,.08); border:1px solid rgba(76,210,255,.32);
  color:#e9eefb; width:54px; height:54px; border-radius:50%; font-size:26px; line-height:1; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:all .25s; }
.lb button:hover{ background:#4cd2ff; color:#03060f; border-color:#4cd2ff; transform:scale(1.06); }
.lb .lb-close{ top:22px; right:22px; }
.lb .lb-prev{ left:22px; top:50%; transform:translateY(-50%); }
.lb .lb-next{ right:22px; top:50%; transform:translateY(-50%); }
.lb .lb-prev:hover, .lb .lb-next:hover{ transform:translateY(-50%) scale(1.06); }
@media (max-width:640px){
  .lb button{ width:44px; height:44px; font-size:22px; }
  .lb .lb-prev{ left:10px; } .lb .lb-next{ right:10px; }
  .lb img{ max-width:96vw; }
}

/* — images responsives (le <picture> ne doit pas casser la mise en page) — */
picture{ display:contents; }

/* — accessibilite : lien d'evitement — */
.skip-link{ position:fixed; top:-120px; left:12px; z-index:3000; background:var(--jedi); color:#03060f;
  padding:10px 16px; border-radius:6px; font-family:'JetBrains Mono',monospace; font-size:13px; font-weight:600;
  text-decoration:none; transition:top .2s; }
.skip-link:focus{ top:12px; }

/* — accessibilite : focus clavier visible — */
:focus-visible{ outline:2px solid var(--jedi); outline-offset:2px; }
form.devis input:focus-visible, form.devis select:focus-visible, form.devis textarea:focus-visible{
  outline:2px solid var(--jedi); outline-offset:2px; }

/* — accessibilite : respect de prefers-reduced-motion — */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}
