/* ===================================================================
   ZÉPHYR — Design system
   =================================================================== */
:root{
  --bg:#0a0a0d;
  --bg-2:#101016;
  --ink:#f3f2ef;
  --muted:#9a9aa6;
  --line:rgba(255,255,255,.10);
  --accent:#8a8ad6;           /* piloté en JS (teinte sélectionnée) */
  --accent-soft:rgba(138,138,214,.18);
  --radius:22px;
  --ease:cubic-bezier(.16,1,.3,1);
  --font-d:'Space Grotesk',system-ui,sans-serif;
  --font-b:'Inter',system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-b);
  font-weight:300;
  line-height:1.55;
  overflow-x:hidden;
}
body.is-locked{overflow:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--accent);color:#0a0a0d}

/* Lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}

/* ---------- Typo helpers ---------- */
.h2{
  font-family:var(--font-d);
  font-weight:600;
  font-size:clamp(2.4rem,6vw,5rem);
  line-height:.98;
  letter-spacing:-.02em;
}
.h2--light{color:#fff}
.h2--center{text-align:center}
.lead{font-size:clamp(1rem,1.5vw,1.25rem);color:var(--muted);max-width:46ch;margin-top:1.4rem}
.lead--light{color:rgba(255,255,255,.82)}
.section-label{
  font-family:var(--font-d);
  font-size:.78rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1.4rem;
}
.section-label--light{color:rgba(255,255,255,.9)}
.section-label--center{text-align:center}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-d);font-weight:500;font-size:.95rem;
  padding:.95rem 1.7rem;border-radius:100px;
  transition:transform .5s var(--ease),background .4s var(--ease),color .4s var(--ease),box-shadow .5s var(--ease);
  white-space:nowrap;cursor:pointer;border:1px solid transparent;
}
.btn--solid{background:var(--accent);color:#0a0a0d;box-shadow:0 10px 40px -12px var(--accent)}
.btn--solid:hover{transform:translateY(-3px);box-shadow:0 18px 50px -10px var(--accent)}
.btn--ghost{border-color:var(--line);color:var(--ink);background:rgba(255,255,255,.02)}
.btn--ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn--text{color:var(--muted);padding-left:.4rem;padding-right:.4rem}
.btn--text:hover{color:var(--ink)}
.btn--xl{font-size:1.05rem;padding:1.15rem 2.6rem;margin-top:.5rem}

/* ---------- Grain ---------- */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ===================================================================
   PRELOADER
   =================================================================== */
.loader{
  position:fixed;inset:0;z-index:10000;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
}
.loader__inner{text-align:center;width:min(80vw,320px)}
.loader__logo{
  font-family:var(--font-d);font-weight:700;letter-spacing:.4em;
  font-size:1.4rem;margin-bottom:1.6rem;padding-left:.4em;
}
.loader__bar{height:1px;background:var(--line);position:relative;overflow:hidden}
.loader__bar span{position:absolute;inset:0;width:0;background:var(--accent);transition:width .2s linear}
.loader__pct{margin-top:1rem;font-family:var(--font-d);color:var(--muted);font-size:.8rem}

/* ===================================================================
   NAV
   =================================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:5000;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.5rem clamp(1.2rem,4vw,3.2rem);
  transition:padding .5s var(--ease),background .5s var(--ease),backdrop-filter .5s var(--ease),border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  padding-top:1rem;padding-bottom:1rem;
  background:rgba(10,10,13,.55);
  backdrop-filter:blur(18px) saturate(1.4);
  border-bottom-color:var(--line);
}
.nav__logo{font-family:var(--font-d);font-weight:700;letter-spacing:.28em;font-size:1.05rem;padding-left:.28em}
.nav__links{display:flex;gap:2.2rem}
.nav__links a{font-size:.9rem;color:var(--muted);position:relative;transition:color .3s}
.nav__links a::after{content:'';position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--accent);transition:width .4s var(--ease)}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{width:100%}
@media(max-width:820px){.nav__links{display:none}}

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 clamp(1.2rem,5vw,5rem);
  overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% 8%, rgba(138,138,214,.10), transparent 60%),
    linear-gradient(180deg,var(--bg),var(--bg-2));
}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:2}
.hero__halo{
  position:absolute;left:50%;top:48%;transform:translate(-50%,-50%);
  width:62vmin;height:62vmin;border-radius:50%;z-index:1;
  background:radial-gradient(circle, var(--accent-soft), transparent 70%);
  filter:blur(40px);
}
.hero__copy{position:relative;z-index:3;max-width:600px;pointer-events:none}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-d);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);margin-bottom:1.6rem;
}
.hero__eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}
.hero__title{
  font-family:var(--font-d);font-weight:600;
  font-size:clamp(3.2rem,11vw,9rem);line-height:1;letter-spacing:-.03em;
  width:max-content;max-width:92vw;   /* le titre n'est plus bridé par la colonne 600px */
}
.hero__title .line{display:block;overflow:hidden;padding-right:.14em}  /* tampon pour l'accent du é + bord droit */
.hero__title .line span{display:block;will-change:transform}
.hero__title .line:nth-child(2) span{
  background:linear-gradient(120deg,var(--accent),#fff 60%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero__sub{font-size:clamp(1rem,1.6vw,1.25rem);color:var(--muted);max-width:42ch;margin-top:1.8rem}
.hero__actions{display:flex;align-items:center;gap:1.2rem;margin-top:2.4rem;flex-wrap:wrap;pointer-events:auto}
.hero__chips{
  position:absolute;right:clamp(1.2rem,5vw,5rem);bottom:14vh;z-index:3;
  display:flex;flex-direction:column;gap:.8rem;align-items:flex-end;
}
.chip{
  font-family:var(--font-d);font-size:.85rem;color:var(--muted);
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  padding:.55rem 1rem;border-radius:100px;backdrop-filter:blur(8px);
}
.chip b{color:var(--ink);font-size:1.05rem;margin-right:.25rem}
@media(max-width:820px){.hero__chips{display:none}}
.hero__scroll{
  position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);z-index:3;
  font-family:var(--font-d);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:.7rem;
}
.hero__scroll span{width:1px;height:42px;background:linear-gradient(var(--accent),transparent);animation:scrolldrop 1.8s var(--ease) infinite}
@keyframes scrolldrop{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ===================================================================
   MARQUEE
   =================================================================== */
.marquee{
  border-block:1px solid var(--line);overflow:hidden;
  padding:1.4rem 0;background:var(--bg-2);
}
.marquee__track{display:flex;width:max-content;animation:marq 32s linear infinite}
.marquee__track span{
  font-family:var(--font-d);font-weight:500;
  font-size:clamp(1.2rem,2.4vw,2rem);letter-spacing:.02em;
  color:var(--ink);white-space:nowrap;opacity:.85;
}
@keyframes marq{to{transform:translateX(-50%)}}

/* ===================================================================
   MANIFESTO
   =================================================================== */
.manifesto{
  padding:clamp(7rem,16vh,12rem) clamp(1.2rem,8vw,10rem);
  max-width:1300px;margin:0 auto;
}
.manifesto__eyebrow{
  font-family:var(--font-d);font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent);margin-bottom:2.2rem;
}
.manifesto__text{
  font-family:var(--font-d);font-weight:400;
  font-size:clamp(1.6rem,4.2vw,3.4rem);line-height:1.25;letter-spacing:-.015em;
}
.manifesto__text .w{display:inline-block;opacity:.16;transition:opacity .3s}

/* ===================================================================
   COMPARE
   =================================================================== */
.compare{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;
  padding:clamp(3rem,8vh,7rem) clamp(1.2rem,5vw,5rem);max-width:1400px;margin:0 auto;
}
.compare__media .tilt{border-radius:var(--radius);overflow:hidden;box-shadow:0 40px 90px -40px rgba(0,0,0,.8)}
.compare__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1}
.stats{display:flex;gap:clamp(1.5rem,3vw,3rem);margin-top:2.6rem;flex-wrap:wrap}
.stat{display:flex;flex-direction:column}
.stat__num{font-family:var(--font-d);font-weight:600;font-size:clamp(1.8rem,3.4vw,2.8rem);letter-spacing:-.02em}
.stat__lbl{color:var(--muted);font-size:.85rem;margin-top:.3rem}
@media(max-width:820px){.compare{grid-template-columns:1fr}.compare__media{order:-1}}

/* ===================================================================
   MODES
   =================================================================== */
.modes{padding:clamp(4rem,9vh,8rem) clamp(1.2rem,5vw,5rem);max-width:1500px;margin:0 auto}
.modes__head{margin-bottom:3.5rem}
.modes__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2vw,1.6rem)}
.mode{
  position:relative;border-radius:var(--radius);overflow:hidden;
  min-height:340px;border:1px solid var(--line);
  background:var(--bg-2);
}
.mode--tall{grid-row:span 2}
.mode img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);filter:brightness(.82)}
.mode:hover img{transform:scale(1.06)}
.mode__body{
  position:absolute;inset:auto 0 0 0;padding:2rem;z-index:2;
  background:linear-gradient(transparent,rgba(8,8,11,.85) 55%);
}
.mode__idx{font-family:var(--font-d);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}
.mode__body h3{font-family:var(--font-d);font-weight:600;font-size:1.7rem;margin:.5rem 0 .6rem;letter-spacing:-.01em}
.mode__body p{color:var(--muted);font-size:.95rem;max-width:38ch}
@media(max-width:820px){.modes__grid{grid-template-columns:1fr}.mode--tall{grid-row:auto}}

/* ===================================================================
   FEATURE / AROMA (full-bleed parallax)
   =================================================================== */
.feature{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}
.feature__bg{
  position:absolute;inset:-12% 0;background-size:cover;background-position:center;
  will-change:transform;
}
.feature::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,8,11,.78),rgba(8,8,11,.25) 60%,transparent)}
.feature__glass{position:relative;z-index:2;padding:clamp(2rem,8vw,8rem);max-width:640px}

/* ===================================================================
   AROMA — design centré
   =================================================================== */
.aroma2{padding:clamp(5rem,11vh,9rem) clamp(1.2rem,5vw,5rem);text-align:center;position:relative;overflow:hidden}
.aroma2__head{max-width:680px;margin:0 auto}
.aroma2__lead{margin:1.4rem auto 0;text-align:center;max-width:54ch}
.aroma2__stage{position:relative;max-width:500px;margin:clamp(2.5rem,5vw,4rem) auto 0}
.aroma2__stage::before{
  content:'';position:absolute;inset:-14%;z-index:0;
  background:radial-gradient(50% 50% at 50% 45%,var(--accent-soft),transparent 70%);
  filter:blur(45px);transition:background .5s var(--ease);
}
.aroma2__stage img{
  position:relative;z-index:1;width:100%;display:block;border-radius:26px;
  border:1px solid var(--line);box-shadow:0 50px 120px -45px rgba(0,0,0,.85);
  animation:aromaFloat 7s ease-in-out infinite;
}
@keyframes aromaFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.aroma2__feats{
  display:flex;justify-content:center;gap:clamp(1.6rem,5vw,4.5rem);
  margin-top:clamp(2.4rem,5vw,3.5rem);flex-wrap:wrap;
}
.afeat{text-align:center;position:relative;padding:0 .4rem}
.afeat b{display:block;font-family:var(--font-d);font-weight:500;font-size:1.15rem;letter-spacing:-.01em}
.afeat span{color:var(--muted);font-size:.88rem;margin-top:.2rem;display:block}

/* ===================================================================
   DISPLAY / BATTERY
   =================================================================== */
.display{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;
  padding:clamp(4rem,9vh,8rem) clamp(1.2rem,5vw,5rem);max-width:1400px;margin:0 auto;
}
.display__media .tilt{border-radius:var(--radius);overflow:hidden;box-shadow:0 40px 90px -40px rgba(0,0,0,.8)}
.display__media img{width:100%;aspect-ratio:4/5;object-fit:cover}
.battery{margin-top:2.6rem}
.battery__cell{
  position:relative;display:flex;align-items:center;gap:.6rem;
  font-family:var(--font-d);font-weight:600;font-size:1.4rem;
  width:240px;height:64px;border:2px solid var(--line);border-radius:14px;
  padding:0 1.1rem;overflow:hidden;background:rgba(255,255,255,.02);
}
.battery__cell i{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent-soft);border-right:2px solid var(--accent);z-index:0}
.battery__cell span,.battery__cell{position:relative;z-index:1}
.battery__hint{color:var(--muted);font-size:.9rem;margin-top:.9rem}
@media(max-width:820px){.display{grid-template-columns:1fr}.display__media{order:-1}}

/* ===================================================================
   COLORS
   =================================================================== */
.colors{padding:clamp(5rem,10vh,9rem) clamp(1.2rem,5vw,5rem);text-align:center}
.colors__hint{color:var(--muted);margin-top:1rem}

/* Configurateur / galerie */
.config{padding:clamp(5rem,10vh,9rem) clamp(1.2rem,5vw,5rem);text-align:center}
.config__grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,4vw,3.5rem);
  max-width:1180px;margin:3rem auto 0;text-align:left;align-items:start;
}
.config__gallery{position:sticky;top:6rem}
.gallery__main{
  border-radius:var(--radius);overflow:hidden;background:#fff;border:1px solid var(--line);
  aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  box-shadow:0 40px 90px -50px rgba(0,0,0,.8);
}
.gallery__main img{width:100%;height:100%;object-fit:contain}
.gallery__thumbs{display:flex;gap:.7rem;margin-top:.9rem;flex-wrap:wrap}
.gallery__thumbs button{
  width:76px;height:76px;border-radius:14px;overflow:hidden;padding:0;cursor:pointer;
  background:#fff;border:1px solid var(--line);transition:border-color .3s,transform .3s var(--ease);
}
.gallery__thumbs button:hover{transform:translateY(-2px)}
.gallery__thumbs button.is-active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.gallery__thumbs img{width:100%;height:100%;object-fit:contain}

.config__panel{padding-top:.5rem}
.config__teinte{font-family:var(--font-d);font-size:.95rem;color:var(--muted);margin-bottom:1.2rem}
.config__teinte b{color:var(--ink)}
.config__panel .swatches{justify-content:flex-start;margin-top:0}
.config__price{display:flex;align-items:baseline;gap:.9rem;margin:1.8rem 0 1.6rem}
.config__now{font-family:var(--font-d);font-weight:700;font-size:clamp(2rem,4vw,2.8rem);color:var(--accent)}
.config__was{color:var(--muted);text-decoration:line-through;font-size:1.2rem}
.config__note{color:var(--muted);font-size:.85rem;margin-top:1.1rem}
@media(max-width:860px){
  .config__grid{grid-template-columns:1fr}
  .config__gallery{position:static}
  #galBuy{display:flex;width:fit-content;margin-left:auto;margin-right:auto}
}
.swatches{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.6rem}
.swatch{
  position:relative;font-family:var(--font-d);font-size:.85rem;color:var(--muted);
  padding:.7rem 1.3rem .7rem 2.6rem;border-radius:100px;
  border:1px solid var(--line);background:rgba(255,255,255,.02);
  transition:color .3s,border-color .3s,transform .4s var(--ease);
}
.swatch::before{
  content:'';position:absolute;left:.7rem;top:50%;transform:translateY(-50%);
  width:18px;height:18px;border-radius:50%;background:var(--sw);
  box-shadow:0 0 0 1px rgba(255,255,255,.15);
}
.swatch:hover{transform:translateY(-3px);color:var(--ink)}
.swatch.is-active{color:#0a0a0d;background:var(--ink);border-color:var(--ink)}

/* Pastilles compactes (hero) */
.hero__colors{display:flex;align-items:center;gap:.7rem;margin-top:2.2rem;pointer-events:auto}
.hero__colors-label{
  font-family:var(--font-d);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin-right:.4rem;
}
.swatch--mini{
  width:28px;height:28px;padding:0;border-radius:50%;
  background:var(--sw);border:1px solid rgba(255,255,255,.22);
  font-size:0;cursor:pointer;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.swatch--mini::before{content:none}
.swatch--mini:hover{transform:translateY(-3px) scale(1.1)}
.swatch--mini.is-active{
  background:var(--sw);color:transparent;border-color:transparent;
  box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--sw);transform:scale(1.05);
}

/* ===================================================================
   SPECS
   =================================================================== */
.specs{padding:clamp(4rem,9vh,8rem) clamp(1.2rem,5vw,5rem);max-width:1400px;margin:0 auto}
.specs__head{margin-bottom:3rem}
.specs__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.spec{background:var(--bg);padding:1.8rem 1.6rem;display:flex;flex-direction:column;gap:.5rem;transition:background .4s}
.spec:hover{background:var(--bg-2)}
.spec span{color:var(--muted);font-size:.8rem;letter-spacing:.05em;text-transform:uppercase}
.spec b{font-family:var(--font-d);font-weight:500;font-size:1.25rem;letter-spacing:-.01em}
@media(max-width:1024px){.specs__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.specs__grid{grid-template-columns:1fr}}

/* ===================================================================
   REVIEWS
   =================================================================== */
.reviews{padding:clamp(4rem,9vh,8rem) clamp(1.2rem,5vw,5rem);max-width:1400px;margin:0 auto}
.reviews__head{text-align:center;margin-bottom:3.5rem}
.reviews__big{font-family:var(--font-d);font-weight:700;font-size:clamp(3rem,8vw,6rem);letter-spacing:-.03em;display:block;line-height:1}
.reviews__stars{color:var(--accent);font-size:1.4rem;letter-spacing:.15em}
.reviews__stars .half{opacity:.35}
.reviews__count{display:block;color:var(--muted);margin-top:.8rem;font-size:.9rem}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.review{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:2.2rem;display:flex;flex-direction:column;justify-content:space-between;gap:1.6rem;
}
.review p{font-size:1.05rem;line-height:1.5}
.review footer{color:var(--muted);font-size:.85rem;font-family:var(--font-d)}
.review footer span{color:var(--accent)}
@media(max-width:880px){.reviews__grid{grid-template-columns:1fr}}

/* ===================================================================
   OFFER
   =================================================================== */
.offer{position:relative;padding:clamp(6rem,14vh,11rem) clamp(1.2rem,5vw,5rem);overflow:hidden;text-align:center;background:var(--bg-2)}
.offer__halo{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:80vmin;height:80vmin;border-radius:50%;
  background:radial-gradient(circle,var(--accent-soft),transparent 65%);filter:blur(30px);
}
.offer__inner{position:relative;z-index:2;max-width:720px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.offer__title{font-family:var(--font-d);font-weight:700;font-size:clamp(2.4rem,7vw,5rem);letter-spacing:-.03em;line-height:1}
.offer__price{display:flex;align-items:baseline;gap:1rem;margin:2rem 0 .4rem}
.offer__now{font-family:var(--font-d);font-weight:700;font-size:clamp(2.6rem,7vw,4rem);color:var(--accent)}
.offer__was{color:var(--muted);text-decoration:line-through;font-size:1.4rem}
.offer__tag{font-family:var(--font-d);font-size:.85rem;padding:.3rem .7rem;border-radius:100px;background:var(--accent);color:#0a0a0d}
.offer__stock{width:100%;max-width:420px;margin:1.8rem 0 2.4rem}
.offer__stock-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem}
.offer__stock-flame{
  font-family:var(--font-d);font-size:.8rem;font-weight:600;letter-spacing:.04em;
  color:var(--ink);
}
.offer__stock-left{font-family:var(--font-d);font-size:.82rem;color:var(--muted)}
.offer__stock-left b{color:var(--accent);font-size:1rem;font-variant-numeric:tabular-nums}
.offer__stock-bar{
  height:8px;border-radius:100px;overflow:hidden;
  background:rgba(255,255,255,.07);border:1px solid var(--line);
}
.offer__stock-bar i{
  display:block;height:100%;width:18%;border-radius:100px;
  background:linear-gradient(90deg,var(--accent),#c4a9f0);
  box-shadow:0 0 16px var(--accent);
  transition:width 1.1s var(--ease);
  animation:stockPulse 2.4s var(--ease) infinite;
}
@keyframes stockPulse{0%,100%{opacity:1}50%{opacity:.65}}
.offer__fine{color:var(--muted);font-size:.85rem;margin-top:1.6rem}

/* ===================================================================
   FOOTER
   =================================================================== */
.footer{padding:clamp(3rem,7vh,6rem) clamp(1.2rem,5vw,5rem) 3rem;text-align:center;border-top:1px solid var(--line)}
.footer__logo{font-family:var(--font-d);font-weight:700;letter-spacing:.4em;font-size:clamp(2rem,8vw,5rem);padding-left:.4em;opacity:.92}
.footer__tag{color:var(--muted);margin-top:1rem;font-family:var(--font-d)}
.footer__legal{color:var(--muted);opacity:.5;font-size:.78rem;margin-top:2.5rem}

/* ===================================================================
   REVEAL (JS)
   =================================================================== */
.reveal{opacity:0;transform:translateY(40px)}

/* ===================================================================
   REDUCED MOTION
   =================================================================== */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .reveal{opacity:1;transform:none}
  .manifesto__text .w{opacity:1}
}

/* ===================================================================
   CTA DE SECTION — bouton « Acheter maintenant » par bloc
   =================================================================== */
.section-cta{display:flex;justify-content:center;margin-top:clamp(2.6rem,5vw,4rem)}
.section-cta--span{grid-column:1 / -1}   /* traverse les grilles 2 colonnes (compare/display) */
.section-cta--left{justify-content:flex-start;margin-top:4.6rem}   /* aligné à gauche sous les stats, abaissé */
.section-cta--full{margin-top:3.2rem}                /* bouton pleine largeur de la colonne */
.section-cta--full .btn{width:100%}

/* ===================================================================
   HERO MOBILE — empilé : ventilateur en haut, texte lisible en bas
   =================================================================== */
@media(max-width:820px){
  .hero{
    justify-content:flex-end;
    text-align:center;
    padding-bottom:3.2rem;
  }
  /* le canvas occupe la moitié haute, le ventilateur s'y recentre seul */
  .hero__canvas{height:50svh;top:0;bottom:auto}
  .hero__halo{top:25%;width:78vmin;height:78vmin}

  .hero__copy{
    max-width:100%;width:100%;
    margin-top:auto;            /* pousse le texte en bas */
    display:flex;flex-direction:column;align-items:center;
  }
  .hero__eyebrow{margin-bottom:1rem}
  .hero__title{
    width:auto;max-width:100%;
    font-size:clamp(2.6rem,13.5vw,4.4rem);
  }
  .hero__title .line{padding-right:0}
  .hero__sub{
    margin:1.1rem auto 0;max-width:32ch;
    font-size:1.02rem;
  }
  .hero__actions{flex-direction:column;align-items:center;justify-content:center;margin-top:1.8rem;gap:1rem}
  .hero__actions .btn--solid{font-size:1.05rem;padding:.95rem 2rem}
  .hero__colors{justify-content:center;margin-top:1.6rem}
  .hero__scroll{display:none}
}
