/* ══════════════════════════════════════════
   BAD KING TATTOO — Grunge Royal Design System
   ══════════════════════════════════════════ */
:root {
  --void:#000;--abyss:#050505;--coal:#0c0c0c;--dark:#111;
  --gold:#d4a825;--gold-hot:#f5d442;--gold-dim:#a8841f;
  --gold-mist:rgba(212,168,37,.07);--gold-line:rgba(212,168,37,.1);
  --white:#fff;--cream:#ede5cc;
  --cream-50:rgba(237,229,204,.72);--cream-20:rgba(237,229,204,.2);
  --ash:#8a8576;--smoke:#2a2a2a;
  --gothic:'UnifrakturCook','UnifrakturMaguntia',cursive;
  --serif:'Cinzel',serif;
  --body:'Cormorant Garamond',serif;
  --raw:'Special Elite',cursive;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
img{max-width:100%;height:auto;display:block}
html{scroll-behavior:smooth;font-size:106.25%}
body{background:var(--void);color:var(--cream);font-family:var(--body);font-size:1.18rem;line-height:1.7;overflow-x:hidden}
/* Custom cursor only on fine-pointer devices (desktop with mouse) */
@media (pointer: fine) {
  body{cursor:none}
  /* But keep usable cursors inside form fields */
  input,textarea{cursor:text}
  select,button,a,summary,.soc,.btn,.burger,.faq-item summary,.page-back,.ft-links a{cursor:none}
}
/* Touch / coarse pointer: hide custom cursor entirely */
@media (pointer: coarse), (hover: none) {
  .cur,.cur-dot{display:none!important}
  body,*{cursor:auto!important}
  input,textarea{cursor:text!important}
  a,button,select,summary,.btn{cursor:pointer!important}
}

/* Keyboard focus visibility (WCAG) */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{
  outline:2px solid var(--gold);outline-offset:3px;border-radius:1px
}
::selection{background:var(--gold);color:var(--void)}
a{color:inherit;text-decoration:none}ul{list-style:none}
button,input,textarea,select{font:inherit;color:inherit}

/* Visually hidden but available to screen readers */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Skip-link (visible on focus, hidden otherwise) */
.skip-link{position:absolute;top:-100px;left:50%;transform:translateX(-50%);z-index:100001;font-family:var(--raw);font-size:.85rem;letter-spacing:3px;text-transform:uppercase;background:var(--gold);color:var(--void);padding:14px 24px;text-decoration:none;border:2px solid var(--void);transition:top .2s}
.skip-link:focus{top:12px;outline:none}

/* ═══ REDUCED MOTION ═══ */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  body,*{cursor:auto!important}
  a,button,select,summary,.btn,.soc,.burger,.faq-item summary,.page-back,.ft-links a{cursor:pointer!important}
  input,textarea{cursor:text!important}
  .cur,.cur-dot,.grain,.scanlines,#inkCanvas,.ink-drips,.ink-drop{display:none!important}
  .loader{display:none!important}
  .anim-fader{display:none!important}
  .sr,.sr-l,.sr-r{opacity:1!important;transform:none!important}
  .hero-splat{opacity:var(--op,.3)!important}
  .hero-logo{opacity:1!important;animation:none!important}
  .hero-sub,.hero-ctas,.scroll-cue{opacity:1!important;animation:none!important}
}

/* ═══ OVERLAYS ═══ */
.grain{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.07;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='5' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:150px;animation:grainShift 8s steps(10) infinite}
@keyframes grainShift{0%{transform:translate(0)}25%{transform:translate(-2px,1px)}50%{transform:translate(1px,-1px)}75%{transform:translate(-1px,2px)}100%{transform:translate(0)}}
.scanlines{position:fixed;inset:0;pointer-events:none;z-index:9997;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.04) 2px,rgba(0,0,0,.04) 4px);opacity:.5}
.vignette{position:fixed;inset:0;pointer-events:none;z-index:9996;background:radial-gradient(ellipse 70% 60% at 50% 50%,transparent 40%,rgba(0,0,0,.6) 100%)}
#inkCanvas{position:fixed;inset:0;z-index:1;pointer-events:none}

/* ═══ CURSOR ═══ */
.cur{position:fixed;width:16px;height:16px;border:2px solid var(--gold);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s;mix-blend-mode:difference}
.cur.big{width:70px;height:70px;background:rgba(212,168,37,.05)}
.cur-dot{position:fixed;width:5px;height:5px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%)}
.ink-drop{position:fixed;border-radius:50%;background:var(--gold);pointer-events:none;z-index:99998;opacity:.3;animation:inkFade 2s ease forwards}
@keyframes inkFade{0%{transform:scale(1);opacity:.3}100%{transform:scale(.3);opacity:0}}

/* ═══ LOADER ═══ */
.loader{position:fixed;inset:0;z-index:100000;background:var(--void);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;transition:opacity .8s,visibility .8s}
.loader.bye{opacity:0;visibility:hidden;pointer-events:none}
.loader-crown{width:90px;height:auto;opacity:0;animation:ldIn .8s ease .2s forwards;filter:contrast(1.4) brightness(1.1)}
.loader-txt{font-family:var(--raw);font-size:1rem;letter-spacing:8px;text-transform:uppercase;color:var(--ash);opacity:0;animation:ldIn .8s ease .5s forwards}
.loader-bar{width:180px;height:2px;background:var(--smoke);position:relative;overflow:hidden;margin-top:4px}
.loader-bar::after{content:'';position:absolute;left:0;top:0;height:100%;width:0;background:var(--gold);animation:ldBar 2.2s ease forwards}
@keyframes ldBar{to{width:100%}}
@keyframes ldIn{to{opacity:1}}

/* ═══ NAV ═══ */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 clamp(16px,4vw,48px);height:70px;display:flex;align-items:center;justify-content:space-between;transition:all .4s}
nav.solid{background:rgba(0,0,0,.93);border-bottom:2px solid rgba(212,168,37,.08)}
.nav-logo{height:80px;width:auto;filter:contrast(1.25) brightness(1.18) drop-shadow(0 2px 6px rgba(0,0,0,.45));transform-origin:32% 75%;transition:filter .35s,transform .35s cubic-bezier(.34,1.6,.5,1),height .35s}
.nav-logo:hover{filter:contrast(1.3) brightness(1.5) drop-shadow(0 0 14px rgba(212,168,37,.55));transform:rotate(-6deg) translateY(-2px)}
nav.solid .nav-logo{height:62px}
.nav-links{display:flex;gap:clamp(16px,3vw,36px)}
.nav-links a{font-family:var(--raw);font-size:1.05rem;letter-spacing:3px;text-transform:uppercase;color:rgba(237,229,204,.7);position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.76,0,.24,1)}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-links a.nav-cta{color:var(--gold);border:1px solid rgba(212,168,37,.45);padding:9px 16px;background:rgba(212,168,37,.05);transition:color .3s,background .3s,border-color .3s}
.nav-links a.nav-cta::after{content:none}
.nav-links a.nav-cta:hover{background:var(--gold);color:var(--void);border-color:var(--gold)}
.nav-links a.active{color:var(--gold)}
.nav-links a.active::after{transform:scaleX(1)}
.burger{display:none;background:none;border:none;padding:8px;z-index:10}
.burger span{display:block;width:28px;height:2px;background:var(--gold);margin:5px 0;transition:all .3s}
.burger.x span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ═══ HERO ═══ */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;z-index:2;overflow:hidden}
.hero-concrete{position:absolute;inset:0;background:radial-gradient(ellipse 50% 40% at 50% 45%,rgba(212,168,37,.05),transparent 70%),url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='c'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.035' numOctaves='6'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23c)' opacity='.04'/%3E%3C/svg%3E")}
.ink-drips{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:3;overflow:hidden}
.ink-drips--page{position:fixed;inset:0 0 auto 0;height:65vh;z-index:1}
.page-header{overflow:hidden}
#bricabrac-hero{position:relative;overflow:hidden}
.ink-drip{position:absolute;top:-5px;width:3px;border-radius:0 0 2px 2px;transform-origin:top;opacity:0}
@keyframes dripCycle{0%{height:0;opacity:0}6%{opacity:.5}55%{height:var(--len,200px);opacity:.18}78%{height:var(--len,200px);opacity:0}100%{height:var(--len,200px);opacity:0}}
.hero-splat{position:absolute;pointer-events:none;z-index:4;opacity:0;will-change:transform,opacity}
.hero-splat.in{animation:splatSmash .5s cubic-bezier(.22,1,.36,1) forwards}
@keyframes splatSmash{from{opacity:0;transform:var(--tf) scale(.4)}to{opacity:var(--op,.5);transform:translateY(var(--py,0px)) var(--tf) scale(1)}}
.hero-corners{position:absolute;inset:clamp(12px,3vw,40px);pointer-events:none;z-index:5}
.hc{position:absolute;width:50px;height:50px}.hc-h,.hc-v{position:absolute;background:var(--gold);opacity:.2}
.hc-h{height:2px;width:50px}.hc-v{width:2px;height:50px}
.hc--tl{top:0;left:0}.hc--tl .hc-h{top:0;left:0}.hc--tl .hc-v{top:0;left:0}
.hc--tr{top:0;right:0}.hc--tr .hc-h{top:0;right:0}.hc--tr .hc-v{top:0;right:0}
.hc--bl{bottom:0;left:0}.hc--bl .hc-h{bottom:0;left:0}.hc--bl .hc-v{bottom:0;left:0}
.hc--br{bottom:0;right:0}.hc--br .hc-h{bottom:0;right:0}.hc--br .hc-v{bottom:0;right:0}
.hero-inner{position:relative;z-index:6;text-align:center}
.hero-logo{width:min(600px,85vw);margin:0 auto;position:relative;opacity:0;animation:logoSlam 1.1s cubic-bezier(.16,1,.3,1) 2.4s forwards,logoBreath 7s ease-in-out 3.9s infinite;filter:drop-shadow(0 0 80px rgba(212,168,37,.12)) contrast(1.2);will-change:transform,filter}
.hero-logo .hl{display:block;width:100%;height:auto}
.hl-letters,.hl-crown{position:absolute;inset:0}
.hl-crown{transform-origin:52.8% 29.3%;will-change:transform,filter,opacity}
@keyframes logoSlam{
  0%{opacity:0;transform:scale(1.45) rotate(1.2deg);filter:blur(14px) brightness(1.9) drop-shadow(0 0 0 rgba(212,168,37,0)) contrast(1.2)}
  45%{opacity:1;transform:scale(.96) rotate(-.4deg);filter:blur(0) brightness(1.35) drop-shadow(0 0 95px rgba(212,168,37,.35)) contrast(1.2)}
  65%{transform:scale(1.025) rotate(.2deg);filter:blur(0) brightness(1.08) drop-shadow(0 0 75px rgba(212,168,37,.2)) contrast(1.2)}
  82%{transform:scale(.995) rotate(0deg)}
  100%{opacity:1;transform:scale(1) rotate(0deg);filter:blur(0) brightness(1) drop-shadow(0 0 80px rgba(212,168,37,.12)) contrast(1.2)}
}
@keyframes logoBreath{0%,100%{filter:drop-shadow(0 0 70px rgba(212,168,37,.1)) contrast(1.2)}50%{filter:drop-shadow(0 0 115px rgba(212,168,37,.22)) contrast(1.2)}}
/* Onde de choc à l'impact du logo (2 anneaux décalés) */
.logo-shock{position:absolute;top:50%;left:50%;width:46%;aspect-ratio:1;transform:translate(-50%,-50%) scale(.3);border:2px solid rgba(212,168,37,.5);border-radius:50%;opacity:0;pointer-events:none;filter:blur(1px)}
.logo-shock--2{border-width:1px;border-color:rgba(212,168,37,.3)}
@keyframes shockwave{0%{opacity:.75;transform:translate(-50%,-50%) scale(.3)}100%{opacity:0;transform:translate(-50%,-50%) scale(2.6)}}

/* ═══ VARIANTES D'ENTRÉE DU LOGO (tirage pondéré au chargement, cf. JS index) ═══
   av-1 Slam royal 16% · av-2 Encre montante 10% · av-3 Tampon 10% · av-4 Glitch 8%
   av-5 Forge 8% · av-6 Balayage 8% · av-7 Couronnement 7% · av-8 Aura 7%
   av-9 Battement 6% · av-10 Coulée 6% · av-11 Néon 5% · av-12 Profondeur 5% · av-13 Spectre 4%
   Les 13 sont chorégraphiées par calques (fond / lettrage / couronne). */
/* av-1 — Slam royal chorégraphié : le lettrage claque, la couronne tombe, le fond éclabousse */
.glitch-box.av-1 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.6s infinite}
.av-1 .hl-letters{opacity:0;animation:lettersSlam .9s cubic-bezier(.16,1,.3,1) 2.4s forwards}
.av-1 .hl-crown{opacity:0;animation:crownDrop .65s cubic-bezier(.34,1.4,.5,1) 3.25s forwards}
.av-1 .hl-bg{opacity:0;animation:bgSplash .8s ease-out 3.6s forwards}
.av-1 .logo-shock{left:52.8%;top:29.3%;width:36%;animation:shockwave .9s cubic-bezier(.22,1,.36,1) 3.5s forwards}
.av-1 .logo-shock--2{left:52.8%;top:29.3%;animation:shockwave 1.1s cubic-bezier(.22,1,.36,1) 3.62s forwards}
@keyframes lettersSlam{0%{opacity:0;transform:scale(1.4) rotate(1deg);filter:blur(12px) brightness(1.9)}45%{opacity:1;transform:scale(.96) rotate(-.3deg);filter:blur(0) brightness(1.3)}70%{transform:scale(1.02) rotate(.15deg);filter:brightness(1.05)}100%{opacity:1;transform:scale(1) rotate(0deg);filter:blur(0) brightness(1)}}
@keyframes crownDrop{0%{opacity:0;transform:translateY(-26%) scale(1.3);filter:blur(5px) brightness(1.6)}55%{opacity:1;transform:translateY(1.4%) scale(.94);filter:blur(0) brightness(1.35)}78%{transform:translateY(-.5%) scale(1.04);filter:brightness(1.1)}100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0) brightness(1)}}
@keyframes bgSplash{0%{opacity:0;transform:scale(.94);filter:blur(7px)}100%{opacity:1;transform:scale(1);filter:blur(0)}}

/* av-2 — Encre montante chorégraphiée : fond, lettrage, couronne remontent en escalier */
.glitch-box.av-2 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.4s infinite}
.av-2 .hl-bg{opacity:0;animation:layerRise 1s cubic-bezier(.22,1,.36,1) 2.4s forwards}
.av-2 .hl-letters{opacity:0;animation:layerRise 1s cubic-bezier(.22,1,.36,1) 2.7s forwards}
.av-2 .hl-crown{opacity:0;animation:crownRise 1.05s cubic-bezier(.22,1,.36,1) 3.05s forwards}
@keyframes layerRise{0%{opacity:0;transform:translateY(6%);filter:blur(8px) brightness(.6)}100%{opacity:1;transform:translateY(0);filter:blur(0) brightness(1)}}
@keyframes crownRise{0%{opacity:0;transform:translateY(9%);filter:blur(8px) brightness(.6)}70%{opacity:1;transform:translateY(-1.2%);filter:blur(0) brightness(1.15)}100%{opacity:1;transform:translateY(0);filter:blur(0) brightness(1)}}

/* av-3 — Triple tampon : fond, lettrage, couronne s'écrasent l'un après l'autre */
.glitch-box.av-3 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.4s infinite}
.av-3 .hl-bg{opacity:0;animation:layerStamp .5s cubic-bezier(.34,1.3,.5,1) 2.4s forwards}
.av-3 .hl-letters{opacity:0;animation:layerStamp .5s cubic-bezier(.34,1.3,.5,1) 2.78s forwards}
.av-3 .hl-crown{opacity:0;animation:crownStamp .55s cubic-bezier(.34,1.3,.5,1) 3.16s forwards}
@keyframes layerStamp{0%{opacity:0;transform:scale(1.9);filter:blur(5px) brightness(1.4)}55%{opacity:1;transform:scale(.96);filter:blur(0) brightness(1.3)}100%{opacity:1;transform:scale(1);filter:blur(0) brightness(1)}}
@keyframes crownStamp{0%{opacity:0;transform:scale(2.1) rotate(-4deg);filter:blur(5px) brightness(1.5)}55%{opacity:1;transform:scale(.93) rotate(.8deg);filter:blur(0) brightness(1.45)}100%{opacity:1;transform:scale(1) rotate(0deg);filter:blur(0) brightness(1)}}
.av-3 .logo-shock{left:52.8%;top:29.3%;width:36%;animation:shockwave .8s cubic-bezier(.22,1,.36,1) 3.42s forwards}
.av-3 .logo-shock--2{left:52.8%;top:29.3%;animation:shockwave 1s cubic-bezier(.22,1,.36,1) 3.55s forwards}

/* av-4 — Glitch en calques : lettrage et couronne sautent en opposition, le fond clignote */
.glitch-box.av-4 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 3.7s infinite}
.av-4 .hl-letters{opacity:0;animation:glitchA 1s linear 2.4s forwards}
.av-4 .hl-crown{opacity:0;animation:glitchB 1s linear 2.45s forwards}
.av-4 .hl-bg{opacity:0;animation:glitchFlicker .9s linear 2.4s forwards}
@keyframes glitchA{0%{opacity:0}8%{opacity:1;transform:translateX(-14px) skewX(3deg);filter:brightness(1.6) contrast(1.8)}16%{transform:translateX(9px) skewX(-2deg)}26%{opacity:.4;transform:translateX(-5px)}36%{opacity:1;transform:translateX(4px);filter:brightness(1.3) contrast(1.4)}52%{opacity:.6;transform:translateX(-2px)}68%{opacity:1;transform:translateX(1px)}100%{opacity:1;transform:translateX(0) skewX(0deg);filter:brightness(1) contrast(1)}}
@keyframes glitchB{0%{opacity:0}10%{opacity:1;transform:translateX(12px) skewX(-4deg);filter:brightness(1.8)}18%{transform:translateX(-8px) skewX(3deg)}30%{opacity:.3;transform:translateX(6px)}40%{opacity:1;transform:translateX(-4px)}58%{opacity:.7;transform:translateX(2px)}72%{opacity:1}100%{opacity:1;transform:translateX(0) skewX(0deg);filter:brightness(1)}}
@keyframes glitchFlicker{0%{opacity:0}12%{opacity:.8}18%{opacity:.15}28%{opacity:.9}38%{opacity:.3}55%{opacity:1}66%{opacity:.6}80%{opacity:1}100%{opacity:1}}

/* av-5 — Forge en calques : la couronne sort incandescente du feu, la chaleur se propage */
.glitch-box.av-5 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.6s infinite}
.av-5 .hl-crown{opacity:0;animation:forgeHot 1.5s ease-out 2.4s forwards}
.av-5 .hl-letters{opacity:0;animation:forgeWarm 1.2s ease-out 2.9s forwards}
.av-5 .hl-bg{opacity:0;animation:forgeEmber 1s ease-out 3.5s forwards}
@keyframes forgeHot{0%{opacity:0;transform:scale(1.06);filter:blur(6px) brightness(3) sepia(1) saturate(3) drop-shadow(0 0 60px rgba(245,212,66,.6))}40%{opacity:1;filter:blur(1px) brightness(1.9) sepia(.6) saturate(2) drop-shadow(0 0 40px rgba(245,212,66,.45))}100%{opacity:1;transform:scale(1);filter:blur(0) brightness(1) sepia(0) saturate(1) drop-shadow(0 0 0 rgba(245,212,66,0))}}
@keyframes forgeWarm{0%{opacity:0;filter:blur(8px) brightness(2) sepia(.8) saturate(2)}100%{opacity:1;filter:blur(0) brightness(1) sepia(0) saturate(1)}}
@keyframes forgeEmber{0%{opacity:0;filter:blur(4px) brightness(1.8) sepia(.7) saturate(2.2)}100%{opacity:1;filter:blur(0) brightness(1) sepia(0) saturate(1)}}

/* av-6 — Balayage en cascade : trois rideaux lumineux décalés, fond puis lettrage puis couronne */
.glitch-box.av-6 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 3.9s infinite}
.av-6 .hl-bg{opacity:0;animation:wipeIn 1s cubic-bezier(.65,0,.35,1) 2.4s forwards}
.av-6 .hl-letters{opacity:0;animation:wipeIn 1s cubic-bezier(.65,0,.35,1) 2.6s forwards}
.av-6 .hl-crown{opacity:0;animation:wipeIn .8s cubic-bezier(.65,0,.35,1) 2.85s forwards}
@keyframes wipeIn{0%{opacity:1;clip-path:inset(0 100% 0 0);transform:translateX(-3%);filter:blur(3px) brightness(1.4)}100%{opacity:1;clip-path:inset(0 0 0 0);transform:translateX(0);filter:blur(0) brightness(1)}}

/* av-7 — Couronnement : le lettrage attend, la couronne descend avec cérémonie */
.glitch-box.av-7 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 5.3s infinite}
.av-7 .hl-letters{opacity:0;animation:softUp 1s ease 2.4s forwards}
.av-7 .hl-bg{opacity:0;animation:bgSplash .9s ease-out 4.3s forwards}
.av-7 .hl-crown{opacity:0;animation:coronation 1.6s cubic-bezier(.45,0,.2,1) 3.1s forwards}
.av-7 .logo-shock{left:52.8%;top:29.3%;width:30%;border-width:1px;animation:shockwave 1.3s cubic-bezier(.22,1,.36,1) 4.45s forwards}
@keyframes softUp{0%{opacity:0;transform:translateY(3%);filter:blur(6px) brightness(.7)}100%{opacity:1;transform:translateY(0);filter:blur(0) brightness(1)}}
@keyframes coronation{0%{opacity:0;transform:translateY(-34%) scale(1.12);filter:blur(4px) brightness(2) drop-shadow(0 0 40px rgba(212,168,37,.6))}30%{opacity:1;filter:blur(1px) brightness(1.6) drop-shadow(0 0 30px rgba(212,168,37,.5))}85%{transform:translateY(.6%) scale(.99);filter:blur(0) brightness(1.2) drop-shadow(0 0 18px rgba(212,168,37,.35))}100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0) brightness(1) drop-shadow(0 0 0 rgba(212,168,37,0))}}

/* av-8 — Aura : la couronne est la source de lumière, son halo se contracte et révèle le reste */
.glitch-box.av-8 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.6s infinite}
.av-8 .hl-crown{opacity:0;animation:auraSource 1.5s ease-out 2.4s forwards}
.av-8 .hl-letters{opacity:0;animation:auraReveal 1.1s ease-out 3s forwards}
.av-8 .hl-bg{opacity:0;animation:auraReveal 1s ease-out 3.5s forwards}
@keyframes auraSource{0%{opacity:0;filter:blur(2px) brightness(.4) drop-shadow(0 0 150px rgba(212,168,37,.7))}45%{opacity:1;filter:blur(0) brightness(1.5) drop-shadow(0 0 90px rgba(212,168,37,.5))}100%{opacity:1;filter:blur(0) brightness(1) drop-shadow(0 0 0 rgba(212,168,37,0))}}
@keyframes auraReveal{0%{opacity:0;filter:blur(3px) brightness(.25)}100%{opacity:1;filter:blur(0) brightness(1)}}

/* av-9 — Battement en calques : premier battement sur tout le corps, second sur la couronne */
.glitch-box.av-9 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 3.9s infinite}
.av-9 .hl-letters,.av-9 .hl-bg{opacity:0;animation:beatBase 1.3s ease-in-out 2.4s forwards}
.av-9 .hl-crown{opacity:0;animation:beatCrown 1.3s ease-in-out 2.4s forwards}
.av-9 .logo-shock{left:52.8%;top:29.3%;width:36%;animation:shockwave .9s cubic-bezier(.22,1,.36,1) 3.18s forwards}
.av-9 .logo-shock--2{left:52.8%;top:29.3%;animation:shockwave 1.1s cubic-bezier(.22,1,.36,1) 3.32s forwards}
@keyframes beatBase{0%{opacity:0;transform:scale(.94);filter:blur(3px)}25%{opacity:1;transform:scale(1.03);filter:blur(0) brightness(1.15)}42%{transform:scale(.99);filter:brightness(1)}62%{transform:scale(1.02);filter:brightness(1.1)}80%{transform:scale(1)}100%{opacity:1;transform:scale(1);filter:blur(0) brightness(1)}}
@keyframes beatCrown{0%{opacity:0;transform:scale(.9);filter:blur(3px)}25%{opacity:1;transform:scale(1.04);filter:blur(0) brightness(1.2)}45%{transform:scale(.98)}62%{transform:scale(1.14);filter:brightness(1.45) drop-shadow(0 0 50px rgba(212,168,37,.5))}82%{transform:scale(.99);filter:brightness(1.05) drop-shadow(0 0 0 rgba(212,168,37,0))}100%{opacity:1;transform:scale(1);filter:brightness(1)}}

/* av-10 — Coulée en calques : l'encre descend de la couronne au lettrage puis au décor */
.glitch-box.av-10 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.2s infinite}
.av-10 .hl-crown{opacity:0;animation:dripIn .9s cubic-bezier(.65,0,.35,1) 2.4s forwards}
.av-10 .hl-letters{opacity:0;animation:dripIn 1.1s cubic-bezier(.65,0,.35,1) 2.7s forwards}
.av-10 .hl-bg{opacity:0;animation:dripIn 1s cubic-bezier(.65,0,.35,1) 3.1s forwards}
@keyframes dripIn{0%{opacity:1;clip-path:inset(0 0 100% 0);transform:translateY(-2.5%);filter:blur(3px) brightness(1.3)}100%{opacity:1;clip-path:inset(0 0 0 0);transform:translateY(0);filter:blur(0) brightness(1)}}

/* av-11 — Néon en calques : l'enseigne s'allume tube par tube, cadre, lettrage, couronne */
.glitch-box.av-11 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.3s infinite}
.av-11 .hl-bg{opacity:0;animation:neonOn 1s linear 2.4s forwards}
.av-11 .hl-letters{opacity:0;animation:neonOn 1.1s linear 2.75s forwards}
.av-11 .hl-crown{opacity:0;animation:neonCrown 1s linear 3.2s forwards}
@keyframes neonOn{0%{opacity:0}7%{opacity:1;filter:brightness(1.6)}12%{opacity:.15}20%{opacity:1;filter:brightness(1.45)}28%{opacity:.3}40%{opacity:1}52%{opacity:.55}66%{opacity:1;filter:brightness(1.2)}100%{opacity:1;filter:brightness(1)}}
@keyframes neonCrown{0%{opacity:0}10%{opacity:1;filter:brightness(2) drop-shadow(0 0 40px rgba(212,168,37,.6))}16%{opacity:.2}26%{opacity:1;filter:brightness(1.7) drop-shadow(0 0 30px rgba(212,168,37,.45))}36%{opacity:.4}50%{opacity:1;filter:brightness(1.4) drop-shadow(0 0 20px rgba(212,168,37,.3))}100%{opacity:1;filter:brightness(1) drop-shadow(0 0 0 rgba(212,168,37,0))}}

/* av-12 — Profondeur en calques : trois plans qui convergent depuis des distances différentes */
.glitch-box.av-12 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.1s infinite}
.av-12 .hl-bg{opacity:0;animation:depthIn 1.2s cubic-bezier(.16,1,.3,1) 2.4s forwards}
.av-12 .hl-letters{opacity:0;animation:depthMid 1.2s cubic-bezier(.16,1,.3,1) 2.55s forwards}
.av-12 .hl-crown{opacity:0;animation:depthFar 1.25s cubic-bezier(.16,1,.3,1) 2.7s forwards}
@keyframes depthIn{0%{opacity:0;transform:scale(1.7);filter:blur(8px) brightness(1.2)}75%{opacity:1}100%{opacity:1;transform:scale(1);filter:blur(0) brightness(1)}}
@keyframes depthMid{0%{opacity:0;transform:scale(2.4);filter:blur(14px) brightness(1.25)}75%{opacity:1}100%{opacity:1;transform:scale(1);filter:blur(0) brightness(1)}}
@keyframes depthFar{0%{opacity:0;transform:scale(3.4);filter:blur(18px) brightness(1.3)}75%{opacity:1}100%{opacity:1;transform:scale(1);filter:blur(0) brightness(1)}}

/* av-13 — Spectre en calques : lettrage et couronne dérivent en sens opposés et fusionnent */
.glitch-box.av-13 .hero-logo{opacity:1;animation:logoBreath 7s ease-in-out 4.1s infinite}
.av-13 .hl-letters{opacity:0;animation:phantomL 1.3s cubic-bezier(.22,1,.36,1) 2.4s forwards}
.av-13 .hl-crown{opacity:0;animation:phantomR 1.3s cubic-bezier(.22,1,.36,1) 2.5s forwards}
.av-13 .hl-bg{opacity:0;animation:ghostFade 1.2s ease 2.8s forwards}
@keyframes phantomL{0%{opacity:0;transform:translateX(-4%) skewX(7deg) scale(1.06);filter:blur(13px)}45%{opacity:.7;transform:translateX(1.6%) skewX(-4deg) scale(1.03);filter:blur(7px)}75%{opacity:1;transform:translateX(-.5%) skewX(1.5deg) scale(1.01);filter:blur(2px)}100%{opacity:1;transform:translateX(0) skewX(0deg) scale(1);filter:blur(0)}}
@keyframes phantomR{0%{opacity:0;transform:translateX(5%) skewX(-8deg) scale(1.08);filter:blur(13px)}45%{opacity:.7;transform:translateX(-2%) skewX(4deg) scale(1.04);filter:blur(7px)}75%{opacity:1;transform:translateX(.6%) skewX(-1.5deg) scale(1.01);filter:blur(2px)}100%{opacity:1;transform:translateX(0) skewX(0deg) scale(1);filter:blur(0)}}
@keyframes ghostFade{0%{opacity:0;filter:blur(8px) brightness(.6)}100%{opacity:1;filter:blur(0) brightness(1)}}


/* ═══ FADER ANIM (prévisualisation des 13 entrées du logo, façon pitch de platine) ═══ */
.anim-fader{position:absolute;right:14px;top:50%;transform:translateY(-50%);z-index:7;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.22;transition:opacity .3s}
.anim-fader:hover,.anim-fader:focus-within{opacity:.95}
.anim-fader-num{font-family:var(--gothic);font-size:1.1rem;color:var(--gold);line-height:1;min-width:2ch;text-align:center;text-shadow:1px 1px 0 rgba(0,0,0,.6)}
.anim-fader-track{height:150px;width:26px;display:flex;align-items:center;justify-content:center}
.anim-fader input{width:150px;transform:rotate(-90deg);-webkit-appearance:none;appearance:none;background:transparent;cursor:none;margin:0}
.anim-fader input::-webkit-slider-runnable-track{height:2px;background:repeating-linear-gradient(90deg,rgba(212,168,37,.7) 0,rgba(212,168,37,.7) 3px,rgba(212,168,37,.15) 3px,rgba(212,168,37,.15) 12.5px)}
.anim-fader input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:9px;height:18px;margin-top:-8px;background:var(--gold);border:1px solid var(--void);box-shadow:0 0 10px rgba(212,168,37,.5)}
.anim-fader input::-moz-range-track{height:2px;background:repeating-linear-gradient(90deg,rgba(212,168,37,.7) 0,rgba(212,168,37,.7) 3px,rgba(212,168,37,.15) 3px,rgba(212,168,37,.15) 12.5px)}
.anim-fader input::-moz-range-thumb{width:9px;height:18px;background:var(--gold);border:1px solid var(--void);border-radius:0;box-shadow:0 0 10px rgba(212,168,37,.5)}
.anim-fader-label{font-family:var(--raw);font-size:.55rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);opacity:.8;writing-mode:vertical-rl}
@media(max-width:900px){.anim-fader{display:none}}

/* Mode replay : la variante choisie au fader se joue immédiatement (sans le délai d'intro 2.4s) */
.glitch-box.av-now .hero-logo{animation-delay:0s,1.5s!important}
.av-now .logo-shock{animation-delay:.45s!important}
.av-now .logo-shock--2{animation-delay:.6s!important}
.glitch-box.av-now.av-9 .logo-shock{animation-delay:.78s!important}
.glitch-box.av-now.av-9 .logo-shock--2{animation-delay:.92s!important}
.glitch-box.av-now.av-4 .hl-letters,.glitch-box.av-now.av-4 .hl-bg{animation-delay:0s!important}
.glitch-box.av-now.av-4 .hl-crown{animation-delay:.05s!important}
.glitch-box.av-now.av-5 .hl-crown{animation-delay:0s!important}
.glitch-box.av-now.av-5 .hl-letters{animation-delay:.5s!important}
.glitch-box.av-now.av-5 .hl-bg{animation-delay:1.1s!important}
.glitch-box.av-now.av-6 .hl-bg{animation-delay:0s!important}
.glitch-box.av-now.av-6 .hl-letters{animation-delay:.2s!important}
.glitch-box.av-now.av-6 .hl-crown{animation-delay:.45s!important}
.glitch-box.av-now.av-8 .hl-crown{animation-delay:0s!important}
.glitch-box.av-now.av-8 .hl-letters{animation-delay:.6s!important}
.glitch-box.av-now.av-8 .hl-bg{animation-delay:1.1s!important}
.glitch-box.av-now.av-9 .hl-letters,.glitch-box.av-now.av-9 .hl-bg,.glitch-box.av-now.av-9 .hl-crown{animation-delay:0s!important}
.glitch-box.av-now.av-10 .hl-crown{animation-delay:0s!important}
.glitch-box.av-now.av-10 .hl-letters{animation-delay:.3s!important}
.glitch-box.av-now.av-10 .hl-bg{animation-delay:.7s!important}
.glitch-box.av-now.av-11 .hl-bg{animation-delay:0s!important}
.glitch-box.av-now.av-11 .hl-letters{animation-delay:.35s!important}
.glitch-box.av-now.av-11 .hl-crown{animation-delay:.8s!important}
.glitch-box.av-now.av-12 .hl-bg{animation-delay:0s!important}
.glitch-box.av-now.av-12 .hl-letters{animation-delay:.15s!important}
.glitch-box.av-now.av-12 .hl-crown{animation-delay:.3s!important}
.glitch-box.av-now.av-13 .hl-letters{animation-delay:0s!important}
.glitch-box.av-now.av-13 .hl-crown{animation-delay:.1s!important}
.glitch-box.av-now.av-13 .hl-bg{animation-delay:.4s!important}
.glitch-box.av-now.av-1 .hl-letters{animation-delay:0s!important}
.glitch-box.av-now.av-1 .hl-crown{animation-delay:.85s!important}
.glitch-box.av-now.av-1 .hl-bg{animation-delay:1.2s!important}
.glitch-box.av-now.av-1 .logo-shock{animation-delay:1.1s!important}
.glitch-box.av-now.av-1 .logo-shock--2{animation-delay:1.22s!important}
.glitch-box.av-now.av-2 .hl-bg{animation-delay:0s!important}
.glitch-box.av-now.av-2 .hl-letters{animation-delay:.3s!important}
.glitch-box.av-now.av-2 .hl-crown{animation-delay:.65s!important}
.glitch-box.av-now.av-3 .hl-bg{animation-delay:0s!important}
.glitch-box.av-now.av-3 .hl-letters{animation-delay:.38s!important}
.glitch-box.av-now.av-3 .hl-crown{animation-delay:.76s!important}
.glitch-box.av-now.av-3 .logo-shock{animation-delay:1.02s!important}
.glitch-box.av-now.av-3 .logo-shock--2{animation-delay:1.15s!important}
.glitch-box.av-now.av-7 .hl-letters{animation-delay:0s!important}
.glitch-box.av-now.av-7 .hl-crown{animation-delay:.7s!important}
.glitch-box.av-now.av-7 .hl-bg{animation-delay:1.9s!important}
.glitch-box.av-now.av-7 .logo-shock{animation-delay:2.05s!important}


.glitch-box{position:relative;display:inline-block}
.glitch-box::before,.glitch-box::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background-image:inherit;background-size:contain;background-repeat:no-repeat;background-position:center;pointer-events:none;opacity:0}
.glitch-box:hover::before{opacity:.7;animation:g1 .15s steps(2) 3;clip-path:polygon(0 15%,100% 15%,100% 35%,0 35%);mix-blend-mode:lighten}
.glitch-box:hover::after{opacity:.7;animation:g2 .15s steps(2) 3;clip-path:polygon(0 55%,100% 55%,100% 80%,0 80%);mix-blend-mode:lighten}
@keyframes g1{0%{transform:translate(-4px,2px)}50%{transform:translate(4px,-2px)}100%{transform:translate(-2px,1px)}}
@keyframes g2{0%{transform:translate(3px,-1px)}50%{transform:translate(-3px,2px)}100%{transform:translate(2px,-2px)}}
.hero-sub{font-family:var(--raw);font-size:clamp(.65rem,1.5vw,.85rem);letter-spacing:5px;text-transform:uppercase;color:var(--gold-dim);margin-top:36px;opacity:0;animation:fadeUp 1s ease 2.9s forwards;position:relative}
.hero-sub::after{content:'';position:absolute;bottom:-10px;left:15%;width:70%;height:2px;background:repeating-linear-gradient(90deg,var(--gold) 0,var(--gold) 8px,transparent 8px,transparent 14px);opacity:.25}
.hero-ctas{display:flex;gap:16px;margin-top:52px;opacity:0;animation:fadeUp 1s ease 3.1s forwards;flex-wrap:wrap;justify-content:center}
.btn{font-family:var(--raw);font-size:.95rem;letter-spacing:5px;text-transform:uppercase;padding:16px 40px;position:relative;overflow:hidden;border:2px solid var(--gold);background:transparent;color:var(--gold);transition:color .3s,text-shadow .3s}
.btn::before{content:'';position:absolute;inset:0;background:var(--gold);z-index:-1;transform:translateX(-102%);transition:transform .4s cubic-bezier(.76,0,.24,1)}
.btn:hover{color:var(--void);text-shadow:0 0 10px rgba(0,0,0,.5)}.btn:hover::before{transform:translateX(0)}
.btn--solid{background:var(--gold);color:var(--void);animation:btnGlow 3.2s ease-in-out 4s infinite;transition:transform .3s,background .3s,border-color .3s,box-shadow .3s}
.btn--solid::before{content:none}
.btn--solid:hover{background:var(--gold-hot);border-color:var(--gold-hot);color:var(--void);transform:translateY(-2px);box-shadow:0 10px 30px rgba(212,168,37,.35)}
@keyframes btnGlow{0%,100%{box-shadow:0 0 14px rgba(212,168,37,.18)}50%{box-shadow:0 0 34px rgba(212,168,37,.45)}}
.btn--ghost{background:rgba(0,0,0,.35);color:var(--cream);border-color:rgba(212,168,37,.45)}
.btn--ghost:hover{color:var(--void);border-color:var(--gold)}

.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);opacity:0;animation:fadeUp 1s ease 3.8s forwards;z-index:6;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue span{font-family:var(--raw);font-size:.7rem;letter-spacing:5px;text-transform:uppercase;color:var(--ash)}
.scroll-arrow{width:1px;height:40px;background:linear-gradient(180deg,var(--gold),transparent);animation:sPulse 2s ease-in-out infinite}
@keyframes sPulse{0%,100%{opacity:1;height:40px}50%{opacity:.2;height:18px}}
@keyframes fadeUp{from{opacity:0;transform:translateY(25px)}to{opacity:1;transform:translateY(0)}}

/* ═══ PAGE HEADER (for subpages) ═══ */
.page-header{padding:clamp(110px,16vw,135px) 48px 48px;position:relative;z-index:2;text-align:center}
.page-header .s-title{text-align:center}
.page-header .s-eyebrow{justify-content:center}
.page-back{font-family:var(--raw);font-size:.7rem;letter-spacing:4px;text-transform:uppercase;color:var(--ash);display:inline-flex;align-items:center;gap:8px;margin-bottom:24px;transition:color .3s}
.page-back:hover{color:var(--gold)}

/* ═══ TEXT BANDS ═══ */
.text-band{overflow:hidden;padding:14px 0;position:relative;z-index:2;border-top:2px solid rgba(212,168,37,.06);border-bottom:2px solid rgba(212,168,37,.06);background:var(--abyss)}
.tb-track{display:flex;gap:40px;animation:tbScroll 20s linear infinite;width:max-content}
.tb-item{font-family:var(--gothic);font-size:clamp(1.2rem,2.5vw,2rem);white-space:nowrap;display:flex;align-items:center;gap:40px;-webkit-text-stroke:1px rgba(212,168,37,.12)}
.tb-item::after{content:'✦';font-size:.6rem;-webkit-text-stroke:0}
@keyframes tbScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ═══ TORN DIVIDER ═══ */
.tear{position:relative;z-index:2;height:50px;overflow:hidden}
.tear svg{position:absolute;width:100%;height:50px}.tear--up svg{bottom:0;left:0}
.tear--down svg{top:0;left:0;transform:scaleY(-1)}
.tear-f{fill:var(--abyss)}.tear-s{fill:none;stroke:var(--gold);stroke-width:.4;opacity:.15}

/* ═══ SECTIONS ═══ */
section{padding:clamp(56px,9vw,110px) clamp(16px,5vw,60px);position:relative;z-index:2;overflow:hidden}
.s-head{margin-bottom:80px;position:relative}
.s-eyebrow{font-family:var(--raw);font-size:1.18rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold);display:inline-flex;padding:5px 14px;border:1px solid var(--gold-line);background:rgba(212,168,37,.03);transform:rotate(-1deg);position:relative}
.s-title{font-family:var(--gothic);font-size:clamp(3rem,8vw,6rem);color:var(--white);margin-top:16px;position:relative;text-shadow:4px 4px 0 rgba(212,168,37,.06),-2px -2px 0 rgba(0,0,0,.6)}
.s-title::after{content:attr(data-t);position:absolute;left:6px;top:6px;z-index:-1;color:transparent;-webkit-text-stroke:1px rgba(212,168,37,.04);filter:blur(4px)}
.s-num{position:absolute;top:-60px;right:0;font-family:var(--gothic);font-size:clamp(5rem,20vw,18rem);color:transparent;-webkit-text-stroke:1px rgba(212,168,37,.03);pointer-events:none;user-select:none;line-height:.75}
.sec-splat{position:absolute;pointer-events:none;z-index:0}

/* ═══ ABOUT ═══ */
#about{background:var(--void)}
.about-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.3fr .8fr;gap:60px;align-items:start}
.about-prose{padding-top:40px}.about-prose p{color:var(--cream-50);font-size:1.18rem;margin-bottom:24px}
.about-prose p:first-of-type::first-letter{font-family:var(--gothic);font-size:5rem;float:left;line-height:.6;margin:8px 16px 0 0;color:var(--gold);text-shadow:3px 3px 0 rgba(212,168,37,.08)}
.about-vis{position:relative;transform:rotate(1.5deg)}
.about-frame{aspect-ratio:3/4;position:relative;background:var(--coal);border:2px solid rgba(212,168,37,.1);box-shadow:8px 8px 0 rgba(212,168,37,.04),-4px -4px 0 rgba(0,0,0,.3)}
.about-frame .about-img{position:absolute;inset:0}
.about-img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.3) contrast(1.05);transition:filter .6s ease}
.about-frame:hover .about-img{filter:grayscale(0) contrast(1.1)}
.about-tape{position:absolute;top:15%;left:-10px;width:calc(100% + 20px);height:28px;background:rgba(212,168,37,.06);transform:rotate(-3deg);z-index:4;border-top:1px solid rgba(212,168,37,.1);border-bottom:1px solid rgba(212,168,37,.1)}
.about-stats{display:flex;gap:0;margin-top:60px}
.a-stat{text-align:center;flex:1;padding:24px 10px;position:relative}.a-stat+.a-stat{border-left:1px solid var(--gold-line)}
.a-num{font-family:var(--gothic);font-size:2.5rem;color:var(--gold);line-height:1;text-shadow:2px 2px 0 rgba(212,168,37,.06)}
.a-label{font-family:var(--raw);font-size:.75rem;letter-spacing:3px;text-transform:uppercase;color:var(--ash);margin-top:6px}
.about-quote{grid-column:1/-1;text-align:center;padding:60px 20px;margin-top:40px;position:relative}
.about-quote::before{content:'';position:absolute;top:50%;left:50%;width:350px;height:200px;transform:translate(-50%,-50%);background:radial-gradient(ellipse,rgba(212,168,37,.04),transparent 70%);border-radius:50%;filter:blur(30px)}
.about-quote blockquote{font-family:var(--body);font-style:italic;font-size:1.6rem;color:rgba(237,229,204,.6);max-width:650px;margin:0 auto;line-height:1.6;position:relative}
.about-quote em{color:var(--gold);font-style:italic}
.about-quote blockquote::before{content:'"';font-family:var(--gothic);font-size:10rem;color:rgba(212,168,37,.04);position:absolute;top:-60px;left:-40px;line-height:1}

/* ═══ PROCESS ═══ */
#process{background:var(--abyss)}
.steps{max-width:900px;margin:0 auto;position:relative}
.steps::before{content:'';position:absolute;top:0;left:38px;width:2px;height:100%;background:repeating-linear-gradient(180deg,var(--gold) 0,var(--gold) 6px,transparent 6px,transparent 12px);opacity:.12}
.step{display:flex;gap:36px;align-items:flex-start;margin-bottom:64px;position:relative}.step:last-child{margin-bottom:0}
.step-marker{width:76px;min-width:76px;text-align:center;position:relative}
.step-n{font-family:var(--gothic);font-size:2rem;color:var(--gold);position:relative;z-index:2}
.step-blot{position:absolute;top:50%;left:50%;width:60px;height:50px;transform:translate(-50%,-50%);background:radial-gradient(ellipse,rgba(212,168,37,.08),transparent 65%);border-radius:50% 40% 55% 45%;filter:blur(4px)}
.step-t{font-family:var(--raw);font-size:1rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.step-d{color:var(--ash);font-size:1.5rem;line-height:1.5;max-width:500px}

/* ═══ CONTACT / RENDEZ-VOUS ═══ */
/* ─── Section rendez-vous repensée ─── */
#contact {
  position: relative;
  padding: clamp(56px, 9vw, 100px) clamp(16px, 5vw, 60px) clamp(56px, 8vw, 90px);
  background: var(--void);
  overflow: hidden;
}
#contact::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(212,168,37,.04), transparent 60%),
    radial-gradient(ellipse 50% 40% at 50% 100%, rgba(212,168,37,.03), transparent 60%);
  pointer-events: none;
  z-index: 0;
}
#contact > * { position: relative; z-index: 1; }

/* Intro / accroche sous le titre */
.rdv-intro {
  max-width: 720px;
  margin: 24px auto 0;
  text-align: center;
  font-family: var(--body);
  font-style: italic;
  font-size: clamp(1.1rem, 1.6vw, 1.3rem);
  line-height: 1.6;
  color: var(--cream);
}
.rdv-intro em { color: var(--gold); font-style: italic; }

/* ─── Process en 3 étapes ─── */
.rdv-process {
  max-width: 1100px;
  margin: clamp(50px, 7vw, 90px) auto clamp(40px, 6vw, 70px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  position: relative;
}
.rdv-process::before {
  content: '';
  position: absolute;
  top: 44px;
  left: 16%;
  right: 16%;
  height: 1px;
  background: repeating-linear-gradient(90deg, var(--gold-line) 0, var(--gold-line) 6px, transparent 6px, transparent 12px);
  z-index: 0;
}

.rdv-step {
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 0 14px;
}
.rdv-step-num {
  width: 64px;
  height: 64px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--gothic);
  font-size: 1.8rem;
  color: var(--gold);
  background: var(--void);
  border: 1px solid var(--gold-line);
  border-radius: 50%;
  position: relative;
  text-shadow: 2px 2px 0 rgba(212,168,37,.08);
}
.rdv-step-num::after {
  content: '';
  position: absolute;
  inset: -5px;
  border: 1px solid var(--gold-line);
  border-radius: 50%;
  opacity: .5;
}
.rdv-step:hover .rdv-step-num {
  border-color: rgba(212,168,37,.4);
  transition: border-color .4s;
}
.rdv-step-title {
  font-family: var(--serif);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--white);
  margin-bottom: 12px;
}
.rdv-step-desc {
  font-family: var(--body);
  font-size: 1rem;
  line-height: 1.55;
  color: var(--cream-50);
  max-width: 260px;
  margin: 0 auto;
}

/* ─── CTA principaux : Insta + Tél ─── */
.rdv-cta-wrap {
  max-width: 880px;
  margin: 0 auto clamp(50px, 7vw, 80px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.rdv-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 14px;
  padding: 40px 28px;
  background: linear-gradient(155deg, var(--coal) 0%, rgba(15,12,9,0.95) 100%);
  border: 1px solid var(--gold-line);
  text-decoration: none;
  color: var(--cream);
  position: relative;
  transition: border-color .4s, transform .4s, background .4s;
  overflow: hidden;
}
.rdv-cta::before,
.rdv-cta::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  border: 1px solid var(--gold);
  opacity: 0;
  transition: opacity .4s;
}
.rdv-cta::before { top: -7px; right: -7px; border-left: none; border-bottom: none; }
.rdv-cta::after  { bottom: -7px; left: -7px;  border-right: none; border-top: none; }
.rdv-cta:hover {
  border-color: rgba(212,168,37,.4);
  transform: translateY(-3px);
}
.rdv-cta:hover::before,
.rdv-cta:hover::after { opacity: .7; }

.rdv-cta-icon {
  width: 48px;
  height: 48px;
  color: var(--gold);
  margin-bottom: 4px;
}
.rdv-cta-icon svg { width: 100%; height: 100%; }
.rdv-cta-label {
  font-family: var(--raw);
  font-size: .75rem;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--gold);
  opacity: .75;
}
.rdv-cta-value {
  font-family: var(--gothic);
  font-size: clamp(1.6rem, 2.4vw, 2.1rem);
  line-height: 1.1;
  color: var(--white);
  text-shadow: 2px 2px 0 rgba(212,168,37,.06);
}
.rdv-cta-hint {
  font-family: var(--body);
  font-style: italic;
  font-size: .95rem;
  color: var(--cream-50);
  margin-top: 2px;
}
.rdv-cta--primary { border-left: 3px solid var(--gold); }

/* ─── Infos pratiques (adresse + horaires) ─── */
.rdv-infos {
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  padding-top: clamp(40px, 5vw, 60px);
  border-top: 1px solid var(--gold-line);
}
.rdv-info-block {
  padding: 6px 4px;
}
.rdv-info-eyebrow {
  font-family: var(--raw);
  font-size: .7rem;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--gold);
  opacity: .7;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.rdv-info-eyebrow::before {
  content: '♛';
  font-family: var(--gothic);
  font-size: 1rem;
  opacity: .8;
}
.rdv-info-title {
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--white);
  margin-bottom: 12px;
}
.rdv-info-block p {
  font-family: var(--body);
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--cream);
  margin-bottom: 8px;
}
.rdv-info-block a {
  color: var(--cream);
  text-decoration: none;
  border-bottom: 1px solid var(--gold-line);
  transition: color .3s, border-color .3s;
}
.rdv-info-block a:hover {
  color: var(--gold);
  border-color: var(--gold);
}
.rdv-zone {
  font-family: var(--body);
  font-style: italic;
  font-size: .92rem;
  color: var(--cream-50);
  margin-top: 8px;
}
.rdv-hours-line {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(212,168,37,.08);
  font-family: var(--body);
  font-size: 1rem;
}
.rdv-hours-line:last-child { border-bottom: none; }
.rdv-hours-day {
  color: var(--cream-50);
  letter-spacing: 1px;
}
.rdv-hours-time {
  color: var(--cream);
  font-family: var(--raw);
  font-size: .85rem;
  letter-spacing: 2px;
}
.rdv-hours-closed .rdv-hours-time {
  color: rgba(237,229,204,.3);
  font-style: italic;
}

/* ─── Réseaux secondaires en bas ─── */
.rdv-socials {
  max-width: 1000px;
  margin: clamp(40px, 5vw, 60px) auto 0;
  padding-top: clamp(30px, 4vw, 40px);
  border-top: 1px solid var(--gold-line);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  text-align: center;
}
.rdv-socials-label {
  font-family: var(--raw);
  font-size: .7rem;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--cream-50);
}
.rdv-socials-row {
  display: flex;
  gap: 16px;
  align-items: center;
}
.rdv-socials-row .soc {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--gold-line);
  color: var(--gold);
  transition: border-color .3s, transform .3s, background .3s;
}
.rdv-socials-row .soc:hover {
  border-color: var(--gold);
  background: rgba(212,168,37,.08);
  transform: translateY(-2px);
}
.rdv-socials-row .soc svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: var(--gold);
  stroke-width: 1.5;
}

/* ─── Responsive ─── */
@media (max-width: 780px) {
  .rdv-process {
    grid-template-columns: 1fr;
    gap: 36px;
    max-width: 420px;
  }
  .rdv-process::before { display: none; }
  .rdv-cta-wrap {
    grid-template-columns: 1fr;
    max-width: 420px;
  }
  .rdv-infos {
    grid-template-columns: 1fr;
    gap: 36px;
  }
}

/* ═══ FOOTER ═══ */
footer{padding:50px clamp(16px,5vw,48px) 30px;text-align:center;position:relative;z-index:2}
footer::before{content:'';position:absolute;top:0;left:5%;width:90%;height:2px;background:linear-gradient(90deg,transparent,rgba(212,168,37,.1),var(--gold),rgba(212,168,37,.1),transparent)}
.ft-crown{width:50px;height:auto;margin:0 auto 14px;filter:contrast(1.3)}
.ft-links{display:flex;justify-content:center;gap:24px;margin-bottom:14px;flex-wrap:wrap}
.ft-links a{font-family:var(--raw);font-size:.75rem;letter-spacing:4px;text-transform:uppercase;color:rgba(237,229,204,.6);transition:color .3s}.ft-links a:hover{color:var(--gold)}
.ft-copy{font-family:var(--raw);font-size:.9rem;letter-spacing:4px;text-transform:uppercase;color:rgba(212, 168, 37, .62);}

/* ═══ SCROLL REVEAL ═══ */
.sr{opacity:0;transform:translateY(50px);transition:all 1s cubic-bezier(.22,1,.36,1)}
.sr.v{opacity:1;transform:translateY(0)}
.sr-l{opacity:0;transform:translateX(-60px) rotate(-1deg);transition:all 1s cubic-bezier(.22,1,.36,1)}
.sr-r{opacity:0;transform:translateX(60px) rotate(1deg);transition:all 1s cubic-bezier(.22,1,.36,1)}
.sr-l.v,.sr-r.v{opacity:1;transform:translateX(0) rotate(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}.d6{transition-delay:.6s}

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px){
  nav{padding:0 16px}
  /* Nav compacte inline : le burger n'apparaît qu'en dessous de 540px */
  .nav-links{gap:13px}
  .nav-links a{font-size:.82rem;letter-spacing:1px}
  .nav-links a.nav-cta{padding:7px 10px}
  .nav-logo{height:58px}
  nav.solid .nav-logo{height:48px}
  .about-grid{grid-template-columns:1fr;gap:40px}.about-vis{max-width:340px;transform:rotate(0)}
  .steps::before{left:28px}.step-marker{width:56px;min-width:56px}
  .hero-ctas{flex-direction:column;align-items:center}
  .hero-splat{max-width:120px}.about-tape{display:none}
  .page-header{padding:104px 20px 36px}
}
@media(max-width:640px){
  .nav-links{gap:10px}
  .nav-links a{font-size:.76rem;letter-spacing:.5px}
  .nav-links a.nav-cta{padding:6px 8px}
}
@media(max-width:540px){
  .nav-links{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.98);flex-direction:column;align-items:center;justify-content:center;gap:24px;transform:translateX(100%);transition:transform .5s cubic-bezier(.76,0,.24,1);z-index:5}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.25rem;letter-spacing:3px}
  .nav-links a.nav-cta{padding:9px 16px}
  .burger{display:block}
  .nav-logo{height:64px}
}
@media(max-width:500px){.about-stats{flex-wrap:wrap}.a-stat{min-width:45%}}

/* ═══ LISIBILITÉ MOBILE (≤600px) — remontée générale des tailles ═══ */
@media (max-width: 600px) {
  /* Le logo hero occupe presque toute la largeur : le lettrage redevient lisible */
  .hero-logo{width:92vw}
  .hero-sub{font-size:.82rem;letter-spacing:3px;margin-top:30px}
  /* CTA pleine largeur, typo plus grande : vrais boutons de pouce */
  .hero-ctas{width:100%;padding:0 24px}
  .hero-ctas .btn{width:100%;max-width:340px;text-align:center}
  .btn{font-size:1.02rem;letter-spacing:4px;padding:17px 28px}
  /* Bande défilante et étapes process */
  .tb-item{font-size:1.5rem}
  .rdv-step-title{font-size:1.18rem}
  .rdv-step-desc{font-size:1.08rem;max-width:300px}
  .rdv-step-num{width:70px;height:70px;font-size:2rem}
  /* Avis */
  .rm-text{font-size:1.05rem}
  /* Footer & navigation secondaire */
  .ft-links{gap:14px 20px}
  .ft-links a{font-size:.9rem;letter-spacing:3px}
  .ft-copy{font-size:1rem;letter-spacing:3px}
  .page-back{font-size:.9rem}
  .scroll-cue span{font-size:.8rem}
}


/* ═══════════════════════════════════════════════════════════════════════
   SECTION AVIS — Carrousel auto-défilant infini

   Inspiré des bandeaux .text-band existants pour une cohérence visuelle.
   Layout : score badge centré, puis marquee horizontal, puis CTA.
   ═══════════════════════════════════════════════════════════════════════ */

#testimonials {
  background: var(--abyss);
  padding: clamp(50px, 8vw, 100px) 0 clamp(50px, 8vw, 90px);
  position: relative;
  overflow: hidden;
}

#testimonials .s-head {
  padding: 0 clamp(16px, 5vw, 60px);
}

/* ─── Score badge (en-tête) ─────────────────────────────────────────── */
.reviews-badge {
  display: inline-flex;
  align-items: stretch;
  gap: 28px;
  margin: 0 auto 60px;
  padding: 28px 44px;
  background: linear-gradient(135deg, var(--coal) 0%, rgba(15,12,9,0.9) 100%);
  border: 1px solid var(--gold-line);
  position: relative;
  box-shadow:
    0 0 60px rgba(212, 168, 37, 0.05),
    inset 0 1px 0 rgba(212, 168, 37, 0.1);
}

/* Wrapper centreur pour éviter les soucis de translateX sur mobile */
#testimonials > .reviews-badge {
  display: flex;
  margin-left: auto;
  margin-right: auto;
  width: max-content;
  max-width: calc(100% - 32px);
}

.reviews-badge::before,
.reviews-badge::after {
  content: '';
  position: absolute;
  width: 12px;
  height: 12px;
  border: 1px solid var(--gold);
  opacity: 0.5;
}
.reviews-badge::before { top: -6px; left: -6px; border-right: none; border-bottom: none; }
.reviews-badge::after  { bottom: -6px; right: -6px; border-left: none; border-top: none; }

.rb-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.rb-stars {
  display: flex;
  gap: 4px;
  font-size: 1.1rem;
  color: var(--gold);
  margin-bottom: 6px;
  filter: drop-shadow(0 0 6px rgba(212, 168, 37, 0.4));
}
.rb-rating {
  display: flex;
  align-items: baseline;
  gap: 2px;
}
.rb-num {
  font-family: var(--gothic);
  font-size: clamp(2.4rem, 4vw, 3.2rem);
  color: var(--white);
  line-height: 1;
  text-shadow: 2px 2px 0 rgba(212, 168, 37, 0.1);
}
.rb-max {
  font-family: var(--serif);
  font-size: 1rem;
  color: var(--cream-50);
}

.rb-divider {
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--gold-line), transparent);
}

.rb-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
}
.rb-count {
  font-family: var(--raw);
  font-size: 0.7rem;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.85;
}
.rb-sources {
  font-family: var(--body);
  font-style: italic;
  font-size: 0.85rem;
  color: var(--cream-50);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.rb-src {
  color: var(--cream);
  text-decoration: none;
  border-bottom: 1px solid var(--gold-line);
  transition: color 0.3s, border-color 0.3s;
}
.rb-src:hover {
  color: var(--gold);
  border-color: var(--gold);
}
.rb-sep {
  color: var(--gold);
  opacity: 0.4;
}

/* ─── Marquee carrousel infini ──────────────────────────────────────── */
.reviews-marquee {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding: 24px 0;
  /* Fade sur les bords pour un effet "fondu enchaîné" */
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

.rm-track {
  display: flex;
  gap: 28px;
  width: max-content;
  animation: rm-scroll 70s linear infinite;
  will-change: transform;
}

@keyframes rm-scroll {
  from { transform: translateX(0); }
  /* On scroll de la moitié de la track parce qu'on a dupliqué le contenu */
  to   { transform: translateX(-50%); }
}

/* Pause au survol */
.reviews-marquee:hover .rm-track {
  animation-play-state: paused;
}

/* Cartes */
.rm-card {
  flex: 0 0 auto;
  width: clamp(300px, 32vw, 400px);
  min-height: 240px;
  background: var(--coal);
  border: 1px solid var(--gold-line);
  padding: 32px 28px 24px;
  position: relative;
  display: flex;
  flex-direction: column;
  transition: border-color 0.4s, transform 0.4s;
}

.rm-card::before {
  content: '"';
  position: absolute;
  top: 4px;
  left: 18px;
  font-family: var(--gothic);
  font-size: 5rem;
  color: var(--gold);
  opacity: 0.18;
  line-height: 1;
  pointer-events: none;
}

.rm-card:hover {
  border-color: rgba(212, 168, 37, 0.35);
  transform: translateY(-3px);
}

.rm-card--featured {
  width: clamp(340px, 38vw, 480px);
  background: linear-gradient(155deg, var(--coal) 0%, rgba(30, 22, 14, 0.95) 100%);
  border-left: 3px solid var(--gold);
}

.rm-card--short {
  width: clamp(260px, 24vw, 320px);
  min-height: 200px;
}

.rm-stars {
  color: var(--gold);
  font-size: 0.95rem;
  letter-spacing: 2px;
  margin-bottom: 14px;
  filter: drop-shadow(0 0 4px rgba(212, 168, 37, 0.3));
  position: relative;
  z-index: 1;
}

.rm-text {
  font-family: var(--body);
  font-style: italic;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--cream);
  flex: 1;
  position: relative;
  z-index: 1;
  margin-bottom: 18px;
}
.rm-text sup { font-style: normal; font-size: 0.65em; }

.rm-author {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 14px;
  border-top: 1px dashed var(--gold-line);
}
.rm-name {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: 1px;
  color: var(--cream);
}
.rm-via {
  font-family: var(--raw);
  font-size: 0.65rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.6;
}

/* ─── CTA "Voir tous les avis" ──────────────────────────────────────── */
.reviews-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: max-content;
  max-width: calc(100% - 32px);
  font-family: var(--raw);
  font-size: 0.78rem;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--gold);
  text-decoration: none;
  border: 1px solid var(--gold-line);
  padding: 16px 28px;
  margin: 50px auto 0;
  transition: all 0.3s;
  background: var(--coal);
}
.reviews-cta:hover {
  background: var(--gold);
  color: var(--void);
  border-color: var(--gold);
  box-shadow: 0 8px 24px rgba(212, 168, 37, 0.2);
}
.reviews-cta svg {
  flex-shrink: 0;
  transition: transform 0.3s;
}
.reviews-cta:hover svg {
  transform: translate(2px, -2px);
}

/* ─── Reduced motion : pause le carrousel ───────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .rm-track {
    animation: none;
    /* Replier en flex-wrap pour un layout statique en grille */
    flex-wrap: wrap;
    width: 100%;
    justify-content: center;
    padding: 0 clamp(16px, 5vw, 60px);
  }
  /* Cacher la 2e série dupliquée pour ne pas afficher en double */
  .rm-card[aria-hidden="true"] { display: none; }
  .reviews-marquee {
    -webkit-mask-image: none;
            mask-image: none;
  }
}

/* ─── Responsive ────────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .reviews-badge {
    flex-direction: column;
    gap: 16px;
    padding: 24px 32px;
    text-align: center;
  }
  .rb-divider {
    width: 60px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--gold-line), transparent);
  }
  .rb-right { align-items: center; }
  .rb-sources { justify-content: center; }

  .rm-track { gap: 18px; }
  .rm-card,
  .rm-card--featured,
  .rm-card--short {
    width: 280px;
    min-height: 220px;
    padding: 28px 22px 20px;
  }
  .rm-text { font-size: 0.95rem; }

  .reviews-cta {
    width: calc(100% - 40px);
    max-width: 320px;
    justify-content: center;
  }
}

@media (max-width: 420px) {
  .reviews-marquee {
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
            mask-image: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
  }
  .rm-track {
    /* Vitesse plus lente sur mobile pour permettre la lecture */
    animation-duration: 90s;
  }
}
