Outiref

Code source de l'URL : http://www.monsieurjs.fr

<!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 &amp; 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 &amp; 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 &amp; colours</h3><p data-i18n="features.f1.d">Store full looks — primary &amp; 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 &amp; 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 &amp; 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 &amp; 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 &amp; 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>