<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, viewport-fit=cover">
<meta name="theme-color" content="#050506">
<title>HALO — One stomp. Total light.</title>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;1,9..144,300&family=Hanken+Grotesk:wght@400;500;600;700&family=Geist+Mono:wght@400;500&display=swap" rel="stylesheet">
<style>
/* ============================================================
HALO — landing standalone · Dark cinematic
============================================================ */
:root{
/* Palette WALNUT — inspirée du produit : noyer chaud, crème, ambre, étincelle cyan */
--ink:#0c0907; /* brun-noir chaud (le boîtier) */
--ink-2:#161009; /* panneau sombre chaud */
--ink-3:#1f1710; /* relief */
--paper:#f3e8d6; /* crème chaude (texte) */
--mute:#b3a48f; /* taupe clair */
--mute-2:#7c6c58; /* taupe sombre */
--line:rgba(243,232,214,.10);
--line-2:rgba(243,232,214,.20);
--wood:#7a4f2c; /* noyer */
--wood-2:#b9824e; /* caramel */
--glow:#e8a64a; /* AMBRE — accent identité (lueur du bois) */
--glow-soft:#ffcf86; /* ambre clair pour halos */
--spark:#46d3c1; /* cyan de l'écran LCD — étincelle rare */
--max:1240px;
--ease:cubic-bezier(.2,.6,0,1);
--font-display:'Fraunces','Times New Roman',serif;
--font-body:'Hanken Grotesk',system-ui,sans-serif;
--font-mono:'Geist Mono',ui-monospace,monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
background:var(--ink);
color:var(--paper);
font-family:var(--font-body);
font-size:16px;
line-height:1.6;
-webkit-font-smoothing:antialiased;
overflow-x:hidden;
}
::selection{background:var(--glow);color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
/* ---- type ---- */
.kicker{
font-family:var(--font-mono);
font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);
}
h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.02;letter-spacing:-.01em;
font-variation-settings:'opsz' 144,'SOFT' 0,'WONK' 0}
.display{font-size:clamp(40px,10.5vw,200px);font-weight:300;letter-spacing:-.02em;line-height:.92;
font-variation-settings:'opsz' 144,'SOFT' 0,'WONK' 0;overflow-wrap:break-word;text-wrap:balance}
.h-xl{font-size:clamp(42px,6.2vw,86px);font-weight:400;letter-spacing:-.015em}
.h-lg{font-size:clamp(30px,4vw,52px);font-weight:400;letter-spacing:-.01em}
.lead{font-size:clamp(18px,2.2vw,24px);line-height:1.55;color:var(--mute);max-width:60ch;font-family:var(--font-body)}
.mono{font-family:var(--font-mono)}
.accent-c{color:var(--glow)}
/* ---- layout ---- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
section{position:relative}
.section-pad{padding:clamp(80px,14vh,180px) 0}
/* ---- buttons ---- */
.btn{
display:inline-flex;align-items:center;gap:10px;
font-family:var(--font-body);font-weight:600;font-size:15px;
padding:15px 26px;border:1px solid var(--line-2);border-radius:2px;
transition:all .25s var(--ease);cursor:pointer;background:transparent;color:var(--paper);
}
.btn:hover{border-color:var(--paper);transform:translateY(-2px)}
.btn--solid{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn--solid:hover{background:var(--glow);border-color:var(--glow)}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
/* ============================================================
NAV
============================================================ */
.nav{
position:fixed;top:0;left:0;right:0;z-index:100;
display:flex;align-items:center;justify-content:space-between;
padding:18px 28px;
transition:background .3s var(--ease),border-color .3s var(--ease),backdrop-filter .3s;
border-bottom:1px solid transparent;
}
.nav.scrolled{
background:rgba(12,9,7,.72);backdrop-filter:blur(14px);border-bottom-color:var(--line);
}
.nav__brand{font-family:var(--font-display);font-weight:400;font-size:25px;letter-spacing:.06em}
.nav__brand .dot{color:var(--glow)}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-size:14px;color:var(--mute);transition:color .2s}
.nav__links a:hover{color:var(--paper)}
.nav__cta{padding:10px 18px;border:1px solid var(--line-2);border-radius:2px;color:var(--paper)!important;transition:all .2s}
.nav__cta:hover{background:var(--paper);color:var(--ink)!important}
.lang{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;color:var(--mute-2);border:1px solid var(--line-2);padding:7px 12px;border-radius:100px;cursor:pointer;transition:border-color .2s}
.lang:hover{border-color:var(--paper)}
.lang__sep{opacity:.35}
.lang [data-lang]{transition:color .2s}
html[lang="en"] .lang [data-lang="en"],html[lang="fr"] .lang [data-lang="fr"]{color:var(--glow)}
@media(max-width:760px){.nav__links a:not(.nav__cta){display:none}}
/* ============================================================
HERO
============================================================ */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:104px 0 56px;overflow:hidden}
/* radial halo light behind product */
.hero__halo{
position:absolute;top:50%;left:50%;transform:translate(-50%,-42%);
width:min(120vw,1100px);height:min(120vw,1100px);border-radius:50%;
background:
radial-gradient(circle, rgba(232,166,74,.26) 0%, rgba(232,166,74,.09) 32%, transparent 64%);
z-index:0;pointer-events:none;
filter:blur(8px);
}
/* faint spectrum ring (the only "color" = light) */
.hero__ring{
position:absolute;top:50%;left:50%;transform:translate(-50%,-42%);
width:min(86vw,720px);height:min(86vw,720px);border-radius:50%;
background:conic-gradient(from 0deg,
#ff5a3c,#ffb03a,#ffe24a,#5bd66a,#3ab6ff,#6a6dff,#ff5ad0,#ff5a3c);
filter:blur(60px);opacity:.16;z-index:0;pointer-events:none;
}
.hero__inner{position:relative;z-index:2;text-align:center}
.hero .kicker{margin-bottom:28px}
.hero__title{margin:0 auto}
.hero__sub{margin:30px auto 0;font-size:clamp(16px,2.4vw,22px);color:var(--mute);max-width:48ch}
.hero__cta{margin-top:40px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero__scroll{position:relative;z-index:2;margin:46px auto 0;font-family:var(--font-mono);font-size:11px;letter-spacing:.3em;color:var(--mute-2);text-transform:uppercase}
@media(max-height:760px){.hero__scroll{display:none}}
/* product visual */
.product{position:relative;z-index:1}
/* ============================================================
ARTISTS CAROUSEL
============================================================ */
.artists{padding:clamp(70px,11vh,130px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.artists .wrap{margin-bottom:46px}
.artists__viewport{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.artists__track{display:flex;gap:20px;width:max-content;animation:artists-roll 36s linear infinite}
.artists:hover .artists__track{animation-play-state:paused}
@keyframes artists-roll{to{transform:translateX(-50%)}}
.artist{display:flex;align-items:center;gap:16px;padding:16px 22px 16px 16px;border:1px solid var(--line);border-radius:100px;background:var(--ink-2);flex:0 0 auto;transition:border-color .3s var(--ease),transform .3s var(--ease)}
.artist:hover{border-color:var(--line-2);transform:translateY(-3px)}
.artist__av{width:48px;height:48px;border-radius:50%;flex:0 0 auto;background:conic-gradient(from 140deg,var(--c1),var(--c2),var(--c1));box-shadow:0 0 18px -4px var(--c2)}
.artist__meta{display:flex;flex-direction:column;line-height:1.3}
.artist__meta b{font-family:var(--font-body);font-weight:600;font-size:14px;letter-spacing:.02em;white-space:nowrap}
.artist__meta span{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute-2)}
@media(prefers-reduced-motion:reduce){.artists__track{animation:none;flex-wrap:wrap;justify-content:center}}
/* ============================================================
MANIFESTO
============================================================ */
.manifesto .big{font-family:var(--font-display);font-weight:300;font-size:clamp(30px,5.2vw,70px);line-height:1.08;letter-spacing:-.015em;max-width:20ch;font-variation-settings:'opsz' 144,'WONK' 0}
.manifesto .big .em{color:var(--glow)}
.manifesto .muted-line{color:var(--mute-2)}
/* ============================================================
FEATURES
============================================================ */
.features__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:60px}
.feature{background:var(--ink);padding:40px 32px;min-height:260px;display:flex;flex-direction:column;transition:background .3s var(--ease)}
.feature:hover{background:var(--ink-2)}
.feature__no{font-family:var(--font-mono);font-size:12px;color:var(--mute-2);letter-spacing:.2em}
.feature__icon{font-size:26px;margin:10px 0 22px;color:var(--glow)}
.feature h3{font-size:23px;font-weight:500;margin-bottom:12px;letter-spacing:-.01em}
.feature p{color:var(--mute);font-size:15px}
@media(max-width:900px){.features__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.features__grid{grid-template-columns:1fr}}
/* ============================================================
HOW
============================================================ */
.how__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:60px}
.step{border-top:1px solid var(--line-2);padding-top:24px}
.step__n{font-family:var(--font-display);font-weight:400;font-size:60px;color:transparent;-webkit-text-stroke:1px var(--mute-2);line-height:1}
.step h3{font-size:22px;margin:18px 0 10px}
.step p{color:var(--mute);font-size:15px}
@media(max-width:760px){.how__grid{grid-template-columns:1fr;gap:32px}}
/* ============================================================
APP tie-in
============================================================ */
.app{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.app__copy h2{margin-bottom:20px}
.app__list{margin-top:26px;display:flex;flex-direction:column;gap:14px}
.app__list li{list-style:none;display:flex;gap:12px;color:var(--mute);font-size:15px}
.app__list .tick{color:var(--glow);font-family:var(--font-mono)}
@media(max-width:860px){.app{grid-template-columns:1fr;gap:36px}}
/* ============================================================
SPECS
============================================================ */
.specs__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line-2);margin-top:50px}
.spec{display:flex;justify-content:space-between;gap:20px;padding:20px 0;border-bottom:1px solid var(--line)}
.spec dt{font-family:var(--font-mono);font-size:13px;letter-spacing:.06em;color:var(--mute);text-transform:uppercase}
.spec dd{font-family:var(--font-mono);font-size:14px;color:var(--paper);text-align:right}
@media(min-width:720px){.specs__grid{column-gap:64px}.specs__grid .spec:nth-child(odd){padding-right:32px}}
@media(max-width:720px){.specs__grid{grid-template-columns:1fr}}
/* ============================================================
CTA / pre-order
============================================================ */
.cta{text-align:center;position:relative;overflow:hidden}
.cta__halo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(90vw,800px);height:420px;border-radius:50%;background:radial-gradient(ellipse,rgba(232,166,74,.18),transparent 65%);filter:blur(20px);pointer-events:none}
.cta__inner{position:relative;z-index:2}
.cta h2{margin-bottom:18px}
.cta .price{font-family:var(--font-mono);color:var(--mute);margin:26px 0 6px;font-size:14px;letter-spacing:.1em}
.cta .price b{color:var(--paper);font-size:30px;font-weight:600}
/* ============================================================
FOOTER
============================================================ */
.footer{border-top:1px solid var(--line);padding:50px 0 60px}
.footer__row{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.footer__brand{font-family:var(--font-display);font-weight:300;font-size:50px;letter-spacing:.05em}
.footer__brand .dot{color:var(--glow)}
.footer small{color:var(--mute-2);font-family:var(--font-mono);font-size:12px;letter-spacing:.05em}
.footer__links{display:flex;gap:24px}
.footer__links a{color:var(--mute);font-size:14px}
.footer__links a:hover{color:var(--paper)}
/* ============================================================
PRODUCT SHOTS (images embarquées via classes, dédupliquées)
============================================================ */
.shot{background-size:cover;background-position:center;background-repeat:no-repeat;background-color:#0a0a0b}
.shot-max{background-image:url(img/shot-max.jpg)}
.shot-mini{background-image:url(img/shot-mini.jpg)}
/* hero product shot */
.product.shot{
width:min(820px,92vw);aspect-ratio:16/9;margin:52px auto 0;border-radius:12px;
border:1px solid rgba(255,255,255,.07);
box-shadow:0 60px 130px -40px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.05);
}
/* ============================================================
MODELS
============================================================ */
.models__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:60px}
.model{border:1px solid var(--line);background:var(--ink-2);border-radius:10px;overflow:hidden;transition:border-color .3s var(--ease),transform .3s var(--ease)}
.model:hover{border-color:var(--line-2);transform:translateY(-4px)}
.model__shot{width:100%;aspect-ratio:16/10}
.model__body{padding:28px 28px 32px}
.model__head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:14px}
.model__head h3{font-size:30px;font-weight:400;letter-spacing:.02em}
.model__head .accent{color:var(--glow)}
.model__tag{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--mute-2);border:1px solid var(--line-2);padding:4px 10px;border-radius:2px}
.model__body p{color:var(--mute);font-size:15px}
.model__specs{list-style:none;margin-top:22px;border-top:1px solid var(--line)}
.model__specs li{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line);font-family:var(--font-mono);font-size:13px}
.model__specs span{color:var(--mute)}
.model__specs b{color:var(--paper);font-weight:500}
@media(max-width:780px){.models__grid{grid-template-columns:1fr;gap:18px}}
/* ============================================================
APP MOCK (faux UI, pas d'image externe)
============================================================ */
.appmock{border:1px solid var(--line-2);border-radius:10px;overflow:hidden;background:#0b0b0d;box-shadow:0 40px 90px -40px rgba(0,0,0,.85)}
.appmock__bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line);background:#0e0e10}
.appmock__bar .dot{width:9px;height:9px;border-radius:50%;background:#2a2a2e}
.appmock__url{margin-left:12px;color:var(--mute-2);font-size:12px}
.appmock__body{padding:26px}
.appmock__k{font-size:11px;letter-spacing:.24em;color:var(--mute-2)}
.appmock__name{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,4vw,44px);letter-spacing:-.015em;margin:6px 0 14px}
.appmock__sw{display:flex;align-items:center;gap:10px}
.appmock__sw i{width:30px;height:30px;border-radius:4px;border:1px solid rgba(255,255,255,.12)}
.appmock__sw .mono{color:var(--glow);font-size:13px;margin-left:4px}
.appmock__vars{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin:24px 0}
.appmock__vars span{text-align:center;padding:12px 0;border:1px solid var(--line);font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;color:var(--mute)}
.appmock__vars .on{background:var(--glow);color:var(--ink);border-color:var(--glow);font-weight:600}
.appmock__masters{display:flex;flex-direction:column;gap:12px}
.appmock__row{display:grid;grid-template-columns:60px 1fr 34px;align-items:center;gap:12px}
.appmock__row .mono{font-size:12px;color:var(--mute)}
.appmock__row i{height:6px;background:var(--ink-3);border:1px solid var(--line);display:block}
.appmock__row b{display:block;height:100%;background:var(--glow)}
.appmock__row .mono:last-child{text-align:right;color:var(--paper)}
/* ============================================================
INTRO / LOGO REVEAL (preloader)
============================================================ */
.pre{
position:fixed;inset:0;z-index:9999;background:radial-gradient(circle at 50% 42%,#140d07,var(--ink) 70%);
display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
transition:opacity 1s var(--ease),visibility 1s var(--ease),transform 1.2s var(--ease);
}
.pre.done{opacity:0;visibility:hidden;transform:scale(1.08)}
/* ----- THE HALO ----- */
.halo{position:relative;width:min(56vw,260px);aspect-ratio:1}
.halo__svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.halo__track{stroke:rgba(243,232,214,.06);stroke-width:1}
.halo__draw{
stroke:url(#hg);stroke-width:3;stroke-linecap:round;
stroke-dasharray:540;stroke-dashoffset:540;transform:rotate(-90deg);transform-origin:center;
filter:drop-shadow(0 0 9px rgba(255,240,210,.85));
animation:halo-draw 1.3s var(--ease) .15s forwards, halo-draw-fade .8s ease 1.55s forwards;
}
@keyframes halo-draw{to{stroke-dashoffset:0}}
@keyframes halo-draw-fade{to{opacity:.28}}
/* spectre de couleur (la lumière) qui éclôt puis vit */
.halo__spectrum{
position:absolute;inset:0;border-radius:50%;
background:conic-gradient(from -90deg,#ff5a3c,#ffb03a,#ffe24a,#5bd66a,#3ab6ff,#6a6dff,#ff5ad0,#ff5a3c);
-webkit-mask:radial-gradient(circle, transparent 73%, #000 75%, #000 82%, transparent 84%);
mask:radial-gradient(circle, transparent 73%, #000 75%, #000 82%, transparent 84%);
opacity:0;filter:saturate(1.15);
animation:spec-in 1s var(--ease) 1s forwards, spec-spin 14s linear 1.1s infinite;
}
@keyframes spec-in{to{opacity:.95}}
@keyframes spec-spin{to{transform:rotate(360deg)}}
/* comète : tête lumineuse qui trace l'anneau */
.halo__comet-wrap{position:absolute;inset:0;animation:halo-trace 1.3s var(--ease) .15s forwards}
@keyframes halo-trace{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.halo__comet{
position:absolute;top:7%;left:50%;width:15px;height:15px;margin-left:-7.5px;border-radius:50%;
background:radial-gradient(circle,#fff,#ffe9c2 42%,rgba(232,166,74,0) 72%);
box-shadow:0 0 18px 6px rgba(255,236,194,.95),0 0 44px 14px rgba(232,166,74,.5);
opacity:0;animation:comet-on .2s ease .15s forwards, comet-off .45s ease 1.5s forwards;
}
@keyframes comet-on{to{opacity:1}}
@keyframes comet-off{to{opacity:0}}
/* bloom : éclat au moment où l'anneau se referme, puis lueur stable */
.halo__bloom{
position:absolute;inset:-25%;border-radius:50%;pointer-events:none;opacity:0;
background:radial-gradient(circle,rgba(255,236,194,.5),rgba(232,166,74,.12) 35%,transparent 62%);
animation:bloom-flash 1.4s var(--ease) 1.35s forwards;
}
@keyframes bloom-flash{0%{opacity:0;transform:scale(.7)}30%{opacity:1;transform:scale(1.05)}100%{opacity:.5;transform:scale(1)}}
/* ----- wordmark ----- */
.pre__word{position:relative;display:flex;gap:.04em;font-family:var(--font-display);font-weight:300;font-size:clamp(46px,10vw,76px);letter-spacing:.06em;color:var(--paper);font-variation-settings:'opsz' 144,'WONK' 0}
.pre__word span{display:inline-block;opacity:0;transform:translateY(26px) rotate(5deg);animation:pre-letter .7s var(--ease) forwards}
.pre__word span:nth-child(1){animation-delay:1.6s}
.pre__word span:nth-child(2){animation-delay:1.72s}
.pre__word span:nth-child(3){animation-delay:1.84s}
.pre__word span:nth-child(4){animation-delay:1.96s}
@keyframes pre-letter{to{opacity:1;transform:none}}
.pre__sweep{position:absolute;inset:0;background:linear-gradient(100deg,transparent 30%,rgba(255,243,218,.85) 50%,transparent 70%);
mix-blend-mode:overlay;transform:translateX(-120%);animation:pre-sweep 1.1s var(--ease) 2.1s forwards;pointer-events:none}
@keyframes pre-sweep{to{transform:translateX(120%)}}
.pre__tag{font-family:var(--font-mono);font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--mute-2);
opacity:0;animation:pre-fade .9s var(--ease) 2.2s forwards}
@keyframes pre-fade{to{opacity:1}}
/* ----- bouton ENTER (apparait quand le logo est construit) ----- */
.pre__enter{
position:relative;display:inline-flex;align-items:center;gap:12px;margin-top:8px;
padding:15px 34px;border:1px solid var(--line-2);border-radius:100px;background:transparent;
color:var(--paper);font-family:var(--font-body);font-weight:600;font-size:13px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;
opacity:0;transform:translateY(16px);pointer-events:none;
transition:opacity .7s var(--ease),transform .7s var(--ease),border-color .3s,background .3s,color .3s;
}
.pre.is-built .pre__enter{opacity:1;transform:none;pointer-events:auto}
.pre__enter:hover{border-color:var(--glow);color:var(--glow);background:rgba(232,166,74,.07)}
.pre__enter-ring{width:9px;height:9px;border-radius:50%;border:1px solid var(--glow);box-shadow:0 0 10px var(--glow);animation:enter-pulse 2s ease-in-out infinite}
@keyframes enter-pulse{0%,100%{box-shadow:0 0 6px var(--glow)}50%{box-shadow:0 0 16px var(--glow)}}
/* scroll lock pendant l'intro */
body.loading{overflow:hidden;height:100vh}
/* ============================================================
ENTRANCE (après l'intro) + vie ambiante
============================================================ */
/* le hero entre quand body.ready */
.hero .kicker,.hero__title,.hero__sub,.hero__cta,.product{opacity:0;transform:translateY(30px)}
body.ready .hero .kicker{animation:up .9s var(--ease) .05s forwards}
body.ready .hero__title{animation:up 1s var(--ease) .18s forwards}
body.ready .hero__sub{animation:up .9s var(--ease) .42s forwards}
body.ready .hero__cta{animation:up .9s var(--ease) .58s forwards}
body.ready .product{animation:up 1.1s var(--ease) .7s forwards}
@keyframes up{to{opacity:1;transform:none}}
/* halo + ring qui vivent en continu */
.hero__ring{animation:halo-spin 48s linear infinite}
.hero__halo{animation:halo-breath 7s ease-in-out infinite}
@keyframes halo-spin{to{transform:translate(-50%,-42%) rotate(360deg)}}
@keyframes halo-breath{0%,100%{opacity:.85;transform:translate(-50%,-42%) scale(1)}50%{opacity:1;transform:translate(-50%,-42%) scale(1.05)}}
/* produit qui flotte doucement */
body.ready .product.shot{animation:up 1.1s var(--ease) .7s forwards, float 8s ease-in-out 1.8s infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
/* lueur CTA qui pulse */
.cta__halo{animation:cta-pulse 6s ease-in-out infinite}
@keyframes cta-pulse{0%,100%{opacity:.7;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}
@media(prefers-reduced-motion:reduce){
.halo__draw,.halo__spectrum,.halo__comet-wrap,.halo__comet,.halo__bloom,
.pre__word span,.pre__sweep,.pre__tag,
.hero .kicker,.hero__title,.hero__sub,.hero__cta,.product,
.hero__ring,.hero__halo,.product.shot,.cta__halo,.pre__enter-ring{animation:none!important;opacity:1!important;transform:none!important}
.halo__draw{stroke-dashoffset:0!important}
.halo__spectrum{opacity:.95!important}
}
/* ============================================================
Reveal on scroll
============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}
</style>
</head>
<body>
<!-- ============ INTRO / LOGO REVEAL — THE HALO IGNITES ============ -->
<div id="preloader" class="pre" role="presentation">
<div class="halo">
<div class="halo__bloom"></div>
<div class="halo__spectrum"></div>
<svg class="halo__svg" viewbox="0 0 220 220" aria-hidden="true">
<circle class="halo__track" cx="110" cy="110" r="86" fill="none"/>
<circle class="halo__draw" cx="110" cy="110" r="86" fill="none"/>
<defs>
<lineargradient id="hg" x1="0" y1="0" x2="1" y2="1">
<stop offset="0" stop-color="#ffd98a"/><stop offset=".5" stop-color="#ffffff"/><stop offset="1" stop-color="#e8a64a"/>
</lineargradient>
</defs>
</svg>
<div class="halo__comet-wrap"><i class="halo__comet"></i></div>
</div>
<div class="pre__word" aria-label="HALO">
<span>H</span><span>A</span><span>L</span><span>O</span>
<i class="pre__sweep"></i>
</div>
<p class="pre__tag" data-i18n="tagline">One stomp. Total light.</p>
<button class="pre__enter" id="enterBtn" type="button">
<span class="pre__enter-ring"></span>
<span class="pre__enter-label" data-i18n="enter">Enter</span>
</button>
</div>
<!-- ============ NAV ============ -->
<nav class="nav" id="nav">
<a href="#top" class="nav__brand">HALO<span class="dot">.</span></a>
<div class="nav__links">
<a href="#features" data-i18n="nav.features">Features</a>
<a href="#how" data-i18n="nav.how">How it works</a>
<a href="#app" data-i18n="nav.app">App</a>
<a href="#specs" data-i18n="nav.specs">Specs</a>
<a href="#preorder" class="nav__cta" data-i18n="nav.preorder">Pre-order</a>
<button class="lang" id="langBtn" type="button" aria-label="Language / Langue">
<span data-lang="fr">FR</span><span class="lang__sep">/</span><span data-lang="en">EN</span>
</button>
</div>
</nav>
<!-- ============ HERO ============ -->
<header class="hero" id="top">
<div class="hero__ring"></div>
<div class="hero__halo"></div>
<div class="wrap hero__inner">
<p class="kicker" data-i18n="hero.kicker">The lighting pedal for musicians</p>
<h1 class="display hero__title" data-i18n="hero.title">ONE STOMP.<br>TOTAL LIGHT.</h1>
<p class="hero__sub" data-i18n="hero.sub">HALO turns your entire stage light show into a stompbox. Design once. Perform with your foot. No engineer. No laptop.</p>
<div class="hero__cta">
<a href="#preorder" class="btn btn--solid"><span data-i18n="hero.cta1">Pre-order</span> <span class="arr">→</span></a>
<a href="#how" class="btn" data-i18n="hero.cta2">See how it works</a>
</div>
<div class="product shot shot-max" role="img" aria-label="HALO MAX — premium lighting pedal"></div>
</div>
<div class="hero__scroll" data-i18n="hero.scroll">Scroll ↓</div>
</header>
<!-- ============ ARTISTS CAROUSEL ============ -->
<section class="artists" id="artists">
<div class="wrap reveal">
<p class="kicker" style="margin-bottom:16px" data-i18n="artists.kicker">On stage with</p>
<h2 class="h-lg" data-i18n="artists.title">Built for people who play.</h2>
</div>
<div class="artists__viewport">
<div class="artists__track">
<article class="artist"><div class="artist__av" style="--c1:#1763d4;--c2:#0bd1d1"></div><div class="artist__meta"><b>AURÉLIE NOX</b><span>indie · electro</span></div></article>
<article class="artist"><div class="artist__av" style="--c1:#cc1f1f;--c2:#ff8a00"></div><div class="artist__meta"><b>MIDNIGHT VOLTAGE</b><span>rock</span></div></article>
<article class="artist"><div class="artist__av" style="--c1:#16a34a;--c2:#0bd1d1"></div><div class="artist__meta"><b>NOVA & THE GLOW</b><span>pop · live</span></div></article>
<article class="artist"><div class="artist__av" style="--c1:#ff5ad0;--c2:#6a6dff"></div><div class="artist__meta"><b>KASHMIR LATELY</b><span>synthwave</span></div></article>
<article class="artist"><div class="artist__av" style="--c1:#ffe24a;--c2:#ff5a3c"></div><div class="artist__meta"><b>ÉCHO PARADE</b><span>worship</span></div></article>
<article class="artist"><div class="artist__av" style="--c1:#3ab6ff;--c2:#6a6dff"></div><div class="artist__meta"><b>RÉMI VANTA</b><span>DJ · techno</span></div></article>
<!-- duplicate pour boucle continue -->
<article class="artist" aria-hidden="true"><div class="artist__av" style="--c1:#1763d4;--c2:#0bd1d1"></div><div class="artist__meta"><b>AURÉLIE NOX</b><span>indie · electro</span></div></article>
<article class="artist" aria-hidden="true"><div class="artist__av" style="--c1:#cc1f1f;--c2:#ff8a00"></div><div class="artist__meta"><b>MIDNIGHT VOLTAGE</b><span>rock</span></div></article>
<article class="artist" aria-hidden="true"><div class="artist__av" style="--c1:#16a34a;--c2:#0bd1d1"></div><div class="artist__meta"><b>NOVA & THE GLOW</b><span>pop · live</span></div></article>
<article class="artist" aria-hidden="true"><div class="artist__av" style="--c1:#ff5ad0;--c2:#6a6dff"></div><div class="artist__meta"><b>KASHMIR LATELY</b><span>synthwave</span></div></article>
<article class="artist" aria-hidden="true"><div class="artist__av" style="--c1:#ffe24a;--c2:#ff5a3c"></div><div class="artist__meta"><b>ÉCHO PARADE</b><span>worship</span></div></article>
<article class="artist" aria-hidden="true"><div class="artist__av" style="--c1:#3ab6ff;--c2:#6a6dff"></div><div class="artist__meta"><b>RÉMI VANTA</b><span>DJ · techno</span></div></article>
</div>
</div>
</section>
<!-- ============ MANIFESTO ============ -->
<section class="section-pad manifesto">
<div class="wrap reveal">
<p class="kicker" style="margin-bottom:32px" data-i18n="manifesto.kicker">Manifesto</p>
<p class="big" data-i18n="manifesto.big">You don't need a lighting engineer.<br><span class="muted-line">You need</span> <span class="em">a pedal.</span></p>
<p class="lead" style="margin-top:34px" data-i18n="manifesto.lead">Built for the stage, not the studio. HALO lives on your pedalboard and gives one performer total command of the room — scenes, colour, intensity and effects, all under your foot.</p>
</div>
</section>
<!-- ============ MODELS ============ -->
<section class="section-pad models" id="models">
<div class="wrap">
<div class="reveal">
<p class="kicker" style="margin-bottom:18px" data-i18n="models.kicker">The range</p>
<h2 class="h-xl" data-i18n="models.title">Two models.<br>One language.</h2>
<p class="lead" style="margin-top:18px" data-i18n="models.lead">Same engine, same app, same instant foot control — pick the footprint that fits your board.</p>
</div>
<div class="models__grid reveal">
<article class="model">
<div class="model__shot shot shot-max" role="img" aria-label="HALO MAX"></div>
<div class="model__body">
<div class="model__head">
<h3>HALO <span class="accent">MAX</span></h3>
<span class="mono model__tag" data-i18n="models.max.tag">Flagship</span>
</div>
<p data-i18n="models.max.desc">The full board. Six footswitches, deep cue banks and tap — for headliners running a full rig.</p>
<ul class="model__specs">
<li><span data-i18n="models.spec.fsw">Footswitches</span><b>6</b></li>
<li><span data-i18n="models.spec.banks">Banks</span><b data-i18n="models.val.unlimited">Unlimited</b></li>
<li><span data-i18n="models.spec.display">Display</span><b data-i18n="models.val.lcd">Colour LCD</b></li>
</ul>
</div>
</article>
<article class="model">
<div class="model__shot shot shot-mini" role="img" aria-label="HALO MINI"></div>
<div class="model__body">
<div class="model__head">
<h3>HALO <span class="accent">MINI</span></h3>
<span class="mono model__tag" data-i18n="models.mini.tag">Compact</span>
</div>
<p data-i18n="models.mini.desc">The essentials, downsized. Three footswitches and the same engine — for solo artists and tight boards.</p>
<ul class="model__specs">
<li><span data-i18n="models.spec.fsw">Footswitches</span><b>3</b></li>
<li><span data-i18n="models.spec.banks">Banks</span><b data-i18n="models.val.unlimited">Unlimited</b></li>
<li><span data-i18n="models.spec.display">Display</span><b data-i18n="models.val.lcd">Colour LCD</b></li>
</ul>
</div>
</article>
</div>
</div>
</section>
<!-- ============ FEATURES ============ -->
<section class="section-pad" id="features">
<div class="wrap">
<div class="reveal">
<p class="kicker" style="margin-bottom:18px" data-i18n="features.kicker">What it does</p>
<h2 class="h-xl" data-i18n="features.title">Everything your show needs.<br>Nothing it doesn't.</h2>
</div>
<div class="features__grid reveal">
<div class="feature"><span class="feature__no">01</span><span class="feature__icon">◎</span><h3 data-i18n="features.f1.t">Scenes & colours</h3><p data-i18n="features.f1.d">Store full looks — primary & secondary colours, intensity, mood — and recall them instantly.</p></div>
<div class="feature"><span class="feature__no">02</span><span class="feature__icon">⏻</span><h3 data-i18n="features.f2.t">Foot control</h3><p data-i18n="features.f2.d">Four footswitches: next, previous, mode, tap. Switch cues mid-riff without lifting your hands.</p></div>
<div class="feature"><span class="feature__no">03</span><span class="feature__icon">✸</span><h3 data-i18n="features.f3.t">FX engine</h3><p data-i18n="features.f3.d">Pulse, strobe, chase, rainbow, wave. Synced to tempo, triggered live, layered per group.</p></div>
<div class="feature"><span class="feature__no">04</span><span class="feature__icon">▦</span><h3 data-i18n="features.f4.t">DMX512 universe</h3><p data-i18n="features.f4.d">512 channels out. Drive PARs, bars, movers, blinders — your whole rig from one box.</p></div>
<div class="feature"><span class="feature__no">05</span><span class="feature__icon">⌬</span><h3 data-i18n="features.f5.t">Variations</h3><p data-i18n="features.f5.d">Every scene holds up to three variations — verse, chorus, drop — a tap apart.</p></div>
<div class="feature"><span class="feature__no">06</span><span class="feature__icon">⧉</span><h3 data-i18n="features.f6.t">WiFi & web app</h3><p data-i18n="features.f6.d">Design your whole show from any phone or laptop over WiFi. No software to install.</p></div>
</div>
</div>
</section>
<!-- ============ HOW ============ -->
<section class="section-pad" id="how">
<div class="wrap">
<div class="reveal">
<p class="kicker" style="margin-bottom:18px" data-i18n="how.kicker">How it works</p>
<h2 class="h-xl" data-i18n="how.title">Three steps to a light show.</h2>
</div>
<div class="how__grid reveal">
<div class="step"><div class="step__n">01</div><h3 data-i18n="how.s1.t">Patch your rig</h3><p data-i18n="how.s1.d">Plug HALO into your DMX chain. Set fixture addresses once in the app.</p></div>
<div class="step"><div class="step__n">02</div><h3 data-i18n="how.s2.t">Design your show</h3><p data-i18n="how.s2.d">Build scenes, pick colours, assign FX and variations from your phone.</p></div>
<div class="step"><div class="step__n">03</div><h3 data-i18n="how.s3.t">Stomp & perform</h3><p data-i18n="how.s3.d">Step on stage. One foot drives the entire room, cue by cue.</p></div>
</div>
</div>
</section>
<!-- ============ APP ============ -->
<section class="section-pad" id="app">
<div class="wrap app">
<div class="app__copy reveal">
<p class="kicker" style="margin-bottom:18px" data-i18n="app.kicker">The app</p>
<h2 class="h-lg" data-i18n="app.title">Design on screen.<br>Perform with your foot.</h2>
<p class="lead" style="margin-top:18px" data-i18n="app.lead">A clean, fast web console for building shows — scenes, groups, fixtures, effects, intensity masters. Then close the laptop and let the pedal do the talking.</p>
<ul class="app__list">
<li><span class="tick">→</span> <span data-i18n="app.l1">Live scene & variation control</span></li>
<li><span class="tick">→</span> <span data-i18n="app.l2">Per-group intensity masters</span></li>
<li><span class="tick">→</span> <span data-i18n="app.l3">Real-time DMX monitoring</span></li>
<li><span class="tick">→</span> <span data-i18n="app.l4">Works on phone, tablet & desktop</span></li>
</ul>
</div>
<div class="appmock reveal" aria-label="HALO web console (aperçu)">
<div class="appmock__bar"><span class="dot"></span><span class="dot"></span><span class="dot"></span><span class="appmock__url mono">halo.local</span></div>
<div class="appmock__body">
<div class="appmock__scene">
<span class="mono appmock__k">SCENE 03 / 14</span>
<div class="appmock__name">SUNSET DRIFT</div>
<div class="appmock__sw"><i style="background:#1763d4"></i><i style="background:#0bd1d1"></i><span class="mono">124 BPM</span></div>
</div>
<div class="appmock__vars">
<span>BASE</span><span>VAR 1</span><span class="on">VAR 2</span><span>VAR 3</span>
</div>
<div class="appmock__masters">
<div class="appmock__row"><span class="mono">GRAND</span><i><b style="width:85%"></b></i><span class="mono">85</span></div>
<div class="appmock__row"><span class="mono">FACE</span><i><b style="width:100%"></b></i><span class="mono">100</span></div>
<div class="appmock__row"><span class="mono">GUN</span><i><b style="width:60%"></b></i><span class="mono">60</span></div>
</div>
</div>
</div>
</div>
</section>
<!-- ============ SPECS ============ -->
<section class="section-pad" id="specs">
<div class="wrap">
<div class="reveal">
<p class="kicker" style="margin-bottom:18px" data-i18n="specs.kicker">Under the hood</p>
<h2 class="h-xl" data-i18n="specs.title">Spec sheet.</h2>
</div>
<dl class="specs__grid reveal">
<div class="spec"><dt data-i18n="specs.protocol">Protocol</dt><dd>DMX512 · 512 ch</dd></div>
<div class="spec"><dt data-i18n="specs.processor">Processor</dt><dd>ESP32 dual-core</dd></div>
<div class="spec"><dt data-i18n="specs.fsw">Footswitches</dt><dd data-i18n="specs.fsw.v">4 (prev/next/mode/tap)</dd></div>
<div class="spec"><dt data-i18n="specs.display">Display</dt><dd data-i18n="specs.display.v">Colour LCD</dd></div>
<div class="spec"><dt data-i18n="specs.conn">Connectivity</dt><dd>WiFi AP + STA</dd></div>
<div class="spec"><dt data-i18n="specs.control">Control</dt><dd data-i18n="specs.control.v">Web app (no install)</dd></div>
<div class="spec"><dt data-i18n="specs.fixtures">Fixtures</dt><dd data-i18n="specs.fixtures.v">PAR · bar · mover · dimmer</dd></div>
<div class="spec"><dt data-i18n="specs.output">Output</dt><dd>3-pin / 5-pin XLR</dd></div>
</dl>
</div>
</section>
<!-- ============ CTA ============ -->
<section class="section-pad cta" id="preorder">
<div class="cta__halo"></div>
<div class="wrap cta__inner reveal">
<p class="kicker" style="margin-bottom:22px" data-i18n="cta.kicker">Limited first run</p>
<h2 class="h-xl" data-i18n="cta.title">Put the light<br>under your foot.</h2>
<p class="price"><span data-i18n="cta.price">Pre-order from</span> <b>€349</b></p>
<div class="hero__cta" style="margin-top:24px">
<a href="#" class="btn btn--solid"><span data-i18n="cta.b1">Reserve yours</span> <span class="arr">→</span></a>
<a href="#" class="btn" data-i18n="cta.b2">Join the waitlist</a>
</div>
</div>
</section>
<!-- ============ FOOTER ============ -->
<footer class="footer">
<div class="wrap footer__row">
<div>
<div class="footer__brand">HALO<span class="dot">.</span></div>
<small data-i18n="tagline">One stomp. Total light.</small>
</div>
<div class="footer__links">
<a href="#features" data-i18n="nav.features">Features</a>
<a href="#specs" data-i18n="nav.specs">Specs</a>
<a href="#preorder" data-i18n="nav.preorder">Pre-order</a>
<a href="#" data-i18n="footer.contact">Contact</a>
</div>
</div>
<div class="wrap" style="margin-top:30px"><small data-i18n="footer.copy">© 2026 HALO Instruments — Research prototype. Not yet for sale.</small></div>
</footer>
<script>
/* ============================================================
i18n — FR / EN
============================================================ */
var I18N={
en:{
'nav.features':'Features','nav.how':'How it works','nav.app':'App','nav.specs':'Specs','nav.preorder':'Pre-order',
'tagline':'One stomp. Total light.','enter':'Enter',
'hero.kicker':'The lighting pedal for musicians',
'hero.title':'ONE STOMP.<br>TOTAL LIGHT.',
'hero.sub':'HALO turns your entire stage light show into a stompbox. Design once. Perform with your foot. No engineer. No laptop.',
'hero.cta1':'Pre-order','hero.cta2':'See how it works','hero.scroll':'Scroll ↓',
'artists.kicker':'On stage with','artists.title':'Built for people who play.',
'manifesto.kicker':'Manifesto',
'manifesto.big':'You don\'t need a lighting engineer.<br><span class="muted-line">You need</span> <span class="em">a pedal.</span>',
'manifesto.lead':'Built for the stage, not the studio. HALO lives on your pedalboard and gives one performer total command of the room — scenes, colour, intensity and effects, all under your foot.',
'models.kicker':'The range','models.title':'Two models.<br>One language.',
'models.lead':'Same engine, same app, same instant foot control — pick the footprint that fits your board.',
'models.max.tag':'Flagship','models.max.desc':'The full board. Six footswitches, deep cue banks and tap — for headliners running a full rig.',
'models.mini.tag':'Compact','models.mini.desc':'The essentials, downsized. Three footswitches and the same engine — for solo artists and tight boards.',
'models.spec.fsw':'Footswitches','models.spec.banks':'Banks','models.spec.display':'Display','models.val.unlimited':'Unlimited','models.val.lcd':'Colour LCD',
'features.kicker':'What it does','features.title':'Everything your show needs.<br>Nothing it doesn\'t.',
'features.f1.t':'Scenes & colours','features.f1.d':'Store full looks — primary & secondary colours, intensity, mood — and recall them instantly.',
'features.f2.t':'Foot control','features.f2.d':'Four footswitches: next, previous, mode, tap. Switch cues mid-riff without lifting your hands.',
'features.f3.t':'FX engine','features.f3.d':'Pulse, strobe, chase, rainbow, wave. Synced to tempo, triggered live, layered per group.',
'features.f4.t':'DMX512 universe','features.f4.d':'512 channels out. Drive PARs, bars, movers, blinders — your whole rig from one box.',
'features.f5.t':'Variations','features.f5.d':'Every scene holds up to three variations — verse, chorus, drop — a tap apart.',
'features.f6.t':'WiFi & web app','features.f6.d':'Design your whole show from any phone or laptop over WiFi. No software to install.',
'how.kicker':'How it works','how.title':'Three steps to a light show.',
'how.s1.t':'Patch your rig','how.s1.d':'Plug HALO into your DMX chain. Set fixture addresses once in the app.',
'how.s2.t':'Design your show','how.s2.d':'Build scenes, pick colours, assign FX and variations from your phone.',
'how.s3.t':'Stomp & perform','how.s3.d':'Step on stage. One foot drives the entire room, cue by cue.',
'app.kicker':'The app','app.title':'Design on screen.<br>Perform with your foot.',
'app.lead':'A clean, fast web console for building shows — scenes, groups, fixtures, effects, intensity masters. Then close the laptop and let the pedal do the talking.',
'app.l1':'Live scene & variation control','app.l2':'Per-group intensity masters','app.l3':'Real-time DMX monitoring','app.l4':'Works on phone, tablet & desktop',
'specs.kicker':'Under the hood','specs.title':'Spec sheet.',
'specs.protocol':'Protocol','specs.processor':'Processor','specs.fsw':'Footswitches','specs.fsw.v':'4 (prev/next/mode/tap)',
'specs.display':'Display','specs.display.v':'Colour LCD','specs.conn':'Connectivity','specs.control':'Control','specs.control.v':'Web app (no install)',
'specs.fixtures':'Fixtures','specs.fixtures.v':'PAR · bar · mover · dimmer','specs.output':'Output',
'cta.kicker':'Limited first run','cta.title':'Put the light<br>under your foot.','cta.price':'Pre-order from','cta.b1':'Reserve yours','cta.b2':'Join the waitlist',
'footer.contact':'Contact','footer.copy':'© 2026 HALO Instruments — Research prototype. Not yet for sale.'
},
fr:{
'nav.features':'Fonctions','nav.how':'Comment ça marche','nav.app':'L\'app','nav.specs':'Specs','nav.preorder':'Précommander',
'tagline':'Toute la lumière, au pied.','enter':'Entrer',
'hero.kicker':'La pédale lumière pour musiciens',
'hero.title':'TOUTE LA LUMIÈRE,<br>AU PIED.',
'hero.sub':'HALO transforme tout ton light show en pédale. Tu le conçois une fois. Tu le joues au pied. Sans éclairagiste. Sans laptop.',
'hero.cta1':'Précommander','hero.cta2':'Voir comment ça marche','hero.scroll':'Défiler ↓',
'artists.kicker':'Sur scène avec','artists.title':'Conçu pour ceux qui jouent.',
'manifesto.kicker':'Manifeste',
'manifesto.big':'Tu n\'as pas besoin d\'un éclairagiste.<br><span class="muted-line">Tu as besoin</span> <span class="em">d\'une pédale.</span>',
'manifesto.lead':'Pensé pour la scène, pas pour le studio. HALO vit sur ton pedalboard et donne à un seul musicien le contrôle total de la salle — scènes, couleurs, intensité et effets, tout au pied.',
'models.kicker':'La gamme','models.title':'Deux modèles.<br>Un même langage.',
'models.lead':'Même moteur, même app, même contrôle instantané au pied — choisis l\'encombrement qui colle à ton board.',
'models.max.tag':'Vaisseau amiral','models.max.desc':'Le board complet. Six footswitches, banques de cues profondes et tap — pour les têtes d\'affiche avec un gros rig.',
'models.mini.tag':'Compact','models.mini.desc':'L\'essentiel, en plus petit. Trois footswitches et le même moteur — pour les artistes solo et les boards serrés.',
'models.spec.fsw':'Footswitches','models.spec.banks':'Banques','models.spec.display':'Écran','models.val.unlimited':'Illimitées','models.val.lcd':'LCD couleur',
'features.kicker':'Ce qu\'elle fait','features.title':'Tout ce qu\'il faut à ton show.<br>Rien de superflu.',
'features.f1.t':'Scènes & couleurs','features.f1.d':'Mémorise des ambiances complètes — couleurs primaire & secondaire, intensité, mood — et rappelle-les instantanément.',
'features.f2.t':'Contrôle au pied','features.f2.d':'Quatre footswitches : suivant, précédent, mode, tap. Change de cue en plein riff sans lever les mains.',
'features.f3.t':'Moteur d\'effets','features.f3.d':'Pulse, strobe, chase, rainbow, wave. Calés au tempo, déclenchés en live, superposés par groupe.',
'features.f4.t':'Univers DMX512','features.f4.d':'512 canaux en sortie. Pilote PARs, barres, lyres, blinders — tout ton rig depuis un seul boîtier.',
'features.f5.t':'Variations','features.f5.d':'Chaque scène contient jusqu\'à trois variations — couplet, refrain, drop — à un tap d\'écart.',
'features.f6.t':'WiFi & app web','features.f6.d':'Conçois tout ton show depuis n\'importe quel téléphone ou laptop en WiFi. Aucun logiciel à installer.',
'how.kicker':'Comment ça marche','how.title':'Trois étapes vers un light show.',
'how.s1.t':'Branche ton rig','how.s1.d':'Connecte HALO à ta chaîne DMX. Règle les adresses une seule fois dans l\'app.',
'how.s2.t':'Conçois ton show','how.s2.d':'Crée des scènes, choisis les couleurs, assigne FX et variations depuis ton téléphone.',
'how.s3.t':'Stomp & joue','how.s3.d':'Monte sur scène. Un pied pilote toute la salle, cue après cue.',
'app.kicker':'L\'app','app.title':'Conçois à l\'écran.<br>Joue au pied.',
'app.lead':'Une console web claire et rapide pour bâtir tes shows — scènes, groupes, fixtures, effets, masters d\'intensité. Puis referme le laptop et laisse la pédale parler.',
'app.l1':'Contrôle live scène & variation','app.l2':'Masters d\'intensité par groupe','app.l3':'Monitoring DMX temps réel','app.l4':'Marche sur téléphone, tablette & ordi',
'specs.kicker':'Sous le capot','specs.title':'Fiche technique.',
'specs.protocol':'Protocole','specs.processor':'Processeur','specs.fsw':'Footswitches','specs.fsw.v':'4 (préc./suiv./mode/tap)',
'specs.display':'Écran','specs.display.v':'LCD couleur','specs.conn':'Connectivité','specs.control':'Contrôle','specs.control.v':'App web (sans install)',
'specs.fixtures':'Fixtures','specs.fixtures.v':'PAR · barre · lyre · dimmer','specs.output':'Sortie',
'cta.kicker':'Première série limitée','cta.title':'Mets la lumière<br>sous ton pied.','cta.price':'Précommande dès','cta.b1':'Réserve la tienne','cta.b2':'Rejoindre la liste',
'footer.contact':'Contact','footer.copy':'© 2026 HALO Instruments — Prototype de recherche. Pas encore en vente.'
}
};
var LANG_KEY='halo.lang';
function detectLang(){
var saved=localStorage.getItem(LANG_KEY);
if(saved==='fr'||saved==='en')return saved;
return (navigator.language||'en').toLowerCase().indexOf('fr')===0?'fr':'en';
}
function applyLang(lang){
var dict=I18N[lang]||I18N.en;
document.documentElement.setAttribute('lang',lang);
document.querySelectorAll('[data-i18n]').forEach(function(el){
var k=el.getAttribute('data-i18n');
if(dict[k]!=null) el.innerHTML=dict[k];
});
localStorage.setItem(LANG_KEY,lang);
}
applyLang(detectLang()); // appliqué AVANT l'intro
/* ---- intro logo reveal : on construit le halo, puis ENTER ouvre la landing ---- */
(function(){
var pre=document.getElementById('preloader');
var enter=document.getElementById('enterBtn');
var reduce=matchMedia('(prefers-reduced-motion: reduce)').matches;
var BUILD_MS=2600; // temps de construction du logo avant que ENTER apparaisse
document.body.classList.add('loading');
function finish(){
if(pre.classList.contains('done'))return;
pre.classList.add('done');
document.body.classList.remove('loading');
document.body.classList.add('ready');
setTimeout(function(){ if(pre&&pre.parentNode) pre.parentNode.removeChild(pre); },1100);
}
// révèle le bouton ENTER une fois le logo construit
if(reduce){ pre.classList.add('is-built'); }
else { setTimeout(function(){ pre.classList.add('is-built'); }, BUILD_MS); }
// seul ENTER ouvre la vraie landing
enter.addEventListener('click', finish);
})();
/* ---- nav background on scroll ---- */
var nav=document.getElementById('nav');
addEventListener('scroll',function(){nav.classList.toggle('scrolled',scrollY>20)},{passive:true});
/* ---- reveal on scroll ---- */
var io=new IntersectionObserver(function(entries){
entries.forEach(function(e){ if(e.isIntersecting){ e.target.classList.add('in'); io.unobserve(e.target);} });
},{threshold:.14,rootMargin:'0px 0px -8% 0px'});
document.querySelectorAll('.reveal').forEach(function(el){io.observe(el)});
/* ---- toggle langue ---- */
document.getElementById('langBtn').addEventListener('click',function(){
var next=document.documentElement.getAttribute('lang')==='fr'?'en':'fr';
applyLang(next);
});
</script>
</body>
</html>