/* ===========================================================
   BeerTap — Refonte 2026
   Système : palette brasserie · type poster moderne · zéro emoji
   =========================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* — Palette brasserie (fournie) — */
  --cream:#FFF4DD;
  --cream-2:#F7E9C9;
  --cream-3:#FBEFD6;
  --ink:#2A1A12;
  --ink-2:#1C110A;
  --malt:#6B3F1D;
  --amber:#D9902F;
  --gold:#F2B705;
  --hop:#4F6F2F;

  /* — Rôles (tweakables) — */
  --accent:var(--gold);
  --accent-2:var(--amber);
  --glow:rgba(242,183,5,.45);

  /* — Texte — */
  --on-cream:#2A1A12;
  --on-cream-soft:#7A5A3C;
  --on-ink:#FBEFD6;
  --on-ink-soft:#B79A78;

  --line-cream:rgba(107,63,29,.16);
  --line-ink:rgba(242,183,5,.14);

  /* — Fonts (tweakables) — */
  --font-display:'Anton',sans-serif;
  --font-body:'Hanken Grotesk',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  /* SF Pro — réservé aux éléments d'interface (nav, chips, mockups) */
  --font-sf:-apple-system,BlinkMacSystemFont,'SF Pro Text','SF Pro Display','Helvetica Neue',sans-serif;

  --maxw:1180px;
}

html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--on-cream);
  font-family:var(--font-body);
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img,video{display:block;max-width:100%}
a{color:inherit}

::selection{background:var(--accent);color:var(--ink)}

/* — Scroll progress — */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:400;
  background:linear-gradient(to right,var(--amber),var(--gold));
  box-shadow:0 0 12px var(--glow);
}

/* — Helpers — */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem)}
.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent-2);display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:'';width:26px;height:1px;background:currentColor;opacity:.7}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:'';width:26px;height:1px;background:currentColor;opacity:.7}

.display{
  font-family:var(--font-display);font-weight:400;
  line-height:.92;letter-spacing:.005em;text-transform:uppercase;
  text-wrap:balance;
}

.lede{
  font-size:clamp(1.05rem,2vw,1.3rem);line-height:1.7;font-weight:400;
  text-wrap:pretty;
}

.icon{width:1.25em;height:1.25em;flex-shrink:0;stroke:currentColor;
  stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* — Buttons — */
.btn{
  --b:var(--ink);--f:var(--cream);
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--font-body);font-weight:700;font-size:.95rem;
  letter-spacing:.02em;text-decoration:none;cursor:pointer;border:none;
  padding:1.05rem 2.2rem;border-radius:100px;
  background:var(--b);color:var(--f);position:relative;overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.9,.3,1),box-shadow .35s,background .25s;
  isolation:isolate;
}
.btn .icon{width:1.1em;height:1.1em;transition:transform .35s}
.btn::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.18),transparent 60%);
  opacity:0;transition:opacity .3s;
}
.btn:hover{transform:translateY(-3px)}
.btn:hover::before{opacity:1}
.btn:hover .icon{transform:translateX(3px)}
.btn.gold{--b:var(--accent);--f:var(--ink);box-shadow:0 10px 30px -8px var(--glow)}
.btn.gold:hover{box-shadow:0 18px 50px -10px var(--glow)}
.btn.ghost{--b:transparent;--f:var(--on-ink);border:1px solid var(--line-ink)}
.btn.ghost:hover{background:rgba(242,183,5,.08)}
.btn.lg{padding:1.2rem 2.8rem;font-size:1.05rem}

/* ========================= NAV ========================= */
nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.3rem clamp(1.2rem,4vw,2.4rem);
  transition:padding .35s,background .35s,box-shadow .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
nav.scrolled{
  padding:.85rem clamp(1.2rem,4vw,2.4rem);
  background:color-mix(in srgb,var(--cream) 82%,transparent);
  backdrop-filter:blur(16px) saturate(1.3);
  border-bottom:1px solid var(--line-cream);
}
.nav-logo{
  display:flex;align-items:center;gap:.6rem;text-decoration:none;
  font-family:var(--font-display);font-size:1.7rem;letter-spacing:.04em;
  color:var(--cream);text-transform:uppercase;transition:color .35s;
}
.nav-logo .mark{width:30px;height:30px;color:var(--accent)}
.nav-links{display:flex;gap:1.8rem;list-style:none;align-items:center}
.nav-links a{
  font-family:var(--font-sf);
  text-decoration:none;font-size:.82rem;font-weight:600;letter-spacing:.04em;
  color:rgba(255,244,221,.72);position:relative;padding:.2rem 0;transition:color .2s;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--accent);transition:width .28s cubic-bezier(.2,.9,.3,1);
}
.nav-links a:hover{color:var(--cream)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-sf);font-weight:700;font-size:.84rem;text-decoration:none;letter-spacing:-.01em;
  padding:.62rem 1.3rem;background:var(--accent);color:var(--ink);
  border-radius:100px;transition:transform .3s,box-shadow .3s,background .25s,color .25s;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 24px -8px var(--glow)}
.nav-burger{display:none;background:none;border:none;color:var(--cream);cursor:pointer}
.nav-burger .icon{width:26px;height:26px;stroke-width:2}

/* nav scrolled onto cream */
nav.scrolled .nav-logo{color:var(--ink)}
nav.scrolled .nav-links a{color:var(--on-cream-soft)}
nav.scrolled .nav-links a:hover{color:var(--ink)}
nav.scrolled .nav-cta{background:var(--ink);color:var(--cream)}
nav.scrolled .nav-cta:hover{background:var(--malt);box-shadow:0 10px 24px -8px rgba(42,26,18,.5)}
nav.scrolled .nav-burger{color:var(--ink)}
@media(max-width:1000px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:290;background:var(--ink-2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;
  opacity:0;pointer-events:none;transition:opacity .35s;
}
.mobile-menu.open{opacity:1;pointer-events:all}
.mobile-menu a{color:var(--on-ink);text-decoration:none;font-family:var(--font-display);
  font-size:2rem;text-transform:uppercase;letter-spacing:.04em}
.mobile-menu a:hover{color:var(--accent)}
.mobile-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--on-ink);cursor:pointer}
.mobile-close .icon{width:30px;height:30px;stroke-width:2}

/* ========================= HERO ========================= */
.hero{
  position:relative;min-height:100svh;
  display:grid;place-items:center;text-align:center;
  padding:9rem 1.2rem 5rem;overflow:hidden;
  background:
    radial-gradient(120% 80% at 50% 8%, rgba(217,144,47,.16) 0%, transparent 55%),
    radial-gradient(90% 70% at 50% 110%, var(--glow) -20%, transparent 55%),
    linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 100%);
  color:var(--on-ink);
}
.hero-grid-bg{
  position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(242,183,5,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(242,183,5,.05) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(80% 60% at 50% 40%,#000,transparent 80%);
          mask-image:radial-gradient(80% 60% at 50% 40%,#000,transparent 80%);
}
.bubbles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.bubble{
  position:absolute;bottom:-12px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,rgba(255,244,221,.55),rgba(242,183,5,.06));
  border:1px solid rgba(242,183,5,.18);animation:rise linear infinite;
}
@keyframes rise{
  0%{transform:translateY(0) translateX(0);opacity:0}
  12%{opacity:.85}88%{opacity:.4}
  100%{transform:translateY(-104svh) translateX(22px);opacity:0}
}

.hero-inner{
  position:relative;z-index:3;
  width:100%;max-width:1180px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,5rem);
  align-items:center;
  text-align:left;
}
.hero-text{display:flex;flex-direction:column;align-items:flex-start}
.hero-product{display:flex;justify-content:center;align-items:center}

/* photo produit */
.hero-product-img{
  width:100%;max-width:480px;
  border-radius:20px;
  box-shadow:0 36px 90px -20px rgba(0,0,0,.9),0 0 0 1px rgba(242,183,5,.1);
  filter:sepia(.05) contrast(1.03);
  opacity:0;
  transform:translateY(32px) rotate(2deg);
  transition:opacity 1.1s cubic-bezier(.2,.9,.3,1),transform 1.2s cubic-bezier(.2,.9,.3,1);
  transition-delay:.65s;
}
.hero.in .hero-product-img{opacity:1;transform:none}
.hero-eyebrow{
  color:var(--accent);margin-bottom:1.6rem;justify-content:flex-start;
  opacity:0;transform:translateY(14px);
  transition:opacity .7s cubic-bezier(.2,.9,.3,1),transform .7s cubic-bezier(.2,.9,.3,1);transition-delay:.15s;
}
.hero-wordmark{
  font-family:var(--font-display);text-transform:uppercase;
  font-size:clamp(4.2rem,17vw,12rem);line-height:.82;letter-spacing:.01em;
  color:var(--cream);position:relative;
}
.hero-wordmark .w-beer,.hero-wordmark .w-tap{
  display:inline-block;opacity:0;transform:translateY(40px) rotate(2deg);
  transition:opacity .9s cubic-bezier(.2,.9,.3,1),transform .9s cubic-bezier(.2,.9,.3,1);
}
.hero-wordmark .w-beer{transition-delay:.3s}
.hero-wordmark .w-tap{transition-delay:.45s}
.hero-wordmark .w-tap{color:var(--accent);text-shadow:0 0 60px var(--glow)}

/* live chrono console */
.hero-console{
  margin:2.4rem auto 0;max-width:520px;width:100%;
  background:linear-gradient(180deg,rgba(255,244,221,.05),rgba(255,244,221,.02));
  border:1px solid var(--line-ink);border-radius:22px;
  padding:1.8rem 1.6rem 1.5rem;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter:blur(6px);
  opacity:0;transform:translateY(30px) scale(.97);
  transition:opacity .9s cubic-bezier(.2,.9,.3,1),transform .9s cubic-bezier(.2,.9,.3,1);transition-delay:.6s;
}
.console-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.console-brand{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);
  font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--on-ink-soft)}
.console-brand .dot{width:7px;height:7px;border-radius:50%;background:var(--hop);box-shadow:0 0 8px var(--hop);animation:blink 2s ease-in-out infinite}
.console-wifi{display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono);
  font-size:.62rem;letter-spacing:.18em;color:var(--hop)}
.console-wifi .icon{width:14px;height:14px;stroke-width:2}
.chrono-readout{
  font-family:var(--font-mono);font-weight:700;
  font-size:clamp(3.6rem,12vw,5.4rem);line-height:1;letter-spacing:.02em;
  color:var(--accent);text-align:center;
  text-shadow:0 0 36px var(--glow);
  font-variant-numeric:tabular-nums;transition:color .25s,text-shadow .25s;
}
.chrono-readout .cs{font-size:.55em;opacity:.8}
.chrono-sub{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--on-ink-soft);text-align:center;margin-top:.5rem}
.chrono-actions{display:flex;gap:.7rem;margin-top:1.4rem}
.chrono-btn{
  flex:1;padding:.95rem;border:none;border-radius:12px;cursor:pointer;
  font-family:var(--font-body);font-weight:700;font-size:.95rem;letter-spacing:.06em;
  text-transform:uppercase;background:var(--accent);color:var(--ink);
  transition:transform .2s,background .2s,box-shadow .2s;
  box-shadow:0 8px 22px -8px var(--glow);
}
.chrono-btn:hover{transform:translateY(-2px)}
.chrono-btn.running{background:#C0392B;color:#fff;box-shadow:0 8px 22px -8px rgba(192,57,43,.6)}
.chrono-btn.ghost{flex:0 0 auto;background:transparent;color:var(--on-ink-soft);
  border:1px solid var(--line-ink);box-shadow:none;padding:.95rem 1.2rem}
.chrono-btn.ghost:hover{color:var(--on-ink);background:rgba(255,255,255,.04)}

.hero-tagline{max-width:480px;margin:1.9rem 0 0;color:var(--on-ink-soft);font-weight:400;
  opacity:0;transform:translateY(18px);
  transition:opacity .8s ease,transform .8s ease;transition-delay:.55s}
.hero.in .hero-tagline{opacity:1;transform:none}
.hero-actions{display:flex;gap:1rem;align-items:center;justify-content:flex-start;flex-wrap:wrap;margin-top:2.2rem;
  opacity:0;transform:translateY(20px);
  transition:opacity .8s ease,transform .8s ease;transition-delay:.75s}
.hero-price{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);
  font-size:.82rem;letter-spacing:.14em;color:var(--on-ink-soft)}
.hero-price b{font-family:var(--font-display);font-size:1.5rem;color:var(--cream);letter-spacing:.02em}

.hero-specs{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:flex-start;margin-top:2rem;
  opacity:0;transform:translateY(20px);
  transition:opacity .8s ease,transform .8s ease;transition-delay:.95s}
.spec-chip{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.5rem 1rem;border-radius:100px;
  background:rgba(255,244,221,.04);border:1px solid var(--line-ink);
  font-family:var(--font-sf);font-size:.8rem;font-weight:500;color:var(--on-ink);letter-spacing:-.005em;
}
.spec-chip .icon{width:1.05rem;height:1.05rem;color:var(--accent)}

.scroll-hint{
  position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-family:var(--font-mono);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--on-ink-soft);opacity:0;animation:fadeIn 1s ease forwards 2.4s;
}
.scroll-hint .bar{width:1px;height:38px;background:linear-gradient(var(--accent),transparent);
  animation:scrollPulse 1.8s ease-in-out infinite}

@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes fadeIn{to{opacity:1}}
@keyframes scrollPulse{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* hero entrance (JS-gated, transition-based for robustness) */
.hero.in .hero-eyebrow,
.hero.in .w-beer,
.hero.in .w-tap,
.hero.in .hero-actions,
.hero.in .hero-specs{opacity:1;transform:none}
.hero.in .hero-console{opacity:1;transform:translateY(0) scale(1)}

/* ========================= MARQUEE ========================= */
.marquee{
  background:var(--ink-2);color:var(--on-ink);
  padding:1.3rem 0;overflow:hidden;position:relative;
  border-top:1px solid var(--line-ink);border-bottom:1px solid var(--line-ink);
}
.marquee::before,.marquee::after{content:'';position:absolute;top:0;bottom:0;width:140px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(to right,var(--ink-2),transparent)}
.marquee::after{right:0;background:linear-gradient(to left,var(--ink-2),transparent)}
.marquee-track{display:flex;gap:3.2rem;align-items:center;width:max-content;animation:scrollX 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:flex;align-items:center;gap:.7rem;white-space:nowrap;
  font-family:var(--font-mono);font-size:.92rem;font-weight:500;letter-spacing:.06em;
  color:var(--on-ink-soft);text-transform:uppercase}
.marquee-item .icon{width:1.05rem;height:1.05rem;color:var(--accent)}
.marquee-item b{color:var(--accent);font-weight:700}
.marquee-sep{color:rgba(242,183,5,.35)}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* ========================= SECTIONS base ========================= */
section{position:relative}
.sec{padding:clamp(5rem,11vw,9rem) 0}
.sec.cream{background:var(--cream);color:var(--on-cream)}
.sec.cream-2{background:var(--cream-2);color:var(--on-cream)}
.sec.ink{background:linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 100%);color:var(--on-ink)}
.sec-head{max-width:720px;margin-bottom:clamp(2.5rem,5vw,4rem)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-title{font-family:var(--font-display);text-transform:uppercase;line-height:.95;
  font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:.01em;margin:1.1rem 0 0}
.sec.ink .sec-title{color:var(--cream)}
.sec-title .hl{color:var(--accent)}
.sec-sub{margin-top:1.2rem;color:var(--on-cream-soft);max-width:54ch}
.sec.ink .sec-sub{color:var(--on-ink-soft)}

/* ===== PRODUIT / CHRONO ===== */
.produit-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
@media(max-width:900px){.produit-grid{grid-template-columns:1fr}}
.feature-list{display:flex;flex-direction:column;gap:.8rem;margin-top:2rem}
.feature-row{
  display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 1.2rem;
  background:var(--cream-3);border:1px solid var(--line-cream);border-radius:16px;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.feature-row:hover{transform:translateX(6px);box-shadow:0 14px 34px -18px rgba(42,26,18,.4);border-color:rgba(217,144,47,.4)}
.feature-ic{width:42px;height:42px;flex-shrink:0;border-radius:12px;display:grid;place-items:center;
  background:rgba(217,144,47,.12);color:var(--accent-2)}
.feature-ic .icon{width:22px;height:22px}
.feature-row h4{font-family:var(--font-sf);font-size:1rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.15rem}
.feature-row p{font-size:.88rem;color:var(--on-cream-soft)}

/* device visual */
.device-stage{position:relative;display:grid;place-items:center}
.device-photo{
  position:relative;border-radius:24px;overflow:hidden;width:100%;
  background:radial-gradient(circle at 50% 40%,#fff,#efe2c6);
  border:1px solid var(--line-cream);
  box-shadow:0 50px 90px -40px rgba(42,26,18,.5);
}
.device-photo img{width:100%;aspect-ratio:1/1;object-fit:cover;mix-blend-mode:multiply}
.device-glow{position:absolute;inset:-10% ;background:radial-gradient(circle at 50% 60%,var(--glow),transparent 60%);
  filter:blur(30px);opacity:.5;z-index:-1}
.device-badge{
  position:absolute;left:1.1rem;bottom:1.1rem;
  display:flex;align-items:center;gap:.5rem;
  padding:.55rem 1rem;border-radius:100px;
  background:var(--ink);color:var(--cream);
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;
  box-shadow:0 14px 30px -12px rgba(0,0,0,.5);
}
.device-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--hop);box-shadow:0 0 8px var(--hop);animation:blink 2s infinite}

/* media strip */
.media-strip{display:grid;grid-template-columns:1.25fr 1fr;gap:1rem;margin-top:clamp(2.5rem,5vw,4rem)}
@media(max-width:760px){.media-strip{grid-template-columns:1fr}}
.media-cell{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line-cream);
  background:var(--cream-2);box-shadow:0 24px 50px -34px rgba(42,26,18,.5)}
.media-cell.tall{grid-row:span 1}
.media-cell img,.media-cell video{width:100%;height:100%;object-fit:cover;display:block}
.media-cell.v1{aspect-ratio:4/5}
.media-cell.v2{aspect-ratio:3/4}
.media-cell.v3{aspect-ratio:4/5}
.media-tag{position:absolute;left:.8rem;top:.8rem;padding:.3rem .8rem;border-radius:100px;
  background:rgba(28,17,10,.7);backdrop-filter:blur(6px);color:var(--cream);
  font-family:var(--font-mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase}
.media-note{position:absolute;left:0;right:0;bottom:0;padding:.7rem .9rem;
  background:linear-gradient(to top,rgba(20,12,6,.92),rgba(20,12,6,.55) 70%,transparent);
  color:var(--cream);font-family:var(--font-sf);font-size:.74rem;line-height:1.35;
  letter-spacing:-.005em;text-wrap:pretty}

/* ===== CONNECTÉ / WIFI ===== */
.wifi-grid{display:grid;grid-template-columns:1fr .85fr;gap:clamp(2rem,5vw,5rem);align-items:center}
@media(max-width:900px){.wifi-grid{grid-template-columns:1fr}}

/* sticky scrollytelling */
.wifi-scroll{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);margin-top:clamp(1.5rem,3vw,2.5rem)}
.wifi-visual{grid-column:2;grid-row:1}
.wifi-steps{grid-column:1;grid-row:1}
.wifi-sticky{position:sticky;top:0;height:100svh;display:flex;align-items:center;justify-content:center}
.wstep{min-height:100svh;display:flex;flex-direction:column;justify-content:center;gap:.9rem;
  opacity:.32;filter:saturate(.6);transition:opacity .5s ease,filter .5s ease}
.wstep.active{opacity:1;filter:none}
.wstep-num{font-family:var(--font-mono);font-size:.8rem;font-weight:700;letter-spacing:.24em;color:var(--accent)}
.wstep .feature-ic{width:56px;height:56px;border-radius:16px;background:rgba(242,183,5,.12);color:var(--accent);
  display:grid;place-items:center}
.wstep .feature-ic .icon{width:28px;height:28px}
.wstep h3{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);line-height:.98;
  text-transform:uppercase;letter-spacing:.01em;color:var(--cream)}
.wstep p{font-size:clamp(1rem,1.6vw,1.18rem);line-height:1.65;color:var(--on-ink-soft);max-width:42ch;text-wrap:pretty}
@media(max-width:900px){
  /* — Pas de scrollytelling sur mobile : iPhone en carrousel tactile + liste d'étapes lisible — */
  .wifi-scroll{display:flex;flex-direction:column;gap:1.6rem;margin-top:1.6rem}
  .wifi-visual,.wifi-steps{grid-column:auto;grid-row:auto}
  .wifi-sticky{position:static;height:auto;padding:0}
  .iphone-stage{gap:1.25rem}
  /* dots tactiles : zone de touche élargie (≥44px) */
  .idot{position:relative}
  .idot::after{content:'';position:absolute;inset:-16px}
  /* étapes : cartes statiques, pleinement lisibles, cliquables */
  .wifi-steps{display:flex;flex-direction:column;gap:1rem}
  .wstep{min-height:auto;opacity:1;filter:none;text-align:left;align-items:flex-start;
    gap:.6rem;padding:1.3rem 1.35rem;cursor:pointer;
    background:rgba(255,244,221,.03);border:1px solid var(--line-ink);border-radius:16px;
    transition:border-color .25s,background .25s}
  .wstep .feature-ic{width:46px;height:46px}
  .wstep .feature-ic .icon{width:24px;height:24px}
  .wstep h3{font-size:clamp(1.5rem,6vw,2rem)}
  .wstep p{margin:0;max-width:none}
  .wstep.active{border-color:rgba(242,183,5,.45);background:rgba(242,183,5,.07)}
}
@media(prefers-reduced-motion:reduce){
  .wifi-sticky{position:static;height:auto}
  .wstep{opacity:1;filter:none;min-height:auto;padding:2rem 0}
}
.wifi-feats{display:flex;flex-direction:column;gap:.7rem;margin-top:2rem}
.wifi-feat{display:flex;gap:1rem;align-items:flex-start;padding:1.15rem 1.2rem;border-radius:16px;
  background:rgba(255,244,221,.03);border:1px solid var(--line-ink);transition:background .3s,border-color .3s,transform .3s}
.wifi-feat:hover{background:rgba(79,111,47,.1);border-color:rgba(79,111,47,.45);transform:translateX(6px)}
.wifi-feat .feature-ic{background:rgba(79,111,47,.16);color:#9CC56A}
.wifi-feat h4{font-family:var(--font-sf);color:var(--cream);font-size:1rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.15rem}
.wifi-feat p{font-size:.88rem;color:var(--on-ink-soft)}
.wifi-text .eyebrow{color:#9CC56A}

/* phone mockup */
.phone{
  font-family:var(--font-sf);
  width:min(300px,82vw);margin:0 auto;border-radius:34px;padding:1.3rem;
  background:linear-gradient(180deg,#16100a,#0d0805);
  border:1px solid var(--line-ink);
  box-shadow:0 60px 120px -40px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.05);
}
.phone-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.3rem}
.phone-title{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.06em;color:var(--accent);text-transform:uppercase}
.phone-conn{display:flex;align-items:center;gap:.4rem;padding:.25rem .7rem;border-radius:100px;
  background:rgba(79,111,47,.16);border:1px solid rgba(79,111,47,.4);
  font-family:var(--font-mono);font-size:.58rem;letter-spacing:.12em;color:#9CC56A}
.phone-conn .dot{width:6px;height:6px;border-radius:50%;background:#9CC56A;box-shadow:0 0 6px #9CC56A;animation:blink 2s infinite}
.phone-label{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--on-ink-soft);margin:1.1rem 0 .6rem;display:flex;align-items:center;gap:.4rem}
.phone-label .icon{width:13px;height:13px}
.pcard{display:flex;align-items:center;gap:.7rem;padding:.65rem .7rem;border-radius:12px;
  background:rgba(242,183,5,.07);border:1px solid rgba(242,183,5,.12);margin-bottom:.45rem}
.pav{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;color:var(--ink)}
.pav .icon{width:18px;height:18px;stroke-width:2}
.pinfo{flex:1;min-width:0}
.pname{font-size:.84rem;color:var(--cream);font-weight:600}
.pbest{font-family:var(--font-mono);font-size:.66rem;color:var(--on-ink-soft)}
.pcrown{color:var(--accent)}
.pcrown .icon{width:16px;height:16px;fill:var(--accent);stroke:var(--accent)}
.rbar{display:flex;align-items:center;gap:.55rem;margin-bottom:.5rem}
.rbar .rn{font-size:.72rem;color:var(--on-ink-soft);width:48px;flex-shrink:0}
.rtrack{flex:1;height:7px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.rfill{height:100%;background:linear-gradient(to right,var(--amber),var(--gold));border-radius:4px;width:0;transition:width 1s cubic-bezier(.2,.9,.3,1)}
.rt{font-family:var(--font-mono);font-size:.66rem;color:var(--gold);width:38px;text-align:right}

/* ===== iPHONE MOCKUP (app réelle) ===== */
.iphone-stage{display:flex;flex-direction:column;align-items:center;gap:1.1rem}
.iphone{
  position:relative;width:min(288px,80vw);
  padding:11px;border-radius:54px;
  background:linear-gradient(155deg,#3a3a3e,#0e0e10 42%,#26262a);
  box-shadow:
    0 70px 130px -45px rgba(0,0,0,.85),
    0 0 0 1px rgba(255,255,255,.06) inset,
    0 1px 2px rgba(255,255,255,.18) inset;
}
.iphone::before{
  content:'';position:absolute;right:-2px;top:150px;width:3px;height:64px;border-radius:3px;
  background:linear-gradient(90deg,#37373b,#0c0c0e);
}
.iphone::after{
  content:'';position:absolute;left:-2px;top:120px;width:3px;height:34px;border-radius:3px;
  background:linear-gradient(90deg,#0c0c0e,#37373b);
  box-shadow:0 46px 0 #0c0c0e,0 46px 0 1px rgba(0,0,0,.2);
}
.iphone-screen{
  position:relative;border-radius:44px;overflow:hidden;
  aspect-ratio:369/800;background:#000;
  box-shadow:0 0 0 2px #000 inset;
}
.iphone-track{display:flex;height:100%;transition:transform .55s cubic-bezier(.5,.05,.2,1)}
.iphone-track img{flex:0 0 100%;width:100%;height:100%;object-fit:cover;display:block}
.iphone-island{
  position:absolute;top:21px;left:50%;transform:translateX(-50%);
  width:86px;height:25px;border-radius:100px;background:#000;z-index:5;
  box-shadow:0 0 0 1px rgba(255,255,255,.04);
}
.iphone-dots{display:flex;gap:.55rem;align-items:center}
.idot{
  width:8px;height:8px;border-radius:50%;border:none;cursor:pointer;padding:0;
  background:rgba(242,183,5,.28);transition:width .3s,background .3s;
}
.idot.active{width:24px;border-radius:100px;background:var(--accent);box-shadow:0 0 12px var(--glow)}
.iphone-cap{
  font-family:var(--font-sf);font-size:.82rem;font-weight:600;letter-spacing:-.005em;
  color:var(--on-ink);min-height:1.2em;text-align:center;transition:opacity .3s;
}

/* ===== COMMENT ÇA MARCHE ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:1rem;counter-reset:step}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}
.step{
  position:relative;padding:2rem 1.4rem 1.6rem;border-radius:18px;overflow:hidden;
  background:var(--cream-3);border:1px solid var(--line-cream);
  transition:transform .35s,box-shadow .35s,border-color .35s;
}
.step:hover{transform:translateY(-6px);box-shadow:0 24px 50px -24px rgba(42,26,18,.4);border-color:rgba(217,144,47,.4)}
.step-num{font-family:var(--font-mono);font-weight:700;font-size:.8rem;color:var(--accent-2);
  letter-spacing:.2em}
.step-ghost{position:absolute;right:-.5rem;top:-1.5rem;font-family:var(--font-display);
  font-size:7rem;line-height:1;color:rgba(217,144,47,.08)}
.step-ic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin:1rem 0 1.1rem;
  background:var(--ink);color:var(--accent)}
.step-ic .icon{width:24px;height:24px}
.step h4{font-family:var(--font-display);font-size:1.35rem;text-transform:uppercase;letter-spacing:.02em;margin-bottom:.5rem}
.step p{font-size:.88rem;color:var(--on-cream-soft);text-wrap:pretty}
.step p strong{color:var(--ink);font-weight:700}

/* ===== ÉVÉNEMENT ===== */
.event-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(2rem,5vw,4rem);align-items:center}
@media(max-width:900px){.event-grid{grid-template-columns:1fr}}
.event-photo{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line-ink);
  box-shadow:0 50px 100px -50px rgba(0,0,0,.8)}
.event-photo video,.event-photo img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}
.event-photo .grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,17,10,.85),transparent 55%)}
.event-photo-cap{position:absolute;left:1.2rem;bottom:1.1rem;right:1.2rem}
.event-photo-cap .t{font-family:var(--font-display);font-size:1.5rem;text-transform:uppercase;color:var(--cream);line-height:1}
.event-photo-cap .s{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;color:var(--accent);text-transform:uppercase;margin-top:.3rem}
.event-stats{display:flex;gap:1.5rem;margin:1.6rem 0 0;flex-wrap:wrap}
.estat .n{font-family:var(--font-display);font-size:2.6rem;color:var(--accent);line-height:1}
.estat .l{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--on-ink-soft);margin-top:.2rem}
.podium{margin-top:1.8rem;display:flex;flex-direction:column;gap:.5rem}
.prow{display:flex;align-items:center;gap:1rem;padding:.75rem 1.1rem;border-radius:12px;
  background:rgba(255,244,221,.03);border:1px solid var(--line-ink);transition:background .25s,transform .25s}
.prow:hover{background:rgba(242,183,5,.07);transform:translateX(4px)}
.prow.top{background:rgba(242,183,5,.08);border-color:rgba(242,183,5,.3)}
.prank{font-family:var(--font-display);font-size:1.3rem;width:34px;text-align:center;color:var(--on-ink-soft)}
.prow.top .prank{color:var(--accent)}
.pmedal{width:30px;height:30px;flex-shrink:0;display:grid;place-items:center;border-radius:50%}
.pmedal .icon{width:20px;height:20px}
.pname2{flex:1;color:var(--cream);font-weight:600;font-size:.95rem}
.ptime{font-family:var(--font-mono);font-weight:700;font-size:1.05rem;color:var(--gold);letter-spacing:.02em}

/* event page extras */
.event-back{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1.6rem;
  font-family:var(--font-sf);font-size:.86rem;font-weight:600;letter-spacing:-.005em;
  color:var(--on-ink-soft);text-decoration:none;transition:color .25s,transform .25s}
.event-back:hover{color:var(--accent);transform:translateX(-3px)}
.event-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:clamp(2.5rem,5vw,4rem)}

/* tournament request */
.tourn{
  margin-top:clamp(3rem,7vw,5.5rem);
  display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2rem,5vw,4rem);align-items:start;
  padding-top:clamp(2.5rem,5vw,3.5rem);border-top:1px solid var(--line-ink);
}
@media(max-width:900px){.tourn{grid-template-columns:1fr}}
.tourn-title{font-family:var(--font-display);text-transform:uppercase;line-height:.95;
  font-size:clamp(2.2rem,5vw,3.4rem);letter-spacing:.01em;color:var(--cream);margin:1rem 0 0}
.tourn-title .hl{color:var(--accent)}
.tourn-lede{margin-top:1.1rem;color:var(--on-ink-soft);max-width:46ch;text-wrap:pretty}
.tourn-lede strong{color:var(--cream);font-weight:700}
.tourn-points{list-style:none;margin:1.5rem 0 0;display:flex;flex-direction:column;gap:.7rem}
.tourn-points li{display:flex;align-items:center;gap:.7rem;font-size:.9rem;color:var(--on-ink)}
.tourn-points .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0;box-shadow:0 0 8px var(--glow)}

.tourn-form{
  background:rgba(255,244,221,.035);border:1px solid var(--line-ink);border-radius:20px;
  padding:clamp(1.5rem,3vw,2.2rem);display:flex;flex-direction:column;gap:1rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.tourn-form.shake{animation:tShake .45s cubic-bezier(.36,.07,.19,.97)}
@keyframes tShake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-7px)}40%,60%{transform:translateX(7px)}}
.tf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:560px){.tf-row{grid-template-columns:1fr}}
.tf-field{display:flex;flex-direction:column;gap:.45rem}
.tf-field>span{font-family:var(--font-sf);font-size:.78rem;font-weight:600;letter-spacing:-.005em;color:var(--on-ink-soft)}
.tf-field input,.tf-field textarea{
  font-family:var(--font-body);font-size:.92rem;color:var(--cream);
  background:rgba(28,17,10,.55);border:1px solid var(--line-ink);border-radius:11px;
  padding:.8rem .95rem;width:100%;transition:border-color .25s,background .25s,box-shadow .25s;resize:vertical;
}
.tf-field input::placeholder,.tf-field textarea::placeholder{color:rgba(183,154,120,.55)}
.tf-field input:focus,.tf-field textarea:focus{
  outline:none;border-color:var(--accent);background:rgba(28,17,10,.8);
  box-shadow:0 0 0 3px rgba(242,183,5,.12);
}
.tf-actions{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;margin-top:.3rem}
.tf-hint{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.02em;color:var(--on-ink-soft);max-width:30ch}
.tf-hint strong{color:var(--accent)}

/* ===== CTA ===== */
.cta{position:relative;overflow:hidden;text-align:center;
  padding:clamp(6rem,12vw,10rem) 1.2rem;
  background:radial-gradient(90% 80% at 50% 50%,rgba(217,144,47,.14),transparent 60%),linear-gradient(180deg,var(--ink-2),var(--ink))}
.cta .bubbles{opacity:.6}
.cta-inner{position:relative;z-index:3;max-width:760px;margin:0 auto}
.cta-title{font-family:var(--font-display);text-transform:uppercase;color:var(--cream);
  font-size:clamp(3rem,10vw,7rem);line-height:.9;letter-spacing:.01em}
.cta-title em{font-style:normal;color:var(--accent);display:block;text-shadow:0 0 50px var(--glow)}
.cta-sub{color:var(--on-ink-soft);margin:1.6rem auto 1.4rem;max-width:42ch}
.cta-price{font-family:var(--font-display);font-size:3.4rem;color:var(--accent);line-height:1;margin-bottom:.2rem}
.cta-price-note{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--on-ink-soft);margin-bottom:2rem}

/* ===== DISCLAIMER ===== */
.disclaimer{background:var(--ink-2);color:var(--on-ink-soft);padding:1.4rem 1.2rem;border-top:1px solid var(--line-ink)}
.disclaimer .wrap{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;align-items:center}
.disc-item{display:flex;align-items:center;gap:.7rem;font-size:.82rem;letter-spacing:.01em;max-width:46ch}
.disc-item .icon{width:1.3rem;height:1.3rem;color:var(--accent);flex-shrink:0}
.disc-item strong{color:var(--cream);font-weight:700}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.ccard{padding:1.8rem;border-radius:18px;text-align:center;background:var(--cream-3);
  border:1px solid var(--line-cream);transition:transform .3s,box-shadow .3s}
.ccard:hover{transform:translateY(-4px);box-shadow:0 24px 50px -28px rgba(42,26,18,.4)}
.ccard-ic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin:0 auto 1rem;
  background:rgba(217,144,47,.12);color:var(--accent-2)}
.ccard-ic .icon{width:24px;height:24px}
.ccard h4{font-size:.78rem;font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--on-cream-soft);margin-bottom:.6rem}
.ccard a{color:var(--accent-2);text-decoration:none;font-weight:600;word-break:break-word}
.ccard a:hover{text-decoration:underline}
.ccard .sub{color:var(--on-cream-soft);font-weight:600}
.ig-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.1rem;border-radius:100px;
  background:linear-gradient(135deg,#f09433,#dc2743,#bc1888);color:#fff !important;text-decoration:none !important;font-size:.85rem;transition:opacity .2s}
.ig-link:hover{opacity:.85}
.ig-link .icon{width:16px;height:16px}

.dual{display:grid;grid-template-columns:1fr 1.4fr;gap:1rem;margin-top:1rem}
@media(max-width:760px){.dual{grid-template-columns:1fr}}
.manual-card{padding:1.8rem;border-radius:18px;background:var(--ink);color:var(--on-ink);
  display:flex;flex-direction:column;justify-content:center;gap:.6rem}
.manual-card .eyebrow{color:var(--accent)}
.manual-card h4{font-family:var(--font-display);font-size:1.6rem;text-transform:uppercase;color:var(--cream)}
.manual-card p{font-size:.86rem;color:var(--on-ink-soft)}
.manual-card .btn{align-self:flex-start;margin-top:.4rem}
.legal{padding:1.8rem;border-radius:18px;background:var(--cream-3);border:1px solid var(--line-cream);border-left:3px solid var(--accent)}
.legal h4{font-family:var(--font-display);font-size:1.3rem;text-transform:uppercase;letter-spacing:.02em;margin-bottom:.9rem}
.legal p{font-size:.82rem;color:var(--on-cream-soft);margin-bottom:.7rem;line-height:1.75}
.legal p:last-child{margin-bottom:0}
.legal strong{color:var(--ink);font-weight:700}

/* henallux note */
.henallux{background:var(--cream-2);padding:1.6rem 1.2rem;text-align:center;border-top:1px solid var(--line-cream)}
.henallux p{font-size:.82rem;color:var(--on-cream-soft);letter-spacing:.01em}
.henallux strong{color:var(--ink)}
.henallux a{color:var(--accent-2);text-decoration:none;font-weight:600}
.henallux a:hover{text-decoration:underline}

/* ===== FOOTER ===== */
footer{background:var(--ink-2);color:var(--on-ink-soft);padding:clamp(3rem,6vw,4.5rem) 1.2rem 2.5rem;text-align:center;border-top:1px solid var(--line-ink)}
.footer-logo{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-display);
  font-size:1.7rem;letter-spacing:.05em;color:var(--accent);text-transform:uppercase;margin-bottom:1rem;cursor:default;user-select:none}
.footer-logo .mark{width:28px;height:28px}
.footer-text{font-size:.8rem;margin-bottom:.4rem;letter-spacing:.01em}
.footer-text a{color:var(--accent-2);text-decoration:none}
.footer-links{margin-top:.8rem;font-size:.78rem}
.footer-links a{color:var(--accent-2);text-decoration:none}
.footer-creator{margin-top:1.6rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.footer-creator img{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid rgba(242,183,5,.35);opacity:.85}
.footer-creator span{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;color:var(--on-ink-soft)}

/* ===== EASTER EGG POPUP ===== */
.egg-overlay{position:fixed;inset:0;z-index:500;display:grid;place-items:center;padding:1rem;
  background:radial-gradient(ellipse at center,rgba(242,183,5,.28),rgba(10,7,2,.92) 70%);
  backdrop-filter:blur(12px);opacity:0;pointer-events:none;transition:opacity .4s}
.egg-overlay.active{opacity:1;pointer-events:all}
.egg-popup{position:relative;width:100%;max-width:440px;padding:3rem 2rem 2.2rem;text-align:center;
  background:linear-gradient(160deg,#34230f,#1a1109);border:2px solid var(--accent);border-radius:22px;
  box-shadow:0 0 70px var(--glow),0 50px 110px rgba(0,0,0,.9);
  transform:translateY(40px) scale(.85) rotate(-3deg);transition:transform .5s cubic-bezier(.34,1.56,.64,1)}
.egg-overlay.active .egg-popup{transform:none}
.egg-close{position:absolute;top:.8rem;right:.8rem;width:34px;height:34px;border-radius:50%;cursor:pointer;
  background:rgba(28,17,10,.7);border:1px solid var(--accent);color:var(--accent);display:grid;place-items:center}
.egg-close .icon{width:18px;height:18px;stroke-width:2}
.egg-trophy{width:74px;height:74px;margin:0 auto .6rem;color:var(--accent);animation:eggBob 1.4s ease-in-out infinite}
.egg-trophy .icon{width:74px;height:74px;stroke-width:1.4}
@keyframes eggBob{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-9px) rotate(4deg)}}
.egg-title{font-family:var(--font-display);font-size:2.6rem;line-height:.95;color:var(--accent);
  text-transform:uppercase;text-shadow:0 0 26px var(--glow);margin-bottom:.4rem}
.egg-sub{color:var(--on-ink);font-size:1rem;margin-bottom:1.4rem;line-height:1.5}
.egg-sub strong{color:var(--gold)}
.egg-code-label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.36em;text-transform:uppercase;color:var(--on-ink-soft);margin-bottom:.6rem}
.egg-code{display:flex;align-items:center;justify-content:center;gap:.7rem;cursor:pointer;
  padding:1rem 1.2rem;border:1.5px dashed var(--accent);border-radius:12px;
  background:rgba(242,183,5,.1);font-family:var(--font-mono);font-weight:700;font-size:1.3rem;
  letter-spacing:.12em;color:var(--gold);transition:transform .2s,background .2s;margin-bottom:.8rem}
.egg-code:hover{transform:scale(1.02);background:rgba(242,183,5,.18)}
.egg-code .icon{width:18px;height:18px;color:var(--on-ink-soft)}
.egg-copied{display:none;font-family:var(--font-mono);font-size:.74rem;color:#9CC56A;margin-top:.5rem;letter-spacing:.06em}
.egg-copied.show{display:block;animation:upFade .3s ease forwards}
.egg-discount{display:inline-block;margin-top:.4rem;padding:.45rem 1.3rem;border-radius:100px;
  background:var(--accent);color:var(--ink);font-family:var(--font-display);font-size:1.2rem;letter-spacing:.06em}

/* ===== REVEAL ANIMATIONS ===== */
.js .reveal{opacity:0;transform:translateY(42px);transition:opacity .9s cubic-bezier(.2,.9,.3,1),transform .9s cubic-bezier(.2,.9,.3,1)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.r-left{transform:translateX(-48px)}
.js .reveal.r-right{transform:translateX(48px)}
.js .reveal.r-left.in,.js .reveal.r-right.in{transform:none}
.js .reveal.r-scale{transform:scale(.92);opacity:0}
.js .reveal.r-scale.in{transform:none;opacity:1}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto}
  .js .reveal{opacity:1 !important;transform:none !important}
  .hero .hero-eyebrow,.hero .w-beer,.hero .w-tap,.hero .hero-console,.hero .hero-actions,.hero .hero-specs,.hero .hero-product-img{opacity:1 !important;transform:none !important}
}

/* ===========================================================
   PHONE TUNING — affinage écrans tactiles (≤ 560px / ≤ 400px)
   =========================================================== */
@media(max-width:560px){
  /* — Inputs : 16px évite le zoom auto iOS au focus — */
  .tf-field input,.tf-field textarea{font-size:16px;padding:.9rem 1rem;border-radius:12px}
  .tf-field>span{font-size:.82rem}

  /* — Rythme vertical resserré — */
  .sec{padding:clamp(3.5rem,13vw,5rem) 0}
  .wrap{padding:0 1.15rem}

  /* — Nav plus compacte — */
  nav{padding:1rem 1.15rem}
  nav.scrolled{padding:.7rem 1.15rem}
  .nav-logo{font-size:1.45rem}
  .nav-logo .mark{width:25px;height:25px}
  .nav-burger{padding:.3rem;margin:-.3rem}
  .mobile-menu{gap:1.3rem}
  .mobile-menu a{font-size:1.7rem}

  /* — Hero : empilage net, CTA pleine largeur — */
  .hero{padding:7.25rem 1.15rem 3.75rem}
  .hero-inner{grid-template-columns:1fr;text-align:center;gap:1.4rem}
  .hero-text{align-items:center}
  .hero-eyebrow{justify-content:center}
  .hero-tagline{margin:1.6rem auto 0;max-width:none;font-size:1.02rem}
  .hero-actions{flex-direction:column;gap:1rem;width:100%;margin-top:2rem;justify-content:center}
  .hero-actions .btn{width:100%;justify-content:center}
  .hero-price{justify-content:center;text-align:center}
  .hero-specs{justify-content:center}
  .hero-product{order:-1}
  .hero-product-img{max-width:220px;border-radius:14px;transform:translateY(18px) rotate(0deg)}
  .hero-console{margin-top:2rem;padding:1.5rem 1.25rem 1.3rem}
  .chrono-actions{gap:.55rem}

  /* — Boutons confort tactile — */
  .btn{padding:1.05rem 1.7rem}
  .btn.lg{padding:1.15rem 1.7rem;font-size:1rem}

  /* — Titres de section — */
  .sec-title{font-size:clamp(2.45rem,12vw,3.4rem)}
  .sec-sub{margin-top:1rem}

  /* — Marquee un peu plus serré — */
  .marquee-track{gap:2.2rem}
  .marquee-item{font-size:.84rem}

  /* — Étapes : pile simple — */
  .step{padding:1.7rem 1.3rem 1.4rem}

  /* — Étapes WiFi resserrées — */
  .wstep{padding:1.2rem 1.25rem}

  /* — Événement — */
  .event-stats{gap:1.2rem}
  .estat .n{font-size:2.25rem}
  .event-photo-cap .t{font-size:1.35rem}
  .podium{margin-top:1.4rem}
  .prow{gap:.8rem;padding:.7rem .9rem}
  .prank{font-size:1.2rem;width:26px}
  .pname2{font-size:.9rem}
  .ptime{font-size:1rem}

  /* — Formulaire tournoi — */
  .tourn-form{padding:1.3rem}
  .tf-actions{flex-direction:column;align-items:stretch;gap:.9rem}
  .tf-actions .btn{width:100%;justify-content:center}
  .tf-hint{max-width:none;text-align:center}

  /* — Disclaimer / contact — */
  .disclaimer .wrap{gap:1.2rem}
  .disc-item{font-size:.85rem}

  /* — CTA finale pleine largeur — */
  .cta .btn.lg{width:100%;justify-content:center}

  /* — Footer — */
  .footer-logo{font-size:1.5rem}
}

/* — Encoches / safe-area (iPhone X+) — */
@supports(padding:max(0px)){
  nav{
    padding-top:max(1.3rem,env(safe-area-inset-top));
    padding-left:max(clamp(1.2rem,4vw,2.4rem),env(safe-area-inset-left));
    padding-right:max(clamp(1.2rem,4vw,2.4rem),env(safe-area-inset-right));
  }
  nav.scrolled{padding-top:max(.85rem,env(safe-area-inset-top))}
  .mobile-menu{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}
  .mobile-close{top:max(1.5rem,env(safe-area-inset-top))}
  footer{padding-bottom:max(2.5rem,calc(env(safe-area-inset-bottom) + 1.5rem))}
  .scroll-hint{bottom:max(1.6rem,calc(env(safe-area-inset-bottom) + .4rem))}
}

@media(max-width:400px){
  .hero-wordmark{font-size:clamp(3.6rem,21vw,5rem)}
  .chrono-readout{font-size:clamp(3rem,16vw,4.4rem)}
  .cta-title{font-size:clamp(2.7rem,13vw,4rem)}
  .sec-title{font-size:clamp(2.2rem,12vw,3rem)}
  .spec-chip{font-size:.74rem;padding:.45rem .85rem}
}
