/* ============================================================
   CELESTALE — site hi-fi (layout, components, motion, responsive)
   Tokens come from ../assets/colors_and_type.css
   Rules respected: no neon glow on boxes, no gradient inside
   boxes (only background sky scenes), minimal borders.
   ============================================================ */

*{box-sizing:border-box;}
html{scroll-behavior:smooth;overflow-x:clip;}
body{
  margin:0;background:var(--noir-bleute);color:var(--fg);
  font-family:var(--font-body);line-height:var(--leading-body);
  overflow-x:clip;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px;}
h1,h2,h3{margin:0;}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);}

/* ---------- type helpers ---------- */
.eyebrow{font-weight:500;font-size:var(--text-sm);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--accent);}
.eyebrow.on-light{color:var(--cyan-deep);}
.display{font-family:var(--font-display);text-transform:uppercase;line-height:.96;letter-spacing:.01em;font-weight:400;}
.h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(30px,4.4vw,52px);line-height:1.02;}
.lead{font-size:var(--text-lg);color:var(--fg-muted);line-height:var(--leading-body);}
.accentword{color:var(--rose-fuchsia);}
.uline{display:inline-block;position:relative;}
.uline::after{content:"";position:absolute;left:-.12em;bottom:.04em;height:.085em;width:calc(100% + .24em);
  background:var(--bleu-ciel);clip-path:ellipse(50% 50% at 50% 50%);
  transform-origin:center;animation:ulineDraw .8s cubic-bezier(.2,.7,.2,1) both;}
.uline.cy::after{background:var(--bleu-ciel);}
.uline.fx::after{background:var(--rose-fuchsia);}
@keyframes ulineDraw{0%{transform:scaleX(0);opacity:0}60%{opacity:1}100%{transform:scaleX(1);opacity:1}}
.tl-points{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:8px;}
.tl-points li{position:relative;padding-left:20px;color:var(--fg-muted);font-size:14px;}
.tl-points li::before{content:"";position:absolute;left:0;top:6px;width:9px;height:9px;border-radius:50%;}
.tl-points li.blue::before{background:var(--bleu-ciel);}
.tl-points li.pink::before{background:var(--rose-fuchsia);}
.tl-points li b{color:var(--fg);font-weight:600;}

/* ---------- buttons ---------- */
/* ---------- buttons (3D "jeu vidéo" : tranche pleine sous le bouton, s'enfonce au clic) ---------- */
.btn{font-family:var(--font-body);font-weight:600;font-size:15px;letter-spacing:.01em;border-radius:var(--radius-pill);padding:14px 26px;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:9px;transition:transform .1s cubic-bezier(.2,.7,.2,1),box-shadow .1s cubic-bezier(.2,.7,.2,1),background .15s,filter .15s;will-change:transform;}
.btn-primary{background:var(--fuchsia);color:#fff;box-shadow:0 5px 0 0 var(--fuchsia-deep),var(--shadow-press);}
.btn-primary:hover{transform:translateY(-2px);background:var(--fuchsia-bright);box-shadow:0 7px 0 0 var(--fuchsia-deep),var(--shadow-press-hover);}
.btn-primary:active{transform:translateY(4px);box-shadow:0 1px 0 0 var(--fuchsia-deep),var(--shadow-sm);}
.btn-secondary{background:var(--cyan);color:var(--noir-bleute);box-shadow:0 5px 0 0 var(--cyan-deep),var(--shadow-press);}
.btn-secondary:hover{transform:translateY(-2px);background:var(--cyan-bright);box-shadow:0 7px 0 0 var(--cyan-deep),var(--shadow-press-hover);}
.btn-secondary:active{transform:translateY(4px);box-shadow:0 1px 0 0 var(--cyan-deep),var(--shadow-sm);}
.btn-ghost{background:transparent;border:2px solid var(--cyan);color:var(--cyan);padding:12px 24px;box-shadow:0 4px 0 0 rgba(31,143,196,.45);}
.btn-ghost:hover{transform:translateY(-2px);background:rgba(66,182,232,.10);box-shadow:0 6px 0 0 rgba(31,143,196,.55);}
.btn-ghost:active{transform:translateY(4px);box-shadow:0 1px 0 0 rgba(31,143,196,.45);}
.btn-ghost.on-light{border-color:var(--cyan-deep);color:var(--cyan-deep);}
.btn-ghost.on-light:hover{background:rgba(31,143,196,.10);}
/* gros boutons (CTA hero accueil) */
.btn-lg{font-size:18px;padding:18px 38px;}
@media (max-width:680px){ .btn-lg{font-size:16px;} }
@media (prefers-reduced-motion: reduce){ .btn{transition:background .15s,box-shadow .15s;} .btn-primary:hover,.btn-secondary:hover,.btn-ghost:hover,.btn-primary:active,.btn-secondary:active,.btn-ghost:active{transform:none;} }
.textlink{color:var(--cyan);font-weight:500;border-bottom:2px solid transparent;transition:border-color .18s;display:inline-block;}
.textlink:hover{border-color:var(--cyan);}

/* ---------- top navigation ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;transition:background .3s,box-shadow .3s;background:linear-gradient(180deg,rgba(1,1,22,.66) 0%,rgba(1,1,22,.34) 58%,rgba(1,1,22,0) 100%);}
/* séparateur de marque : fin hairline cyan qui s'estompe sur les bords — remplace l'ancien trait noir */
.nav::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;pointer-events:none;opacity:0;transition:opacity .3s;background:linear-gradient(90deg,transparent 0%,rgba(66,182,232,.45) 22%,rgba(66,182,232,.55) 50%,rgba(66,182,232,.45) 78%,transparent 100%);}
.nav.scrolled{background:rgba(1,1,22,.82);backdrop-filter:blur(10px);box-shadow:0 12px 30px -10px rgba(1,1,22,.65);}
.nav.scrolled::after{opacity:1;}
.nav-inner{max-width:1200px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:22px;}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer;}
.brand img{height:40px;width:auto;}
.brand b{font-family:var(--font-display);text-transform:uppercase;font-size:20px;letter-spacing:.02em;}
.nav-links{display:flex;gap:6px;margin-left:auto;align-items:center;}
.nav-links a{font-size:15px;color:var(--blanc-rose);opacity:.86;padding:9px 13px;border-radius:var(--radius-pill);transition:color .18s,background .18s,opacity .18s;cursor:pointer;text-shadow:0 1px 12px rgba(1,1,22,.6);}
.nav-links a:hover{color:#fff;opacity:1;}
.nav-links a.active{color:#fff;opacity:1;background:var(--ink-700);text-shadow:none;}
.nav-cta{display:flex;align-items:center;gap:12px;}

/* ---------- curseur : flèche bleue classique ---------- */
@media (hover:hover) and (pointer:fine){
  html, body{
    cursor: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="26" height="26" viewBox="0 0 26 26"><path d="M3 2 L3 19 L7.6 14.7 L10.7 21.4 L13.4 20.2 L10.2 13.7 L16.3 13.7 Z" fill="%2342b6e8" stroke="%23ffffff" stroke-width="1.4" stroke-linejoin="round"/></svg>') 3 2, auto;
  }
}

/* bandeau streamers déroulant (auto + glisser) */
.draggable-rail{cursor:grab;user-select:none;-webkit-user-select:none;scrollbar-width:none;-ms-overflow-style:none;}
.draggable-rail::-webkit-scrollbar{display:none;}
.draggable-rail.grabbing{cursor:grabbing;}
.draggable-rail .str,.draggable-rail .evstr,.draggable-rail img{pointer-events:none;}

/* ---------- transition de page : damier (tuiles en cascade) ---------- */
html.cel-enter-cover::before{content:"";position:fixed;inset:0;z-index:9999;background:var(--noir-bleute);pointer-events:none;}
.cel-grid{position:fixed;inset:0;z-index:10000;display:grid;pointer-events:none;}
.cel-grid .cel-cell{background:var(--noir-bleute);opacity:0;transform:scale(.4);will-change:transform,opacity;}
@media (prefers-reduced-motion:reduce){html.cel-enter-cover::before{display:none!important;}.cel-grid{display:none!important;}}

/* language switcher */
.lang{position:relative;}
.lang-btn{display:flex;align-items:center;gap:6px;background:var(--ink-800);border:1px solid var(--ink-600);color:var(--fg);border-radius:var(--radius-pill);padding:8px 14px;font-family:var(--font-body);font-size:14px;cursor:pointer;}
.lang-btn:hover{border-color:var(--cyan-deep);}
.lang-menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--ink-800);border:1px solid var(--ink-600);border-radius:var(--radius-md);padding:6px;min-width:150px;box-shadow:var(--shadow-md);display:none;}
.lang-menu.open{display:block;}
.lang-menu button{display:flex;width:100%;gap:10px;align-items:center;background:transparent;border:none;color:var(--fg-muted);font-family:var(--font-body);font-size:14px;padding:9px 12px;border-radius:var(--radius-sm);cursor:pointer;text-align:left;}
.lang-menu button:hover{background:var(--ink-700);color:var(--fg);}
.lang-menu button.on{color:var(--cyan);}

.burger{display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:transparent;border:none;cursor:pointer;padding:8px;min-width:44px;min-height:44px;}
.burger span{width:24px;height:2px;background:var(--fg);border-radius:2px;transition:.25s;}
.nav.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav.menu-open .burger span:nth-child(2){opacity:0;}
.nav.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ---------- routing ---------- */
.page{display:none;}
.page.active{display:block;}
main{padding-top:0;}

/* ---------- hero / sky scene ---------- */
.hero{position:relative;overflow:hidden;display:flex;align-items:center;min-height:92vh;padding:120px 0 70px;}
.hero .wrap{position:relative;z-index:3;}
.sky{position:absolute;inset:0;pointer-events:none;z-index:1;}
.sky img{position:absolute;will-change:transform;}
.cloud{animation:floatA 9s ease-in-out infinite;}
.cloud.s{animation:floatB 11s ease-in-out infinite;}
.cloud.t{animation:floatA 13s ease-in-out infinite;}
.sun{animation:sunPulse 7s ease-in-out infinite;transform-origin:center bottom;}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(-24px)}}
@keyframes sunPulse{0%,100%{transform:scale(1);opacity:.55}50%{transform:scale(1.05);opacity:.7}}
@keyframes driftX{0%{transform:translateX(-80px)}100%{transform:translateX(110vw)}}

.hero-center{text-align:center;}
[data-page="discovery"] .hero{min-height:100vh;}
.hero h1{font-family:var(--font-display);text-transform:uppercase;line-height:.95;letter-spacing:.01em;font-weight:400;font-size:clamp(46px,7vw,104px);margin:18px auto 0;max-width:1000px;}
.hero .lead{margin:26px auto 0;max-width:620px;}
.hero-center .lead{margin-left:auto;margin-right:auto;}
.hero .cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}
.hero-center .cta{justify-content:center;}

/* stat strip */
.stats{display:flex;gap:48px;flex-wrap:wrap;margin-top:60px;}
.hero-center .stats{justify-content:center;}
.stat .num{font-family:var(--font-display);font-size:clamp(34px,4vw,50px);line-height:1;color:var(--cyan);}
.stat .lab{font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--fg-faint);margin-top:8px;}

/* ---------- generic section ---------- */
.section{padding:96px 0;position:relative;}
.section.tight{padding:64px 0;}
.section-head{max-width:720px;margin-bottom:48px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head .lead{margin-top:18px;}

/* surfaces / cards */
.card{background:var(--surface);border:1px solid var(--ink-600);border-radius:var(--radius-lg);padding:28px;}
.grid{display:grid;gap:20px;}
.g2{grid-template-columns:repeat(2,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}

.feature .ic{width:48px;height:48px;border-radius:var(--radius-md);background:var(--ink-700);display:flex;align-items:center;justify-content:center;color:var(--cyan);margin-bottom:18px;}
.feature h3{font-family:var(--font-body);font-weight:500;font-size:var(--text-lg);margin-bottom:8px;}
.feature p{color:var(--fg-muted);font-size:15px;margin:0;}

/* stat band (dark panel, no gradient) */
.band{background:var(--bg-raised);border-radius:var(--radius-xl);padding:54px 40px;}
.band .stats{margin-top:0;justify-content:space-around;gap:32px;}
.statbig .num{font-family:var(--font-display);font-size:clamp(40px,5vw,68px);line-height:1;}
.statbig{text-align:center;}
.statbig .lab{font-size:13px;color:var(--fg-muted);margin-top:10px;text-transform:none;letter-spacing:0;}

/* market contrast */
.contrast{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.contrast .col h3{font-family:var(--font-body);font-weight:500;font-size:var(--text-md);color:var(--fg-muted);margin-bottom:18px;}
.metric{display:flex;align-items:baseline;gap:14px;padding:16px 0;border-bottom:1px solid var(--ink-600);}
.metric .v{font-family:var(--font-display);font-size:32px;line-height:1;min-width:130px;}
.metric.down .v{color:var(--fuchsia);}
.metric.up .v{color:var(--cyan);}
.metric .t{color:var(--fg-muted);font-size:14px;}
.ugcstats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.ugcstats .metric{flex-direction:column;align-items:flex-start;gap:10px;padding:26px 26px 28px;background:var(--bg-raised);border-radius:var(--radius-lg);border-bottom:none;}
.ugcstats .metric .v{min-width:0;font-size:clamp(34px,4vw,48px);}
@media (max-width:680px){.ugcstats{grid-template-columns:1fr;}}

/* edge / split */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
.split .media{border-radius:var(--radius-lg);overflow:hidden;min-height:320px;position:relative;background:radial-gradient(120% 120% at 50% 0%, #0d4f74, #06243a 72%);}
.split .media:has(.dash){background:transparent;min-height:0;overflow:visible;}
.dash{margin:0;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--ink-600);background:var(--ink-900);box-shadow:var(--shadow-lg);}
.dash-bar{display:flex;align-items:center;gap:8px;padding:11px 14px;background:var(--ink-800);border-bottom:1px solid var(--ink-600);}
.dash-bar .dot{width:11px;height:11px;border-radius:50%;background:var(--ink-500);flex:0 0 auto;}
.dash-bar .dot:nth-child(1){background:#ff5f57;}
.dash-bar .dot:nth-child(2){background:#febc2e;}
.dash-bar .dot:nth-child(3){background:#28c840;}
.dash-url{margin-left:10px;font-family:var(--font-body);font-size:12.5px;color:var(--fg-faint);letter-spacing:.01em;}
.dash-live{margin-left:auto;display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:11.5px;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--bleu-ciel);}
.dash-live i{width:7px;height:7px;border-radius:50%;background:var(--fuchsia);flex:0 0 auto;animation:dashPulse 1.8s ease-in-out infinite;}
@keyframes dashPulse{0%,100%{opacity:1;}50%{opacity:.3;}}
.dash img{display:block;width:100%;height:auto;}
.dash-wide{max-width:1040px;margin-inline:auto;}
.dash-cap{margin:14px 2px 0;font-family:var(--font-body);font-size:13.5px;color:var(--fg-faint);line-height:var(--leading-snug);text-wrap:pretty;}
@media (prefers-reduced-motion:reduce){.dash-live i{animation:none;}}

/* flèche de défilement dans les héros */
.hero{position:relative;}
.scroll-cue{position:absolute;left:50%;bottom:24px;z-index:4;width:46px;height:46px;
  border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;
  background:rgba(1,1,22,.42);border:1px solid var(--ink-500);color:var(--bleu-ciel);
  cursor:pointer;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:border-color .2s,background .2s,color .2s;
  animation:cueBob 2.2s ease-in-out infinite;}
.scroll-cue svg{width:22px;height:22px;}
.scroll-cue:hover{border-color:var(--bleu-ciel);background:rgba(1,1,22,.62);color:var(--blanc-rose);}
.scroll-cue:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px;}
@keyframes cueBob{0%,100%{transform:translate(-50%,0);}50%{transform:translate(-50%,7px);}}
@media (prefers-reduced-motion:reduce){.scroll-cue{animation:none;transform:translateX(-50%);}}
@media (max-width:760px){.scroll-cue{width:42px;height:42px;bottom:18px;}}
.quote{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(22px,2.4vw,30px);line-height:1.12;margin-top:24px;}

/* founders / cards */
.founder{text-align:left;}
.founder .ph{aspect-ratio:1/1;border-radius:var(--radius-lg);background:var(--ink-700);overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--ink-400);margin-bottom:16px;}
.founder .ph svg{width:46%;height:46%;}
.founder .ph img{width:100%;height:100%;object-fit:cover;}
img[src$="joran.jpg"]{object-position:50% 8%;}
.founder h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-lg);}
.founder .role{color:var(--cyan);font-size:14px;font-weight:500;margin:2px 0 10px;}
.founder ul{margin:0;padding:0;list-style:none;color:var(--fg-muted);font-size:14px;}
.founder li{padding:2px 0;}
.founder .ln{display:inline-flex;margin-top:12px;color:var(--fg-faint);}

/* board */
.board-item{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;}
.board-item .av{width:100%;height:auto;aspect-ratio:1/1;border-radius:var(--radius-lg);background:var(--ink-700);overflow:hidden;display:block;margin-bottom:16px;}
.board-item .av img{width:100%;height:100%;object-fit:cover;}
.board-item .av svg{width:30%;height:30%;}
.board-item h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-lg);text-align:center;}
.board-item .org{color:var(--cyan);font-size:13px;line-height:1.3;margin:4px 0 10px;font-weight:500;}
.board-item p{color:var(--fg-muted);font-size:14px;margin:0;text-wrap:pretty;}
.board-item .ln{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;margin-top:14px;
  border-radius:var(--radius-pill);color:var(--fg-faint);background:var(--ink-800);
  transition:color .2s, background .2s, transform .2s cubic-bezier(.2,.7,.2,1);}
.board-item .ln:hover{color:#fff;background:#0a66c2;transform:translateY(-2px);}
.board-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;}
.board-grid > .board-item{flex:0 1 calc(25% - 15px);}
@media (max-width:980px){ .board-grid > .board-item{flex:0 1 calc(50% - 10px);} }
@media (max-width:680px){ .board-grid > .board-item{flex:0 1 100%;} }

/* timeline */
.timeline{position:relative;padding-left:34px;}
.timeline::before{content:"";position:absolute;left:9px;top:8px;bottom:8px;width:2px;background:var(--ink-600);}
.tl{position:relative;padding:0 0 36px;}
.tl::before{content:"";position:absolute;left:-30px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--cyan);border:3px solid var(--noir-bleute);}
.tl.on::before{background:var(--fuchsia);}
.tl .yr{font-family:var(--font-display);font-size:22px;color:var(--cyan);}
.tl.on .yr{color:var(--fuchsia);}
.tl h3{font-family:var(--font-body);font-weight:500;font-size:var(--text-md);margin:4px 0 4px;}
.tl p{color:var(--fg-muted);font-size:14px;margin:0;}
.tl-link{display:inline-flex;align-items:center;gap:7px;margin-top:10px;color:var(--cyan);font-size:14px;font-weight:500;border-bottom:2px solid transparent;transition:border-color .18s,gap .18s;}
.tl-link:hover{border-color:var(--cyan);gap:10px;}

/* event / realisation cards */
.event{overflow:hidden;}
.event .top{position:relative;aspect-ratio:16/9;overflow:hidden;background:radial-gradient(120% 120% at 50% 0%, #0d4f74, #06243a 72%);display:flex;align-items:center;justify-content:center;}
.event .top::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(1,1,22,0) 38%,rgba(1,1,22,.6));}
.event .top .thumb-tt{position:absolute;left:22px;right:22px;bottom:18px;z-index:2;font-family:var(--font-display);text-transform:uppercase;font-size:clamp(24px,2.7vw,38px);line-height:.96;color:#fff;text-shadow:0 3px 0 rgba(1,1,22,.45);text-align:left;}
.event .top .tag{position:absolute;top:14px;left:14px;background:rgba(1,1,22,.6);backdrop-filter:blur(6px);border:1px solid rgba(244,228,240,.18);border-radius:var(--radius-pill);padding:6px 13px;font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-wide);}
.event .body{padding:22px 24px 26px;}
.event h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-lg);}
.event .when{color:var(--fg-faint);font-size:13px;margin:4px 0 10px;}
.event p{color:var(--fg-muted);font-size:14px;margin:0 0 16px;}
.event .nums{display:flex;gap:22px;flex-wrap:wrap;}
.event .nums b{font-family:var(--font-display);color:var(--cyan);font-size:24px;display:block;line-height:1;}
.event .nums span{font-size:12px;color:var(--fg-faint);}
a.event{text-decoration:none;color:inherit;display:block;}
a.event .top::before{content:"\2197";position:absolute;top:12px;right:12px;z-index:3;width:30px;height:30px;border-radius:50%;background:rgba(1,1,22,.55);backdrop-filter:blur(6px);border:1px solid rgba(244,228,240,.2);color:#fff;display:grid;place-items:center;font-size:15px;font-weight:700;transition:background .2s,color .2s,transform .2s;}
a.event:hover .top::before{background:var(--cyan);color:var(--noir-bleute);transform:translateY(-2px);}
/* productions : chiffres et bouton « Découvrir le jeu » alignés en bas de carte */
a.event.card{display:flex !important;flex-direction:column;}
.event > .top{flex:none;}
.event > .body{flex:1 1 auto;display:flex;flex-direction:column;}
.event .body > .evstreamers{order:1;}
.event .body > .nums{order:2;margin-top:auto;padding-top:18px;}
.event .body > .cardcta{order:3;margin-top:18px;display:flex;}

/* offers */
.offer{position:relative;}
.offer-img{width:100%;height:172px;object-fit:cover;border-radius:var(--radius-md);
  margin-bottom:18px;display:block;border:1px solid var(--ink-600);}
.offer .no{font-family:var(--font-display);font-size:34px;color:var(--ink-500);line-height:1;}
.offer h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-xl);margin:8px 0 12px;}
.offer p{color:var(--fg-muted);font-size:15px;margin:0 0 16px;}
.offer ul{margin:0;padding:0;list-style:none;}
.offer li{color:var(--fg-muted);font-size:14px;padding:7px 0;border-top:1px solid var(--ink-600);display:flex;gap:10px;align-items:center;}
.offer li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cyan);flex:0 0 7px;}

/* creators */
.creators{display:flex;flex-wrap:wrap;gap:18px;}
.creator{width:96px;text-align:center;}
.creator .av{width:62px;height:62px;border-radius:50%;background:var(--ink-700);border:2px solid var(--ink-600);margin:0 auto 8px;display:flex;align-items:center;justify-content:center;color:var(--ink-400);overflow:hidden;}
.creator .av svg{width:34px;height:34px;}
.creator .nm{font-size:13px;line-height:1.15;}
.creator .ct{font-size:12px;color:var(--cyan);font-weight:500;margin-top:2px;}

/* streamer marquee */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.marquee .track{display:flex;gap:40px;width:max-content;animation:scrollX 30s linear infinite;}
.marquee span{font-family:var(--font-display);text-transform:uppercase;font-size:24px;color:var(--ink-400);white-space:nowrap;}
@keyframes scrollX{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* CTA band with sky */
.ctaband{position:relative;overflow:hidden;border-radius:var(--radius-xl);padding:72px 40px;text-align:center;background:radial-gradient(120% 130% at 50% -20%, #0d4f74, #06243a 70%);}
.ctaband .sky{z-index:0;}
.ctaband .wrap{position:relative;z-index:2;}

/* contact form */
.form{display:grid;gap:18px;}
.field label{display:block;font-size:13px;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--fg-faint);margin-bottom:8px;}
.field input,.field select,.field textarea{width:100%;background:var(--ink-800);border:1px solid var(--ink-600);border-radius:var(--radius-md);color:var(--fg);font-family:var(--font-body);font-size:15px;padding:14px 16px;transition:border-color .18s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cyan);}
.field textarea{min-height:140px;resize:vertical;}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;}
.coord a{color:var(--cyan);}
.socials{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px;}
.socials a{width:44px;height:44px;border-radius:50%;background:var(--ink-700);border:1px solid var(--ink-600);display:flex;align-items:center;justify-content:center;color:var(--fg-muted);transition:transform .18s,color .18s,border-color .18s;}
.socials a:hover{transform:translateY(-3px);color:var(--fg);border-color:var(--cyan-deep);}
.socials svg{width:20px;height:20px;}

/* ---------- footer ---------- */
.footer{background:var(--bg-raised);border-top:1px solid var(--ink-600);padding:64px 0 36px;margin-top:40px;}
.footer-cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;}
.footer .blurb{color:var(--fg-muted);font-size:14px;max-width:300px;margin:14px 0 0;}
.footer h3{font-family:var(--font-display);text-transform:uppercase;font-size:15px;letter-spacing:.04em;margin-bottom:14px;color:var(--fg);}
.footer ul{list-style:none;margin:0;padding:0;}
.footer li{padding:6px 0;}
.footer li a{color:var(--fg-muted);font-size:14px;cursor:pointer;}
.footer li a:hover{color:var(--fg);}
.footer .fun a{color:var(--cyan);font-weight:500;}
.footer .accolade{display:inline-flex;align-items:center;gap:8px;margin-top:18px;border:1px solid var(--ink-600);border-radius:var(--radius-pill);padding:8px 14px;font-size:13px;color:var(--fg-muted);}
.footer .accolade::before{content:"\2605";color:var(--or);}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:48px;padding-top:24px;border-top:1px solid var(--ink-600);color:var(--fg-faint);font-size:13px;}

/* ---------- scroll reveal (progressive enhancement: only hides when html.js) ---------- */
@media (prefers-reduced-motion: no-preference){
  html.js .reveal{opacity:0;transform:translateY(34px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
  html.js .reveal.in{opacity:1;transform:none;}
  .reveal.d1{transition-delay:.08s;}
  .reveal.d2{transition-delay:.16s;}
  .reveal.d3{transition-delay:.24s;}
  .reveal.d4{transition-delay:.32s;}
}

/* ---------- bonus game ---------- */
.game{position:relative;border-radius:var(--radius-xl);overflow:hidden;min-height:600px;background:linear-gradient(180deg,#7fcdf0 0%,#bfe6f6 46%,#1f8fc4 100%);box-shadow:var(--shadow-md);}
.game .water{position:absolute;left:0;right:0;bottom:0;height:140px;background:linear-gradient(180deg,#2aa3d6,#1f7fb0);}
.game .ponton{position:absolute;left:50%;bottom:46px;transform:translateX(-50%);width:360px;z-index:2;filter:drop-shadow(0 16px 18px rgba(1,1,22,.28));}
.game .celestin{position:absolute;left:50%;bottom:128px;transform:translateX(-50%);width:160px;z-index:3;animation:bob 2.6s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0) rotate(-2deg)}50%{transform:translateX(-50%) translateY(-12px) rotate(2deg)}}
.game .hud-top{position:absolute;top:20px;left:20px;right:20px;z-index:5;display:flex;justify-content:space-between;gap:12px;}
.gpill{background:rgba(1,1,22,.5);backdrop-filter:blur(6px);border:1px solid rgba(244,228,240,.18);border-radius:var(--radius-pill);padding:10px 16px;color:#fff;font-weight:500;display:flex;align-items:center;gap:9px;}
.gpill .coin{width:18px;height:18px;border-radius:50%;background:var(--or);border:2px solid var(--or-fonce);}
.castWrap{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:6;}
.cast{background:var(--fuchsia);color:#fff;font-family:var(--font-display);text-transform:uppercase;font-size:22px;letter-spacing:.02em;padding:18px 44px;border:none;border-radius:var(--radius-lg);box-shadow:0 7px 0 var(--fuchsia-deep);cursor:pointer;transition:transform .08s,box-shadow .08s;}
.cast:active{transform:translateY(5px);box-shadow:0 2px 0 var(--fuchsia-deep);}
.cast[disabled]{opacity:.7;cursor:default;}
.popup{position:absolute;inset:0;z-index:8;display:none;align-items:center;justify-content:center;background:rgba(1,1,22,.45);backdrop-filter:blur(4px);}
.popup.show{display:flex;animation:fade .25s ease;}
@keyframes fade{from{opacity:0}to{opacity:1}}
.popcard{background:var(--ink-800);border:1px solid var(--ink-600);border-radius:var(--radius-lg);padding:26px;width:320px;text-align:center;box-shadow:var(--shadow-lg);animation:pop .35s cubic-bezier(.2,.9,.3,1.2);}
@keyframes pop{from{transform:scale(.82);opacity:0}to{transform:none;opacity:1}}
.popcard .rar{font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:500;}
.popcard img{width:150px;margin:8px auto;}
.popcard .fish{font-family:var(--font-display);text-transform:uppercase;font-size:26px;margin:2px 0 6px;}
.popcard .rw{color:var(--or);font-weight:500;margin-bottom:18px;}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .nav-links{display:none;position:fixed;top:69px;left:0;right:0;flex-direction:column;gap:2px;background:rgba(1,1,22,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--ink-600);padding:14px 20px 22px;}
  .nav.menu-open .nav-links{display:flex;}
  .nav-links a{padding:13px 14px;font-size:17px;}
  .burger{display:flex;}
  .split,.contrast,.contact-grid{grid-template-columns:1fr;gap:28px;}
  .g4{grid-template-columns:repeat(2,1fr);}
  .g3{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:680px){
  .wrap{padding:0 20px;}
  .section{padding:64px 0;}
  .g2,.g3,.g4{grid-template-columns:1fr;}
  .footer-cols{grid-template-columns:1fr 1fr;}
  .stats{gap:28px 36px;}
  .band{padding:36px 24px;}
  .hero{min-height:auto;padding:120px 0 60px;}
  .nav-cta .btn{display:none;}
  .game{min-height:520px;}
  .game .ponton{width:74%;}
  /* héros mobile : texte centré + décor (nuages/soleil) réduit et repoussé dans les coins */
  [data-page="discovery"] .hero{min-height:auto;}
  .hero:not(.team-hero) .wrap{text-align:center;}
  .hero:not(.team-hero) h1{margin-left:auto;margin-right:auto;}
  .hero:not(.team-hero) .lead{margin-left:auto;margin-right:auto;}
  .hero:not(.team-hero) .cta{justify-content:center;}
  .hero .sky .sun{width:118px!important;left:auto!important;right:-20px!important;top:62px!important;bottom:auto!important;opacity:.24!important;}
  .hero .sky .cloud{width:116px!important;opacity:.36!important;left:-32px!important;right:auto!important;top:auto!important;bottom:24px!important;}
  .hero .sky .cloud.s,.hero .sky .cloud.t{left:auto!important;right:-26px!important;top:auto!important;bottom:94px!important;width:106px!important;opacity:.32!important;}
}
@media (max-width:420px){
  .footer-cols{grid-template-columns:1fr;}
}

/* ============================================================
   AJOUTS — activités, streamers, organisations, philosophie, jeu
   ============================================================ */

/* trois activités (réutilise .offer) */
.activity .no{color:var(--cyan);}
.activity.own .no{color:var(--fuchsia);}
.owntag{display:inline-block;font-size:12px;font-weight:500;padding:5px 13px;border-radius:var(--radius-pill);background:var(--ink-700);color:var(--fg-muted);margin-bottom:12px;}
.activity.own .owntag{color:var(--corail-clair);}
.owntag.you{color:var(--cyan);}

/* hover tactile sur les cartes (sans glow) */
@media (hover:hover){
  .card{transition:transform .22s cubic-bezier(.2,.7,.2,1),border-color .22s;}
  .card:hover{transform:translateY(-5px);border-color:var(--cyan-deep);}
}

/* bande "avec qui on a joué" : photos streamers */
.streamers{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:22px 16px;}
.str{display:flex;flex-direction:column;align-items:center;text-align:center;gap:9px;}
.str .ph{width:94px;height:94px;border-radius:50%;overflow:hidden;border:2.5px solid var(--ink-600);
  display:flex;align-items:center;justify-content:center;position:relative;transition:transform .2s cubic-bezier(.2,.7,.2,1),border-color .2s;}
.str:hover .ph{transform:translateY(-5px);border-color:var(--cyan);}
.str .ph .ini{font-family:var(--font-display);font-size:30px;color:#fff;opacity:.95;text-shadow:0 2px 0 rgba(1,1,22,.3);}
.str .ph img{width:100%;height:100%;object-fit:cover;}
.str .nm{font-weight:500;font-size:14px;line-height:1.1;}
.str .ct{font-size:12px;color:var(--cyan);font-weight:500;}

/* liste streamers en défilement horizontal */
.streamrail{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.streamtrack{display:flex;gap:30px;width:max-content;animation:scrollX 52s linear infinite;}
.streamrail:hover .streamtrack{animation-play-state:paused;}
.streamtrack .str{width:108px;flex:none;}

/* bandeau organisations */
.orgband{background:var(--bg-raised);border-radius:var(--radius-xl);padding:40px 36px;}
.orgs{display:flex;flex-wrap:wrap;align-items:stretch;justify-content:center;gap:20px;}
.org{display:flex;flex-direction:column;align-items:center;gap:13px;min-width:220px;flex:1;}
.org .orglogo{width:100%;height:118px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:var(--radius-lg);padding:22px 28px;}
.org .orglogo img{max-height:100%;max-width:100%;width:auto;object-fit:contain;}
.org span{font-size:12px;color:var(--fg-muted);letter-spacing:.06em;text-transform:uppercase;text-align:center;}
.orgnames{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:22px 52px;}
.orgname{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(22px,2.7vw,36px);line-height:1;color:var(--blanc-rose);letter-spacing:var(--tracking-display);}

/* philosophie de travail (équipe) */
.philo{position:relative;overflow:hidden;background:radial-gradient(120% 130% at 100% 0%, #0d4f74, #06243a 66%);
  border-radius:var(--radius-xl);padding:54px 44px;display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center;}
.philo .pc{position:relative;z-index:2;}
.philo .lead{margin-top:18px;}
.philo p.sub{color:var(--fg-muted);margin-top:14px;font-size:15px;}
.chiprow{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;}
.chip{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(244,228,240,.22);border-radius:var(--radius-pill);
  padding:9px 16px;font-size:14px;color:var(--blanc-rose);background:rgba(1,1,22,.3);}
.chip::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cyan);}

/* jeu intégré dans Contact */
.gamewrap{margin-bottom:54px;}
.gameframe{position:relative;width:100%;height:min(74vh,640px);min-height:520px;border:1px solid var(--ink-600);
  border-radius:var(--radius-xl);overflow:hidden;background:linear-gradient(180deg,#0a3a5c,#2d8fc4);box-shadow:var(--shadow-md);}
.gameframe iframe{width:100%;height:100%;border:0;display:block;}
.gamebar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px;}
.gamebar .full{font-size:13px;color:var(--cyan);font-weight:500;border-bottom:2px solid transparent;cursor:pointer;}
.gamebar .full:hover{border-color:var(--cyan);}
.gameposter{width:100%;height:100%;border:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:radial-gradient(120% 130% at 50% 0%, #0d4f74, #06243a 72%);color:#fff;font-family:var(--font-body);transition:filter .2s;}
.gameposter:hover{filter:brightness(1.1);}
.gameposter .gp-icon{width:84px;height:84px;border-radius:50%;background:var(--fuchsia);display:grid;place-items:center;box-shadow:0 7px 0 var(--fuchsia-deep);transition:transform .18s;}
.gameposter:hover .gp-icon{transform:scale(1.06);}
.gameposter .gp-icon svg{width:36px;height:36px;margin-left:5px;fill:#fff;}
.gameposter .gp-title{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(22px,3vw,32px);}
.gameposter .gp-note{font-size:13px;color:rgba(255,255,255,.8);}
/* jeu : encart mobile (mini-jeu non jouable au toucher) */
.game-mobile-only{display:none;}
.gamenote{display:none;align-items:center;gap:18px;background:var(--bg-raised);border:1px solid var(--ink-600);border-radius:var(--radius-xl);padding:26px 24px;box-shadow:var(--shadow-md);}
.gamenote .gn-ic{flex:none;width:54px;height:54px;border-radius:var(--radius-lg);display:grid;place-items:center;background:rgba(66,182,232,.12);color:var(--cyan);}
.gamenote .gn-ic svg{width:26px;height:26px;}
.gamenote .gn-tx b{display:block;font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-md);letter-spacing:var(--tracking-display);color:var(--blanc-rose);margin-bottom:6px;}
.gamenote .gn-tx p{margin:0;color:var(--fg-muted);font-size:14px;line-height:var(--leading-snug);text-wrap:pretty;}
@media(max-width:760px){
  .game-desktop-only{display:none !important;}
  .gamenote.game-mobile-only{display:flex;}
  .footer li.fun{display:none;}
}
.videowrap{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius-xl);overflow:hidden;background:#06243a;box-shadow:var(--shadow-md);}
.videowrap iframe{width:100%;height:100%;border:0;display:block;}
.videoposter{position:absolute;inset:0;width:100%;height:100%;border:0;cursor:pointer;background-size:cover;background-position:center;display:grid;place-items:center;}
.videoposter::after{content:"";position:absolute;inset:0;background:rgba(1,1,22,.34);transition:background .2s;}
.videoposter:hover::after{background:rgba(1,1,22,.18);}
.vp-play{position:relative;z-index:1;width:84px;height:84px;border-radius:50%;background:var(--fuchsia);display:grid;place-items:center;box-shadow:0 7px 0 var(--fuchsia-deep);transition:transform .18s;}
.videoposter:hover .vp-play{transform:scale(1.07);}
.vp-play svg{width:36px;height:36px;margin-left:5px;fill:#fff;}

@media (max-width:980px){
  .philo{grid-template-columns:1fr;gap:26px;padding:40px 28px;}
  .org{min-width:140px;}
}
@media (max-width:680px){
  .streamers{grid-template-columns:repeat(auto-fill,minmax(92px,1fr));}
  .str .ph{width:78px;height:78px;}
  .orgs{flex-direction:column;}
  .gameframe{height:78vh;min-height:480px;}
}

/* timeline reformatée (Histoire) */
.timeline.alt{padding-left:0;}
.timeline.alt::before{left:120px;}
.timeline.alt .tl{display:grid;grid-template-columns:120px 1fr;gap:34px;padding:0 0 30px;align-items:start;}
.timeline.alt .tl::before{left:114px;top:24px;transform:translateY(-50%);}
.timeline.alt .tl .yr{font-size:30px;text-align:right;padding-right:18px;}
.timeline.alt .tl h3{margin-top:0;font-size:var(--text-lg);}
@media (max-width:680px){
  .timeline.alt::before{left:64px;}
  .timeline.alt .tl{grid-template-columns:64px 1fr;gap:24px;}
  .timeline.alt .tl::before{left:58px;top:18px;}
  .timeline.alt .tl .yr{font-size:22px;padding-right:10px;}
}

/* page outil Discovery */
.steps{counter-reset:step;}
.step .idx{font-family:var(--font-display);font-size:30px;color:var(--cyan);line-height:1;margin-bottom:12px;}
.step h3{font-family:var(--font-body);font-weight:500;font-size:var(--text-lg);margin-bottom:8px;}
.step p{color:var(--fg-muted);font-size:15px;margin:0;}
.toolnote{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--ink-600);border-radius:var(--radius-pill);padding:8px 16px;font-size:13px;color:var(--fg-muted);}
.toolnote::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--menthe);}

/* mini dashboard radar */
.radar{background:var(--bg-raised);border:1px solid var(--ink-600);border-radius:var(--radius-lg);padding:22px 24px;}
.radar .rhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.radar .rtitle{font-family:var(--font-display);text-transform:uppercase;font-size:16px;letter-spacing:.04em;}
.radar .live{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--fg-muted);}
.radar .live::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--fuchsia);animation:pulse 1.6s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.radar .row{display:flex;align-items:center;gap:14px;padding:12px 0;border-top:1px solid var(--ink-600);}
.radar .gn{min-width:150px;}
.radar .row:first-of-type{border-top:none;}
.radar .gname{font-size:14px;min-width:118px;}
.radar .gmeta{font-size:11px;color:var(--fg-faint);}
.radar .bar{flex:1;height:8px;background:var(--ink-700);border-radius:999px;overflow:hidden;}
.radar .bar i{display:block;height:100%;background:var(--cyan);border-radius:999px;}
.radar .row.hot .bar i{background:var(--fuchsia);}
.radar .score{font-family:var(--font-display);color:var(--cyan);font-size:16px;min-width:48px;text-align:right;}
.radar .row.hot .score{color:var(--fuchsia);}
.radar .rfoot{margin-top:14px;font-size:11px;color:var(--fg-faint);}

/* ---------- vision: numbered philosophy ---------- */
.philo-grid .pno{font-family:var(--font-display);font-size:34px;line-height:1;color:var(--cyan);margin-bottom:10px;}
.philo-grid h3{font-family:var(--font-body);font-weight:500;font-size:var(--text-lg);margin-bottom:8px;}
.philo-grid p{color:var(--fg-muted);font-size:15px;margin:0;}

/* vision: philosophy en lignes (casse le rythme des cartes) */
.philo-rows{display:flex;flex-direction:column;margin-top:8px;}
.philo-row{display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;
  padding:26px 0;border-top:1px solid var(--ink-600);}
.philo-row:last-child{border-bottom:1px solid var(--ink-600);}
.philo-n{font-family:var(--font-display);font-size:clamp(38px,5vw,62px);line-height:.82;
  color:transparent;-webkit-text-stroke:1.5px var(--cyan);text-stroke:1.5px var(--cyan);
  letter-spacing:.01em;min-width:1.6em;}
.philo-tx{padding-top:4px;}
.philo-when{display:inline-block;font-family:var(--font-body);font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--bleu-ciel);margin-bottom:8px;}
.philo-tx h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-xl);
  letter-spacing:.01em;margin:0 0 8px;color:var(--blanc-rose);}
.philo-tx p{color:var(--fg-muted);font-size:15px;margin:0;max-width:62ch;}
.philo-img{width:190px;height:120px;flex:none;display:grid;place-items:center;overflow:hidden;
  border-radius:var(--radius-md);background:var(--bg-raised);border:1px solid var(--ink-600);}
.philo-img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.philo-img.contain{width:auto;background:none;border:none;overflow:visible;}
.philo-img.contain img{width:auto;height:100%;object-fit:contain;}
@media (max-width:760px){
  .philo-row{grid-template-columns:auto 1fr;}
  .philo-img{grid-column:1 / -1;width:100%;height:170px;margin-top:6px;}
}
@media (max-width:680px){
  .philo-row{grid-template-columns:1fr;gap:8px;padding:22px 0;}
  .philo-n{font-size:40px;}
}

/* vision: pipeline en cartes verticales (image, titre, texte) */
.pipe-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;margin-top:8px;}
.pipe-card{display:flex;flex-direction:column;background:var(--bg-raised);
  border:1px solid var(--ink-600);border-radius:var(--radius-lg);overflow:hidden;}
.pipe-media{position:relative;height:150px;background:var(--noir-bleute);overflow:hidden;}
.pipe-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.pipe-media.contain{background:linear-gradient(165deg, var(--ink-700), var(--noir-bleute));}
.pipe-media.contain img{object-fit:contain;padding:12px;box-sizing:border-box;}
.pipe-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:7px;}
.pipe-when{font-family:var(--font-body);font-size:12px;font-weight:600;text-transform:uppercase;
  letter-spacing:var(--tracking-wide);color:var(--bleu-ciel);}
.pipe-card h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-lg);
  letter-spacing:.01em;margin:0;color:var(--blanc-rose);line-height:1.05;}
.pipe-card p{color:var(--fg-muted);font-size:14px;margin:0;text-wrap:pretty;}

/* ---------- équipe: studio narrative ---------- */
.storywrap{max-width:1040px;margin-inline:auto;}
.story-lead{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(26px,3.4vw,44px);line-height:1.08;margin:0 0 28px;text-align:center;text-wrap:balance;max-width:1040px;margin-inline:auto;}
.story-body{max-width:none;}
.story-body p{color:var(--fg-muted);font-size:var(--text-md);line-height:var(--leading-body);margin:0 0 18px;text-align:justify;text-wrap:pretty;}
.story-body p:last-child{margin-bottom:0;}

/* ---------- équipe: detailed founder bios ---------- */
.bios{display:flex;flex-direction:column;gap:20px;}
.bio{display:grid;grid-template-columns:220px 1fr;gap:32px;align-items:start;text-align:left;padding:30px;}
.bio-ph{aspect-ratio:1/1;border-radius:var(--radius-lg);overflow:hidden;background:var(--ink-700);}
.bio-ph img{width:100%;height:100%;object-fit:cover;object-position:50% 20%;}
.bio-txt h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-xl);margin:0;}
.bio-txt .brole{color:var(--cyan);font-size:14px;font-weight:500;margin:4px 0 16px;}
.bio-txt p{color:var(--fg-muted);font-size:15px;line-height:var(--leading-body);margin:0 0 14px;text-wrap:pretty;}
.bio-txt .chiprow{margin-top:16px;}
@media (max-width:680px){
  .bio{grid-template-columns:1fr;gap:20px;padding:24px;}
  .bio-ph{max-width:160px;}
}

/* ---------- legal / privacy prose ---------- */
.legal{max-width:820px;}
.legal h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--text-lg);letter-spacing:var(--tracking-display);margin:34px 0 12px;}
.legal h3:first-child{margin-top:0;}
.legal p{color:var(--fg-muted);font-size:var(--text-md);line-height:var(--leading-body);margin:0 0 14px;text-wrap:pretty;}
.legal a{color:var(--cyan);}
.legal .ldl{display:grid;gap:0;margin:0 0 6px;}
.legal .ldl > div{display:grid;grid-template-columns:200px 1fr;gap:16px;padding:11px 0;border-bottom:1px solid var(--ink-600);}
.legal .ldl dt{color:var(--fg-faint);font-size:14px;}
.legal .ldl dd{margin:0;color:var(--blanc-rose);font-size:15px;}
.legal-list{margin:6px 0 16px;padding-left:20px;color:var(--fg-muted);font-size:15px;line-height:var(--leading-body);}
.legal-list li{margin-bottom:10px;}
.legal-list b{color:var(--blanc-rose);font-weight:500;}
.legal-table{overflow-x:auto;margin:8px 0 18px;border:1px solid var(--ink-600);border-radius:var(--radius-md);}
.legal-table table{width:100%;border-collapse:collapse;font-size:14px;}
.legal-table th{text-align:left;color:var(--fg-faint);font-weight:500;padding:12px 16px;border-bottom:1px solid var(--ink-600);background:var(--bg-raised);}
.legal-table td{color:var(--fg-muted);padding:12px 16px;border-bottom:1px solid var(--ink-600);}
.legal-table tr:last-child td{border-bottom:none;}
@media (max-width:680px){
  .legal .ldl > div{grid-template-columns:1fr;gap:2px;}
  .legal-table table{font-size:13px;}
  .legal-table th,.legal-table td{padding:8px 9px;overflow-wrap:anywhere;}
}

/* ---------- founder cards: clickable + modal (accueil) ---------- */
.founder-open{cursor:pointer;transition:transform .22s cubic-bezier(.2,.7,.2,1);}
.founder-open:hover{transform:translateY(-4px);}
.founder-open:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;}

.founder-modal{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(1,1,22,.72);backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .26s ease, visibility .26s ease;}
.founder-modal.open{opacity:1;visibility:visible;}
.fm-panel{position:relative;width:min(560px,100%);max-height:90vh;overflow:auto;
  background:var(--bg-raised);border:1px solid var(--ink-600);border-radius:var(--radius-xl);
  padding:30px 28px 32px;box-shadow:var(--shadow-lg);
  transform:translateY(14px) scale(.97);opacity:0;transition:transform .3s cubic-bezier(.2,.7,.2,1), opacity .3s ease;}
.founder-modal.open .fm-panel{transform:translateY(0) scale(1);opacity:1;}
.fm-close{position:absolute;top:14px;right:14px;width:38px;height:38px;display:grid;place-items:center;
  border-radius:var(--radius-pill);background:var(--ink-800);color:var(--fg-muted);
  transition:color .2s, background .2s;z-index:2;}
.fm-close:hover{color:#fff;background:var(--ink-700);}
.fm-body .bio{display:block;background:transparent;border:0;box-shadow:none;padding:0;text-align:left;}
.fm-body .bio-ph{width:160px;aspect-ratio:1/1;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:18px;}
.fm-body .bio-txt .chiprow{margin-top:16px;}
@media (prefers-reduced-motion: reduce){
  .founder-modal, .fm-panel{transition:opacity .15s ease;}
  .fm-panel{transform:none;}
}

/* ---------- équipe: hero collage ciel ---------- */
.team-hero .thero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:48px;align-items:center;width:100%;}
.team-hero .thero-copy h1{font-family:var(--font-display);text-transform:uppercase;line-height:.97;letter-spacing:.01em;font-weight:400;
  font-size:clamp(40px,5.4vw,84px);margin:0;max-width:none;text-align:left;}
.team-hero .thero-copy .lead{margin:24px 0 0;max-width:46ch;text-align:left;}
.team-hero .stage{position:relative;height:480px;}
.team-hero .tile{position:absolute;border-radius:var(--radius-lg);overflow:hidden;background:var(--ink-700);
  box-shadow:var(--shadow-lg);opacity:0;transform:scale(.6);}
.team-hero .tile img{width:100%;height:100%;object-fit:cover;object-position:50% 22%;display:block;}
.team-hero .tile .cap{position:absolute;left:0;right:0;bottom:0;padding:20px 14px 11px;
  font-family:var(--font-body);font-weight:500;font-size:14px;color:#fff;
  background:linear-gradient(to top, rgba(1,1,22,.8), transparent);}
.team-hero .t-a{width:198px;height:232px;left:0;top:0;z-index:2;}
.team-hero .t-b{width:186px;height:220px;left:54%;top:28px;z-index:2;}
.team-hero .t-c{width:198px;height:232px;left:9%;top:248px;z-index:3;}
.team-hero .t-d{width:182px;height:214px;left:60%;top:258px;z-index:3;}
@keyframes teampop{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:none}}
.team-hero .stage.in .tile{animation:teampop .55s cubic-bezier(.2,1.4,.4,1) both;}
.team-hero .stage.in .t-a{animation-delay:.08s;}
.team-hero .stage.in .t-b{animation-delay:.20s;}
.team-hero .stage.in .t-c{animation-delay:.32s;}
.team-hero .stage.in .t-d{animation-delay:.44s;}
html:not(.js) .team-hero .tile{opacity:1;transform:none;}
@media (prefers-reduced-motion: reduce){
  .team-hero .tile{opacity:1;transform:none;}
  .team-hero .stage.in .tile{animation:none;}
}
@media (max-width:900px){
  .team-hero .thero-grid{grid-template-columns:1fr;gap:30px;}
  .team-hero .stage{height:auto;display:grid;grid-template-columns:1fr 1fr;gap:14px;}
  .team-hero .tile{position:static;width:auto;height:auto;aspect-ratio:1/1.18;}
  .team-hero .t-a,.team-hero .t-b,.team-hero .t-c,.team-hero .t-d{left:auto;top:auto;}
}

/* ---------- video : carte média (design system) ---------- */
.videocard{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);
  outline:1px solid var(--ink-600);outline-offset:0;
  transition:outline-color .25s ease, box-shadow .25s ease, transform .25s cubic-bezier(.2,.7,.2,1);}
.videocard:hover{outline-color:var(--cyan);transform:translateY(-3px);
  box-shadow:var(--shadow-lg);}
.videocard .videowrap{border-radius:0;box-shadow:none;}
.videocard .vtag{position:absolute;top:16px;left:16px;z-index:3;display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px 7px 12px;border-radius:var(--radius-pill);
  background:rgba(1,1,22,.58);backdrop-filter:blur(6px);
  color:var(--blanc-rose);font-size:13px;font-weight:500;letter-spacing:.01em;}
.videocard .vtag::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--cyan);
  animation:vlive 1.8s ease-in-out infinite;}
@keyframes vlive{0%,100%{opacity:1}50%{opacity:.35}}
@media (prefers-reduced-motion: reduce){.videocard .vtag::before{animation:none;}}

/* ---------- event card: streamer strip ---------- */
.evstreamers{margin-top:24px;}
.evstreamers .evlabel{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:13px;}
.evstr-row{display:flex;flex-wrap:wrap;gap:14px 20px;}
.evstr{display:flex;align-items:center;gap:10px;}
.evstr .ph{width:40px;height:40px;border-radius:50%;overflow:hidden;background:var(--ink-700);flex:0 0 auto;box-shadow:0 0 0 1px var(--ink-600);}
.evstr .ph img{width:100%;height:100%;object-fit:cover;display:block;}
.evstr .meta{display:flex;flex-direction:column;line-height:1.18;}
.evstr .nm{font-size:14px;font-weight:500;color:var(--blanc-rose);}
.evstr .ct{font-size:12px;color:var(--cyan);}

/* ============================================================
   MOBILE POLISH — pass dédié petite largeur (A→Z)
   ============================================================ */
@media (max-width:680px){
  .section-head{margin-bottom:32px;}
  .ctaband{padding:48px 24px;}
  .band{padding:32px 22px;}
  .band .stats{display:grid;grid-template-columns:1fr 1fr;gap:26px 18px;justify-items:center;text-align:center;}
  .footer-cols{gap:26px 24px;}
}
@media (max-width:560px){
  .hero{min-height:auto;padding:102px 0 46px;}
  .hero h1{font-size:clamp(33px,9vw,44px);margin-top:14px;}
  .hero .lead{font-size:var(--text-md);margin-top:18px;}
  .team-hero .thero-copy h1{font-size:clamp(31px,8.4vw,42px);}
  .h2{font-size:clamp(26px,7.4vw,34px);}
  .story-lead{font-size:clamp(24px,7vw,32px);}
  .quote{font-size:clamp(20px,5.6vw,26px);}
  .section{padding:54px 0;}
  .section.tight{padding:44px 0;}
  .hero .cta{width:100%;gap:10px;}
  .hero .cta .btn{flex:1 1 0;justify-content:center;padding:14px 16px;}
  .ctaband{padding:40px 20px;}
  .ctaband .h2{font-size:clamp(24px,7vw,32px);}
  .radar{padding:18px 16px;}
  .radar .gn{min-width:104px;}
  .radar .gname{min-width:0;}
  .radar .score{min-width:38px;}
  .radar .row{gap:10px;}
  .team-hero .stage{gap:10px;}
  .split .media{min-height:220px;}
  .event .body{padding:20px 18px 22px;}
  .event .nums{gap:16px 20px;}
}
@media (max-width:400px){
  .nav-inner{padding:12px 16px;gap:10px;}
  .brand b{font-size:18px;}
  .brand img{height:34px;}
  .lang-btn{padding:7px 10px;}
  .wrap{padding:0 16px;}
}

/* ===== apparition du texte, masque montant (titres) ===== */
.tw-w{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.12em;margin-bottom:-.12em;}
.tw-wi{display:inline-block;}
@media (prefers-reduced-motion:no-preference){
  html.js .tw-split .tw-wi{transform:translateY(120%);transition:transform .62s cubic-bezier(.2,.7,.2,1);transition-delay:calc(var(--i)*.045s);}
  html.js .tw-split.tw-in .tw-wi{transform:none;}
}
html.js .tw-split.anim-force .tw-wi{transform:translateY(120%);transition:transform .62s cubic-bezier(.2,.7,.2,1);transition-delay:calc(var(--i)*.045s);}
html.js .tw-split.anim-force.tw-in .tw-wi{transform:none;}
/* verrou anti-gel : état final visible garanti, sans dépendre d'une transition */
.tw-split.tw-done .tw-wi{transform:none !important;transition:none !important;}

/* ===== apparition, masque montant par ligne (fiches jeux) ===== */
.tw-line{display:block;overflow:hidden;padding-bottom:.12em;margin-bottom:-.12em;}
@media (prefers-reduced-motion:no-preference){
  html.twjs .tw-line .tw-line-i{display:block;transform:translateY(120%);transition:transform .64s cubic-bezier(.2,.7,.2,1);}
  html.twjs .tw-line.tw-in .tw-line-i{transform:none;}
}
html.twjs .tw-line.anim-force .tw-line-i{display:block;transform:translateY(120%);transition:transform .64s cubic-bezier(.2,.7,.2,1);}
html.twjs .tw-line.anim-force.tw-in .tw-line-i{transform:none;}
.tw-line.tw-done .tw-line-i{transform:none !important;transition:none !important;}

/* ===== apparition du corps de texte (paragraphes, listes) ===== */
html.js .tr-fade, html.twjs .tr-fade{opacity:0;transform:translateY(16px);}
@media (prefers-reduced-motion:no-preference){
  html.js .tr-fade, html.twjs .tr-fade{transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1);transition-delay:calc(var(--tri,0)*.06s);}
}
html.js .tr-fade.anim-force, html.twjs .tr-fade.anim-force{transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1);transition-delay:calc(var(--tri,0)*.06s);}
html.js .tr-fade.tr-in, html.twjs .tr-fade.tr-in{opacity:1;transform:none;}
.tr-fade.tr-done{opacity:1 !important;transform:none !important;transition:none !important;}