:root{
  --beige:#0c0c0d;
  --beige-2:#141416;
  --gold:#9a9aa0;
  --gold-15:rgba(255,255,255,.05);
  --gold-25:rgba(255,255,255,.09);
  --gold-30:rgba(255,255,255,.13);
  --gold-40:rgba(255,255,255,.2);
  --card:#161618;
  --dark:#08080a;
  --dark-2:#161618;
  --ink:#FFFFFF;
  --cream:#FFFFFF;
  --muted:#9a9aa0;
  --font-h:'Outfit',sans-serif;
  --font-b:'Inter',sans-serif;
  --font-m:'JetBrains Mono',monospace;
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  font-family:var(--font-b);
  background:var(--beige);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
  line-height:1.6;
}
/* barre de défilement masquée (navigation par sections) — le scroll reste actif */
html{scrollbar-width:none;-ms-overflow-style:none}
html::-webkit-scrollbar{width:0;height:0;display:none}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
section{scroll-margin-top:0;position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center}
footer{}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{font-family:var(--font-b);font-weight:500;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
h2.section-title{font-family:var(--font-h);font-weight:700;font-size:clamp(32px,5vw,48px);line-height:1.05;letter-spacing:-.01em}
.section-sub{font-size:18px;max-width:560px;margin-top:14px;opacity:.78}
.dark{background:var(--dark);color:var(--cream)}
.dark .section-sub{opacity:.7}
/* dark-theme section rhythm : fonds transparents pour laisser voir le ciel étoilé */
.section-sub{opacity:.72}

/* ===== LOADER ===== */
#loader{position:fixed;inset:0;z-index:9999;background:var(--dark);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;transition:opacity .7s ease;}
#loader.hide{opacity:0;pointer-events:none}
#loader .ld-logo{position:relative;width:118px;height:118px;animation:loaderIn .9s cubic-bezier(.2,.8,.2,1) both}
#loader .ld-logo img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 14px 40px rgba(200,149,96,.25))}
#loader .ld-ring{position:absolute;inset:-14px;border-radius:50%;border:1.5px solid var(--gold-30);border-top-color:var(--gold);animation:ldspin 1.1s linear infinite}
@keyframes ldspin{to{transform:rotate(360deg)}}
@keyframes loaderIn{0%{opacity:0;transform:scale(.8)}100%{opacity:1;transform:scale(1)}}
#loader .ld-bar{width:190px;height:2px;background:rgba(242,238,233,.12);border-radius:2px;overflow:hidden}
#loader .ld-bar span{display:block;height:100%;width:0;background:var(--cream);border-radius:2px;transition:width .15s linear}
#loader .ld-word{font-family:var(--font-m);font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:rgba(242,238,233,.55);text-indent:.42em}

/* ===== LOADER 3D ===== */
#loader .ld-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
/* le logo 2D ne sert que de secours si WebGL échoue (classe .fallback) */
#loader .ld-logo{display:none}
#loader.fallback .ld-logo{display:block}
#loader .ld-ui{position:absolute;left:50%;bottom:11%;transform:translateX(-50%);z-index:2;transition:opacity .45s ease}
#loader.finale .ld-ui{opacity:0}
#loader .ld-flash{position:absolute;inset:0;background:#f6efe4;opacity:0;pointer-events:none;z-index:3;transition:opacity .14s ease}
#loader .ld-flash.on{opacity:1}

/* reveal du titre hero façon night.co : les lignes montent d'un seul bloc
   derrière un masque, écrasées verticalement (scaleY), puis se détendent
   jusqu'à leur vraie forme (wrappers .lnw créés par loader3d.js) */
h1.mega .ln.masked{overflow:hidden}
h1.mega .lnw{display:block;transform:translateY(108%) scaleY(.35);transform-origin:50% 100%;transition:transform 1.1s cubic-bezier(.16,1,.3,1);will-change:transform}
body.ready h1.mega.in .lnw{transform:none}
/* le titre n'utilise plus le fondu hero-reveal : le masque fait tout */
h1.mega.hero-reveal{opacity:1;transform:none;transition:none}
@media(prefers-reduced-motion:reduce){h1.mega .lnw{transition:none;transform:none}}

/* ===== CUSTOM CURSOR ===== */
/* ===== CUSTOM LOGO CURSOR ===== */
html.cc-on, html.cc-on *{cursor:none !important}
#cursorLogo{position:fixed;top:0;left:0;width:52px;height:52px;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);opacity:0;transition:opacity .25s ease;will-change:transform;filter:drop-shadow(0 4px 11px rgba(0,0,0,.5))}
html:not(.cc-on) #cursorLogo{display:none}
#cursorLogo.in{opacity:1}
.cc-ripple{position:fixed;border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);border-style:solid;border-width:2px}
.cc-particle{position:fixed;border-radius:50%;pointer-events:none;z-index:9998}

/* ===== NAVBAR ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:900;transition:background .35s,border-color .35s;padding:13px 30px;display:flex;align-items:center;justify-content:space-between;gap:20px}
nav.scrolled{background:transparent}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-b);font-weight:600;font-size:14px;cursor:pointer;border:none;transition:transform .25s,box-shadow .25s,background .25s,color .25s}

/* left group */
.nav-left{position:relative;display:flex;align-items:center}

/* unified nav buttons — liquid glass */
.nav-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-m);font-weight:600;font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;height:38px;padding:0 19px;border-radius:100px;cursor:pointer;color:var(--cream);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:inset 0 1px 0 rgba(255,255,255,.22),inset 0 -8px 16px rgba(0,0,0,.18),0 6px 20px rgba(0,0,0,.3);transition:transform .28s cubic-bezier(.2,.7,.2,1),background .28s,box-shadow .28s,border-color .28s,color .28s;white-space:nowrap}
.nav-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.28);box-shadow:inset 0 1px 0 rgba(255,255,255,.34),inset 0 -8px 16px rgba(0,0,0,.16),0 12px 30px rgba(0,0,0,.4)}
.nav-btn--solid i{font-size:14px;transition:transform .3s}
.nav-btn--solid:hover i{transform:translateX(3px)}

/* ===== LIQUID GLASS (boutons Créateurs / Nous contacter) =====
   transposition CSS du composant React LiquidButton :
   fond transparent + réfraction SVG du fond + liseré de verre + hover scale */
.nav-btn--liquid{position:relative;isolation:isolate;background:transparent;border:none;backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:none;transition:transform .3s cubic-bezier(.2,.7,.2,1),color .28s}
.nav-btn--liquid:hover{transform:scale(1.06);background:transparent;border-color:transparent;box-shadow:none}
/* couche de réfraction : déforme ce qui passe derrière (Chrome/Edge) */
.nav-btn--liquid .lq-glass{position:absolute;inset:0;z-index:-1;border-radius:inherit;overflow:hidden;pointer-events:none;backdrop-filter:url(#liquid-glass);-webkit-backdrop-filter:url(#liquid-glass)}
/* flou de secours si le filtre SVG n'est pas supporté en backdrop (Firefox) */
.nav-btn--liquid::before{content:"";position:absolute;inset:0;z-index:-2;border-radius:inherit;pointer-events:none;backdrop-filter:blur(3px) saturate(1.4);-webkit-backdrop-filter:blur(3px) saturate(1.4)}
/* liseré de verre : pile d'ombres internes du composant (mode sombre) */
.nav-btn--liquid::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;box-shadow:0 0 8px rgba(0,0,0,.03),0 2px 6px rgba(0,0,0,.08),inset 3px 3px .5px -3.5px rgba(255,255,255,.09),inset -3px -3px .5px -3.5px rgba(255,255,255,.85),inset 1px 1px 1px -.5px rgba(255,255,255,.6),inset -1px -1px 1px -.5px rgba(255,255,255,.6),inset 0 0 6px 6px rgba(255,255,255,.12),inset 0 0 2px 2px rgba(255,255,255,.06),0 0 12px rgba(0,0,0,.15)}

/* center logo */
.nav-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:0;z-index:2}
.nav-center .nav-word{margin-top:-3px}
.nav-center img{width:33px;height:33px;object-fit:contain;filter:drop-shadow(0 6px 18px rgba(0,0,0,.6))}
.nav-center .nav-word{font-family:var(--font-h);font-weight:700;font-size:19px;letter-spacing:-.01em;text-transform:none;color:var(--cream)}

/* right group */
.nav-right{display:flex;align-items:center;gap:11px}

/* legacy gold button (used in body sections) */
.btn-gold{background:var(--cream);color:var(--dark);padding:12px 24px;border-radius:100px;font-size:15px}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.5)}
.btn-outline{border:1.5px solid var(--cream);color:var(--cream);background:transparent;padding:12px 24px;border-radius:100px;font-size:15px}
.btn-outline:hover{background:var(--cream);color:var(--dark)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}
.mobile-menu{position:fixed;inset:0;z-index:899;background:var(--beige);transform:translateX(100%);transition:transform .4s cubic-bezier(.7,0,.2,1);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:32px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{font-family:var(--font-h);font-weight:600;font-size:22px;letter-spacing:-.01em}
.mobile-menu .btn-gold{margin-top:14px;font-size:14px;font-weight:600;padding:14px 30px;white-space:nowrap}

/* ===== HERO ===== */
#hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 28px 80px;overflow:hidden;position:relative}
.hero-center{position:relative;z-index:2;width:100%;max-width:1500px;display:flex;flex-direction:column;align-items:center}
h1.mega{font-family:var(--font-h);font-weight:800;font-size:clamp(40px,9vw,132px);line-height:.94;letter-spacing:-.02em;color:var(--cream);text-transform:uppercase;position:relative;white-space:nowrap}
h1.mega .ln{display:block;position:relative}
h1.mega .ln::before,h1.mega .ln::after{content:attr(data-text);position:absolute;inset:0;text-transform:uppercase;pointer-events:none;opacity:0;mix-blend-mode:screen}
h1.mega .ln::before{color:#3b6bff}
h1.mega .ln::after{color:#ff3b6b}
@media(prefers-reduced-motion:no-preference){
  h1.mega.glitch .ln::before{animation:glxA 3s ease-in-out infinite}
  h1.mega.glitch .ln::after{animation:glxB 3s ease-in-out infinite}
}
@keyframes glxA{0%,90%,100%{transform:translate(0,0);opacity:0}92%{transform:translate(-4px,1px);opacity:.6}95%{transform:translate(2px,-1px);opacity:.5}98%{transform:translate(-1px,0);opacity:.3}}
@keyframes glxB{0%,90%,100%{transform:translate(0,0);opacity:0}92%{transform:translate(4px,-1px);opacity:.6}95%{transform:translate(-2px,1px);opacity:.5}98%{transform:translate(1px,0);opacity:.3}}
.hero-tag{margin-top:38px;font-family:var(--font-m);font-weight:500;font-size:clamp(12px,1.15vw,15px);letter-spacing:.14em;line-height:1.7;text-transform:uppercase;color:rgba(242,238,233,.62);max-width:560px}
/* side labels */
.side-lbl{position:absolute;top:50%;transform:translateY(-50%);font-family:var(--font-m);font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);z-index:3;line-height:1.5;display:none}
.side-lbl.left{left:46px;text-align:left}
.side-lbl.right{right:46px;text-align:right}
@media(min-width:1300px){.side-lbl{display:block}}
/* scroll cue */
.hero-scroll{position:absolute;bottom:30px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:9px;font-family:var(--font-m);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:rgba(242,238,233,.42);z-index:3}
.hero-scroll .ln{width:1px;height:38px;background:linear-gradient(rgba(242,238,233,.5),transparent);animation:scrolldn 1.8s ease-in-out infinite}
@keyframes scrolldn{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.3}50%{transform:scaleY(1);opacity:1}}
/* reveal du hero : gated par body.ready (fin du loader) ET .in (présence
   dans le viewport) → se rejoue à chaque retour sur la section */
.hero-reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
body.ready .hero-reveal.in{opacity:1;transform:none}
body.ready .hero-reveal.d1{transition-delay:.08s}
body.ready .hero-reveal.d2{transition-delay:.2s}
body.ready .hero-reveal.d3{transition-delay:.32s}

/* ===== TICKER ===== */
.ticker{background:var(--dark);overflow:hidden;padding:16px 0;white-space:nowrap;border-top:.5px solid var(--gold-25);border-bottom:.5px solid var(--gold-25)}
.ticker-track{display:inline-flex;animation:scrollx 30s linear infinite}
.ticker-track span{font-family:var(--font-h);font-weight:500;font-size:14px;letter-spacing:.06em;color:var(--gold);padding:0 6px;text-transform:uppercase}
.ticker-track .star{opacity:.6}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ===== À PROPOS ===== */
#about{color:var(--cream);padding:clamp(90px,12vw,150px) 0 0}
.about-grid{display:grid;grid-template-columns:0.8fr 1.2fr;column-gap:clamp(40px,7vw,110px);row-gap:0;align-items:start}
.about-left .eyebrow{margin-bottom:18px;display:block}
.about-left h2{font-family:var(--font-h);font-weight:800;font-size:clamp(40px,5.4vw,76px);line-height:.96;letter-spacing:-.03em;text-transform:uppercase;color:var(--cream)}
.about-left .rule{margin-top:30px;width:64px;height:2px;background:var(--gold-40)}
.about-body p{font-family:var(--font-b);font-size:clamp(17px,1.45vw,21px);line-height:1.75;color:rgba(255,255,255,.74);text-wrap:pretty}
.about-body p + p{margin-top:26px}
.about-body p strong{color:var(--cream);font-weight:600}
@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:36px}}

/* ===== TRUST MARQUEE ===== */
.trust{grid-column:1/-1;margin-top:72px;border-top:1px solid rgba(255,255,255,.08);padding-top:30px}
.trust-label{font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:.25em;color:#fff;margin-bottom:24px}
.marquee{position:relative;width:100vw;margin-left:calc(-50vw + 50%);overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent,#000 80px,#000 calc(100% - 80px),transparent);mask-image:linear-gradient(to right,transparent,#000 80px,#000 calc(100% - 80px),transparent)}
.marquee-track{display:flex;width:max-content;white-space:nowrap;animation:trustScroll 40s linear infinite}
.marquee-set{display:flex;align-items:center;flex:none}
.brand-logo{display:inline-flex;align-items:center;justify-content:center;padding:0 40px;width:130px;box-sizing:content-box;flex:none}
.brand-logo img{max-height:30px;max-width:130px;width:auto;height:auto;object-fit:contain;display:block;filter:grayscale(1) brightness(0) invert(1);opacity:.45;transition:opacity .3s ease}
.brand-logo:hover img{opacity:1}
.brand-sep{flex:none;width:1px;height:16px;background:rgba(255,255,255,.1)}
@keyframes trustScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== MANIFESTE ===== */
#manifeste{padding:64px 0}
.man-grid{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:center}
.founder-photo{width:280px;height:280px;border-radius:16px;border:2px solid var(--gold);box-shadow:0 0 24px rgba(200,149,96,.3)}
.man-quote{font-family:var(--font-h);font-weight:700;font-size:clamp(26px,3.4vw,34px);line-height:1.2;letter-spacing:-.01em;color:var(--cream)}
.man-quote .gold{color:var(--gold)}
.man-body{margin-top:22px;font-size:16.5px;line-height:1.75;opacity:.78;max-width:560px}
.man-name{margin-top:18px;font-family:var(--font-h);font-weight:600;font-size:15px;color:var(--gold)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:54px;border-top:.5px solid var(--gold-25);padding-top:40px}
.stat .num{font-family:var(--font-h);font-weight:700;font-size:clamp(32px,4vw,44px);color:var(--gold);line-height:1}
.stat .lbl{margin-top:8px;font-size:13.5px;letter-spacing:.04em;opacity:.7}

/* ===== ROSTER (couvertures éditoriales) ===== */
#creators{padding:34px 0 64px}
#creators .wrap{width:100%}
.section-head{margin-bottom:44px}
.roster{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;width:100%}
.talent-card{position:relative;display:block;width:100%;aspect-ratio:3/4;border:none;padding:0;margin:0;background:#111;overflow:hidden;cursor:pointer;text-align:left;border-radius:2px}
.talent-card .tc-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .9s cubic-bezier(.2,.7,.2,1),filter .5s ease;filter:saturate(.92)}
.talent-card:hover .tc-img{transform:scale(1.05);filter:saturate(1.05)}
.talent-card .tc-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,10,.86) 0%,rgba(8,8,10,.32) 38%,rgba(8,8,10,0) 62%);pointer-events:none}
.talent-card .tc-dot{position:absolute;top:12px;left:12px;width:30px;height:30px;background:url("../assets/images/pulsehub-logo.png") center/contain no-repeat;filter:drop-shadow(0 2px 6px rgba(0,0,0,.45));z-index:2}
.talent-card .tc-bars{position:absolute;top:14px;right:14px;width:46px;height:22px;z-index:2;background-image:repeating-linear-gradient(90deg,#fff 0,#fff 1.5px,transparent 1.5px,transparent 3px,#fff 3px,#fff 4px,transparent 4px,transparent 7px);opacity:.9}
.talent-card .tc-num{position:absolute;bottom:16px;right:16px;font-family:var(--font-m);font-weight:600;font-size:12px;letter-spacing:.1em;color:rgba(255,255,255,.78);z-index:2}
.talent-card .tc-name{position:absolute;left:18px;right:18px;bottom:16px;z-index:2;color:#fff;font-family:var(--font-h);text-transform:uppercase;line-height:.92;letter-spacing:-.02em}
.talent-card .tc-name .l1{display:block;font-weight:800;font-size:clamp(20px,2vw,28px)}
.talent-card .tc-name .l2{display:block;font-weight:800;font-size:clamp(26px,2.7vw,38px)}
.talent-card .tc-cta{position:absolute;left:18px;bottom:16px;z-index:3;display:flex;align-items:center;gap:7px;font-family:var(--font-m);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#fff;opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s ease}
.talent-card:hover .tc-name{opacity:0;transform:translateY(-6px);transition:opacity .3s,transform .3s}
.talent-card:hover .tc-cta{opacity:1;transform:translateY(0);transition-delay:.06s}

/* ===== REVEAL DES CARTES façon night.co =====
   réplique des états GSAP de night.co/talent : la carte arrive 100px sous
   sa position, bord inférieur replié (clip), et se déplie en glissant
   jusqu'à sa place pendant qu'elle apparaît. Cascade par colonne. */
.talent-card.reveal{opacity:0;transform:translateY(100px);clip-path:inset(0 0 100px 0);transition:opacity 1s cubic-bezier(.23,1,.32,1) var(--tcd,0s),transform 1s cubic-bezier(.23,1,.32,1) var(--tcd,0s),clip-path 1s cubic-bezier(.23,1,.32,1) var(--tcd,0s)}
.talent-card.reveal.in{opacity:1;transform:none;clip-path:inset(0 0 0 0)}
.roster .talent-card:nth-child(4n+2){--tcd:.08s}
.roster .talent-card:nth-child(4n+3){--tcd:.16s}
.roster .talent-card:nth-child(4n+4){--tcd:.24s}
@media(prefers-reduced-motion:reduce){
  .talent-card.reveal{opacity:1;transform:none;clip-path:none;transition:none}
}

/* ===== TALENT MODAL (spread éditorial) ===== */
.talent-modal{position:fixed;inset:0;z-index:9600;display:flex;align-items:center;justify-content:center;padding:clamp(14px,2.5vw,40px);background:rgba(4,4,6,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .4s ease}
.talent-modal.open{opacity:1;pointer-events:auto}
.tm-card{position:relative;width:100%;max-width:1180px;height:min(86vh,820px);background:var(--dark);border:.5px solid var(--gold-30);border-radius:6px;overflow:hidden;display:grid;grid-template-columns:1fr 1.05fr;transform:translateY(28px) scale(.985);transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.talent-modal.open .tm-card{transform:none}
.tm-photo{position:relative;height:100%;overflow:hidden;background:#111}
.tm-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}
.tm-photo .tc-dot{position:absolute;top:18px;left:18px;width:40px;height:40px;background:url("../assets/images/pulsehub-logo.png") center/contain no-repeat;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}
.tm-photo .tc-bars{position:absolute;top:20px;right:20px;width:54px;height:26px;background-image:repeating-linear-gradient(90deg,#fff 0,#fff 1.5px,transparent 1.5px,transparent 3px,#fff 3px,#fff 4px,transparent 4px,transparent 7px);opacity:.9}
.tm-panel{position:relative;display:flex;flex-direction:column;height:100%;padding:clamp(28px,3vw,48px);overflow:hidden}
.tm-scroll{flex:1;overflow-y:auto;padding-right:6px;-webkit-overflow-scrolling:touch}
.tm-scroll::-webkit-scrollbar{width:5px}
.tm-scroll::-webkit-scrollbar-thumb{background:var(--gold-30);border-radius:4px}
.tm-close{position:absolute;top:clamp(20px,2.4vw,32px);right:clamp(20px,2.4vw,32px);z-index:4;display:inline-flex;align-items:center;gap:9px;background:none;border:none;cursor:pointer;font-family:var(--font-m);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);opacity:.7;transition:opacity .25s}
.tm-close:hover{opacity:1}
.tm-close .ic{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;border:1px solid var(--gold-40);font-size:15px;transition:background .25s,transform .25s}
.tm-close:hover .ic{background:var(--gold-15);transform:rotate(90deg)}
.tm-name{font-family:var(--font-h);text-transform:uppercase;line-height:.92;letter-spacing:-.02em;color:var(--cream);margin-top:14px;padding-right:120px}
.tm-name .l1{display:block;font-weight:800;font-size:clamp(30px,3.4vw,52px)}
.tm-name .l2{display:block;font-weight:800;font-size:clamp(38px,4.6vw,72px)}
.tm-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px}
.tm-tags span{font-family:var(--font-m);font-weight:500;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--cream);border:1px solid var(--gold-40);border-radius:100px;padding:7px 15px}
.tm-stats{display:flex;gap:34px;margin-top:26px}
.tm-stats .v{font-family:var(--font-h);font-weight:700;font-size:clamp(22px,2.4vw,30px);line-height:1;color:var(--cream)}
.tm-stats .k{font-family:var(--font-m);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;opacity:.55;margin-top:7px}
.tm-biolabel{font-family:var(--font-m);font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:30px 0 14px}
.tm-bio{font-family:var(--font-b);font-size:15px;line-height:1.72;color:rgba(255,255,255,.72);text-wrap:pretty;margin-top:30px}
.tm-bio p+p{margin-top:13px}
.tm-foot{flex:none;border-top:.5px solid var(--gold-25);margin-top:24px;padding-top:22px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.tm-socials{display:flex;gap:10px}
.tm-socials a{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--gold-40);color:var(--cream);font-size:20px;transition:background .25s,color .25s,transform .25s}
.tm-socials a:hover{background:var(--cream);color:var(--dark);transform:translateY(-3px)}
.tm-follow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-b);font-weight:600;font-size:14px;letter-spacing:.02em;text-transform:uppercase;background:var(--cream);color:#08080a;border:none;border-radius:100px;padding:15px 28px;cursor:pointer;transition:transform .25s,box-shadow .25s}
.tm-follow:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,0,0,.5)}
.tm-follow i{font-size:17px;transition:transform .3s}
.tm-follow:hover i{transform:translateX(4px)}

/* ===== FORMATS ===== */
#formats{padding:64px 0}
.format-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
.format-card{background:var(--card);border:.5px solid var(--gold-25);border-radius:16px;padding:30px;transition:background .3s,color .3s,transform .3s;cursor:default}
.format-card .ico{width:52px;height:52px;border-radius:12px;background:var(--gold-15);display:flex;align-items:center;justify-content:center;font-size:26px;color:var(--cream);margin-bottom:20px;transition:background .3s}
.format-card h3{font-family:var(--font-h);font-weight:600;font-size:20px;margin-bottom:10px}
.format-card p{font-size:14.5px;line-height:1.6;opacity:.75;margin-bottom:18px}
.fc-badges{display:flex;gap:8px;flex-wrap:wrap}
.fc-badges span{font-size:11.5px;font-weight:500;color:var(--gold);background:var(--gold-15);border:.5px solid var(--gold-30);border-radius:100px;padding:4px 11px}
.format-card:hover{background:#34201A;border-color:var(--gold);transform:translateY(-4px);box-shadow:0 18px 44px rgba(0,0,0,.45)}
.format-card:hover p{opacity:.7}
.format-card:hover .ico{background:var(--gold-25)}

/* ===== PLATEFORMES & NICHES ===== */
#playground{padding:64px 0}
.pg-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:44px;align-items:start}
.pg-block h3{font-family:var(--font-h);font-weight:600;font-size:15px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.platforms{display:flex;flex-direction:column;gap:14px}
.plat-card{display:flex;align-items:center;gap:16px;background:var(--dark-2);border:.5px solid var(--gold-25);border-radius:12px;padding:18px 22px}
.plat-card i{font-size:28px;color:var(--cream)}
.plat-card .ti-brand-youtube{color:var(--cream)}
.plat-card .ti-brand-tiktok{color:var(--cream)}
.plat-card .ti-brand-twitch{color:var(--cream)}
.plat-card .ti-brand-instagram{color:var(--cream)}
.plat-card .pn{font-family:var(--font-h);font-weight:600;font-size:18px}
.plat-card .ps{margin-left:auto;font-size:13px;color:var(--gold);background:var(--gold-15);padding:5px 13px;border-radius:100px}
.niches{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.niche{font-weight:500;color:var(--gold);background:var(--gold-15);border:1px solid var(--gold-40);border-radius:100px;padding:9px 18px;opacity:0;transform:scale(.7);transition:opacity .4s,transform .4s}
.niche.in{opacity:1;transform:scale(1)}

/* ===== POURQUOI ===== */
#why{padding:64px 0}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.why-card{background:var(--dark-2);border:.5px solid var(--gold-25);border-radius:16px;padding:34px}
.why-card .ico{width:56px;height:56px;border-radius:14px;background:var(--gold-15);display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--cream);margin-bottom:22px}
.why-card h3{font-family:var(--font-h);font-weight:600;font-size:21px;margin-bottom:12px}
.why-card p{font-size:15px;line-height:1.65;opacity:.72}

/* ===== PROCESSUS ===== */
#process{padding:64px 0}
.timeline{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
.tl-line{position:absolute;top:28px;left:12%;width:76%;height:2px;z-index:0}
.tl-line path{stroke:var(--gold);stroke-width:2;fill:none;stroke-dasharray:1;stroke-dashoffset:1}
.step{position:relative;z-index:1;text-align:center}
.step .circle{width:56px;height:56px;border-radius:50%;background:var(--cream);color:var(--dark);display:flex;align-items:center;justify-content:center;font-size:25px;margin:0 auto 18px;box-shadow:0 0 0 8px var(--beige)}
.step .n{font-family:var(--font-h);font-weight:600;font-size:12px;letter-spacing:.18em;color:var(--gold);margin-bottom:8px}
.step h3{font-family:var(--font-h);font-weight:600;font-size:19px;margin-bottom:8px}
.step p{font-size:14px;line-height:1.55;opacity:.72;max-width:230px;margin:0 auto}

/* ===== CONTACT + FOOTER (fusionnés) ===== */
#contact{position:relative;background:var(--dark);color:var(--cream);min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;padding:0;overflow:hidden;isolation:isolate}
/* ouverture de la section : masque radial à bord doux piloté par main.js,
   ancré au bas du viewport et lié à la portion visible de la section —
   il monte avec le scroll à l'aller et se referme au retour. */
/* video background plein écran, floutée + boucle infinie */
.contact-video{position:absolute;inset:0;width:100%;height:100%;z-index:-2;pointer-events:none;object-fit:cover;filter:blur(14px) brightness(.6);transform:scale(1.08)}
@keyframes contactBgShift{0%{background-position:0% 0%}100%{background-position:100% 100%}}
.contact-overlay{position:absolute;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(120% 90% at 50% 30%,rgba(8,8,10,.35) 0%,rgba(8,8,10,.66) 55%,rgba(8,8,10,.9) 100%)}
.contact-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:120px 32px 60px}
/* clickable CTA : logo à gauche + gros texte */
.contact-cta{display:inline-flex;align-items:center;gap:clamp(20px,3vw,46px);cursor:pointer;background:none;border:none;color:var(--cream);transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.contact-cta:hover{transform:translateY(-4px)}
.contact-cta .cta-logo{width:clamp(78px,11vw,150px);height:clamp(78px,11vw,150px);object-fit:contain;flex:none;filter:drop-shadow(0 16px 44px rgba(0,0,0,.6));transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.contact-cta:hover .cta-logo{transform:rotate(-9deg) scale(1.05)}
.contact-cta .cta-text{font-family:var(--font-h);font-weight:800;font-size:clamp(40px,8.4vw,118px);line-height:.9;letter-spacing:-.035em;text-transform:uppercase;text-align:left;position:relative}
.contact-cta .cta-text .ln{display:block;position:relative}
.contact-cta .cta-text .ln::before,.contact-cta .cta-text .ln::after{content:attr(data-text);position:absolute;inset:0;text-transform:uppercase;pointer-events:none;opacity:0;mix-blend-mode:screen}
.contact-cta .cta-text .ln::before{color:#3b6bff}
.contact-cta .cta-text .ln::after{color:#ff3b6b}
@media(prefers-reduced-motion:no-preference){
  .contact-cta:hover .cta-text .ln::before{animation:glxA 2.4s ease-in-out infinite}
  .contact-cta:hover .cta-text .ln::after{animation:glxB 2.4s ease-in-out infinite}
}
.contact-cta .cta-arrow{display:flex;align-items:center;gap:8px;margin-top:18px;font-family:var(--font-m);font-weight:600;font-size:clamp(12px,1vw,14px);letter-spacing:.18em;text-transform:uppercase;color:var(--gold);opacity:.85}
.contact-cta .cta-arrow i{font-size:1.2em;transition:transform .35s}
.contact-cta:hover .cta-arrow i{transform:translateX(6px)}

/* ===== MODAL CONTACT ===== */
.cm-overlay{position:fixed;inset:0;z-index:9500;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(4,4,6,.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .35s ease}
.cm-overlay.open{opacity:1;pointer-events:auto}
.cm-card{position:relative;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;background:radial-gradient(140% 120% at 0% 0%,#1c1c1f 0%,#121214 55%,#0d0d0f 100%);border:.5px solid var(--gold-30);border-radius:26px;padding:clamp(34px,4vw,52px) clamp(28px,3.4vw,46px);box-shadow:0 40px 120px rgba(0,0,0,.7);transform:translateY(26px) scale(.97);transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.cm-overlay.open .cm-card{transform:none}
.cm-close{position:absolute;top:20px;right:20px;z-index:3;width:38px;height:38px;border-radius:50%;background:transparent;border:none;color:var(--cream);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.7;transition:opacity .25s,background .25s,transform .25s}
.cm-close:hover{opacity:1;background:var(--gold-15);transform:rotate(90deg)}
.cm-title{font-family:var(--font-h);font-weight:800;font-size:clamp(34px,5.6vw,52px);line-height:.95;letter-spacing:-.03em;text-transform:uppercase;color:var(--cream);position:relative;pointer-events:none}
.cm-title .ln{display:inline-block;position:relative}
.cm-title .ln::before,.cm-title .ln::after{content:attr(data-text);position:absolute;inset:0;pointer-events:none;opacity:0;mix-blend-mode:screen}
.cm-title .ln::before{color:#3b6bff}
.cm-title .ln::after{color:#ff3b6b}
.cm-overlay.open .cm-title .ln::before{animation:glxA 3s ease-in-out infinite .3s}
.cm-overlay.open .cm-title .ln::after{animation:glxB 3s ease-in-out infinite .3s}
.cm-sub{margin-top:14px;font-family:var(--font-b);font-weight:600;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:rgba(242,238,233,.62);line-height:1.5;max-width:360px}
.cm-form{margin-top:30px}
.cm-field{margin-bottom:30px}
.cm-field label{display:block;font-family:var(--font-b);font-weight:700;font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--cream);margin-bottom:14px}
.cm-field input,.cm-field textarea{width:100%;font-family:var(--font-b);font-size:15px;color:var(--cream);background:transparent;border:none;border-bottom:1px solid var(--gold-40);padding:8px 2px;transition:border-color .25s}
.cm-field textarea{resize:vertical;min-height:64px;line-height:1.6}
.cm-field input::placeholder,.cm-field textarea::placeholder{color:rgba(242,238,233,.28)}
.cm-field input:focus,.cm-field textarea:focus{outline:none;border-bottom-color:var(--cream)}
.cm-submit{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-b);font-weight:600;font-size:14px;letter-spacing:.02em;text-transform:uppercase;background:var(--cream);color:#08080a;border:none;border-radius:100px;padding:15px 26px;cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s}
.cm-submit:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,0,0,.5);background:var(--gold)}
.cm-submit i{font-size:16px;transition:transform .3s}
.cm-submit:hover i{transform:translateX(4px)}
.cm-note{margin-top:18px;font-size:12px;opacity:.45}
.cm-thanks{display:none;margin-top:30px}
.cm-thanks-msg{font-family:var(--font-h);font-weight:600;font-size:18px;color:var(--gold);line-height:1.5}
.cm-thanks-close{display:inline-flex;align-items:center;margin-top:22px;font-family:var(--font-b);font-weight:600;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--cream);background:transparent;border:1px solid var(--gold-30);border-radius:100px;padding:11px 24px;cursor:pointer;transition:background .25s,border-color .25s,transform .25s}
.cm-thanks-close:hover{background:rgba(255,255,255,.07);border-color:var(--gold-40);transform:translateY(-2px)}
/* champ honeypot anti-spam : invisible et hors-flux, mais pas display:none
   (certains bots ignorent display:none) */
.cm-hp{position:absolute;left:-9999px;width:0;height:0;opacity:0;pointer-events:none}
/* message d'erreur d'envoi */
.cm-error{display:none;margin-top:18px;font-size:13.5px;line-height:1.5;color:#ff8a80}
/* état d'envoi en cours */
.cm-submit.is-sending{opacity:.6;pointer-events:none}

/* ===== FOOTER (100% transparent) ===== */
footer{background:transparent;color:var(--cream)}
footer .wrap{max-width:1640px;padding:30px clamp(40px,5vw,90px) 0;border-top:.5px solid var(--gold-25)}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:clamp(40px,6vw,96px);padding:0 0 14px}
.foot-brand .b{display:flex;align-items:center;gap:11px;margin-bottom:8px}
.foot-brand .b img{width:34px;height:34px;object-fit:contain}
.foot-brand .b span{font-family:var(--font-h);font-weight:600;font-size:22px}
.foot-brand p{font-family:var(--font-h);font-weight:500;font-size:15px;opacity:.55;max-width:260px}
.foot-col h4{font-family:var(--font-h);font-weight:600;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.foot-col a{display:block;font-size:14px;opacity:.7;margin-bottom:6px;transition:opacity .2s;cursor:pointer}
.foot-col a:hover{opacity:1}
.foot-bottom{padding:12px 0 12px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:13px;opacity:.55}
.foot-bottom .links{display:flex;gap:24px}
.foot-bottom .links a{cursor:pointer}
@media(max-width:768px){
  .contact-cta{flex-direction:column;text-align:center;gap:24px}
  .contact-cta .cta-text{text-align:center}
  .contact-cta .cta-arrow{justify-content:center}
}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== IMAGE SLOT STYLING ===== */
image-slot{--ph-color:var(--gold)}

/* ===== RESPONSIVE ===== */
@media(max-width:1200px){
  .roster{gap:22px}
}
@media(max-width:900px){
  .man-grid{grid-template-columns:1fr;gap:32px;text-align:center}
  .founder-photo{margin:0 auto}
  .man-body{margin-left:auto;margin-right:auto}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .nav-left{display:none}
}
@media(max-width:768px){
  .wrap,.nav-inner{padding:0 22px}
  nav{padding:16px 18px}
  /* navbar mobile : logo à gauche, burger à droite, bouton contact dans le menu */
  .nav-center{position:static;left:auto;top:auto;transform:none;flex-direction:row;gap:9px;align-items:center;margin-right:auto}
  .nav-center .nav-word{margin-top:0;font-size:18px}
  .nav-btn--solid{display:none}
  .nav-btn{font-size:11px;padding:0 16px;height:38px}
  h1.mega{white-space:normal;font-size:clamp(34px,13vw,72px)}
  #hero{padding:130px 22px 90px}
  .burger{display:flex}
  .roster{grid-template-columns:repeat(2,1fr)}
  .tm-card{grid-template-columns:1fr;height:min(90vh,860px);overflow-y:auto}
  .tm-photo{height:auto;aspect-ratio:4/5}
  .tm-name{padding-right:96px}
  .format-grid{grid-template-columns:1fr}
  .pg-grid{grid-template-columns:1fr;gap:44px}
  .why-grid{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr;gap:36px}
  .tl-line{display:none}
  .step p{max-width:none}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px 20px}
  .foot-top{grid-template-columns:1fr 1fr;gap:30px 24px}
  .foot-brand{grid-column:1 / -1}
  .foot-bottom{justify-content:center;text-align:center}
  .form-row{grid-template-columns:1fr}
  #cursor{display:none}
}
@media(hover:none){#cursor{display:none}}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .niche{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
