:root{
  --bg:#0a0910;
  --panel:#171325cc;
  --text:#f7eaff;
  --muted:#c7b7d9;
  --accent1:#ff2d95;
  --accent2:#e94bff;
  --accent3:#ff9ad6;
  --radius:18px;
  --shadow:0 22px 60px -22px #000a,0 10px 30px -12px #0008;
  --ring:0 0 0 2px color-mix(in oklab, var(--accent2) 60%, white 0%);
  --safe-bottom: max(env(safe-area-inset-bottom, 0px), 0px);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 1200px at 80% -10%, #1d0c2a 0%, var(--bg) 50%),
    linear-gradient(120deg,#07070c 0%,var(--bg) 60%);
  overflow-x:hidden;
  /* réserve un espace bas en mobile pour éviter le crop des CTA par le toggle Discord */
  padding-bottom: clamp(0px, 4vh, 80px);
}

/* Header */
header{position:sticky;top:0;z-index:40;background:linear-gradient(#0a0a12cc,#0a0a1277);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid #ffffff15}
.nav{max-width:1200px;margin:0 auto;padding:14px 20px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.brand{display:flex;align-items:center;text-decoration:none}
.logo-brand{height:42px;width:auto;display:block;filter:drop-shadow(0 2px 8px #0006)}
nav ul{margin:0;padding:0;display:flex;gap:18px;list-style:none;flex-wrap:wrap}
nav a{color:var(--muted);text-decoration:none;padding:8px 10px;border-radius:10px}
nav a:hover{color:var(--text);background:#ffffff0a}
.cta{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}

/* Buttons */
.btn{--pad:12px 16px;padding:var(--pad);border-radius:12px;border:1px solid #ffffff20;background:#ffffff08;color:var(--text);font-weight:700;text-decoration:none;box-shadow:var(--shadow);transition:.2s;cursor:pointer}
.btn:hover{transform:translateY(-1px);background:#ffffff12}
.btn.primary{background:linear-gradient(135deg,var(--accent1),var(--accent2) 60%,var(--accent3));border:0;box-shadow:0 12px 30px -12px color-mix(in oklab,var(--accent2) 80%, black 20%)}
.btn.login{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;background:linear-gradient(#ffffff08,#ffffff08) padding-box,linear-gradient(135deg,var(--accent1),var(--accent2)) border-box;border:1px solid transparent}
.login-ico{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:#0e0a16;border:1px solid #ffffff22}

/* HERO */
.hero{position:relative;min-height:clamp(560px,86vh,880px);display:grid;align-items:end}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(112%) contrast(104%) brightness(.78)}
.hero-bg::before, .hero-bg::after{content:"";position:absolute;inset:0;pointer-events:none}
.hero-bg::before{opacity:.11;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.85'/></svg>");background-size:800px 800px}
.hero-bg::after{background:
  radial-gradient(120% 90% at 70% 20%, rgba(233,75,255,.25), transparent 55%),
  radial-gradient(100% 80% at 20% 75%, rgba(255,45,149,.22), transparent 60%),
  radial-gradient(65% 60% at 50% 60%, rgba(255,255,255,.14), transparent 60%),
  radial-gradient(140% 100% at 50% 100%, rgba(0,0,0,.55), rgba(0,0,0,.75));
  mix-blend-mode:screen}
.hero-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:clamp(18px,4vw,32px) 20px 40px;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(16px,3vw,40px);align-items:end}
.hero-copy .kicker{color:var(--muted);font-weight:800;letter-spacing:.14em;text-transform:uppercase}
.title{font-size:clamp(34px,7vw,78px);line-height:1.07;margin:.2em 0 .3em;font-weight:900;background:linear-gradient(90deg,#fff 20%,var(--accent3),var(--accent2),var(--accent1));-webkit-background-clip:text;color:transparent;text-shadow:0 0 40px #ffffff0a}
.subtitle{color:var(--muted)}
.hero-cta{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}
.hero-cta .btn{min-width:140px}

/* Mobile hero stack */
@media (max-width:700px){
  .hero-inner{grid-template-columns:1fr;gap:18px}
  .hero{min-height:auto}
  .hero-cta{flex-direction:column;align-items:flex-start}
  .hero-cta .btn{width:100%}
}

/* Réseaux */
.social-bar{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.social.pill{display:flex;align-items:center;gap:8px;font-weight:800;text-decoration:none;color:#ffeaff;background:#ffffff14;border:1px solid #ffffff25;border-radius:999px;padding:8px 12px;backdrop-filter:blur(6px)}
.social.pill:hover{background:#ffffff1c}
.social.pill .ico{width:20px;height:20px;display:block}

/* PRISM */
.prism{align-self:center;display:grid;gap:10px;justify-items:center}
.prism-glass{position:relative;width:min(520px,44vw);aspect-ratio:16/9;border-radius:20px;background:linear-gradient(180deg,#120e1b,#0e0a16);border:1px solid #ffffff22;overflow:hidden;isolation:isolate;box-shadow:0 30px 120px -40px #000a,0 6px 20px -12px #0008}
.logo-main{position:absolute;inset:0;margin:auto;width:min(78%,560px);height:auto;object-fit:contain}
.prism-glass.png .scanlines{opacity:.12}
.prism-glass.png .glass-sheen{opacity:.22}
.logo-main.png{filter:none;mix-blend-mode:normal}
.glass-sheen{position:absolute;inset:-30% -10% auto -10%;height:60%;background:linear-gradient(12deg,transparent 20%,#ffffff18 50%,transparent 80%);transform:translateY(-20%) skewY(-8deg);animation:sheen 7s ease-in-out infinite}
@keyframes sheen{0%{transform:translateY(-40%) skewY(-8deg);opacity:.7}50%{transform:translateY(10%) skewY(-8deg);opacity:.3}100%{transform:translateY(-40%) skewY(-8deg);opacity:.7}}
.scanlines{position:absolute;inset:0;background:repeating-linear-gradient(to bottom,#ffffff10 0 1px,transparent 1px 3px);mix-blend-mode:soft-light;opacity:.25;pointer-events:none}
.halo{position:absolute;inset:-20%;background:radial-gradient(40% 50% at 80% 10%,color-mix(in oklab,var(--accent1) 35%, transparent),transparent 60%),radial-gradient(50% 60% at 10% 90%,color-mix(in oklab,var(--accent2) 30%, transparent),transparent 60%);filter:blur(30px);opacity:.7;pointer-events:none}
.logo-tagline{margin:0;color:#ffe7f7;font-weight:700;display:flex;align-items:center;gap:8px}
.logo-tagline .dot{width:8px;height:8px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#ff2d95);box-shadow:0 0 12px #ff2d9577}
.logo-highlights{list-style:none;margin:0;padding:0;display:flex;gap:10px;flex-wrap:wrap}
.logo-highlights li{font-size:12px;color:#ffeaff;background:#ffffff15;border:1px solid #ffffff22;padding:6px 10px;border-radius:999px}

/* Sections */
.section{max-width:1200px;margin:70px auto;padding:0 20px}
.sec-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.sec-title{font-size:clamp(22px,5.5vw,36px);font-weight:900}
.sec-sub{color:var(--muted)}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:clamp(12px,1.6vw,16px)}
@media (max-width:1100px){.grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:700px){.grid{grid-template-columns:1fr}.prism-glass{width:min(560px,92vw)}}

/* Cards */
.card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--panel);border:1px solid #ffffff18;box-shadow:var(--shadow);aspect-ratio:3/4;display:flex;flex-direction:column;justify-content:flex-end;transform-style:preserve-3d;transition:transform .12s, box-shadow .2s;border-color:#ffffff18;--tiltX:0deg;--tiltY:0deg;transform:perspective(1000px) rotateX(var(--tiltX)) rotateY(var(--tiltY))}
.card:hover{box-shadow:0 30px 90px -26px #000d,0 0 0 1px #ffffff22 inset}
.cover{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(108%) contrast(102%);transform:translateZ(20px) scale(1.02)}
.cover:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,#0a0a10ee 10%,#0a0a1000 55% 70%,#0a0a10ee 100%),radial-gradient(60% 40% at 50% 10%,#00000088,transparent 70%)}
.safe-blur{filter:blur(14px) saturate(60%) !important}

/* Plateformes */
.platforms{position:absolute;top:10px;right:10px;display:flex;gap:8px;background:#1a1424cc;border:1px solid #ffffff22;border-radius:10px;padding:6px 8px;backdrop-filter:blur(6px);z-index:5}
.platforms svg{width:16px;height:16px;display:block}

/* Bas de carte */
.card .meta{position:relative;z-index:2;display:flex;flex-direction:column;gap:10px;padding:16px 124px 16px 16px}
.tagz{display:flex;gap:8px;flex-wrap:wrap}
.tag{font-size:11px;color:#ffeaff;background:#ffffff15;border:1px solid #ffffff25;padding:5px 8px;border-radius:999px}
.title-sm{font-weight:900;font-size:18px;letter-spacing:.3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-width:100%}

/* CTA */
.play{position:absolute;right:12px;bottom:12px;z-index:5;display:flex;align-items:center;gap:8px;height:40px;padding:0 16px;border-radius:12px;border:1px solid #ffffff22;background:#1a1424cc;backdrop-filter:blur(8px);font-weight:800;text-decoration:none;color:var(--text);box-shadow:0 6px 22px -10px #0008;transform:translateZ(30px);transition:transform .15s, background .15s}
.play svg{width:16px;height:16px}
.play:hover{transform:translateZ(30px) translateY(-1px);background:#201631cc}

/* Glow */
.glow{position:absolute;inset:-20%;background:radial-gradient(40% 40% at var(--mx,50%) var(--my,70%), color-mix(in oklab, var(--accent1) 30%, transparent), transparent 60%);opacity:0;transition:opacity .2s}
.card:hover .glow{opacity:1}

/* Studio */
.studio{position:relative;border-radius:16px;padding:18px;border:1px solid #ffffff15;background:linear-gradient(180deg,#ffffff08,#ffffff04);box-shadow:var(--shadow)}

/* Marquee */
.marquee{overflow:hidden;mask:linear-gradient(90deg,transparent, #000 8%, #000 92%, transparent);margin:8px 0 4px}
.marquee-track{display:inline-flex;gap:24px;white-space:nowrap;align-items:center;animation:marq 18s linear infinite;will-change:transform}
.marquee-track span{display:inline-block;padding:10px 16px;background:#ffffff14;border:1px solid #ffffff22;border-radius:999px;font-weight:800;letter-spacing:.02em}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Team */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:14px}
@media (max-width:960px){.team{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.team{grid-template-columns:1fr}}
.member{background:#120e1b;border:1px solid #ffffff14;border-radius:14px;padding:14px;display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:center}
.avatar{width:64px;height:64px;border-radius:12px;overflow:hidden;border:1px solid #ffffff22;background:#1b1526}
.avatar img{width:100%;height:100%;object-fit:cover}
.m-name{font-weight:900}.m-role{color:var(--muted);font-size:13px}
.m-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.m-tags span{font-size:11px;padding:4px 8px;border-radius:999px;background:#ffffff10;border:1px solid #ffffff18}

/* Footer */
footer{margin:80px 0 30px;color:#f1d9ffb0;font-size:14px}
.foot{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;gap:12px;align-items:center;justify-content:space-between;border-top:1px solid #ffffff15;padding-top:18px;flex-wrap:wrap}
.links{display:flex;gap:14px;flex-wrap:wrap}
.links a{color:#ffe6ff;text-decoration:none;opacity:.9}
.links a:hover{text-decoration:underline}
.links.socials a{background:#ffffff10;border:1px solid #ffffff20;padding:6px 10px;border-radius:999px}

/* Accessibilité focus */
.btn:focus-visible,
.discord-toggle:focus-visible{outline:none;box-shadow:var(--ring)}

/* Motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition:none!important}
}

/* === Discord: bouton toggle + panneau === */
.discord-toggle{
  position:fixed;
  bottom: calc(16px + var(--safe-bottom));
  right: 16px;
  width:46px;
  height:46px;
  border-radius:50%;
  border:1px solid #ffffff33;
  background:linear-gradient(135deg,var(--accent1),var(--accent2));
  color:#fff;
  box-shadow:0 10px 30px -12px #000a, 0 0 0 1px #ffffff22 inset;
  display:grid;
  place-items:center;
  cursor:pointer;
  z-index:1000;
  transition:transform .25s ease, background .25s ease;
}
.discord-toggle:hover{ transform:scale(1.1); background:linear-gradient(135deg,var(--accent2),var(--accent3)); }

/* Panneau (fermé par défaut) */
.discord-widget{
  position:fixed;
  bottom: calc(76px + var(--safe-bottom));
  right: 16px;
  width:300px;
  height:400px;
  border-radius:12px;
  overflow:hidden;
  border:1px solid #ffffff22;
  background:#0e0a16;
  box-shadow:0 8px 28px -8px #000a;
  z-index:999;
  opacity:0;
  pointer-events:none;
  transform:translateY(20px) scale(0.96);
  transition:opacity .28s ease, transform .28s ease;
}
.discord-widget iframe{ width:100%; height:100%; border:none; border-radius:12px; }
.discord-widget.open{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0) scale(1);
}

/* Responsive mobile */
@media (max-width:560px){
  .discord-widget{
    width:92vw;
    height:60vh;
    right:4vw;
    bottom: calc(76px + var(--safe-bottom));
  }
  .discord-toggle{
    width:44px;height:44px;
    bottom: calc(14px + var(--safe-bottom));
    right: 14px;
  }
  /* Ajuste la typographie pour éviter le crop en très petit écran */
  .title{font-size:clamp(28px,8.5vw,44px)}
  .sec-title{font-size:clamp(20px,6vw,28px)}
}
