/* =========================================================
   TRYZARIA SURVIVAL — design system
   Golden-hour sakura : ciel violet -> rose -> orange,
   or du logo + bleu diamant, pétales qui tombent.
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --dusk:#241439;          /* base nuit/crépuscule */
  --dusk-2:#160b27;        /* plus sombre (footer, cartes) */
  --plum:#4a2870;          /* violet mystique */
  --sakura:#ff7eb6;        /* rose cerisier */
  --sakura-soft:#ffb7d5;   /* pétales clairs */
  --sunset:#ff9a4d;        /* orange coucher de soleil */
  --ember:#ff6b3d;         /* braise lanternes */
  --gold:#f6c94a;          /* or du logo */
  --gold-deep:#c8941e;     /* contour or */
  --diamond:#5ad7ea;       /* bleu diamant (armure/épée) */
  --cream:#fff3e8;         /* texte clair */
  --muted:rgba(255,243,232,.64);
  --glass:rgba(31,18,52,.55);
  --glass-brd:rgba(255,183,213,.22);
  --maxw:1160px;
  --radius:18px;
  --radius-lg:26px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 18px 50px -18px rgba(10,4,24,.8);
  --shadow-gold:0 14px 40px -12px rgba(246,201,74,.45);
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Nunito",system-ui,sans-serif;
  color:var(--cream);
  background:var(--dusk-2);
  line-height:1.65;
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---------- Atmosphère (fond fixe) ---------- */
.sky{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(255,154,77,.55), transparent 55%),
    radial-gradient(90% 70% at 12% 8%, rgba(255,126,182,.40), transparent 60%),
    linear-gradient(170deg,#2c1850 0%,#241439 38%,#1a0f2e 70%,#160b27 100%);
}
.sky::after{ /* grain doux */
  content:"";position:absolute;inset:0;opacity:.05;
  background-image:radial-gradient(rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:3px 3px;
}
.petals{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.petal{
  position:absolute;top:-8%;width:14px;height:14px;
  background:radial-gradient(circle at 35% 30%, var(--sakura-soft), var(--sakura) 70%);
  border-radius:60% 0 60% 0;
  opacity:.85;will-change:transform;
  animation:fall linear infinite;
}
@keyframes fall{
  0%{transform:translateY(-10vh) translateX(0) rotate(0deg)}
  100%{transform:translateY(112vh) translateX(60px) rotate(420deg)}
}

/* ---------- Utilitaires layout ---------- */
.wrap{width:min(100% - 40px,var(--maxw));margin-inline:auto}
.section{padding:88px 0}
.section--tight{padding:56px 0}
.eyebrow{
  font-family:"Press Start 2P",monospace;
  font-size:.62rem;letter-spacing:.5px;color:var(--gold);
  text-transform:uppercase;display:inline-block;margin-bottom:18px;
  text-shadow:0 2px 0 rgba(0,0,0,.35);
}
.h-section{
  font-family:"Fredoka",sans-serif;font-weight:600;
  font-size:clamp(1.9rem,4.5vw,3rem);line-height:1.05;
  letter-spacing:-.5px;
}
.lead{color:var(--muted);font-size:1.08rem;max-width:60ch}
.center{text-align:center}
.center .lead{margin-inline:auto}

/* ---------- Header ---------- */
.hdr{
  position:sticky;top:0;z-index:60;
  backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(22,11,39,.82),rgba(22,11,39,.5));
  border-bottom:1px solid var(--glass-brd);
}
.hdr__in{display:flex;align-items:center;gap:18px;height:70px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Fredoka",sans-serif;
  font-weight:600;font-size:1.25rem;letter-spacing:.3px}
.brand img{width:38px;height:38px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}
.brand b{color:var(--gold)}
.brand span{color:var(--sakura);font-size:.7rem;font-family:"Press Start 2P",monospace;
  align-self:flex-end;margin-bottom:3px}

.nav{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav a{
  padding:9px 14px;border-radius:11px;font-weight:700;font-size:.96rem;
  color:var(--muted);transition:.2s var(--ease);
}
.nav a:hover{color:var(--cream);background:rgba(255,183,213,.1)}
.nav a.is-active{color:var(--gold);background:rgba(246,201,74,.12)}

.nav-tools{display:flex;align-items:center;gap:10px;margin-left:8px}

.burger{
  display:none;margin-left:auto;width:44px;height:44px;border-radius:12px;
  border:1px solid var(--glass-brd);background:var(--glass);cursor:pointer;
  flex-direction:column;gap:5px;align-items:center;justify-content:center;
}
.burger span{width:20px;height:2px;background:var(--cream);border-radius:2px;transition:.25s}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Boutons ---------- */
.btn{
  --bg:var(--glass);
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 22px;border-radius:13px;font-weight:800;font-size:.98rem;
  font-family:"Nunito",sans-serif;cursor:pointer;border:1px solid transparent;
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--sunset));
  color:#3a1d05;box-shadow:var(--shadow-gold);
  border:1px solid rgba(255,255,255,.25);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 20px 48px -12px rgba(255,154,77,.6)}
.btn-ghost{background:var(--glass);border:1px solid var(--glass-brd);color:var(--cream)}
.btn-ghost:hover{border-color:var(--sakura);background:rgba(255,126,182,.12);transform:translateY(-2px)}
.btn-discord{background:#5865F2;color:#fff;border:1px solid rgba(255,255,255,.2)}
.btn-discord:hover{transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(88,101,242,.8)}
.btn-sm{padding:9px 15px;font-size:.9rem;border-radius:11px}

/* ---------- IP copy ---------- */
.ip{
  display:inline-flex;align-items:center;gap:0;border-radius:13px;overflow:hidden;
  border:1px solid var(--glass-brd);background:var(--glass);backdrop-filter:blur(8px);
}
.ip__code{
  font-family:"Press Start 2P",monospace;font-size:.74rem;color:var(--diamond);
  padding:0 16px;letter-spacing:.5px;
}
.ip__btn{
  background:linear-gradient(135deg,var(--gold),var(--sunset));color:#3a1d05;
  border:none;padding:13px 16px;font-weight:800;cursor:pointer;font-family:"Nunito";
  display:inline-flex;align-items:center;gap:7px;transition:.2s;
}
.ip__btn:hover{filter:brightness(1.07)}
.ip--header .ip__code{font-size:.62rem;padding:0 11px}
.ip--header .ip__btn{padding:10px 13px;font-size:.84rem}

/* ---------- Hero ---------- */
.hero{position:relative;padding:54px 0 64px;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero__title{
  font-family:"Fredoka",sans-serif;font-weight:700;
  font-size:clamp(2.6rem,6.4vw,4.4rem);line-height:.98;letter-spacing:-1px;
  text-shadow:0 6px 0 rgba(0,0,0,.22);
}
.hero__title .g{color:var(--gold);text-shadow:0 4px 0 var(--gold-deep),0 8px 22px rgba(246,201,74,.4)}
.hero__sub{margin:20px 0 30px;font-size:1.16rem;color:var(--muted);max-width:46ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero__badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.badge{
  display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border-radius:999px;
  font-size:.82rem;font-weight:800;background:rgba(90,215,234,.12);
  border:1px solid rgba(90,215,234,.3);color:var(--diamond);
}
.badge--pink{background:rgba(255,126,182,.12);border-color:rgba(255,126,182,.34);color:var(--sakura-soft)}
.badge--gold{background:rgba(246,201,74,.13);border-color:rgba(246,201,74,.35);color:var(--gold)}

.hero__art{position:relative}
.hero__art img{
  border-radius:var(--radius-lg);border:1px solid var(--glass-brd);
  box-shadow:var(--shadow);transform:rotate(1.2deg);
}
.hero__art::before{
  content:"";position:absolute;inset:-14px;border-radius:32px;z-index:-1;
  background:conic-gradient(from 120deg,var(--sakura),var(--sunset),var(--gold),var(--diamond),var(--sakura));
  filter:blur(38px);opacity:.5;
}
.hero__float{
  position:absolute;right:-18px;bottom:-26px;width:96px;
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.55));
  animation:bob 4.5s ease-in-out infinite;
}
@keyframes bob{50%{transform:translateY(-12px) rotate(-4deg)}}

/* ---------- Piliers / features ---------- */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.card{
  background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--radius);
  padding:26px 24px;backdrop-filter:blur(8px);transition:.28s var(--ease);position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-5px);border-color:var(--sakura);box-shadow:var(--shadow)}
.card__ico{
  width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:1.6rem;
  background:linear-gradient(135deg,rgba(246,201,74,.2),rgba(255,126,182,.18));
  border:1px solid var(--glass-brd);margin-bottom:16px;
}
.card h3{font-family:"Fredoka",sans-serif;font-weight:600;font-size:1.22rem;margin-bottom:7px}
.card p{color:var(--muted);font-size:.96rem}
.card__tag{
  position:absolute;top:14px;right:14px;font-family:"Press Start 2P",monospace;
  font-size:.5rem;color:var(--gold);opacity:.7;
}

/* ---------- Trailer ---------- */
.trailer{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--glass-brd);box-shadow:var(--shadow);aspect-ratio:16/9;background:#000;
}
.trailer iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- Étapes rejoindre ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:s}
.step{
  background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--radius);
  padding:26px 22px 24px;position:relative;
}
.step::before{
  counter-increment:s;content:counter(s);
  font-family:"Press Start 2P",monospace;font-size:1rem;color:#3a1d05;
  width:42px;height:42px;border-radius:11px;display:grid;place-items:center;margin-bottom:14px;
  background:linear-gradient(135deg,var(--gold),var(--sunset));box-shadow:var(--shadow-gold);
}
.step h4{font-family:"Fredoka";font-weight:600;font-size:1.1rem;margin-bottom:6px}
.step p{color:var(--muted);font-size:.95rem}
.step code{background:rgba(90,215,234,.14);color:var(--diamond);padding:2px 8px;border-radius:7px;
  font-family:"Press Start 2P",monospace;font-size:.66rem}

/* ---------- Bandeau CTA ---------- */
.cta-band{
  border-radius:var(--radius-lg);padding:44px;display:flex;flex-wrap:wrap;gap:24px;
  align-items:center;justify-content:space-between;
  background:linear-gradient(120deg,rgba(255,126,182,.16),rgba(246,201,74,.14));
  border:1px solid var(--glass-brd);
}
.cta-band h3{font-family:"Fredoka";font-weight:600;font-size:clamp(1.5rem,3vw,2.1rem);max-width:20ch}
.cta-band p{color:var(--muted);margin-top:6px}

/* ---------- Page hero (sous-pages) ---------- */
.page-hero{padding:64px 0 30px;text-align:center}
.page-hero .h-section{font-size:clamp(2.2rem,5vw,3.4rem)}

/* ---------- Votes ---------- */
.vote-card{
  background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--radius);
  padding:26px 24px;display:flex;flex-direction:column;gap:14px;transition:.28s var(--ease);
}
.vote-card:hover{transform:translateY(-5px);border-color:var(--gold);box-shadow:var(--shadow)}
.vote-card__n{font-family:"Press Start 2P",monospace;font-size:.78rem;color:var(--gold)}
.vote-card h3{font-family:"Fredoka";font-weight:600;font-size:1.2rem}
.vote-card p{color:var(--muted);font-size:.94rem;flex:1}
.vote-card .btn{width:100%}

.reward{display:flex;gap:13px;align-items:flex-start;padding:16px 18px;border-radius:14px;
  background:var(--glass);border:1px solid var(--glass-brd)}
.reward .e{font-size:1.5rem;line-height:1}
.reward h4{font-family:"Fredoka";font-weight:600;font-size:1.02rem;margin-bottom:2px}
.reward p{color:var(--muted);font-size:.9rem}

/* ---------- Boutique vitrine ---------- */
.shop-note{
  display:inline-flex;align-items:center;gap:9px;padding:9px 16px;border-radius:999px;
  background:rgba(246,201,74,.12);border:1px solid rgba(246,201,74,.35);color:var(--gold);
  font-weight:800;font-size:.9rem;
}
.rank{
  background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--radius-lg);
  padding:30px 26px;position:relative;overflow:hidden;transition:.28s var(--ease);
}
.rank:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.rank--feature{border-color:var(--gold);box-shadow:var(--shadow-gold)}
.rank__glow{position:absolute;inset:0;z-index:-1;opacity:.5;filter:blur(40px)}
.rank__name{font-family:"Fredoka";font-weight:600;font-size:1.5rem}
.rank__price{font-family:"Press Start 2P",monospace;font-size:1.1rem;color:var(--gold);margin:10px 0 18px}
.rank ul li{padding:7px 0;color:var(--muted);font-size:.95rem;display:flex;gap:9px;align-items:flex-start}
.rank ul li::before{content:"◆";color:var(--diamond);font-size:.7rem;margin-top:5px}
.rank .btn{width:100%;margin-top:20px;opacity:.7;cursor:not-allowed}
.soon-pill{position:absolute;top:18px;right:18px;font-family:"Press Start 2P",monospace;
  font-size:.5rem;color:#3a1d05;background:var(--gold);padding:6px 9px;border-radius:8px}

/* ---------- Wiki ---------- */
.wiki{display:grid;grid-template-columns:240px 1fr;gap:36px;align-items:start}
.wiki-nav{position:sticky;top:90px;background:var(--glass);border:1px solid var(--glass-brd);
  border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:3px}
.wiki-nav button{
  text-align:left;background:none;border:none;color:var(--muted);cursor:pointer;
  padding:11px 14px;border-radius:11px;font-family:"Nunito";font-weight:700;font-size:.96rem;transition:.2s;
}
.wiki-nav button:hover{color:var(--cream);background:rgba(255,183,213,.1)}
.wiki-nav button.is-active{color:var(--gold);background:rgba(246,201,74,.12)}
.wiki-panel{display:none;animation:fade .4s var(--ease)}
.wiki-panel.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.wiki-panel h2{font-family:"Fredoka";font-weight:600;font-size:1.9rem;margin-bottom:8px}
.wiki-panel h3{font-family:"Fredoka";font-weight:600;font-size:1.2rem;margin:24px 0 8px;color:var(--sakura-soft)}
.wiki-panel p{color:var(--muted);margin-bottom:12px}
.wiki-panel ul.dot li{padding:6px 0;color:var(--muted);display:flex;gap:10px}
.wiki-panel ul.dot li::before{content:"🌸";font-size:.85rem}
.wiki-tip{background:rgba(90,215,234,.1);border:1px solid rgba(90,215,234,.3);border-left:3px solid var(--diamond);
  padding:14px 18px;border-radius:12px;margin:16px 0;color:var(--cream)}
.placeholder{font-style:italic;opacity:.7}

/* ---------- Toast ---------- */
.toast{
  position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(140%);
  background:linear-gradient(135deg,var(--gold),var(--sunset));color:#3a1d05;
  padding:13px 22px;border-radius:13px;font-weight:800;box-shadow:var(--shadow-gold);
  z-index:200;display:flex;align-items:center;gap:9px;transition:transform .4s var(--ease);
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- Footer ---------- */
.ftr{background:var(--dusk-2);border-top:1px solid var(--glass-brd);padding:54px 0 30px;margin-top:40px}
.ftr__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
.ftr__brand{display:flex;gap:13px;align-items:center;margin-bottom:14px}
.ftr__brand img{width:52px;height:52px}
.ftr__brand b{font-family:"Fredoka";font-weight:600;font-size:1.3rem}
.ftr h5{font-family:"Fredoka";font-weight:600;margin-bottom:12px;color:var(--gold)}
.ftr a{color:var(--muted);display:block;padding:5px 0;transition:.2s}
.ftr a:hover{color:var(--sakura-soft)}
.ftr__bottom{margin-top:36px;padding-top:20px;border-top:1px solid rgba(255,183,213,.12);
  display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;color:var(--muted);font-size:.86rem}

/* ---------- Reveal au scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Accessibilité ---------- */
:focus-visible{outline:3px solid var(--diamond);outline-offset:3px;border-radius:6px}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero__grid{grid-template-columns:1fr;gap:34px}
  .hero__art{order:-1}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .ftr__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav,.nav-tools{
    position:fixed;inset:70px 0 auto 0;flex-direction:column;align-items:stretch;
    background:rgba(22,11,39,.97);backdrop-filter:blur(16px);padding:14px 20px;gap:6px;
    border-bottom:1px solid var(--glass-brd);transform:translateY(-130%);transition:transform .3s var(--ease);
    margin:0;
  }
  .nav-tools{top:auto;position:static;transform:none;background:none;backdrop-filter:none;
    padding:10px 20px 18px;border:none}
  .nav.open{transform:translateY(0)}
  .nav.open + .nav-tools{}
  .nav a{padding:13px 14px;font-size:1.05rem}
  .burger{display:flex}
  .grid-3,.steps,.grid-2{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .wiki{grid-template-columns:1fr}
  .wiki-nav{position:static;flex-direction:row;overflow-x:auto;flex-wrap:nowrap}
  .wiki-nav button{white-space:nowrap}
  .ftr__grid{grid-template-columns:1fr}
  .cta-band{padding:30px}
  .section{padding:60px 0}
}
@media(max-width:420px){
  .grid-4{grid-template-columns:1fr}
  .ip--header{display:none}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* =========================================================
   AJOUTS — Sélecteur de langue + Section Boss
   ========================================================= */

/* ---------- Sélecteur de langue ---------- */
.lang-toggle{
  display:inline-flex;border:1px solid var(--glass-brd);border-radius:11px;
  overflow:hidden;background:var(--glass);backdrop-filter:blur(8px);
}
.lang-toggle button{
  background:none;border:none;color:var(--muted);cursor:pointer;
  padding:9px 12px;font-family:"Nunito";font-weight:800;font-size:.82rem;
  letter-spacing:.3px;transition:.2s var(--ease);
}
.lang-toggle button:hover{color:var(--cream)}
.lang-toggle button.is-active{
  background:linear-gradient(135deg,var(--gold),var(--sunset));color:#3a1d05;
}

/* ---------- Section Boss ---------- */
.boss-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.boss-card{
  --el:var(--sakura);
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(165deg,rgba(31,18,52,.7),rgba(22,11,39,.85));
  border:1px solid var(--glass-brd);transition:.3s var(--ease);
  display:flex;flex-direction:column;
}
.boss-card::before{ /* liseré coloré selon l'élément */
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  border:1px solid color-mix(in srgb,var(--el) 55%,transparent);opacity:.0;transition:.3s;
}
.boss-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.boss-card:hover::before{opacity:1}

.boss-stage{
  position:relative;height:280px;display:grid;place-items:end center;overflow:hidden;
}
.boss-glow{
  position:absolute;left:50%;bottom:-30%;width:78%;aspect-ratio:1;transform:translateX(-50%);
  background:radial-gradient(circle, color-mix(in srgb,var(--el) 70%,transparent) 0%, transparent 66%);
  filter:blur(18px);opacity:.7;transition:.35s var(--ease);
}
.boss-card:hover .boss-glow{opacity:1;bottom:-22%}
.boss-floor{
  position:absolute;left:50%;bottom:26px;width:54%;height:26px;transform:translateX(-50%);
  background:radial-gradient(ellipse, rgba(0,0,0,.6), transparent 70%);filter:blur(5px);
}
.boss-img{
  position:relative;z-index:2;max-height:248px;width:auto;
  filter:drop-shadow(0 16px 24px rgba(0,0,0,.55));
  transition:transform .4s var(--ease);will-change:transform;
}
.boss-card:hover .boss-img{transform:translateY(-8px) scale(1.05)}
.boss-stage--frame .boss-img{
  max-height:none;height:280px;width:100%;object-fit:cover;
  -webkit-mask-image:radial-gradient(circle at 50% 46%,#000 52%,transparent 74%);
  mask-image:radial-gradient(circle at 50% 46%,#000 52%,transparent 74%);
}

.boss-body{padding:8px 24px 26px;position:relative;z-index:3}
.boss-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.boss-el{
  display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;
  font-size:.74rem;font-weight:800;
  color:var(--el);
  background:color-mix(in srgb,var(--el) 14%,transparent);
  border:1px solid color-mix(in srgb,var(--el) 38%,transparent);
}
.boss-el::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--el);
  box-shadow:0 0 8px var(--el)}
.boss-diff{
  display:inline-flex;align-items:center;padding:5px 11px;border-radius:999px;
  font-family:"Press Start 2P",monospace;font-size:.5rem;color:var(--muted);
  background:rgba(255,255,255,.05);border:1px solid var(--glass-brd);
}
.boss-body h3{font-family:"Fredoka";font-weight:600;font-size:1.5rem;margin-bottom:7px}
.boss-body p{color:var(--muted);font-size:.97rem}
.boss-note{
  text-align:center;margin-top:22px;color:var(--muted);font-size:.84rem;font-style:italic;opacity:.8;
}

@media(prefers-reduced-motion:no-preference){
  .boss-img{animation:bossbob 5s ease-in-out infinite}
  .boss-card:nth-child(2) .boss-img{animation-delay:-1.2s}
  .boss-card:nth-child(3) .boss-img{animation-delay:-2.4s}
  .boss-card:nth-child(4) .boss-img{animation-delay:-3.6s}
  @keyframes bossbob{50%{transform:translateY(-7px)}}
  .boss-card:hover .boss-img{animation-play-state:paused}
}

@media(max-width:760px){
  .boss-grid{grid-template-columns:1fr}
  .boss-stage{height:240px}
  .boss-img{max-height:210px}
  .lang-toggle button{padding:8px 11px}
}

/* ---------- Vitrine Boss (image de groupe) ---------- */
.boss-teaser{max-width:66ch;margin-inline:auto}
.boss-poster{position:relative;margin:0}
.boss-poster img{
  width:100%;display:block;border-radius:var(--radius-lg);
  border:1px solid var(--glass-brd);box-shadow:var(--shadow);position:relative;z-index:1;
}
.boss-poster::before{
  content:"";position:absolute;inset:-14px;border-radius:32px;z-index:0;
  background:conic-gradient(from 140deg,#86c544,#46d6e6,#ff7a3d,#e6c79a,#86c544);
  filter:blur(42px);opacity:.38;
}
.boss-chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:24px}
.boss-chip{
  --el:var(--gold);
  display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:14px;
  background:var(--glass);border:1px solid var(--glass-brd);backdrop-filter:blur(8px);
  transition:.22s var(--ease);
}
.boss-chip::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--el);
  box-shadow:0 0 10px var(--el);flex:none}
.boss-chip:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--el) 55%,transparent)}
.boss-chip b{font-family:"Fredoka";font-weight:600;font-size:1rem;line-height:1.1}
.boss-chip span{color:var(--muted);font-size:.78rem}
@media(max-width:520px){
  .boss-chip{flex:1 1 calc(50% - 12px);justify-content:center}
}
