@import url('https://fonts.googleapis.com/css2?family=Outfit:ital,wght@0,800;1,800&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
:root{
  /* Palette legacy (garder pour compat partout dans le fichier) */
  --bg:#07070f;--s1:#0f0f1c;--s2:#161628;--s3:#1d1d34;--s4:#252542;
  --red:#e8304a;--red2:#ff5068;--gold:#f5a623;--gold2:#ffc85e;
  --text:#f0eef8;--text2:#a8a6be;--muted:#5e5c76;
  --border:rgba(255,255,255,.06);--border2:rgba(255,255,255,.11);
  --nav-h:68px;
  --ff-head:'Syne',system-ui,sans-serif;
  --ff-body:'Plus Jakarta Sans','DM Sans',system-ui,sans-serif;
  --r:12px;--r2:20px;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  /* Tokens sémantiques (design moderne — à utiliser pour le nouveau CSS) */
  --color-bg: var(--bg);
  --color-surface-1: var(--s1);
  --color-surface-2: var(--s2);
  --color-primary: var(--red);
  --color-primary-bright: var(--red2);
  --color-accent: var(--gold);
  --color-text: var(--text);
  --color-text-secondary: var(--text2);
  --color-muted: var(--muted);
  --glass-surface: rgba(15, 15, 28, 0.72);
  --glass-blur: 22px;
  --shadow-soft: 0 8px 32px rgba(0, 0, 0, 0.42);
  --shadow-lift: 0 20px 50px rgba(0, 0, 0, 0.55);
  --gradient-primary: linear-gradient(135deg, #ff3b5f 0%, var(--red) 40%, var(--gold) 100%);
  --gradient-bg-depth: radial-gradient(1200px 600px at 12% -20%, rgba(232,48,74,.22), transparent 55%),
    radial-gradient(900px 500px at 88% 0%, rgba(245,166,35,.09), transparent 50%),
    var(--bg);
  --radius-md: var(--r);
  --radius-xl: var(--r2);
  --transition-fast: 0.2s var(--ease-out);
  --transition-smooth: 0.32s var(--ease-out);
  --text-fluid-xl: clamp(2rem, 1.55rem + 2.25vw, 3.35rem);
  --text-fluid-body: clamp(0.9375rem, 0.9rem + 0.2vw, 1.0625rem);
  --section-y: clamp(2rem, 4vw + 1rem, 4.5rem);
  --lh-relaxed: 1.62;
}

@media (prefers-color-scheme: light) {
  :root.light-theme-auto {
    --bg:#f4f5fb;--s1:#ffffff;--s2:#ebeefa;--s3:#e2e6f6;--s4:#d8dcf0;
    --text:#0f1120;--text2:#454869;--muted:#6e7191;
    --border:rgba(15,17,32,.07);--border2:rgba(15,17,32,.14);
    --glass-surface: rgba(255, 255, 255, 0.76);
    --gradient-bg-depth: radial-gradient(1000px 500px at 10% -10%, rgba(232,48,74,.08), transparent 50%),
      var(--bg);
  }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

body{background:var(--gradient-bg-depth);background-color:var(--bg);color:var(--color-text);font-family:var(--ff-body);font-size:var(--text-fluid-body);min-height:100vh;line-height:var(--lh-relaxed);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;letter-spacing:-.015em;transition:background-color 0.45s var(--ease-out)}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:4px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.18);background-clip:padding-box}
a{color:inherit;text-decoration:none}
button{font-family:var(--ff-body);cursor:pointer;outline:none}
select{font-family:var(--ff-body);outline:none}
input{outline:none}
html{scroll-behavior:smooth}
::selection{background:rgba(255,45,85,.45);color:#fff}
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid rgba(255,45,85,.6);outline-offset:2px;border-radius:6px}

/* BANDE SÉPARATRICE ROUGE & OR */
.hero-separator {
  height: 4px;
  width: 100%;
  background: linear-gradient(90deg, transparent 0%, var(--red) 30%, var(--gold) 70%, transparent 100%);
  box-shadow: 0 0 15px rgba(245, 166, 35, 0.4);
  position: relative;
  z-index: 10;
  margin-bottom: 10px;
}

@keyframes premiumPop {
  0% { transform: scale(.85) translateY(30px); opacity: 0; }
  100% { transform: scale(1) translateY(0); opacity: 1; }
}

.premium-dropdown {
  pointer-events: all;
}

/* ═══════════════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:0 clamp(1rem,3vw,2rem);
  background:linear-gradient(180deg,var(--glass-surface) 0%,rgba(10,10,15,.52) 100%);
  backdrop-filter:blur(var(--glass-blur)) saturate(165%);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(165%);
  border-bottom:1px solid var(--border);box-shadow:var(--shadow-soft);
  transition:background var(--transition-smooth),box-shadow var(--transition-smooth),opacity 0.5s ease;
}
.nav-left{display:flex;align-items:center;gap:10px;flex:1}
.nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo{font-family:var(--ff-head);font-size:26px;font-weight:800;letter-spacing:-1.2px;color:#fff;background:none;-webkit-background-clip:unset;-webkit-text-fill-color:#fff;background-clip:unset;cursor:pointer;flex-shrink:0;filter:none;transition:transform .2s ease}
.logo:hover{transform:scale(1.05)}
.logo-accent{color:#f77f00}
.nav-links{display:flex;gap:4px;align-items:center;overflow-x:auto;scrollbar-width:none;flex:1;justify-content:center;min-width:0}
.nav-links::-webkit-scrollbar{display:none}
.nav-link{font-family:'Bebas Neue',var(--ff-head);font-size:17px;font-weight:400;color:#fff;padding:9px 22px;border-radius:9px;border:none;background:none;letter-spacing:.06em;text-transform:uppercase;transition:all .2s var(--ease-out);white-space:nowrap}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav-link.active{color:#fff;background:rgba(247,127,0,.12);border:1px solid rgba(247,127,0,.35);box-shadow:0 2px 12px rgba(247,127,0,.12),inset 0 1px 0 rgba(255,255,255,.05)}
.search-pill{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:9px 18px;border-radius:24px;color:var(--muted);font-size:11.5px;font-weight:600;cursor:pointer;transition:all .25s var(--ease-out);text-transform:uppercase;letter-spacing:1.2px}
.search-pill:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.18);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.4)}

/* Panneaux type « carte » avec verre moderne — utilisable sur nouvelles sections */
.glass-panel{
  background:var(--glass-surface);
  backdrop-filter:blur(var(--glass-blur)) saturate(150%);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);
  border:1px solid var(--border2);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-soft);
}


/* ═══════════════════════════════════════════════════
   HERO — VERSION CORRIGÉE
   ═══════════════════════════════════════════════════ */

.hero{
  pointer-events: none;  /* ← Ajoute ici */
  position:relative;
  height:85vh;
  min-height:600px;
  max-height:880px;
  overflow:hidden;
  margin-top:0;
  /* padding-top évite une bande de couleur body sous la navbar (ancien margin-top) */
  padding-top:var(--nav-h);
  background:#000;
}
.hero * { pointer-events: auto; }
.hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center 30%;
  filter:brightness(.88) saturate(1.12);
  transition:opacity 1s var(--ease-out), transform 12s ease-out;
  transform:scale(1.02); /* <--- C'EST ICI QUE ÇA ZOOM */
  z-index:1;
}
.hero-bg.out{opacity:0}

/* DÉGRADÉS */
.hero-grad1{
  position:absolute;
  bottom:0;left:0;right:0;
  height:60%;
  background:linear-gradient(0deg, var(--bg) 0%, rgba(7,7,15,.85) 30%, rgba(7,7,15,.4) 60%, transparent 100%);
  pointer-events:none;
  z-index:2;
}
.hero-grad2{
  position:absolute;
  top:0;bottom:0;left:0;
  width:55%;
  background:linear-gradient(90deg, rgba(7,7,15,.85) 0%, rgba(7,7,15,.5) 50%, transparent 100%);
  pointer-events:none;
  z-index:2;
}
.hero::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at center,transparent 40%,rgba(0,0,0,.4) 100%);
  pointer-events:none;
  z-index:2;
}

/* CONTENU HERO — TITRE, DESCRIPTION, BOUTONS */
.hero-content{
  position:absolute;
  bottom:120px;
  left:4rem;
  max-width:620px;
  z-index:5;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  transition:opacity 0.5s ease;
}
.hero-content.out{opacity:0}
.hero-badge{
  background:rgba(232,48,74,.15);
  border:1px solid rgba(232,48,74,.4);
  padding:6px 14px;
  font-size:10.5px;
  font-weight:700;
  letter-spacing:1.5px;
  border-radius:5px;
  backdrop-filter:blur(8px);
  margin-bottom:18px;
  text-transform:uppercase;
  color:#fff;
}
.hero-title{
  font-family:var(--ff-head);
  font-size:var(--text-fluid-xl);
  font-weight:700;
  line-height:1.05;
  letter-spacing:-1.5px;
  color:#fff;
  margin-bottom:18px;
  text-shadow:0 4px 24px rgba(0,0,0,.6);
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
  display:block;
}
.hero-title.hero-title-logo{
  background:none;
  padding:0;
  filter:drop-shadow(0 6px 28px rgba(0,0,0,.55));
}
.hero-title.hero-title-logo img{
  display:block;
  width:auto;
  height:auto;
  max-width:min(560px, 92vw);
  max-height:clamp(64px, 14vw, 132px);
  object-fit:contain;
  object-position:left center;
}
.hero-title.hero-title-w500{
  background:none;
  padding:0;
  filter:drop-shadow(0 8px 32px rgba(0,0,0,.58));
}
.hero-title.hero-title-w500 img{
  display:block;
  width:auto;
  height:auto;
  max-height:clamp(120px, 26vw, 220px);
  max-width:min(148px, 40vw);
  object-fit:cover;
  object-position:center top;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
}
.hero-meta{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
  flex-wrap:wrap;
}
.hero-rating{
  background:rgba(245,166,35,.15);
  border:1px solid rgba(245,166,35,.35);
  padding:5px 12px;
  font-weight:700;
  font-size:12px;
  letter-spacing:.3px;
  border-radius:6px;
  color:var(--gold2);
}
.hero-year{
  font-size:14px;
  color:rgba(255,255,255,.75);
  font-weight:500;
}
.hero-desc{
  font-size:16px;
  line-height:1.7;
  color:rgba(255,255,255,.82);
  margin-bottom:28px;
  max-width:540px;
  text-shadow:0 2px 8px rgba(0,0,0,.6);
}
.hero-btns{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

/* DOTS DU HERO */
.hero-dots{
  position:absolute;
  bottom:32px;
  left:4rem;
  display:flex;
  gap:8px;
  z-index:5;
}
.hero-dot{
  width:24px;
  height:3px;
  border-radius:2px;
  background:rgba(255,255,255,.25);
  cursor:pointer;
  transition:all .3s var(--ease-out);
}
.hero-dot:hover{background:rgba(255,255,255,.5)}
.hero-dot.active{
  width:36px;
  background:#fff;
  box-shadow:0 0 12px rgba(255,255,255,.4);
}

/* ═══════════════════════════════════════════════════
   BOUTONS
   ═══════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:8px;font-weight:600;font-size:14px;border:none;letter-spacing:-.01em;transition:all .22s var(--ease-out)}
.btn-primary{background:linear-gradient(135deg,#ff2d55 0%,#e8304a 100%);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.15) inset,0 -1px 0 rgba(0,0,0,.2) inset,0 6px 20px rgba(232,48,74,.4),0 2px 6px rgba(232,48,74,.25);position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}
.btn-primary:hover::before{left:100%}
.btn-primary:hover{background:linear-gradient(135deg,#ff4567 0%,#ff2d55 100%);transform:translateY(-2px);box-shadow:0 1px 0 rgba(255,255,255,.2) inset,0 -1px 0 rgba(0,0,0,.2) inset,0 12px 28px rgba(232,48,74,.5),0 4px 10px rgba(232,48,74,.35)}
.btn-primary:active{transform:translateY(0)}
.btn-secondary{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.btn-secondary:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.25);transform:translateY(-2px)}
.btn-sm{padding:7px 16px;font-size:12px;border-radius:8px}
.icon-btn{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:#fff;width:40px;height:40px;border-radius:10px;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .22s var(--ease-out);flex-shrink:0;cursor:pointer}
.icon-btn:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);transform:translateY(-1px)}

/* ═══════════════════════════════════════════════════
   STUDIO BAR & SECTIONS
   ═══════════════════════════════════════════════════ */
.studio-bar{display:flex;gap:14px;padding:1.2rem 2.5rem;overflow-x:auto;border-bottom:1px solid rgba(255,255,255,.04);scrollbar-width:none}
.studio-bar::-webkit-scrollbar{display:none}
.studio-card{flex-shrink:0;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:28px 48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .28s var(--ease-out);min-width:220px;min-height:130px}
.studio-card:hover{background:rgba(255,255,255,.05);transform:translateY(-4px);border-color:rgba(255,255,255,.12);box-shadow:0 12px 32px rgba(0,0,0,.5)}
.studio-card.active{background:linear-gradient(135deg,rgba(232,48,74,.16),rgba(232,48,74,.05));border-color:rgba(232,48,74,.4);box-shadow:0 8px 24px rgba(232,48,74,.2)}
.studio-logo{width:130px;height:75px;object-fit:contain;display:block;opacity:.88}
.studio-flag{font-size:58px;line-height:1}
.studio-text{font-family:var(--ff-head);font-size:15px;font-weight:700}

.section{padding:.8rem 2.5rem 2rem}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.4rem}
.section-title{font-family:'Bebas Neue',var(--ff-head);font-size:22px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.section-title::before{display:none}
.section-title--split{gap:7px;line-height:1}
.section-title-w{color:#fff;font-weight:400}
.section-title-o{color:#f77f00;font-weight:400;text-shadow:0 0 20px rgba(247,127,0,.25)}
.see-all{background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--muted);padding:7px 16px;border-radius:8px;font-size:12px;font-weight:500;transition:all .2s var(--ease-out)}
.see-all:hover{color:#fff;border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.04)}

/* ═══════════════════════════════════════════════════
   CAROUSEL
   ═══════════════════════════════════════════════════ */
.carousel-wrap{position:relative;display:flex;align-items:center}
.scroll-row{flex:1;overflow:hidden;padding:24px 0 30px;position:relative}
.scroll-row::before,.scroll-row::after{content:'';position:absolute;top:0;bottom:0;width:60px;pointer-events:none;z-index:5}
.scroll-row::before{left:0;background:linear-gradient(90deg,var(--bg) 0%,transparent 100%)}
.scroll-row::after{right:0;background:linear-gradient(270deg,var(--bg) 0%,transparent 100%)}
.row-inner{display:flex;gap:14px;transition:transform .48s cubic-bezier(.25,.46,.45,.94)}
.c-arrow{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:rgba(15,15,28,.92);border:1px solid rgba(255,255,255,.1);color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;z-index:10;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 8px 24px rgba(0,0,0,.5);transition:all .25s var(--ease-out)}
.c-arrow:hover{background:#fff;color:#0a0a0f;border-color:#fff;transform:translateY(-50%) scale(1.08)}
.c-arrow-l{left:-11px}
.c-arrow-r{right:-11px}

/* ═══════════════════════════════════════════════════
   CARDS
   ═══════════════════════════════════════════════════ */
.card {
  flex: 0 0 260px;
  width: 260px;
  cursor: pointer;
  border-radius: 10px;
  background: transparent;
  transition: transform .35s var(--ease-out);
  position: relative;
  overflow: visible;
}
.card-clip{border-radius:10px;overflow:hidden;position:relative;box-shadow:0 4px 12px rgba(0,0,0,.4);transition:box-shadow .35s var(--ease-out)}
.card:hover{transform:translateY(-8px) scale(1.04);z-index:5}
.card:hover .card-clip{box-shadow:0 24px 48px rgba(0,0,0,.7),0 0 0 2px rgba(255,255,255,.12),0 0 32px rgba(247,127,0,.25)}
.card-img {
  width: 100%;
  height: 300px; /* au lieu de 272px */
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: saturate(1.05) contrast(1.02);
  transition: transform .5s var(--ease-out),filter .35s ease;
}
.card:hover .card-img{transform:scale(1.02);filter:saturate(1.15) contrast(1.05) brightness(1.05)}.card-shine{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,transparent 40%,transparent 60%,rgba(255,255,255,.03) 100%);pointer-events:none}
.card-over{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.5) 35%,transparent 65%);opacity:0;transition:opacity .3s ease;pointer-events:none}
.card:hover .card-over{opacity:1}
.card-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;color:#0a0a0f;font-size:16px;backdrop-filter:blur(10px);box-shadow:0 8px 24px rgba(0,0,0,.5);opacity:0;transition:all .3s var(--ease-spring)}
.card:hover .card-play{opacity:1;transform:translate(-50%,-50%) scale(1.05);background:#fff}
.card-info{padding:11px 4px 4px;background:transparent;border-radius:0;border-top:none}
.card-title{
  font-weight:600;
  font-size:13px;
  letter-spacing:-.01em;
  line-height:1.4;
  color:rgba(255,255,255,.95);
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  white-space:normal;
  min-height:2.7em;
}
.card-sub{display:flex;justify-content:space-between;color:rgba(255,255,255,.45);font-size:11.5px;margin-top:5px}
.card-stars{color:#ffa726;font-weight:700;letter-spacing:.2px}
.card-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:5px}
.card-tag{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.05);border-radius:4px;padding:3px 8px;font-size:11px;color:rgba(255,255,255,.55);font-weight:500}
.release-badge{position:absolute;top:7px;left:7px;z-index:10;background:rgba(0,0,0,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:5px 11px;border-radius:6px;font-size:11px;font-weight:700;color:#ffa726;border-left:2px solid #f5a623;letter-spacing:.5px;box-shadow:0 2px 8px rgba(0,0,0,.4)}
.release-badge--date{top:auto;bottom:8px;right:7px;left:7px;max-width:none;font-size:10px;line-height:1.3;letter-spacing:0;text-align:center;color:#fff;border-left-color:#f77f00}
.del-btn{position:absolute;top:7px;right:7px;z-index:10;background:rgba(7,7,15,.85);color:var(--muted);border:1px solid var(--border2);width:27px;height:27px;border-radius:6px;font-size:12px;display:none;align-items:center;justify-content:center;transition:.18s}
.card:hover .del-btn{display:flex}
.del-btn:hover{background:#f77f00;color:#fff;border-color:#f77f00}
.cont-badge{position:absolute;top:7px;left:7px;z-index:5;background:linear-gradient(135deg,#f77f00,#ff9500);color:#fff;border-radius:6px;padding:5px 11px;font-size:11px;font-weight:700;letter-spacing:.4px;box-shadow:0 4px 12px rgba(247,127,0,.4)}
.cont-time{font-size:11px;color:var(--gold2);margin-top:3px}
.card-rank-chip{
  position:absolute;
  bottom:12px;
  left:12px;
  z-index:12;
  display:flex;
  align-items:baseline;
  gap:1px;
  padding:8px 13px 7px;
  border-radius:12px;
  background:rgba(6,6,10,.88);
  border:1px solid rgba(247,127,0,.28);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 8px 28px rgba(0,0,0,.55),0 0 20px rgba(247,127,0,.12),inset 0 1px 0 rgba(255,255,255,.08);
}
.card-rank-chip .card-rank-hash{
  font-family:var(--ff-head);
  font-size:10px;
  font-weight:800;
  color:rgba(247,127,0,.55);
  line-height:1;
  margin-right:1px;
}
.card-rank-chip .card-rank-num{
  font-family:var(--ff-head);
  font-size:24px;
  font-weight:900;
  line-height:1;
  letter-spacing:-.04em;
  color:#f77f00;
  text-shadow:0 0 18px rgba(247,127,0,.45);
}
.card-rank-chip--top{
  padding:9px 14px 8px;
  border-color:rgba(247,127,0,.4);
  box-shadow:0 8px 32px rgba(0,0,0,.6),0 0 24px rgba(247,127,0,.2),inset 0 1px 0 rgba(255,255,255,.1);
}
.card-rank-chip--top .card-rank-num{
  font-size:26px;
  color:#ff9500;
}

.card-trending{
  flex:0 0 200px!important;
  width:200px;
  margin-left:0!important;
}
.card-trending .card-clip{
  border-radius:16px;
  box-shadow:0 12px 40px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.06);
}
.card-trending:hover .card-clip{
  box-shadow:0 26px 56px rgba(0,0,0,.72), 0 0 0 1px rgba(255,255,255,.14), 0 0 40px rgba(247,127,0,.2);
}
.card-trending .card-img{
  height:294px;
  border-radius:inherit;
}
.card-trending .card-info--trend,
.card-info--trend{
  padding:14px 2px 4px!important;
}
.card-trending .card-title,
.card-info--trend .card-title{
  font-family:var(--ff-head);
  font-weight:750;
  font-size:14px!important;
  line-height:1.36!important;
  letter-spacing:-.35px!important;
  min-height:auto!important;
  -webkit-line-clamp:2;
}
.card-trending .card-sub,
.card-info--trend .card-sub{
  margin-top:8px!important;
  font-size:12.5px!important;
  color:rgba(255,255,255,.58)!important;
  align-items:center;
  gap:8px!important;
}
.card-trending .card-stars,
.card-info--trend .card-stars{
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:12.5px!important;
  color:#ffb74d!important;
  background:rgba(255,167,77,.09);
  border:1px solid rgba(255,167,77,.22);
  border-radius:999px;
  padding:3px 9px!important;
}
.card-trending .card-tags,
.card-info--trend .card-tags{
  margin-top:10px!important;
  gap:5px!important;
}
.card-trending .card-tag,
.card-info--trend .card-tag{
  border-radius:999px!important;
  padding:5px 10px!important;
  font-size:10.5px!important;
  font-weight:600!important;
  background:rgba(255,255,255,.07)!important;
  border:1px solid rgba(255,255,255,.08)!important;
  color:rgba(255,255,255,.82)!important;
}

.carousel-wrap:has(#trendRow) .scroll-row{padding-top:26px;padding-bottom:38px}
#trendRow .row-inner{gap:clamp(16px,1.8vw,24px)}

/* ═══════════════════════════════════════════════════
   GRIDS
   ═══════════════════════════════════════════════════ */
.movies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:32px 24px;padding:1.6rem 2.5rem}
.chip{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:7px 18px;font-size:13px;color:var(--muted);white-space:nowrap;font-weight:500;transition:all .2s var(--ease-out);cursor:pointer}
.chip:hover{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.12)}
.chip.active{background:linear-gradient(135deg,rgba(232,48,74,.2),rgba(232,48,74,.1));color:#ff5068;border-color:rgba(232,48,74,.4);box-shadow:0 2px 12px rgba(232,48,74,.2)}
.load-more-wrap{text-align:center;padding:1.5rem}

/* ═══════════════════════════════════════════════════
   CHART / TOP 10 — gabarit éditorial (remplace l’ancien Top 10)
   ═══════════════════════════════════════════════════ */
.chart10{
  padding-top:calc(var(--nav-h) + clamp(1.5rem,4.5vw,3.25rem));
  padding-bottom:clamp(3rem,8vw,5.25rem);
  min-height:100vh;
  box-sizing:border-box;
  position:relative;
}
.chart10-inner{
  max-width:1200px;
  margin-inline:auto;
  padding-inline:clamp(1rem,4vw,2.75rem);
}
.chart10-busy{
  text-align:center;
  padding:2.5rem 1rem;
  color:var(--muted);
  font-weight:700;
  letter-spacing:.04em;
  font-size:14px;
}
.chart10-err{
  margin:1rem auto 2rem;
  padding:1rem 1.25rem;
  border-radius:14px;
  background:rgba(232,48,74,.08);
  border:1px solid rgba(232,48,74,.35);
  color:var(--red2);
  max-width:640px;
  text-align:center;
  font-weight:600;
}
.chart10-topbar{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(1rem,3vw,1.85rem);
  align-items:flex-end;
  margin-bottom:clamp(1.85rem,4.5vw,3.25rem);
}
.chart10-back-btn{align-self:flex-start;margin-top:.15rem}
.chart10-kicker{
  display:inline-block;
  margin:0 0 .5rem;
  font-size:10px;font-weight:800;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--muted);
}
.chart10-display{
  margin:0 0 .6rem;font-family:var(--ff-head);
  font-weight:800;letter-spacing:-.055em;line-height:1.05;
  font-size:clamp(2rem,5vw + 1rem,3.75rem);
  color:#fff;
}
.chart10-numline{
  background:linear-gradient(135deg,#fff 0%,var(--gold2) 45%,var(--red2) 92%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.chart10-lede{
  margin:0;max-width:640px;line-height:1.65;color:var(--text2);
  font-size:clamp(.9rem,.86rem + .25vw,.98rem)
}

/* ── Rang #1 : hero tableau + synopsis ─────────────── */
.chart10-feature{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,2.05fr) minmax(0,.85fr);
  gap:0;
  min-height:clamp(340px,48vw,420px);
  border-radius:28px;
  overflow:hidden;
  cursor:pointer;
  margin-bottom:clamp(2rem,5vw,3.25rem);
  border:1px solid rgba(255,255,255,.085);
  background:var(--s2);
  box-shadow:var(--shadow-lift),0 0 0 1px rgba(255,255,255,.04) inset;
  transition:border-color .3s ease,transform .42s var(--ease-out),box-shadow .42s ease;
}
.chart10-feature:focus-visible{
  outline:2px solid rgba(232,48,74,.68);outline-offset:4px
}
.chart10-feature:hover{
  transform:translateY(-6px);
  border-color:rgba(232,48,74,.38);
}
.chart10-feature-visual{
  grid-column:1/-1;
  grid-row:1;
  width:100%;height:120%;
  object-fit:cover;display:block;
  transform:translateY(-6%);
  transition:transform 9s ease-out;
}
.chart10-feature:hover .chart10-feature-visual{transform:translateY(-6%) scale(1.04)}
.chart10-feature-scrim{
  grid-column:1/-1;grid-row:1;pointer-events:none;
}
.chart10-feature-scrim--side{
  background:linear-gradient(118deg,#07070f 0%,rgba(7,7,15,.93) 40%,rgba(7,7,18,.52) 70%,transparent 100%)
}
.chart10-feature-scrim--bottom{
  background:linear-gradient(180deg,transparent 20%,rgba(5,6,14,.94) 100%);
  opacity:.85;
}
.chart10-feature-pane,.chart10-posterbox{
  position:relative;
  z-index:2;
}
.chart10-feature-pane{
  grid-column:1;
  grid-row:1;
  align-self:end;
  padding:clamp(1.5rem,4vw,2.6rem);
  padding-right:clamp(1rem,3vw,1.5rem);
  max-width:min(100%,640px);
}
.chart10-badge-rank{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-bottom:.75rem;
  padding:.35rem .9rem;border-radius:999px;
  background:rgba(0,0,0,.42);
  border:1px solid rgba(247,127,0,.42);
  font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.92);
}
.chart10-crown{color:var(--gold2)}
.chart10-feature-heading{
  margin:0 0 .55rem;font-family:var(--ff-head);font-weight:800;
  font-size:clamp(1.55rem,2.25vw + 1rem,2.55rem);letter-spacing:-.04em;
  line-height:1.08;color:#fff;
  text-shadow:0 3px 30px rgba(0,0,0,.82);
}
.chart10-feature-muted{
  margin:0 0 1rem;font-size:13px;font-weight:600;
  letter-spacing:.05em;color:rgba(255,255,255,.8);
}
.chart10-hotrate{color:var(--gold2)!important;font-weight:800}
.chart10-dot{padding:0 .2rem;color:rgba(255,255,255,.3)}
.chart10-blurb{
  margin:0 0 1.1rem;line-height:1.68;font-size:.9rem;color:rgba(255,255,255,.78);max-height:8.8em;display:-webkit-box;
  -webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
}
.chart10-chiprow{display:flex;flex-wrap:wrap;gap:.35rem .5rem}
.chart10-pill{
  padding:4px 12px;font-size:11px;font-weight:700;
  border-radius:999px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.74);
}
.chart10-posterbox{
  grid-column:2;grid-row:1;
  align-self:center;justify-self:center;padding:clamp(.75rem,2vw,1.75rem);padding-right:clamp(1.25rem,3vw,2.25rem);
}
.chart10-cover{
  width:min(156px,32vw);border-radius:16px;display:block;
  box-shadow:0 24px 60px rgba(0,0,0,.82),0 0 0 1px rgba(255,255,255,.06);
}
.chart10-cover-fallback{
  width:min(156px,32vw);aspect-ratio:2/3;border-radius:16px;
  background:linear-gradient(160deg,#f77f00,#2a1735);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;color:#fff;text-transform:uppercase;
  letter-spacing:.1em;font-size:.75rem;text-align:center;
  padding:.5rem;border:1px solid rgba(255,255,255,.1);
}

/* ── Rang 2→10 ─────────────────────────────────────── */
.chart10-follow{padding-top:.25rem}
.chart10-follow-strip{margin-bottom:1.25rem}
.chart10-follow-heading{
  margin:0 0 .35rem;font-family:var(--ff-head);font-weight:800;
  letter-spacing:.04em;color:#fff;font-size:clamp(1.05rem,.95rem + .5vw,1.35rem);
}
.chart10-follow-caption{margin:0;font-size:13px;color:var(--muted);line-height:1.55}
.chart10-tracklist{
  list-style:none;margin:0;padding:0;display:flex;
  flex-direction:column;gap:10px;
}
.chart10-row{
  position:relative;
  display:grid;
  grid-template-columns:52px minmax(64px,.28fr) 1fr 28px;
  gap:clamp(10px,2vw,18px);align-items:center;
  padding:12px clamp(14px,2vw,20px);border-radius:18px;
  border:1px solid rgba(255,255,255,.06);
  background:linear-gradient(120deg,rgba(18,18,36,.94),rgba(10,11,26,.76));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 8px 32px rgba(0,0,0,.28);
  cursor:pointer;text-align:left;font:inherit;color:inherit;
  transition:background .28s ease,transform .35s var(--ease-out),border-color .28s ease;
  overflow:hidden;
}
.chart10-row::before{
  content:'';
  position:absolute;
  left:0;top:50%;
  transform:translateY(-50%);
  width:4px;height:62%;min-height:32px;
  border-radius:0 8px 8px 0;
  background:linear-gradient(180deg,var(--gold2),#f77f00);
  box-shadow:0 0 10px rgba(247,127,0,.28);
  opacity:.92;
  z-index:2;
  pointer-events:none;
  transition:opacity .25s ease;
}
.chart10-row:hover,.chart10-row:focus-visible{
  border-color:rgba(247,127,0,.42);
  transform:translateX(6px);
  background:linear-gradient(120deg,rgba(28,20,52,.94),rgba(18,24,54,.92));
}
.chart10-row:focus-visible{outline:2px solid rgba(247,127,0,.58);outline-offset:2px}
.chart10-row:hover::before,.chart10-row:focus-visible::before{opacity:1}
.chart10-ranknum{
  font-family:var(--ff-head);font-weight:900;font-variant-numeric:tabular-nums;
  font-size:clamp(1.05rem,.95rem + .6vw,1.45rem);
  letter-spacing:-.02em;
  background:linear-gradient(142deg,var(--muted),rgba(255,255,255,.95));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.chart10-row-visual{
  width:clamp(54px,12vw,70px);border-radius:14px;
  overflow:hidden;flex-shrink:0;
  aspect-ratio:2/3;box-shadow:0 14px 32px rgba(0,0,0,.5);
  border:1px solid rgba(255,255,255,.1);
}
.chart10-row-visual.chart10-row-noposter{background:linear-gradient(135deg,var(--s3),var(--s2))}
.chart10-row-poster{width:100%;height:100%;object-fit:cover;display:block}
.chart10-row-fallback{width:100%;height:100%;background:linear-gradient(135deg,rgba(247,127,0,.35),var(--s3))}
.chart10-row-core{min-width:0}
.chart10-row-title{margin:0 0 .2rem;font-family:var(--ff-head);font-weight:800;
  letter-spacing:-.035em;line-height:1.2;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.chart10-row-meta{margin:0;font-size:11.5px;font-weight:650;color:rgba(255,255,255,.62);letter-spacing:.04em;text-transform:uppercase}
.chart10-row-goto{
  justify-self:end;font-weight:900;font-size:1.35rem;line-height:1;
  background:linear-gradient(180deg,#fff,var(--muted));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;opacity:.38;
}
.chart10-row:hover .chart10-row-goto,.chart10-row:focus-visible .chart10-row-goto{opacity:.9}

@media(max-width:840px){
  .chart10-topbar{
    grid-template-columns:1fr;
  }
  .chart10-feature{
    grid-template-columns:1fr;
    min-height:auto;
    border-radius:24px;
  }
  .chart10-feature-pane{
    padding:clamp(1.25rem,4vw,1.85rem);padding-bottom:clamp(1.85rem,5vw,2.5rem);
    max-width:100%;
    align-self:end;
    background:linear-gradient(180deg,transparent,rgba(3,5,14,.94) 52%);
    margin-top:auto;
    grid-column:1 / -1;
  }
  .chart10-posterbox{
    grid-column:1;grid-row:1;
    position:absolute;top:clamp(14px,3vw,24px);right:clamp(14px,3vw,24px);
    padding:0;
  }
  .chart10-cover,.chart10-cover-fallback{width:clamp(104px,22vw,128px)}
  .chart10-feature-heading{font-size:clamp(1.32rem,.8rem + 2.5vw,1.92rem)}
}
@media(max-width:520px){
  .chart10-row{
    grid-template-columns:44px 56px 1fr 22px;
    gap:8px;padding:10px 12px;border-radius:16px;
  }
  .chart10-ranknum{font-size:1rem}
  .chart10-row-visual{width:54px;border-radius:12px}
  .chart10-row-title{font-size:14px;white-space:normal;display:-webkit-box;
    -webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.22}
}

/* ═══════════════════════════════════════════════════
   MODAL DETAIL
   ═══════════════════════════════════════════════════ */
.modal-bg{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:flex-start;justify-content:center;opacity:0;pointer-events:none;transition:.3s;overflow-y:auto}
.modal-bg.open{opacity:1;pointer-events:all}
.modal{background:var(--bg);width:100vw;min-height:100vh;transform:translateY(20px);transition:.32s cubic-bezier(.34,1.4,.64,1)}
.modal-bg.open .modal{transform:translateY(0)}
body.no-nav nav{display:none}
.modal-floating-back{
  position:fixed;
  top:max(14px,env(safe-area-inset-top));
  left:max(14px,env(safe-area-inset-left));
  z-index:250;
  display:none;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:#fff;
  font-family:'Bebas Neue',var(--ff-head);
  font-size:15px;
  font-weight:400;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:pointer;
  transition:color .2s ease,border-color .2s ease,background .2s ease;
  box-shadow:0 8px 24px rgba(0,0,0,.45);
}
.modal-bg.open .modal-floating-back{display:inline-flex}
.modal-floating-back:hover{color:#f77f00;border-color:rgba(247,127,0,.45);background:rgba(247,127,0,.15)}
.modal-back-arrow{font-size:18px;line-height:1;font-family:var(--ff-body);font-weight:700}

.modal-hero {
  position: relative;
  height: 72vh;
  max-height: 640px;
  min-height: 320px;
  overflow: hidden;
  background: transparent;
  z-index: 0;
}
.modal-hero-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
  filter: saturate(1.1) brightness(.55);
  transform: none;
  transition: none;
  z-index: 0;
}
.modal-bg.open .modal-hero-img { transform: none; }
.modal-hero-grad{
  position:absolute;
  bottom:0;left:0;right:0;
  height:100%;
  background:linear-gradient(180deg,
    transparent 0%,
    transparent 30%,
    rgba(7,7,15,.6) 60%,
    rgba(7,7,15,.9) 80%,
    var(--bg) 100%) !important;
  pointer-events:none;
  z-index:2;
}
.modal-hero::before{
  content:'';
  position:absolute;
  top:0;bottom:0;left:0;
  width:45%;
  background:linear-gradient(90deg, rgba(7,7,15,.4) 0%, rgba(7,7,15,.15) 50%, transparent 100%);
  pointer-events:none;
  z-index:1;
}
.modal-hero::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 70% 50% at 20% 100%,rgba(247,127,0,.12) 0%,transparent 65%);
  z-index:1;
  pointer-events:none;
}

.film-detail-layout{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:2.5rem;
  margin-top:-200px;
  position:relative;
  z-index:5;
  margin-bottom:2.5rem;
  align-items:end;
  padding:0 3rem;
}
.film-poster-side{
  position:sticky;
  top:20px;
  align-self:start;
}
.film-poster-img{
  width:100%;
  aspect-ratio:2/3;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 30px 60px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.07),0 0 60px rgba(247,127,0,.18);
  transition:transform .4s var(--ease-out);
}
.film-poster-img img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.film-poster-img:hover{transform:translateY(-4px)}
.poster-quick-actions{
  margin-top:14px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.poster-mini-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.85);
  padding:10px 14px;
  border-radius:10px;
  font-size:12.5px;
  font-weight:600;
  cursor:pointer;
  transition:.2s var(--ease-out);
  font-family:var(--ff-body);
}
.poster-mini-btn:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.18);
  transform:translateX(2px);
}
.poster-mini-btn svg{width:14px;height:14px}

.film-info-side{padding-top:0;min-width:0;align-self:end}
.film-tagline{
  font-style:italic;
  color:rgba(255,255,255,.55);
  font-size:15px;
  margin-bottom:14px;
  font-weight:300;
  letter-spacing:.2px;
  border-left:2px solid rgba(232,48,74,.4);
  padding-left:12px;
}
.film-title-big{
  font-family:var(--ff-head);
  font-size:clamp(2.4rem, 4.5vw, 3.8rem);
  font-weight:900;
  line-height:1;
  letter-spacing:-1.5px;
  color:#fff;
  margin-bottom:18px;
  text-shadow:0 4px 30px rgba(0,0,0,.7);
}
.film-title-logo-wrap{
  margin-bottom:18px;
  max-width:100%;
}
.film-title-logo-img{
  display:block;
  width:auto;
  height:auto;
  max-width:min(460px, 100%);
  max-height:clamp(52px, 11vw, 124px);
  object-fit:contain;
  object-position:left center;
  filter:drop-shadow(0 4px 26px rgba(0,0,0,.6));
}
.film-title-w500-wrap{
  margin-bottom:18px;
  max-width:100%;
}
.film-title-w500-img{
  display:block;
  height:auto;
  max-height:clamp(72px, 14vw, 140px);
  max-width:min(120px, 32vw);
  width:auto;
  object-fit:cover;
  object-position:center top;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.1);
  filter:drop-shadow(0 4px 26px rgba(0,0,0,.65));
}
.film-meta-row{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
  flex-wrap:wrap;
}
.film-rating-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:linear-gradient(135deg,#f5a623,#e8a02d);
  color:#0a0a0f;
  padding:6px 12px;
  border-radius:7px;
  font-weight:800;
  font-size:13px;
  letter-spacing:-.2px;
  box-shadow:0 4px 14px rgba(245,166,35,.3);
}
.film-rating-pill svg{width:14px;height:14px;fill:#0a0a0f}
.film-flux-badge-slot{display:inline-flex;align-items:center}
.film-flux-badge-slot[hidden]{display:none!important}
.film-flux-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.35);
  color:#22c55e;
  padding:5px 12px;
  border-radius:7px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;
  white-space:nowrap;
}
.film-meta-item{
  color:rgba(255,255,255,.7);
  font-size:13px;
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:5px;
}
.film-meta-dot{
  width:3px;height:3px;
  border-radius:50%;
  background:rgba(255,255,255,.3);
}
.film-genres-row{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-bottom:22px;
}
.film-genre-pill{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.85);
  padding:5px 12px;
  border-radius:6px;
  font-size:12px;
  font-weight:600;
  transition:.2s;
}
.film-genre-pill:hover{
  background:rgba(247,127,0,.12);
  border-color:rgba(247,127,0,.3);
  color:#fff;
}
.film-overview-text{
  font-size:15px;
  line-height:1.75;
  color:rgba(255,255,255,.78);
  max-width:760px;
  margin-bottom:26px;
  font-weight:400;
}
.film-actions-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:8px;
}
.film-btn-watch{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:linear-gradient(135deg,#f77f00 0%,#ff9500 100%);
  color:#fff;
  padding:14px 32px;
  border-radius:10px;
  font-size:15px;
  font-weight:700;
  border:none;
  cursor:pointer;
  letter-spacing:-.2px;
  transition:all .25s var(--ease-out);
  box-shadow:0 1px 0 rgba(255,255,255,.15) inset,0 8px 24px rgba(247,127,0,.4),0 2px 6px rgba(247,127,0,.25);
}
.film-btn-watch:hover{
  transform:translateY(-2px);
  background:linear-gradient(135deg,#ff9500 0%,#ffb347 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.2) inset,0 14px 32px rgba(247,127,0,.55),0 4px 10px rgba(247,127,0,.35);
}
.film-btn-watch--vip{
  background:linear-gradient(135deg,#f77f00 0%,#ff9500 100%);
}
.film-btn-watch svg{width:18px;height:18px;fill:#fff}
.film-btn-secondary{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  padding:13px 24px;
  border-radius:10px;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:all .22s var(--ease-out);
  backdrop-filter:blur(12px);
}
.film-btn-secondary:hover{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.22);
  transform:translateY(-2px);
}
.film-btn-secondary svg{width:16px;height:16px}

.film-trailer-section{margin:2.5rem 0}
.film-trailer-wrap{
  position:relative;
  width:100%;
  max-width:1100px;
  aspect-ratio:16/9;
  border-radius:16px;
  overflow:hidden;
  background:#000;
  box-shadow:0 20px 50px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.06);
  cursor:pointer;
  transition:transform .3s var(--ease-out);
}
.film-trailer-wrap:hover{transform:translateY(-3px)}
.film-trailer-thumb{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  filter:brightness(.7) saturate(1.1);
  transition:filter .3s,transform .5s;
}
.film-trailer-wrap:hover .film-trailer-thumb{
  filter:brightness(.85) saturate(1.2);
  transform:scale(1.04);
}
.film-trailer-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,rgba(0,0,0,.3) 0%,rgba(0,0,0,.1) 50%,rgba(0,0,0,.4) 100%);
}
.film-trailer-play-btn{
  width:90px;height:90px;
  border-radius:50%;
  background:rgba(255,255,255,.95);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 40px rgba(0,0,0,.6),0 0 0 8px rgba(255,255,255,.1);
  transition:all .3s var(--ease-spring);
  position:relative;
}
.film-trailer-wrap:hover .film-trailer-play-btn{
  transform:scale(1.1);
  background:#fff;
  box-shadow:0 16px 50px rgba(247,127,0,.4),0 0 0 12px rgba(247,127,0,.15);
}
.film-trailer-play-btn::before{
  content:'';
  position:absolute;
  inset:-3px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.3);
  animation:trailerPulse 2.5s ease-in-out infinite;
}
@keyframes trailerPulse{
  0%,100%{transform:scale(1);opacity:.6}
  50%{transform:scale(1.15);opacity:0}
}
.film-trailer-play-btn svg{
  width:32px;height:32px;
  fill:#0a0a0f;
  margin-left:4px;
}
.film-trailer-label{
  position:absolute;
  top:18px;left:18px;
  background:rgba(0,0,0,.65);
  backdrop-filter:blur(12px);
  color:#fff;
  padding:6px 12px;
  border-radius:7px;
  font-size:11px;
  font-weight:800;
  letter-spacing:1.2px;
  text-transform:uppercase;
  display:flex;align-items:center;gap:6px;
  border:1px solid rgba(255,255,255,.12);
}
.film-trailer-label::before{
  content:'';
  width:6px;height:6px;
  border-radius:50%;
  background:#ff2d55;
  box-shadow:0 0 8px #ff2d55;
  animation:trailerLive 1.5s ease-in-out infinite;
}
@keyframes trailerLive{
  0%,100%{opacity:1}
  50%{opacity:.4}
}
.film-trailer-title{
  position:absolute;
  bottom:20px;left:24px;right:24px;
  color:#fff;
  font-family:var(--ff-head);
  font-size:18px;
  font-weight:700;
  text-shadow:0 2px 12px rgba(0,0,0,.7);
}
.film-trailer-iframe{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  border:none;
}

.film-section{margin:2.5rem 0}
.film-modal-tabs{
  display:flex;gap:8px;margin:2rem 0 0;padding:0;border-bottom:1px solid rgba(255,255,255,.06);
}
.film-modal-tab{
  padding:12px 22px;border:none;border-radius:10px 10px 0 0;background:transparent;
  color:rgba(255,255,255,.45);font-size:14px;font-weight:400;cursor:pointer;
  font-family:'Bebas Neue',var(--ff-head);letter-spacing:.06em;text-transform:uppercase;
  transition:.2s ease;border-bottom:2px solid transparent;margin-bottom:-1px;
}
.film-modal-tab:hover{color:rgba(255,255,255,.75)}
.film-modal-tab.active{
  color:#fff;background:rgba(247,127,0,.08);border-bottom-color:#f77f00;
}
.film-modal-panels{margin-top:0}
.film-modal-panel{display:none;animation:staffFadeIn .35s ease}
.film-modal-panel.active{display:block}
.film-director-card{
  margin-top:1.25rem;padding:14px 16px;border-radius:12px;
  background:rgba(255,255,255,.03);border:1px solid rgba(247,127,0,.15);
  display:flex;flex-direction:column;gap:4px;
}
.film-director-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:rgba(247,127,0,.85)}
.film-director-name{
  background:none;border:none;padding:0;color:#fff;font-size:15px;font-weight:700;
  cursor:pointer;text-align:left;font-family:var(--ff-body);
}
.film-director-name:hover{color:#f77f00}
.film-section-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:1.4rem;
}
.film-section-bar{display:none}
.film-section-title{
  font-family:'Bebas Neue',var(--ff-head);
  font-size:22px;
  font-weight:400;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#fff;
  margin:0;
  display:flex;
  align-items:center;
  gap:7px;
  line-height:1;
}
.film-section-title .section-title-w{color:#fff;font-weight:400}
.film-section-title .section-title-o{color:#f77f00;font-weight:400;text-shadow:0 0 20px rgba(247,127,0,.25)}
.film-section-count{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.7);
  padding:3px 10px;
  border-radius:7px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.3px;
}

.saga-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:18px;
}
.saga-card{
  position:relative;
  cursor:pointer;
  border-radius:12px;
  overflow:hidden;
  background:var(--s1);
  transition:all .3s var(--ease-out);
  border:1px solid rgba(255,255,255,.05);
}
.saga-card:hover{
  transform:translateY(-6px);
  border-color:rgba(247,127,0,.3);
  box-shadow:0 20px 40px rgba(0,0,0,.6),0 0 30px rgba(247,127,0,.2);
}
.saga-card-img{
  width:100%;
  aspect-ratio:2/3;
  object-fit:cover;
  display:block;
  transition:transform .5s var(--ease-out);
}
.saga-card:hover .saga-card-img{transform:scale(1.05)}
.saga-card-num{
  position:absolute;
  top:10px;left:10px;
  width:32px;height:32px;
  border-radius:9px;
  background:linear-gradient(135deg,#f77f00,#ff9500);
  color:#fff;
  font-family:var(--ff-head);
  font-size:14px;
  font-weight:900;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(247,127,0,.5);
  z-index:3;
  letter-spacing:-.5px;
}
.saga-card-info{
  padding:11px 12px 13px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.4));
}
.saga-card-title{
  font-size:13px;
  font-weight:600;
  color:#fff;
  line-height:1.35;
  margin-bottom:5px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.saga-card-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-size:11px;
  color:rgba(255,255,255,.5);
}
.saga-card-rating{
  color:#f5a623;
  font-weight:700;
}
.saga-card-current{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(247,127,0,.85),rgba(247,127,0,.6));
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;
  z-index:15;
  color:#fff;
  font-family:var(--ff-head);
  font-weight:800;
  text-align:center;
  padding:1rem;
  pointer-events:none;
}
.saga-card-current::before{
  content:'▶';
  font-size:30px;
  margin-bottom:6px;
}

.season-selector-bar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.season-pill{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.7);
  padding:8px 18px;
  border-radius:9px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  transition:.2s var(--ease-out);
  font-family:var(--ff-body);
}
.season-pill:hover{
  background:rgba(255,255,255,.08);
  color:#fff;
}
.season-pill.active{
  background:linear-gradient(135deg,#f77f00,#ff9500);
  border-color:transparent;
  color:#fff;
  box-shadow:0 4px 14px rgba(247,127,0,.4);
}

.episodes-grid-pro{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:14px;
}
.ep-card-pro{
  background:var(--s1);
  border:1px solid rgba(255,255,255,.05);
  border-radius:12px;
  overflow:hidden;
  cursor:pointer;
  transition:all .25s var(--ease-out);
  display:flex;
  flex-direction:column;
}
.ep-card-pro:hover{
  border-color:rgba(247,127,0,.3);
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(0,0,0,.5);
}
.ep-card-pro-thumb{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:var(--s2);
  overflow:hidden;
}
.ep-card-pro-thumb img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .5s var(--ease-out);
}
.ep-card-pro:hover .ep-card-pro-thumb img{transform:scale(1.06)}
.ep-card-pro-thumb::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.5));
}
.ep-card-pro-num{
  position:absolute;
  top:10px;left:10px;
  background:rgba(0,0,0,.75);
  backdrop-filter:blur(8px);
  color:#fff;
  padding:4px 10px;
  border-radius:6px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.3px;
  z-index:2;
}
.ep-card-pro-play{
  position:absolute;
  bottom:12px;right:12px;
  width:38px;height:38px;
  border-radius:50%;
  background:rgba(255,255,255,.95);
  display:flex;align-items:center;justify-content:center;
  opacity:0;
  transform:scale(.8);
  transition:.3s var(--ease-spring);
  z-index:2;
}
.ep-card-pro:hover .ep-card-pro-play{
  opacity:1;
  transform:scale(1);
}
.ep-card-pro-play svg{
  width:14px;height:14px;
  fill:#0a0a0f;
  margin-left:2px;
}
.ep-card-pro-info{
  padding:13px 14px 14px;
  flex:1;
  display:flex;
  flex-direction:column;
}
.ep-card-pro-title{
  font-size:14px;
  font-weight:700;
  color:#fff;
  margin-bottom:5px;
  letter-spacing:-.1px;
  line-height:1.35;
}
.ep-card-pro-overview{
  font-size:12px;
  color:rgba(255,255,255,.55);
  line-height:1.5;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  flex:1;
}
.ep-card-pro-meta{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.05);
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-size:11px;
  color:rgba(255,255,255,.4);
}
.ep-card-pro-rating{
  color:#f5a623;
  font-weight:700;
}

.cast-row-pro{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding:6px 4px 16px;
  scrollbar-width:none;
  scroll-behavior:smooth;
}
.cast-row-pro::-webkit-scrollbar{display:none}
.cast-card-pro{
  flex:0 0 110px;
  text-align:center;
  cursor:pointer;
  transition:transform .25s var(--ease-out);
}
.cast-card-pro:hover{transform:translateY(-4px)}
.cast-photo-pro{
  width:100px;height:100px;
  border-radius:50%;
  object-fit:cover;
  background:var(--s2);
  border:3px solid transparent;
  margin:0 auto 10px;
  display:block;
  box-shadow:0 6px 20px rgba(0,0,0,.4);
  transition:all .3s var(--ease-out);
}
.cast-card-pro:hover .cast-photo-pro{
  border-color:rgba(232,48,74,.5);
  box-shadow:0 8px 28px rgba(232,48,74,.3);
}
.cast-name-pro{
  font-size:12.5px;
  font-weight:700;
  color:#fff;
  margin-bottom:2px;
  letter-spacing:-.1px;
  display:-webkit-box;
  -webkit-line-clamp:1;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.cast-char-pro{
  font-size:11px;
  color:rgba(255,255,255,.45);
  font-style:italic;
  display:-webkit-box;
  -webkit-line-clamp:1;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.modal-body{position:relative;z-index:5;padding:0 3.5rem 4rem;margin-top:-80px;max-width:1180px;margin-left:auto;margin-right:auto}
.modal-title{font-family:var(--ff-head);font-size:52px;font-weight:800;margin-bottom:7px;letter-spacing:-.8px;line-height:1.04}
.modal-tagline{color:var(--text2);font-style:italic;font-size:15px;margin-bottom:12px}
.modal-meta{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0;align-items:center}
.modal-rating{background:rgba(245,166,35,.11);border:1px solid rgba(245,166,35,.28);color:var(--gold2);font-weight:700;font-size:12px;padding:4px 11px;border-radius:6px}
.modal-genre{background:var(--s2);border:1px solid var(--border);border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500}
.modal-overview{font-size:15px;line-height:1.75;max-width:800px;margin-bottom:22px;color:var(--text2)}
.modal-actions{display:flex;gap:10px;margin:26px 0;flex-wrap:wrap;align-items:center}
.cast-row{display:flex;gap:14px;overflow-x:auto;padding-bottom:12px;margin-bottom:16px;scrollbar-width:none}
.cast-row::-webkit-scrollbar{display:none}
.cast-card{flex-shrink:0;text-align:center;width:78px}
.cast-photo{width:68px;height:68px;border-radius:50%;object-fit:cover;background:var(--s2);border:2px solid var(--border)}
.cast-name{font-size:10.5px;margin-top:4px;color:var(--text2)}
.cast-char{font-size:9.5px;color:var(--muted);margin-top:2px;font-style:italic}
.sec-divider{display:flex;align-items:center;gap:10px;margin:22px 0 13px}
.sec-divider-title{font-family:var(--ff-head);font-size:16px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.sec-divider-line{flex:1;height:1px;background:var(--border)}
.ep-box{background:var(--s2);border:1px solid var(--border);border-radius:var(--r2);padding:20px;margin:22px 0}
.ep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-top:16px}
.ep-card{background:var(--s3);border-radius:12px;overflow:hidden;cursor:pointer;transition:.18s;border:1px solid var(--border)}
.ep-card:hover{transform:translateY(-3px);border-color:#f77f00}
.ep-thumb{width:100%;height:140px;background:var(--s4);display:flex;align-items:center;justify-content:center;overflow:hidden}
.ep-thumb img{width:100%;height:100%;object-fit:cover}
.ep-info{padding:11px 13px}
.ep-num{font-weight:700;font-size:14px;margin-bottom:2px;font-family:var(--ff-head)}
.ep-name{font-size:12.5px;color:var(--text2)}
.ep-runtime{font-size:11px;color:var(--muted);margin-top:2px}

/* CAST CAROUSEL */
.cast-carousel-wrap{position:relative;margin-bottom:16px}
.cast-arrow{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:rgba(15,15,28,.94);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;z-index:10;cursor:pointer;backdrop-filter:blur(12px);box-shadow:0 6px 18px rgba(0,0,0,.55);transition:all .22s var(--ease-out);opacity:0}
.cast-carousel-wrap:hover .cast-arrow{opacity:1}
.cast-arrow:hover{background:#fff;color:#0a0a0f;transform:translateY(-50%) scale(1.1)}
.cast-arrow-l{left:-14px}
.cast-arrow-r{right:-14px}

/* ═══════════════════════════════════════════════════
   PLAYER
   ═══════════════════════════════════════════════════ */
.player-bg{position:fixed;inset:0;z-index:700;background:#000;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:.28s}
.player-bg.open{opacity:1;pointer-events:all}
.player-topbar{position:absolute;top:0;left:0;right:0;z-index:10;padding:14px 20px;background:linear-gradient(180deg,rgba(0,0,0,.88),transparent);display:flex;align-items:center;gap:12px;transition:opacity .35s}
.player-close{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);color:#fff;width:38px;height:38px;border-radius:8px;font-size:17px;display:flex;align-items:center;justify-content:center;transition:.18s;flex-shrink:0}
.player-close:hover{background:var(--red)}
.player-title{font-family:var(--ff-head);font-size:18px;font-weight:700}
.player-sub{color:var(--muted);font-size:13px}
.player-video-wrap{flex:1;position:relative;background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden}
#playerVideo{width:100%;height:100%;object-fit:contain;background:#000;display:none}
#playerIframe{width:100%;height:100%;border:none;background:#000;display:none}
.src-bar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;padding:9px 18px;background:rgba(7,7,15,.97);border-top:1px solid var(--border2);flex-shrink:0}
.src-lbl{color:var(--muted);font-size:12px;font-weight:700;margin-right:3px}
.src-btn{padding:5px 13px;border-radius:7px;background:var(--s3);border:1px solid var(--border2);color:var(--text2);font-size:12px;font-weight:600;transition:.18s;font-family:var(--ff-body)}
.src-btn:hover{background:var(--s4);color:var(--text)}
.src-btn.active{background:rgba(232,48,74,.18);border-color:var(--red);color:var(--red2)}
.ep-nav-btns{display:flex;gap:6px}
.ep-nav-btn{display:flex;align-items:center;gap:5px;padding:6px 13px;border-radius:7px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);color:#fff;font-size:12px;font-weight:600;transition:.18s;font-family:var(--ff-body)}
.ep-nav-btn:hover{background:var(--red);border-color:var(--red)}
.no-stream{display:none;position:absolute;inset:0;background:#000;z-index:8;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}
.no-stream.show{display:flex}
.no-stream-icon{font-size:52px;margin-bottom:18px}
.no-stream-title{font-family:var(--ff-head);font-size:28px;font-weight:700;margin-bottom:10px}
.no-stream-sub{color:var(--muted);font-size:15px;margin-bottom:22px}
.quality-bar{display:flex;align-items:center;gap:6px}
.quality-lbl{color:var(--muted);font-size:12px;font-weight:700}
.quality-btn{padding:4px 10px;border-radius:6px;background:var(--s3);border:1px solid var(--border2);color:var(--text2);font-size:11px;font-weight:700;transition:.18s;font-family:var(--ff-body)}
.quality-btn:hover{background:var(--s4);color:var(--text)}
.quality-btn.active{background:rgba(232,48,74,.18);border-color:var(--red);color:var(--red2)}

/* Lecteur — contrôles custom */
.player-controls {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 12;
  display: none;
  align-items: center;
  gap: 12px;
  padding: 12px 18px 16px;
  background: linear-gradient(0deg, rgba(0,0,0,.92) 0%, rgba(0,0,0,.5) 70%, transparent);
  opacity: 0;
  transition: opacity 0.25s;
}
.player-video-wrap:hover .player-controls,
.player-controls.player-controls--visible { opacity: 1; }
.player-video-wrap.show-controls .player-controls { display: flex; }
.player-ctrl-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,.12);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.2s;
}
.player-ctrl-btn:hover { background: var(--red); }
.player-progress {
  flex: 1;
  height: 5px;
  -webkit-appearance: none;
  appearance: none;
  background: rgba(255,255,255,.15);
  border-radius: 99px;
  cursor: pointer;
}
.player-progress::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--red2);
  box-shadow: 0 0 8px rgba(232,48,74,.6);
}
.player-progress::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--red2);
  border: none;
}
.player-time {
  font-size: 11px;
  font-weight: 700;
  color: rgba(255,255,255,.75);
  min-width: 38px;
  font-variant-numeric: tabular-nums;
}

/* Cartes affiche-only (catalogue) */
.card--poster { width: 100%; flex: unset; }
.card--poster .card-info { display: none !important; }
.card--poster .card-clip { border-radius: 16px !important; }
.card--poster .card-img { height: auto; aspect-ratio: 2/3; }
.card--poster .card-play { display: none; }
.card-type-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 6;
  padding: 5px 11px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  opacity: 0;
  transition: opacity 0.25s;
}
.card--poster:hover .card-type-badge { opacity: 1; }
.card-hover-info {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 5;
  padding: 14px 12px 12px;
  background: linear-gradient(0deg, rgba(0,0,0,.95) 0%, rgba(0,0,0,.6) 55%, transparent);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.25s, transform 0.25s;
  pointer-events: none;
}
.card--poster:hover .card-hover-info { opacity: 1; transform: translateY(0); }
.card--poster:hover .card-over { opacity: 1; }
.card-hover-title {
  font-family: 'Bebas Neue', var(--ff-head);
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #fff;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card-hover-meta {
  font-family: 'Bebas Neue', var(--ff-head);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: none;
  color: rgba(255,255,255,.78);
  margin-top: 5px;
  line-height: 1.35;
}
.card-hover-rating {
  color: #f77f00;
  text-shadow: 0 0 12px rgba(247,127,0,.35);
}
.card-hover-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 6px;
}
.card-hover-tags span {
  font-family: 'Bebas Neue', var(--ff-head);
  font-size: 10px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(247,127,0,.12);
  border: 1px solid rgba(247,127,0,.28);
  color: #ff9500;
  font-weight: 400;
}
.film-poster-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(148px,1fr));
  gap:16px;
}
.film-poster-grid .card--poster,
.film-poster-grid .card--poster.card-trending{
  width:100%;
  flex:unset;
  margin-left:0!important;
}
.film-poster-grid .card--poster .card-img{
  height:auto;
  aspect-ratio:2/3;
}
.film-poster-grid--lg{
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:22px;
}
.film-poster-grid--lg .card--poster .card-clip{
  border-radius:16px!important;
}
.film-poster-grid--saga{
  display:flex;
  flex-wrap:nowrap;
  align-items:flex-start;
  overflow-x:auto;
  overflow-y:hidden;
  gap:16px;
  padding:4px 2px 14px;
  scroll-snap-type:x proximity;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:#f77f00 #0a0a0a;
}
.film-poster-grid--saga::-webkit-scrollbar{height:6px}
.film-poster-grid--saga::-webkit-scrollbar-track{
  background:#0a0a0a;
  border-radius:4px;
  border:1px solid rgba(247,127,0,.12);
}
.film-poster-grid--saga::-webkit-scrollbar-thumb{
  background:linear-gradient(90deg,#f77f00,#ff9500);
  border-radius:4px;
  box-shadow:0 0 8px rgba(247,127,0,.35);
}
.film-poster-grid--saga::-webkit-scrollbar-thumb:hover{background:#ff9500}
.film-poster-grid--saga::-webkit-scrollbar-button{display:none}
.film-poster-grid--saga .card--poster{
  flex:0 0 182px;
  width:182px;
  min-width:182px;
  scroll-snap-align:start;
}
.film-poster-grid--saga .card--poster .card-clip{
  border-radius:12px!important;
}
.scroll-row .card--poster .card-img {
  height: auto;
  aspect-ratio: 2/3;
}
.card-info { display: none !important; }
#catalogueGrid.movies-grid,
#studioGrid.movies-grid,
#moviesGrid.movies-grid {
  grid-template-columns: repeat(auto-fill, minmax(228px, 1fr));
  gap: 22px 16px;
  padding: 1.6rem 2.5rem 2rem;
}
#catalogueGrid .card--poster,
#studioGrid .card--poster,
#moviesGrid .card--poster {
  max-width: none;
  justify-self: stretch;
  width: 100%;
}

/* ═══════════════════════════════════════════════════
   SEARCH MODAL
   ═══════════════════════════════════════════════════ */
.search-bg{position:fixed;inset:0;z-index:300;background:rgba(7,7,15,.97);backdrop-filter:blur(24px);display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:opacity .28s}
.search-bg.open{opacity:1;pointer-events:all}
.search-top{padding:1.8rem 2.8rem 1.2rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:1.1rem}
.search-hd{display:flex;align-items:center;gap:14px}
.search-icon{color:#f59e0b;flex-shrink:0}
#searchInput{flex:1;background:transparent;border:none;border-bottom:2px solid rgba(245,158,11,.45);padding:9px 0;color:#fff;font-size:30px;outline:none;font-family:var(--ff-head);font-weight:700;caret-color:#f59e0b}
#searchInput::placeholder{color:var(--muted)}
.search-close{background:var(--s2);border:1px solid var(--border2);color:#fff;width:42px;height:42px;border-radius:9px;font-size:17px;display:flex;align-items:center;justify-content:center;transition:.18s}
.search-close:hover{background:#ea580c;border-color:#ea580c}
.search-filters{display:flex;gap:7px;flex-wrap:wrap}
.search-body{flex:1;overflow-y:auto;padding:1.8rem 2.8rem}
.search-label{font-family:var(--ff-head);font-size:15px;font-weight:700;color:var(--muted);margin-bottom:1.1rem;letter-spacing:.3px;text-transform:uppercase}
.search-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(188px,1fr));gap:16px 12px}.trending-chips{display:flex;flex-wrap:wrap;gap:7px}
.t-chip{padding:7px 16px;border-radius:8px;background:var(--s2);border:1px solid var(--border);color:var(--text2);font-size:13px;font-weight:500;transition:.18s}
.t-chip:hover{background:var(--s3)}

/* ═══════════════════════════════════════════════════
   WHEEL
   ═══════════════════════════════════════════════════ */
/* Modal roue aléatoire → wheel-modal.css */

/* ═══════════════════════════════════════════════════
   CACHE & LOADING
   ═══════════════════════════════════════════════════ */
.cache-modal{position:fixed;inset:0;z-index:500;background:rgba(7,7,15,.96);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:.28s}
.cache-modal.open{opacity:1;pointer-events:all}
.cache-box{background:var(--s1);border:1px solid var(--border2);border-radius:var(--r2);padding:2rem;max-width:560px;width:calc(100% - 2rem);max-height:90vh;overflow-y:auto}
.cache-title{font-family:var(--ff-head);font-size:22px;font-weight:700;margin-bottom:6px}
.cache-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0}
.cache-stat{background:var(--s2);border:1px solid var(--border);border-radius:var(--r);padding:14px;text-align:center}
.cache-stat-n{font-family:var(--ff-head);font-size:28px;font-weight:800;color:var(--red2)}
.cache-stat-l{font-size:12px;color:var(--muted);margin-top:3px}
.cache-prog-wrap{background:var(--s3);border-radius:8px;height:8px;overflow:hidden;margin:14px 0}
.cache-prog-fill{height:100%;background:linear-gradient(90deg,var(--red),var(--gold));border-radius:8px;transition:width .5s}
.cache-log{background:var(--s3);border-radius:var(--r);padding:12px;max-height:180px;overflow-y:auto;font-size:11px;font-family:monospace;color:var(--muted);margin:14px 0;line-height:1.8}
.cache-log-line{display:flex;gap:8px}
.cache-log-ok{color:#22c55e}
.cache-log-err{color:var(--red2)}
.cache-log-info{color:var(--gold2)}
.cache-actions{display:flex;gap:9px;flex-wrap:wrap}
.cache-btn{padding:8px 18px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid var(--border2);background:var(--s2);color:var(--text2);transition:.18s;cursor:pointer;font-family:var(--ff-body)}
.cache-btn:hover{background:var(--s3);color:var(--text)}
.cache-btn.danger{border-color:rgba(232,48,74,.35);color:var(--red2)}
.cache-btn.danger:hover{background:rgba(232,48,74,.12)}
.cache-btn.primary{background:var(--red);border-color:var(--red);color:#fff}
.cache-btn.primary:hover{background:#c02040}

.loading-bg{position:fixed;inset:0;z-index:600;background:rgba(7,7,15,.97);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:22px;opacity:0;pointer-events:none;transition:.28s}
.loading-bg.open{opacity:1;pointer-events:all}
.loading-logo{font-family:var(--ff-head);font-size:42px;font-weight:800;background:linear-gradient(135deg,#e8304a,#f5a623,#e8304a);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 1.8s linear infinite}
@keyframes shimmer{0%{background-position:0% center}100%{background-position:200% center}}
.spinner{width:54px;height:54px;border:3px solid rgba(255,255,255,.06);border-top-color:var(--red);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-sub{color:var(--muted);font-size:14px;text-align:center}
.loading-dots span{animation:blink 1.4s infinite}
.loading-dots span:nth-child(2){animation-delay:.2s}
.loading-dots span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:0}40%{opacity:1}}
.loading-prog-wrap{width:240px;background:var(--s2);height:3px;border-radius:8px;overflow:hidden}
.loading-prog{height:100%;width:0%;background:linear-gradient(90deg,var(--red),var(--gold));transition:width .3s;border-radius:8px}
.loading-step{color:var(--muted);font-size:12px}

/* ═══════════════════════════════════════════════════
   ADS MODAL & CENTER ALERT
   ═══════════════════════════════════════════════════ */
.center-alert-bg{position:fixed;inset:0;z-index:99999;background:rgba(4,4,12,.95);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}
.center-alert-bg.show{opacity:1;pointer-events:all}
.center-alert-box{background:linear-gradient(160deg,rgba(20,20,35,.98),rgba(12,12,28,.99));border:1px solid rgba(245,166,35,.3);border-radius:24px;padding:42px 36px;max-width:420px;width:calc(100% - 2rem);text-align:center;box-shadow:0 32px 80px rgba(0,0,0,.85),0 0 0 1px rgba(255,255,255,.05) inset,0 0 60px rgba(245,166,35,.1);transform:scale(.92);transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.center-alert-bg.show .center-alert-box{transform:scale(1)}
.center-alert-icon{width:84px;height:84px;border-radius:50%;background:linear-gradient(135deg,rgba(245,166,35,.18),rgba(245,166,35,.06));border:1.5px solid rgba(245,166,35,.4);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:0 8px 24px rgba(245,166,35,.15)}
.center-alert-title{font-family:var(--ff-head);font-size:26px;font-weight:800;color:#fff;margin-bottom:10px;letter-spacing:-.6px}
.center-alert-text{color:var(--text2);font-size:14px;line-height:1.65;margin-bottom:22px}
.center-alert-actions{display:flex;flex-direction:column;gap:0;width:100%;max-width:280px;margin:0 auto}
.center-alert-timer{font-family:var(--ff-head);font-size:64px;font-weight:800;background:linear-gradient(135deg,#e8304a,#f5a623);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1;letter-spacing:-2px;filter:drop-shadow(0 4px 16px rgba(232,48,74,.3))}
.pop-anim{animation:popScale .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes popScale{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}

.watch-gate-modal{position:fixed;inset:0;z-index:2147483646;background:rgba(4,4,12,.92);backdrop-filter:blur(28px) saturate(160%);-webkit-backdrop-filter:blur(28px) saturate(160%);display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .35s ease}
.watch-gate-modal.open{opacity:1;pointer-events:all}
.watch-gate-box{background:linear-gradient(165deg,rgba(18,18,32,.98),rgba(10,10,20,.99));border:1px solid rgba(245,166,35,.22);border-radius:24px;padding:2rem 1.5rem 1.75rem;max-width:420px;width:100%;min-height:520px;max-height:calc(100vh - 2rem);overflow:auto;position:relative;box-shadow:0 40px 100px rgba(0,0,0,.85),0 0 80px rgba(245,166,35,.08),inset 0 1px 0 rgba(255,255,255,.06)}
.watch-gate-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);color:rgba(255,255,255,.7);cursor:pointer;font-size:16px;z-index:2;transition:.2s}
.watch-gate-close:hover{background:rgba(232,48,74,.2);border-color:rgba(232,48,74,.4);color:#fff}
.watch-gate-top{text-align:center;margin-bottom:1.25rem;padding-right:2rem}
.watch-gate-badge{display:inline-block;font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:#f5a623;background:rgba(245,166,35,.12);border:1px solid rgba(245,166,35,.25);padding:5px 12px;border-radius:999px;margin-bottom:10px}
.watch-gate-title{font-family:var(--ff-head);font-size:clamp(20px,4vw,26px);font-weight:800;color:#fff;margin:0 0 8px;letter-spacing:-.4px}
.watch-gate-sub{color:rgba(255,255,255,.55);font-size:13px;line-height:1.6;margin:0 0 14px}
.watch-gate-progress-global{height:5px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden}
.watch-gate-progress-fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,#f5a623,#e8304a);transition:width .35s ease}
.watch-gate-panel{text-align:left}
.watch-gate-layout{display:flex;flex-direction:column;gap:1rem}
@media(max-width:720px){.watch-gate-layout{flex-direction:column}}
.watch-gate-ad-list{display:none}

.watch-gate-ad-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);font-size:12px;color:rgba(255,255,255,.5);transition:.25s}
.watch-gate-ad-item.active{border-color:rgba(245,166,35,.45);background:rgba(245,166,35,.08);color:#fff}
.watch-gate-ad-item.done{border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.08);color:#86efac}
.watch-gate-ad-item-num{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;background:rgba(255,255,255,.08);flex-shrink:0}
.watch-gate-ad-item.done .watch-gate-ad-item-num{background:rgba(34,197,94,.2)}
.watch-gate-ad-head{display:none}
.watch-gate-ad-label{display:none}
.watch-gate-progress-track{display:none}
.watch-gate-ad-card{text-align:center;padding:1.75rem 1.25rem;border-radius:16px;border:1px solid rgba(245,166,35,.2);background:linear-gradient(160deg,rgba(245,166,35,.06),rgba(232,48,74,.04));margin-bottom:4px}
.watch-gate-ad-card-icon{margin-bottom:12px;line-height:1;display:flex;justify-content:center;color:#f5a623}
.watch-gate-ad-card-icon svg{width:42px;height:42px}
.watch-gate-btn-icon{display:inline-flex;align-items:center;justify-content:center;gap:10px}
a.watch-gate-btn{color:#fff;text-decoration:none;box-sizing:border-box}
a.watch-gate-btn.is-used{opacity:.45;pointer-events:none;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.watch-gate-btn-icon svg{width:17px;height:17px;flex-shrink:0}
.watch-gate-ad-confirm-hidden{display:none!important}
.watch-gate-ad-card-desc{color:rgba(255,255,255,.65);font-size:14px;line-height:1.65;margin:0 0 18px}
.watch-gate-ad-status{font-size:12px;color:rgba(255,255,255,.45);margin:12px 0 0;min-height:18px;line-height:1.5}
.watch-gate-ad-status.ok{color:#86efac}
.watch-gate-ad-status.err{color:#f87171}
.watch-gate-hint{font-size:12px;color:rgba(255,255,255,.4);margin:10px 0 12px;line-height:1.5;text-align:center}
.watch-gate-btn{width:100%;padding:14px 18px;border-radius:12px;border:none;font-family:var(--ff-head);font-size:14px;font-weight:800;letter-spacing:.3px;cursor:pointer;transition:.2s;text-transform:uppercase}
.watch-gate-btn-primary{background:linear-gradient(135deg,#f5a623,#e8304a);color:#fff;box-shadow:0 8px 24px rgba(232,48,74,.3)}
.watch-gate-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 32px rgba(232,48,74,.4)}
.watch-gate-btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.watch-gate-btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.65);margin-top:8px}
.watch-gate-cf-icon{text-align:center;margin:8px 0 12px;color:#f5a623;display:flex;justify-content:center}
.watch-gate-cf-icon svg{width:42px;height:42px}
.watch-gate-cf-text{text-align:center;color:rgba(255,255,255,.55);font-size:14px;line-height:1.6;margin:0 0 16px}
.watch-gate-cf-widget{display:flex;justify-content:center;align-items:center;min-height:70px;margin-bottom:8px}
.watch-gate-cf-loading{font-size:12px;color:rgba(255,255,255,.35)}
.watch-gate-loading-panel,.watch-gate-error-panel{text-align:center;padding:2rem 1rem}
.watch-gate-spinner{width:44px;height:44px;border:3px solid rgba(255,255,255,.1);border-top-color:#f5a623;border-radius:50%;animation:watchGateSpin .8s linear infinite;margin:0 auto 16px}
@keyframes watchGateSpin{to{transform:rotate(360deg)}}
.watch-gate-error-icon{margin-bottom:12px;color:#f87171;display:flex;justify-content:center}
.watch-gate-error-icon svg{width:40px;height:40px}
.watch-gate-ad-item-num svg{width:14px;height:14px}
.watch-gate-error-msg{color:rgba(255,255,255,.7);font-size:14px;line-height:1.6;margin:0 0 18px}
.watch-gate-ad-warning{font-size:12px;font-weight:700;color:#fbbf24;background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2);border-radius:10px;padding:10px 14px;margin:0 0 10px;text-align:center;line-height:1.5}.watch-gate-ad-funding{font-size:12px;color:rgba(255,255,255,.45);text-align:center;line-height:1.6;margin:0 0 16px;padding:0 4px}.watch-gate-error-actions{display:flex;flex-direction:column;gap:0;max-width:280px;margin:0 auto}

/* Legacy ads modal aliases (compat) */
.ads-modal,.ads-box{display:none!important}

/* ═══════════════════════════════════════════════════
   NOTIFICATIONS
   ═══════════════════════════════════════════════════ */
.notif-bell{position:relative;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .22s var(--ease-out);color:rgba(255,255,255,.85);flex-shrink:0}
.notif-bell:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);transform:translateY(-1px);color:#fff}
.notif-badge{position:absolute;top:-3px;right:-3px;background:linear-gradient(135deg,#ff2d55,#e8304a);color:#fff;font-size:9.5px;font-weight:800;min-width:17px;height:17px;padding:0 5px;display:flex;align-items:center;justify-content:center;border-radius:9px;border:2px solid #0a0a0f;opacity:0;transform:scale(0);transition:.3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px rgba(232,48,74,.5);letter-spacing:-.2px}
.notif-badge.visible{opacity:1;transform:scale(1)}
@keyframes bellShake{0%,100%{transform:rotate(0)}20%{transform:rotate(14deg)}40%{transform:rotate(-12deg)}60%{transform:rotate(8deg)}80%{transform:rotate(-4deg)}}

.notif-inbox{position:fixed;top:76px;right:1.75rem;width:400px;max-height:580px;background:linear-gradient(180deg,rgba(15,15,24,.98) 0%,rgba(8,8,16,.99) 100%);border:1px solid rgba(255,255,255,.06);border-radius:16px;z-index:500;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,.85),0 0 0 1px rgba(255,255,255,.03) inset,0 -1px 0 rgba(255,255,255,.04) inset;opacity:0;transform:translateY(-12px) scale(.97);pointer-events:none;transition:.28s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%)}
.notif-inbox.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.notif-inbox-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}
.notif-inbox-title{font-family:var(--ff-head);font-size:15px;font-weight:700;color:#fff;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}
.notif-inbox-title::before{content:'';width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e;animation:notifPulse 2s ease-in-out infinite}
@keyframes notifPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}
.notif-mark-all{background:transparent;border:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.55);font-size:11px;font-weight:600;cursor:pointer;padding:5px 11px;border-radius:7px;transition:.18s;font-family:var(--ff-body);letter-spacing:.2px}
.notif-mark-all:hover{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.15)}
.notif-list{flex:1;overflow-y:auto;padding:6px 8px 8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent}
.notif-list::-webkit-scrollbar{width:5px}
.notif-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:3px}
.notif-empty{text-align:center;padding:3.5rem 1.5rem 3rem;color:rgba(255,255,255,.4);font-size:13px}
.notif-empty-icon{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:rgba(255,255,255,.25)}
.notif-empty-icon svg{width:22px;height:22px}
.notif-empty-title{color:rgba(255,255,255,.65);font-weight:600;font-size:13.5px;margin-bottom:4px;font-family:var(--ff-head);letter-spacing:-.2px}
.notif-empty-sub{color:rgba(255,255,255,.3);font-size:11.5px}
.notif-item{display:flex;gap:12px;padding:12px 12px;cursor:pointer;border-radius:11px;border:1px solid transparent;transition:all .2s var(--ease-out);position:relative;margin-bottom:3px;overflow:hidden}
.notif-item:hover{background:rgba(255,255,255,.035)}
.notif-item.unread{background:linear-gradient(90deg,rgba(232,48,74,.08) 0%,rgba(232,48,74,.02) 100%)}
.notif-item.unread::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:linear-gradient(180deg,#ff2d55,#e8304a);border-radius:0 2px 2px 0;box-shadow:0 0 8px rgba(232,48,74,.4)}
.notif-dot{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}
.notif-dot svg{width:18px;height:18px}
.notif-dot::after{content:'';position:absolute;inset:0;border-radius:10px;border:1px solid currentColor;opacity:.25}
.notif-dot-announce{background:rgba(245,166,35,.12);color:#f5a623}
.notif-dot-report{background:rgba(232,48,74,.12);color:#ff5068}
.notif-dot-info{background:rgba(96,165,250,.1);color:#60a5fa}
.notif-dot-success{background:rgba(34,197,94,.1);color:#22c55e}
.notif-dot-ticket{background:rgba(168,85,247,.1);color:#a855f7}
.notif-dot-warning{background:rgba(245,158,11,.12);color:#f59e0b}
.notif-dot-system{background:rgba(255,255,255,.06);color:rgba(255,255,255,.7)}
.notif-body-title{font-size:13.5px;font-weight:600;color:rgba(255,255,255,.95);margin-bottom:3px;line-height:1.35;letter-spacing:-.1px}
.notif-body-sub{font-size:12px;color:rgba(255,255,255,.5);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.notif-body-time{font-size:10.5px;color:rgba(255,255,255,.3);margin-top:6px;display:flex;align-items:center;gap:6px;font-weight:500;letter-spacing:.1px}
.notif-body-time svg{width:10px;height:10px;opacity:.6}
.notif-item.unread .notif-body-title{color:#fff}
.notif-item.unread .notif-body-sub{color:rgba(255,255,255,.65)}
.notif-full-body{display:none;margin-top:10px;font-size:12.5px;color:rgba(255,255,255,.7);line-height:1.7;background:rgba(255,255,255,.03);padding:11px 13px;border-radius:9px;border:1px solid rgba(255,255,255,.05)}
.notif-item.expanded .notif-full-body{display:block}
.notif-ticket-link{margin-top:8px;display:inline-flex;align-items:center;gap:6px;font-size:11px;background:rgba(232,48,74,.1);color:#ff5068;padding:4px 10px;border-radius:6px;font-weight:700;border:1px solid rgba(232,48,74,.2);letter-spacing:.2px;transition:.18s}
.notif-ticket-link:hover{background:rgba(232,48,74,.18);border-color:rgba(232,48,74,.35)}
.notif-ticket-link svg{width:11px;height:11px}

.notif-popup-wrap{position:fixed;top:84px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:380px}
.notif-popup{background:linear-gradient(160deg,rgba(18,18,28,.98),rgba(10,10,18,.99));border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:14px 44px 14px 14px;box-shadow:0 20px 50px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.03) inset,0 -1px 0 rgba(255,255,255,.05) inset;display:flex;gap:12px;align-items:flex-start;transform:translateX(120%);transition:transform .5s cubic-bezier(.34,1.56,.64,1);pointer-events:all;position:relative;cursor:pointer;overflow:hidden;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.notif-popup::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--popup-accent,#ff2d55),var(--popup-accent2,#e8304a));border-radius:3px 0 0 3px}
.notif-popup::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 0% 50%,var(--popup-glow,rgba(232,48,74,.06)) 0%,transparent 60%);pointer-events:none}
.notif-popup.show{transform:translateX(0)}
.notif-popup:hover{transform:translateX(-3px);border-color:rgba(255,255,255,.12)}
.notif-popup.type-announce{--popup-accent:#f5a623;--popup-accent2:#e8a02d;--popup-glow:rgba(245,166,35,.08)}
.notif-popup.type-success{--popup-accent:#22c55e;--popup-accent2:#16a34a;--popup-glow:rgba(34,197,94,.08)}
.notif-popup.type-info{--popup-accent:#60a5fa;--popup-accent2:#3b82f6;--popup-glow:rgba(96,165,250,.08)}
.notif-popup.type-report{--popup-accent:#ff2d55;--popup-accent2:#e8304a;--popup-glow:rgba(232,48,74,.08)}
.notif-popup.type-ticket{--popup-accent:#a855f7;--popup-accent2:#9333ea;--popup-glow:rgba(168,85,247,.08)}
.notif-popup.type-warning{--popup-accent:#f59e0b;--popup-accent2:#d97706;--popup-glow:rgba(245,158,11,.08)}
.notif-popup-timer{position:absolute;bottom:0;left:0;height:2px;background:linear-gradient(90deg,var(--popup-accent),var(--popup-accent2));border-radius:0 2px 2px 0;width:100%;animation:notifTimer 5.5s linear forwards;box-shadow:0 0 8px var(--popup-accent)}
@keyframes notifTimer{from{width:100%}to{width:0%}}
.notif-popup-icon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:var(--popup-accent);position:relative;z-index:1}
.notif-popup-icon svg{width:18px;height:18px}
.notif-popup-content{flex:1;min-width:0;position:relative;z-index:1}
.notif-popup-label{display:inline-block;font-size:9.5px;font-weight:800;color:var(--popup-accent);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:4px;opacity:.9}
.notif-popup-title{font-weight:700;font-size:13.5px;color:#fff;margin-bottom:4px;line-height:1.3;letter-spacing:-.1px}
.notif-popup-text{font-size:12px;color:rgba(255,255,255,.6);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.notif-popup-close{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.5);cursor:pointer;font-size:10px;line-height:1;border-radius:6px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;transition:.15s;z-index:2}
.notif-popup-close:hover{background:rgba(255,45,85,.2);color:#fff;border-color:rgba(255,45,85,.4)}

.toast{position:fixed;bottom:30px;left:30px;z-index:999999;background:linear-gradient(160deg,rgba(20,20,30,.96),rgba(12,12,20,.98));backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:14px 20px;display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.95);font-size:13.5px;font-weight:500;letter-spacing:-.1px;box-shadow:0 18px 40px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.03) inset;transform:translateY(100%) scale(.95);opacity:0;transition:all .45s cubic-bezier(.34,1.56,.64,1);max-width:380px;pointer-events:none}
.toast.show{transform:translateY(0) scale(1);opacity:1}
.toast::before{content:'';width:4px;align-self:stretch;background:linear-gradient(180deg,#ff2d55,#e8304a);border-radius:4px;box-shadow:0 0 8px rgba(232,48,74,.4)}

/* ═══════════════════════════════════════════════════
   STAFF PANEL - REFONTE PREMIUM
   ═══════════════════════════════════════════════════ */
.staff-panel { position:fixed; inset:0; z-index:9000; background:#040408; display:flex; flex-direction:column; opacity:0; pointer-events:none; transition:.4s cubic-bezier(0.16, 1, 0.3, 1); }
.staff-panel::before { content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%; background:radial-gradient(circle at 50% 0%, rgba(232,48,74,0.08), transparent 50%), radial-gradient(circle at 100% 50%, rgba(245,166,35,0.05), transparent 40%); pointer-events:none; z-index:0; }
.staff-panel.open { opacity:1; pointer-events:all; }

/* Topbar */
.staff-topbar { position:relative; z-index:10; height:70px; background:rgba(10,10,15,0.4); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px); border-bottom:1px solid rgba(255,255,255,0.04); display:flex; align-items:center; padding:0 2rem; gap:16px; flex-shrink:0; }
.staff-logo { font-family:var(--ff-head); font-size:22px; font-weight:800; background:linear-gradient(135deg, #fff, #a8a6be); -webkit-background-clip:text; -webkit-text-fill-color:transparent; letter-spacing:-0.5px; display:flex; align-items:center; gap:8px; }
.staff-badge { background:linear-gradient(135deg, rgba(245,166,35,0.15), rgba(232,48,74,0.15)); border:1px solid rgba(245,166,35,0.3); color:var(--gold2); font-size:10px; font-weight:800; padding:4px 12px; border-radius:20px; text-transform:uppercase; letter-spacing:1px; box-shadow:0 4px 12px rgba(245,166,35,0.1); }

/* Layout Corps */
.staff-body { display:flex; flex:1; overflow:hidden; position:relative; z-index:1; }

/* Sidebar */
.staff-sidebar { width:260px; background:rgba(15,15,24,0.3); backdrop-filter:blur(20px); border-right:1px solid rgba(255,255,255,0.03); padding:1.5rem 0.8rem; flex-shrink:0; overflow-y:auto; display:flex; flex-direction:column; gap:4px; }
.staff-nav-item { display:flex; align-items:center; gap:12px; padding:12px 16px; color:rgba(255,255,255,0.5); font-size:13.5px; font-weight:600; cursor:pointer; transition:.25s ease; border-radius:12px; border:1px solid transparent; }
.staff-nav-item:hover { color:#fff; background:rgba(255,255,255,0.03); }
.staff-nav-item.active { color:#fff; background:linear-gradient(90deg, rgba(232,48,74,0.15), transparent); border-color:rgba(232,48,74,0.2); box-shadow:inset 4px 0 0 var(--red); }
.staff-nav-icon { font-size:18px; width:24px; text-align:center; opacity:0.8; transition:.25s; filter:grayscale(1); }
.staff-nav-item.active .staff-nav-icon { opacity:1; filter:grayscale(0); filter:drop-shadow(0 2px 8px rgba(232,48,74,0.4)); transform:scale(1.1); }
.staff-nav-sep { height:1px; background:linear-gradient(90deg, transparent, rgba(255,255,255,0.05), transparent); margin:12px 0; }

/* Content Area */
.staff-content { flex:1; overflow-y:auto; padding:3rem 4rem; scrollbar-width:none; }
.staff-content::-webkit-scrollbar { display:none; }
.staff-section { display:none; animation:staffFadeIn .4s cubic-bezier(0.16, 1, 0.3, 1); max-width:1200px; margin:0 auto; }
.staff-section.active { display:block; }
@keyframes staffFadeIn { from{ opacity:0; transform:translateY(15px); } to{ opacity:1; transform:translateY(0); } }

/* Headers de Section */
.staff-section-title { font-family:var(--ff-head); font-size:32px; font-weight:800; color:#fff; margin-bottom:8px; letter-spacing:-1px; display:flex; align-items:center; gap:12px; }
.staff-section-sub { color:var(--muted); font-size:14px; margin-bottom:32px; line-height:1.6; max-width:600px; }

/* Cards Stats (Vue d'ensemble) */
.staff-cards { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px, 1fr)); gap:20px; margin-bottom:36px; }
.staff-card { background:linear-gradient(160deg, rgba(25,25,35,0.4), rgba(15,15,25,0.6)); backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,0.05); border-radius:20px; padding:24px; transition:.3s ease; position:relative; overflow:hidden; }
.staff-card::before { content:''; position:absolute; top:0; left:0; width:100%; height:3px; background:var(--c, rgba(255,255,255,0.1)); opacity:0.5; }
.staff-card:hover { transform:translateY(-4px); border-color:rgba(255,255,255,0.1); box-shadow:0 12px 30px rgba(0,0,0,0.5), 0 0 40px var(--c-glow, transparent); }
.staff-card-n { font-family:var(--ff-head); font-size:42px; font-weight:800; color:#fff; line-height:1; margin-bottom:8px; letter-spacing:-1px; }
.staff-card-l { font-size:13px; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:0.5px; }

/* Variations Cards */
.sc-red { --c:var(--red); --c-glow:rgba(232,48,74,0.15); }
.sc-gold { --c:var(--gold); --c-glow:rgba(245,166,35,0.15); }
.sc-green { --c:#22c55e; --c-glow:rgba(34,197,94,0.15); }
.sc-blue { --c:#3b82f6; --c-glow:rgba(59,130,246,0.15); }

/* Blocs & Panels génériques */
.staff-panel-box { background:linear-gradient(145deg, rgba(20,20,30,0.4), rgba(10,10,15,0.6)); border:1px solid rgba(255,255,255,0.04); border-radius:20px; padding:28px; margin-bottom:24px; box-shadow:0 10px 30px rgba(0,0,0,0.3); }
.staff-panel-header { font-family:var(--ff-head); font-size:18px; font-weight:700; margin-bottom:20px; color:#fff; display:flex; align-items:center; gap:10px; }

/* Boutons Staff */
.sp-btn { padding:10px 20px; border-radius:12px; font-size:13.5px; font-weight:600; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); color:var(--text2); cursor:pointer; transition:.2s ease; font-family:var(--ff-body); display:inline-flex; align-items:center; gap:8px; justify-content:center; }
.sp-btn:hover { background:rgba(255,255,255,0.08); color:#fff; transform:translateY(-1px); }
.sp-btn.primary { background:linear-gradient(135deg, var(--red), var(--red2)); border:none; color:#fff; box-shadow:0 6px 15px rgba(232,48,74,0.3); }
.sp-btn.primary:hover { box-shadow:0 8px 20px rgba(232,48,74,0.5); filter:brightness(1.1); }
.sp-btn.gold { background:linear-gradient(135deg, rgba(245,166,35,0.15), rgba(245,166,35,0.05)); border:1px solid rgba(245,166,35,0.3); color:var(--gold2); }
.sp-btn.gold:hover { background:rgba(245,166,35,0.25); border-color:var(--gold); color:#fff; box-shadow:0 4px 15px rgba(245,166,35,0.2); }
.sp-btn.danger { background:rgba(232,48,74,0.1); border:1px solid rgba(232,48,74,0.2); color:var(--red2); }
.sp-btn.danger:hover { background:rgba(232,48,74,0.2); color:#fff; }

/* Formulaires Staff */
.staff-form-group { margin-bottom:20px; }
.staff-form-label { display:block; font-size:12.5px; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.staff-form-input, .staff-form-select, .staff-form-textarea { width:100%; background:rgba(0,0,0,0.3); border:1px solid rgba(255,255,255,0.06); color:#fff; padding:14px 18px; border-radius:12px; font-family:var(--ff-body); font-size:14.5px; transition:.2s ease; outline:none; }
.staff-form-input:focus, .staff-form-select:focus, .staff-form-textarea:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(245,166,35,0.15); background:rgba(0,0,0,0.5); }
.staff-form-textarea { min-height:140px; resize:vertical; line-height:1.6; }

/* Tableaux (Reports / Utils) */
.staff-table-wrap { background:rgba(15,15,25,0.5); border:1px solid rgba(255,255,255,0.04); border-radius:16px; overflow:hidden; }
.staff-table { width:100%; border-collapse:collapse; font-size:13.5px; }
.staff-table th { text-align:left; padding:16px 20px; background:rgba(0,0,0,0.3); color:var(--muted); font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; border-bottom:1px solid rgba(255,255,255,0.05); }
.staff-table td { padding:16px 20px; border-bottom:1px solid rgba(255,255,255,0.02); color:rgba(255,255,255,0.8); vertical-align:middle; }
.staff-table tr:hover td { background:rgba(255,255,255,0.02); color:#fff; }
.staff-status { display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:6px; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:0.5px; }
.staff-status.open { background:rgba(232,48,74,0.15); color:var(--red2); border:1px solid rgba(232,48,74,0.3); }
.staff-status.done { background:rgba(34,197,94,0.15); color:#22c55e; border:1px solid rgba(34,197,94,0.3); }

/* Lignes Utilisateurs / Tickets */
.staff-list-row { display:flex; align-items:center; gap:16px; padding:16px 20px; background:rgba(255,255,255,0.015); border:1px solid rgba(255,255,255,0.04); border-radius:14px; margin-bottom:10px; transition:.2s ease; cursor:pointer; }
.staff-list-row:hover { background:rgba(255,255,255,0.04); border-color:rgba(255,255,255,0.1); transform:translateX(4px); }
.staff-list-row.unread { border-left:4px solid var(--red); background:linear-gradient(90deg, rgba(232,48,74,0.08), transparent); }

/* Cache Prog & Logs */
.sp-prog-wrap { background:rgba(0,0,0,0.4); border-radius:10px; height:12px; overflow:hidden; margin:20px 0; border:1px solid rgba(255,255,255,0.05); }
.sp-prog-fill { height:100%; background:linear-gradient(90deg, var(--red), var(--gold)); border-radius:10px; transition:width .4s ease; box-shadow:0 0 10px rgba(245,166,35,0.4); }
.sp-log { background:#000; border:1px solid rgba(255,255,255,0.05); border-radius:12px; padding:16px; max-height:250px; overflow-y:auto; font-size:12px; font-family:monospace; margin:20px 0; line-height:1.7; }
/* ═══════════════════════════════════════════════════
   TICKET MODAL
   ═══════════════════════════════════════════════════ */
.ticket-modal{position:fixed;inset:0;z-index:9500;background:rgba(7,7,15,.97);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:.28s}
.ticket-modal.open{opacity:1;pointer-events:all}
.ticket-box{background:var(--s1);border:1px solid var(--border2);border-radius:20px;max-height:85vh;display:flex;flex-direction:row;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.8)}
.ticket-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}
.t-status{padding:3px 10px;border-radius:5px;font-size:11px;font-weight:800}
.t-status.open{background:rgba(232,48,74,.15);color:var(--red2);border:1px solid rgba(232,48,74,.3)}
.t-status.replied{background:rgba(34,197,94,.1);color:#22c55e;border:1px solid rgba(34,197,94,.25)}
.t-status.closed{background:rgba(255,255,255,.05);color:var(--muted);border:1px solid var(--border)}
.ticket-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;scrollbar-width:none}
.ticket-msgs::-webkit-scrollbar{display:none}
.ticket-msg{max-width:80%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.55;word-break:break-word}
.ticket-msg.user{background:rgba(232,48,74,.14);border:1px solid rgba(232,48,74,.22);align-self:flex-end;border-bottom-right-radius:4px}
.ticket-msg.staff-msg{background:var(--s3);border:1px solid var(--border2);align-self:flex-start;border-bottom-left-radius:4px}
.ticket-msg-from{font-size:10px;color:var(--muted);margin-bottom:4px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.ticket-msg-ts{font-size:10px;color:var(--muted);margin-top:5px;text-align:right}
.ticket-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:10px;flex-shrink:0}
.ticket-footer textarea{flex:1;background:var(--s2);border:1px solid var(--border2);color:#fff;padding:10px 13px;border-radius:10px;font-family:var(--ff-body);font-size:13px;resize:none;height:58px;outline:none;transition:border-color .2s}
.ticket-footer textarea:focus{border-color:var(--red)}
.ticket-send{background:var(--red);color:#fff;border:none;border-radius:10px;padding:0 18px;font-weight:700;font-size:13px;cursor:pointer;font-family:var(--ff-body);transition:.18s}
.ticket-send:hover{background:#c02040}

/* ═══════════════════════════════════════════════════
   USER MENU & DROPDOWNS
   ═══════════════════════════════════════════════════ */
.user-profile{position:relative;margin-left:8px;display:none;align-items:center;flex-shrink:0}
.user-pill{display:flex;align-items:center;gap:10px;background:transparent;border:1px solid rgba(255,255,255,0.08);padding:4px 14px 4px 4px;border-radius:30px;cursor:pointer;transition:0.2s}
.user-pill:hover,.user-pill.active{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.2)}
.premium-dropdown{position:absolute;top:55px;right:0;background:#0c0d12;border:1px solid rgba(255,255,255,0.05);border-radius:12px;width:260px;padding:0;display:none;flex-direction:column;z-index:1000;box-shadow:0 20px 40px rgba(0,0,0,0.8);overflow:hidden}
.premium-dropdown.open{display:flex}
.pd-item{background:none;border:none;color:var(--text2);padding:10px 20px;text-align:left;font-size:13px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:0.5px;width:100%;transition:0.2s}
.pd-item:hover{background:rgba(255,255,255,0.03);color:#fff}

.coins-pill{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,rgba(245,166,35,.15),rgba(245,166,35,.08));border:1px solid rgba(245,166,35,.35);padding:9px 16px;border-radius:10px;color:var(--gold2);font-weight:700;font-size:14px;cursor:pointer;transition:all .22s var(--ease-out);height:42px;box-shadow:0 2px 8px rgba(245,166,35,.1);letter-spacing:-.01em}
.coins-pill:hover{background:linear-gradient(135deg,rgba(245,166,35,.22),rgba(245,166,35,.12));border-color:rgba(245,166,35,.5);transform:translateY(-1px);box-shadow:0 4px 16px rgba(245,166,35,.2)}
.discord-login-btn{display:flex;align-items:center;gap:8px;background:#5865F2;color:#fff;border:none;padding:9px 18px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;letter-spacing:-.01em;height:42px;box-shadow:0 4px 12px rgba(88,101,242,.3);transition:all .22s var(--ease-out)}
.discord-login-btn:hover{background:#4752c4;transform:translateY(-2px);box-shadow:0 8px 20px rgba(88,101,242,.4)}

.hamburger-btn{background:transparent;border:none;color:var(--muted);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s;margin-left:6px;flex-shrink:0}
.hamburger-btn:hover{background:var(--s2);color:var(--text)}
.main-dropdown{position:fixed;top:68px;right:1.75rem;background:var(--s1);border:1px solid var(--border2);border-radius:14px;width:240px;z-index:1000;display:none;flex-direction:column;padding:10px;box-shadow:0 12px 40px rgba(0,0,0,.6)}
.main-dropdown.open{display:flex;animation:dropIn .2s cubic-bezier(0.25, 0.46, 0.45, 0.94)}
@keyframes dropIn{from{opacity:0;transform:translateY(-10px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.dd-item{background:transparent;border:none;color:var(--text2);text-align:left;padding:10px 14px;font-size:13.5px;font-weight:600;border-radius:9px;cursor:pointer;transition:.15s;display:flex;align-items:center;gap:12px;font-family:var(--ff-body)}
.dd-item:hover{background:var(--s2);color:var(--text);transform:translateX(2px)}
.dd-item-icon{font-size:16px;width:20px;text-align:center}
.dd-divider{height:1px;background:var(--border);margin:6px 0}
.dd-item.danger:hover{background:rgba(232,48,74,.15);color:var(--red2)}

/* ═══ LIKES / DISLIKES ══════════════════════════════════════ */
.like-bar {
  display:flex; align-items:center; gap:10px; margin:0 0 22px;
  padding:12px 16px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:12px;
}
.like-btn {
  display:inline-flex; align-items:center; gap:7px;
  background:transparent;
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);
  padding:8px 16px; border-radius:9px;
  font-family:var(--ff-body); font-size:13px; font-weight:700;
  cursor:pointer; transition:all .22s var(--ease-out);
  position:relative; overflow:hidden;
}
.like-btn:hover { transform:translateY(-2px); }
.like-btn.like-btn-up:hover  { background:rgba(34,197,94,.12); border-color:rgba(34,197,94,.4); color:#22c55e; }
.like-btn.like-btn-dn:hover  { background:rgba(232,48,74,.12); border-color:rgba(232,48,74,.4); color:var(--red2); }
.like-btn.active-up {
  background:rgba(34,197,94,.18); border-color:rgba(34,197,94,.5);
  color:#22c55e;
  box-shadow:0 4px 16px rgba(34,197,94,.25);
}
.like-btn.active-dn {
  background:rgba(232,48,74,.18); border-color:rgba(232,48,74,.5);
  color:var(--red2);
  box-shadow:0 4px 16px rgba(232,48,74,.25);
}
.like-btn svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; }
.like-btn.active-up svg, .like-btn.active-dn svg { fill:currentColor; }
.like-ratio-bar { flex:1; height:5px; background:rgba(255,255,255,.07); border-radius:4px; overflow:hidden; }
.like-ratio-fill { height:100%; background:linear-gradient(90deg,#22c55e,#16a34a); border-radius:4px; transition:width .5s var(--ease-out); }
.like-ratio-label { font-size:11px; color:rgba(255,255,255,.4); font-weight:700; white-space:nowrap; }
.like-login-hint { font-size:11px; color:rgba(255,255,255,.35); font-style:italic; margin-left:auto; }
@keyframes likePop { 0%{transform:scale(1)} 40%{transform:scale(1.25)} 100%{transform:scale(1)} }
.like-pop { animation:likePop .35s cubic-bezier(.34,1.56,.64,1); }

/* ═══════════════════════════════════════════════════
   PROFILE GATE
   ═══════════════════════════════════════════════════ */
#profileGate{position:fixed;inset:0;background:#0c0d12;z-index:9999999;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity 0.5s, visibility 0.5s}
#profileGate.gate-hidden,
#profileGate[style*="opacity: 0"]{pointer-events:none!important;visibility:hidden}
#pgProfilesRow,
.pg-profiles-row{display:flex!important;flex-direction:row!important;flex-wrap:wrap!important;justify-content:center!important;align-items:flex-start!important;gap:clamp(20px,4vw,32px)!important;max-width:920px;width:100%}
#pgVipProfiles{display:contents}
.pg-title{font-family:var(--ff-head);font-size:42px;font-weight:800;color:#fff;margin-bottom:50px;text-transform:uppercase;letter-spacing:-1px}
.pg-card{display:flex;flex-direction:column;align-items:center;gap:15px;cursor:pointer;transition:0.3s;opacity:0.6;flex:0 0 auto}
.pg-card:hover{opacity:1;transform:scale(1.05)}
.pg-avatar-box{width:140px;height:140px;border-radius:50%;overflow:hidden;border:3px solid transparent;transition:0.3s;box-shadow:0 10px 20px rgba(0,0,0,0.5)}.pg-card:hover .pg-avatar-box{border-color:#fff}
.pg-name{font-size:14px;font-weight:700;color:#fff;letter-spacing:1px;text-transform:uppercase}
.pg-manage-btn{margin-top:60px;background:rgba(247,127,0,.08);border:1px solid rgba(247,127,0,.35);color:#f77f00;padding:12px 28px;font-family:'Bebas Neue',var(--ff-head);font-size:14px;font-weight:400;letter-spacing:.1em;text-transform:uppercase;border-radius:10px;cursor:pointer;transition:0.3s;position:relative;z-index:2}
.pg-manage-btn:hover{color:#fff;background:linear-gradient(135deg,#f77f00,#ff9500);border-color:transparent;box-shadow:0 8px 28px rgba(247,127,0,.35)}
#profileManagerModal.pm-modal,.pm-modal{position:fixed;inset:0;z-index:100000050;background:rgba(0,0,0,.88);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:none;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) 16px max(16px,env(safe-area-inset-bottom))}
.pm-dialog{width:100%;max-width:520px;max-height:min(90vh,720px);overflow:hidden;display:flex;flex-direction:column;background:linear-gradient(165deg,#101010 0%,#060606 100%);border:1px solid rgba(247,127,0,.22);border-radius:20px;box-shadow:0 32px 80px rgba(0,0,0,.85),0 0 0 1px rgba(255,255,255,.04)}
.pm-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:20px 22px;border-bottom:1px solid rgba(247,127,0,.12);background:rgba(247,127,0,.04)}
.pm-head-title{font-family:'Bebas Neue',var(--ff-head);font-size:1.375rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin:0}
.pm-head-title span{color:#f77f00}
.pm-close{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:rgba(255,255,255,.65);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;padding:0;flex-shrink:0}
.pm-close:hover{color:#fff;border-color:rgba(247,127,0,.4);background:rgba(247,127,0,.12)}
.pm-body{padding:22px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.pm-intro{font-size:.8125rem;color:rgba(255,255,255,.55);line-height:1.65;text-align:center;margin:0 0 1.5rem}
.pm-intro strong{color:#f77f00;font-weight:700}
.pm-list{display:flex;flex-direction:column;gap:10px;margin-bottom:1.5rem}
.pm-profile-row{display:flex;align-items:center;gap:14px;padding:14px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:14px;transition:border-color .2s,background .2s}
.pm-profile-row:hover{background:rgba(247,127,0,.05);border-color:rgba(247,127,0,.22)}
.pm-avatar-btn{width:56px;height:56px;border-radius:50%;background:rgba(0,0,0,.5);border:2px solid rgba(247,127,0,.2);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;overflow:hidden;transition:.2s;padding:0}
.pm-avatar-btn:hover{border-color:rgba(247,127,0,.55);box-shadow:0 0 20px rgba(247,127,0,.2)}
.pm-avatar-btn img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.pm-profile-meta{flex:1;min-width:0}
.pm-profile-name{font-family:'Bebas Neue',var(--ff-head);font-size:1.0625rem;letter-spacing:.04em;color:#fff;margin-bottom:2px}
.pm-profile-tag{font-size:.625rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#f77f00}
.pm-profile-input{display:none;width:100%;background:rgba(0,0,0,.65);border:1px solid rgba(247,127,0,.35);color:#fff;padding:8px 12px;border-radius:8px;font-size:.875rem;outline:none}
.pm-row-actions{display:flex;gap:6px;flex-shrink:0}
.pm-icon-btn{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.55);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;padding:0}
.pm-icon-btn:hover{color:#fff;border-color:rgba(247,127,0,.4);background:rgba(247,127,0,.12)}
.pm-icon-btn--danger:hover{color:#ff8a8a;border-color:rgba(255,100,100,.35);background:rgba(255,80,80,.1)}
.pm-add-block{background:rgba(0,0,0,.35);border:1px dashed rgba(247,127,0,.28);border-radius:16px;padding:1.75rem 1.25rem;text-align:center;display:flex;flex-direction:column;align-items:center}
.pm-add-avatar{width:72px;height:72px;margin:0 auto 1rem;border-radius:50%;background:rgba(247,127,0,.06);border:2px solid rgba(247,127,0,.25);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:.2s;padding:0}
.pm-add-avatar:hover{transform:translateY(-2px);border-color:rgba(247,127,0,.5);box-shadow:0 8px 24px rgba(247,127,0,.2)}
.pm-add-avatar img,.pm-add-avatar svg{width:100%;height:100%;object-fit:cover;border-radius:50%}
.pm-add-title{font-family:'Bebas Neue',var(--ff-head);font-size:1.0625rem;letter-spacing:.06em;color:#fff;margin-bottom:.875rem}
.pm-input{width:100%;max-width:320px;margin:0 auto 1rem;display:block;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.1);color:#fff;padding:13px 16px;border-radius:10px;font-size:.875rem;text-align:center;outline:none;transition:.2s;-webkit-appearance:none;appearance:none}
.pm-input:focus{border-color:rgba(247,127,0,.45);background:rgba(0,0,0,.75);box-shadow:0 0 0 2px rgba(247,127,0,.15)}
.pm-input::placeholder{color:rgba(255,255,255,.35)}
.pm-btn-primary{background:linear-gradient(135deg,#f77f00,#ff9500);color:#fff!important;border:none;padding:12px 28px;border-radius:10px;font-family:'Bebas Neue',var(--ff-head);font-size:.9375rem;letter-spacing:.08em;cursor:pointer;transition:.2s;box-shadow:0 8px 24px rgba(247,127,0,.35);display:inline-block;width:auto;max-width:100%}
.pm-btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(247,127,0,.45)}
.pm-limit-msg{text-align:center;padding:1rem;border-radius:12px;background:rgba(247,127,0,.06);border:1px solid rgba(247,127,0,.18);color:rgba(255,255,255,.55);font-size:.875rem;margin:0}
.am-modal{position:fixed;inset:0;z-index:100000060;background:rgba(0,0,0,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:none;align-items:center;justify-content:center;padding:16px}
.am-dialog{width:100%;max-width:560px;max-height:85vh;background:#0a0a0a;border:1px solid rgba(247,127,0,.2);border-radius:18px;overflow:hidden;display:flex;flex-direction:column}
.am-head{position:relative;display:flex;align-items:center;justify-content:center;padding:16px 48px;border-bottom:1px solid rgba(247,127,0,.12);font-family:'Bebas Neue',var(--ff-head);font-size:1.125rem;letter-spacing:.08em;color:#fff;text-transform:uppercase}
.am-head span{color:#f77f00}
.am-close{position:absolute;right:14px;top:50%;transform:translateY(-50%)}
.am-body{padding:18px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.am-category{font-family:'Bebas Neue',var(--ff-head);color:#f77f00;margin:0 0 10px;font-size:1rem;letter-spacing:.06em;text-transform:uppercase}
.am-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px;margin-bottom:1.25rem}
.am-grid img{width:100%;aspect-ratio:1;border-radius:50%;cursor:pointer;object-fit:cover;border:2px solid transparent;background:#111;transition:.18s}
.am-grid img:hover{border-color:#f77f00;transform:scale(1.05)}
body.profile-manager-open .mobile-bottom-bar,body.profile-gate-open .mobile-bottom-bar,body.player-open .mobile-bottom-bar{display:none!important}

/* ═══════════════════════════════════════════════════
   MY LIST FAB
   ═══════════════════════════════════════════════════ */
.my-list-fab{position:fixed;bottom:26px;right:20px;z-index:150;background:var(--red);border-radius:11px;padding:11px 20px;display:flex;gap:8px;font-weight:700;border:none;color:#fff;font-size:13px;box-shadow:0 5px 22px rgba(232,48,74,.38);transition:.18s}
.my-list-fab:hover{background:#c02040;transform:translateY(-2px)}

/* ═══════════════════════════════════════════════════
   VIP PAGE
   ═══════════════════════════════════════════════════ */

/* VIP modal — voir premium-modal.css */

/* ── Bannière Premium (accueil) ── */
.premium-banner{
  margin:20px 30px;
  border-radius:var(--r2);
  padding:28px 32px;
  background:var(--s1);
  border:1px solid rgba(245,166,35,.2);
  box-shadow:0 8px 32px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.04);
  position:relative;
  overflow:hidden;
}
.premium-banner::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 75% 85% at 100% 15%,rgba(245,166,35,.14),transparent 55%),
    radial-gradient(ellipse 55% 65% at 0% 100%,rgba(232,48,74,.07),transparent 50%);
  pointer-events:none;
}
.premium-banner-grid{
  display:grid;
  grid-template-columns:1fr minmax(240px,360px);
  gap:28px 40px;
  align-items:center;
  position:relative;
  z-index:1;
}
.premium-banner-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--gold2);
  margin-bottom:10px;
}
.premium-banner-title{
  font-family:var(--ff-head);
  font-size:clamp(24px,3vw,30px);
  font-weight:800;
  margin:0 0 6px;
  letter-spacing:-.5px;
  background:linear-gradient(135deg,#f5a623,#ffd60a);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.premium-banner-kicker{
  font-size:11px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 20px;
}
.premium-banner-features{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px 24px;
  list-style:none;
  margin:0 0 24px;
  padding:0;
}
.premium-banner-features li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:13px;
  line-height:1.45;
  color:rgba(255,255,255,.88);
}
.premium-banner-check{
  flex-shrink:0;
  width:22px;
  height:22px;
  border-radius:6px;
  background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.28);
  color:#4ade80;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-top:1px;
}
.premium-banner-feature-soon strong{color:var(--gold2);font-weight:700}
.premium-banner-soon{
  font-size:10px;
  font-weight:700;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:var(--muted);
  margin-left:4px;
}
.premium-banner-cta{
  background:linear-gradient(135deg,#e85d04,#f5a623 55%,#ffd60a);
  border:none;
  color:#1a1a2e;
  font-weight:800;
  padding:14px 28px;
  border-radius:50px;
  cursor:pointer;
  font-size:13px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  transition:transform .22s var(--ease-out),box-shadow .22s;
  box-shadow:0 4px 18px rgba(232,93,4,.28);
  font-family:var(--ff-body);
  max-width:320px;
  width:100%;
}
.premium-banner-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(232,93,4,.42);
}
.premium-banner-visual{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.premium-banner-price-card{
  background:linear-gradient(145deg,rgba(245,166,35,.1),rgba(232,48,74,.05));
  border:1px solid rgba(245,166,35,.25);
  border-radius:16px;
  padding:22px 20px;
  text-align:center;
}
.premium-banner-crown{
  width:48px;
  height:48px;
  margin:0 auto 10px;
  border-radius:12px;
  background:rgba(245,166,35,.15);
  border:1px solid rgba(245,166,35,.3);
  color:var(--gold2);
  display:flex;
  align-items:center;
  justify-content:center;
}
.premium-banner-price{
  font-family:'Outfit',sans-serif;
  font-size:52px;
  font-weight:800;
  font-style:italic;
  line-height:1;
  background:linear-gradient(135deg,#fff 30%,#f5a623 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.premium-banner-price-sub{
  font-size:13px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  margin-top:4px;
}
.premium-banner-price-note{
  font-size:11px;
  color:var(--muted);
  margin:10px 0 0;
}
.premium-banner-perks{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.premium-banner-perk{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:12px;
  padding:14px 10px;
  text-align:center;
  transition:border-color .2s,background .2s;
}
.premium-banner-perk:hover{
  background:rgba(255,255,255,.05);
  border-color:rgba(245,166,35,.2);
}
.premium-banner-perk-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  margin:0 auto 8px;
  border-radius:9px;
  background:rgba(245,166,35,.1);
  border:1px solid rgba(245,166,35,.22);
  color:var(--gold2);
}
.premium-banner-perk-label{
  display:block;
  font-size:11px;
  font-weight:700;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:rgba(255,255,255,.75);
}
@media(max-width:860px){
  .premium-banner-grid{grid-template-columns:1fr;gap:24px}
  .premium-banner-visual{max-width:400px}
  .premium-banner-cta{max-width:none}
}
@media(max-width:560px){
  .premium-banner{margin:16px 16px;padding:22px 20px}
  .premium-banner-features{grid-template-columns:1fr;gap:10px}
}

/* paypal shine — voir premium-modal.css */

.vip-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:68vh;padding:3rem 2rem;text-align:center;position:relative;overflow:hidden}
.vip-bg-slider{position:absolute;inset:0;z-index:0}
.vip-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;animation:vipSlideAnim 24s infinite linear}
.vip-slide:nth-child(1){animation-delay:0s}
.vip-slide:nth-child(2){animation-delay:6s}
.vip-slide:nth-child(3){animation-delay:12s}
.vip-slide:nth-child(4){animation-delay:18s}
@keyframes vipSlideAnim{0%{opacity:0;transform:scale(1)}10%{opacity:0.35}25%{opacity:0.35}35%{opacity:0;transform:scale(1.12)}100%{opacity:0;transform:scale(1)}}
.vip-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,var(--bg) 0%,rgba(7,7,15,0.6) 40%,var(--bg) 100%)}
.vip-icon{font-size:64px;margin-bottom:18px}
.vip-title{font-family:var(--ff-head);font-size:36px;font-weight:800;margin-bottom:14px;letter-spacing:-.5px}
.vip-sub{color:var(--text2);font-size:15px;line-height:1.7;margin-bottom:32px;max-width:520px}
.vip-card{background:var(--s1);border:1px solid var(--border2);border-radius:18px;padding:28px;max-width:520px;width:100%}
.vip-steps{display:flex;flex-direction:column;gap:14px;margin-bottom:24px;text-align:left}
.vip-step{display:flex;align-items:center;gap:14px;color:var(--text2);font-size:14px}
.vip-num{width:32px;height:32px;border-radius:50%;background:rgba(245,166,35,.15);border:1px solid rgba(245,166,35,.4);color:var(--gold2);display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}

.discord-btn{display:inline-flex;align-items:center;gap:11px;background:#5865F2;color:#fff;font-size:16px;font-weight:700;padding:14px 32px;border-radius:11px;border:none;transition:.18s;cursor:pointer;font-family:var(--ff-body)}
.discord-btn:hover{background:#4752c4;transform:translateY(-2px)}

/* ═══════════════════════════════════════════════════
   SKELETON
   ═══════════════════════════════════════════════════ */
.skeleton {
  background: linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);
  background-size: 200% 100%;
  animation: sk 1.5s infinite;
  border-radius: var(--r);
  flex: 0 0 200px; /* au lieu de 184px */
  height: 300px;   /* au lieu de 272px */
}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-grid{height:240px;border-radius:var(--r)}

/* ═══════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════ */
.site-footer{margin-top:5rem;padding:4rem 2.5rem 1.5rem;border-top:1px solid rgba(255,255,255,.05);background:linear-gradient(180deg,var(--bg) 0%,#050509 100%);color:var(--muted);font-size:13px;line-height:1.6;position:relative}
.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(247,127,0,.35),rgba(255,149,0,.25),rgba(247,127,0,.35),transparent)}
.footer-content{max-width:1280px;margin:0 auto 3rem;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem}
.footer-brand .footer-logo{font-family:var(--ff-head);font-size:30px;font-weight:800;color:#fff;letter-spacing:-1.2px;margin-bottom:14px}
.footer-brand .footer-logo .logo-accent{color:#f77f00}
.footer-tagline{color:var(--text2);font-size:13.5px;line-height:1.7;max-width:340px;margin-bottom:20px}
.footer-socials{display:flex;gap:10px}
.social-btn{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:var(--text2);display:flex;align-items:center;justify-content:center;transition:all .25s var(--ease-out);cursor:pointer}
.social-btn:hover{transform:translateY(-3px);border-color:transparent}
.social-discord:hover{background:#5865F2;color:#fff;box-shadow:0 8px 22px rgba(88,101,242,.4)}
.social-tiktok:hover{background:linear-gradient(135deg,#69C9D0,#EE1D52);color:#fff;box-shadow:0 8px 22px rgba(238,29,82,.4)}
.footer-section h4{color:#fff;font-family:var(--ff-head);font-size:14px;font-weight:700;margin-bottom:18px;letter-spacing:.3px;position:relative;padding-bottom:12px}
.footer-section h4::after{content:'';position:absolute;bottom:0;left:0;width:24px;height:2px;background:linear-gradient(90deg,#f77f00,#ff9500);border-radius:2px}
.footer-links{display:flex;flex-direction:column;gap:11px}
.footer-links a{display:flex;align-items:center;gap:10px;color:var(--text2);font-size:13px;font-weight:500;text-decoration:none;transition:all .2s var(--ease-out);cursor:pointer}
.footer-links a svg{width:14px;height:14px;opacity:.65;flex-shrink:0;transition:.2s}
.footer-links a:hover{color:#fff;transform:translateX(4px)}
.footer-links a:hover svg{opacity:1;color:#f77f00}
.footer-disclaimer{max-width:1280px;margin:0 auto 2rem;padding:18px 22px;background:linear-gradient(135deg,rgba(247,127,0,.06),rgba(255,149,0,.03));border:1px solid rgba(247,127,0,.18);border-radius:14px;display:flex;gap:14px;align-items:flex-start;font-size:12.5px;color:var(--text2);line-height:1.65}
.footer-disclaimer-icon{width:38px;height:38px;border-radius:10px;background:rgba(247,127,0,.1);border:1px solid rgba(247,127,0,.22);color:#f77f00;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.footer-disclaimer strong{color:#ff9500}
.footer-disclaimer a{color:#f77f00;text-decoration:none;font-weight:600}
.footer-disclaimer a:hover{text-decoration:underline}
.footer-bottom{max-width:1280px;margin:0 auto;border-top:1px solid rgba(255,255,255,.05);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-copyright{font-size:12.5px;color:var(--text2)}
.footer-copyright strong{color:#fff;font-weight:700}
.footer-bottom-links{display:flex;gap:14px;align-items:center;font-size:12.5px}
.footer-bottom-links a{color:var(--text2);text-decoration:none;font-weight:500;transition:color .2s;cursor:pointer}
.footer-bottom-links a:hover{color:#fff}
.footer-sep{color:rgba(255,255,255,.15)}

/* --- OPTIMISATIONS MOBILE (SWIPE & CATALOGUES) --- */
@media (max-width: 768px) {
    /* 1. On cache les flèches de navigation sur téléphone car on utilise le doigt */
    .row-btn {
        display: none !important;
    }
    
    /* 2. On rend le défilement fluide et "magnétique" (comme une vraie appli) */
    .row-inner {
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        padding-left: 4%; /* Marge pour le premier élément */
        padding-right: 4%;
        scroll-padding-left: 4%;
    }
    
    .movie-card {
        scroll-snap-align: start; /* Les cartes s'alignent parfaitement quand on swipe */
    }
}

/* ═══════════════════════════════════════════════════
   LEGAL MODALS
   ═══════════════════════════════════════════════════ */
.legal-modal{position:fixed;inset:0;z-index:99998;background:rgba(0,0,0,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:none;align-items:center;justify-content:center;padding:20px;animation:legalFadeIn .25s ease}
.legal-modal.open{display:flex}
@keyframes legalFadeIn{from{opacity:0}to{opacity:1}}
.legal-box{background:#0a0a0a;border:1px solid rgba(247,127,0,.18);border-radius:16px;width:100%;max-width:720px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.85),0 0 0 1px rgba(255,255,255,.03) inset;animation:legalSlideIn .35s var(--ease-out);overflow:hidden}
@keyframes legalSlideIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.legal-header{padding:18px 22px;border-bottom:1px solid rgba(247,127,0,.12);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;gap:12px}
.legal-title{display:flex;align-items:center;gap:14px;min-width:0}
.legal-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:linear-gradient(135deg,#f77f00,#ff9500);box-shadow:0 6px 18px rgba(247,127,0,.25)}
.legal-icon svg{display:block}
.legal-title-main{font-family:'Bebas Neue',var(--ff-head);font-size:22px;font-weight:400;color:#fff;letter-spacing:.07em;text-transform:uppercase;line-height:1.1}
.legal-title-sub{font-size:11px;color:rgba(255,255,255,.42);margin-top:4px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.legal-close-btn{flex-shrink:0;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.08);border-radius:8px;width:36px;height:36px}
.legal-close-btn:hover{color:#f77f00;border-color:rgba(247,127,0,.35);background:rgba(247,127,0,.08)}
.legal-body{flex:1;overflow-y:auto;padding:22px 24px 26px;scrollbar-width:thin}
.legal-body::-webkit-scrollbar{width:5px}
.legal-body::-webkit-scrollbar-thumb{background:rgba(247,127,0,.25);border-radius:3px}
.legal-lead{font-size:14px;color:rgba(255,255,255,.78);line-height:1.7;margin:0 0 22px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.06)}
.legal-meta{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(247,127,0,.85);margin-bottom:8px}
.legal-section{margin-bottom:22px;padding:0}
.legal-section:last-child{margin-bottom:0}
.legal-section-title{font-family:'Bebas Neue',var(--ff-head);font-size:15px;font-weight:400;color:#f77f00;margin:0 0 10px;letter-spacing:.08em;text-transform:uppercase;line-height:1.3}
.legal-section p{color:rgba(255,255,255,.62);font-size:14px;line-height:1.72;margin:0 0 10px}
.legal-section p:last-child{margin-bottom:0}
.legal-section p strong,.legal-section li strong{color:rgba(255,255,255,.92);font-weight:600}
.legal-section a{color:#ff9500;text-decoration:none;font-weight:600;border-bottom:1px solid rgba(255,149,0,.25);transition:color .2s,border-color .2s}
.legal-section a:hover{color:#f77f00;border-bottom-color:rgba(247,127,0,.55)}
.legal-list{margin:10px 0 0;padding:0;list-style:none}
.legal-list li{color:rgba(255,255,255,.62);font-size:14px;line-height:1.65;padding:8px 0 8px 18px;position:relative;border-bottom:1px solid rgba(255,255,255,.04)}
.legal-list li:last-child{border-bottom:none;padding-bottom:0}
.legal-list li::before{content:'';position:absolute;left:0;top:15px;width:5px;height:5px;border-radius:50%;background:#f77f00}
ol.legal-list{counter-reset:legal}
ol.legal-list li{padding-left:28px}
ol.legal-list li::before{counter-increment:legal;content:counter(legal);width:18px;height:18px;border-radius:5px;background:rgba(247,127,0,.18);border:1px solid rgba(247,127,0,.35);color:#f77f00;font-size:10px;font-weight:700;font-family:var(--ff-body);display:flex;align-items:center;justify-content:center;top:10px}
.legal-callout{padding:14px 16px;border-radius:10px;font-size:13px;line-height:1.65;margin:12px 0 0;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02);color:rgba(255,255,255,.62)}
.legal-callout strong{display:block;color:#fff;font-family:'Bebas Neue',var(--ff-head);font-size:13px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}
.legal-callout-accent{background:rgba(247,127,0,.06);border-color:rgba(247,127,0,.22)}
.legal-callout-accent strong{color:#f77f00}
.legal-callout-warning{background:rgba(247,127,0,.04);border-color:rgba(247,127,0,.18)}
.legal-callout-warning strong{color:#ff9500}
.legal-callout-neutral{background:rgba(255,255,255,.02);border-color:rgba(255,255,255,.08)}
.legal-callout-info{background:rgba(247,127,0,.04);border-color:rgba(247,127,0,.15)}
.legal-callout-info strong{color:#f77f00}
.legal-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.legal-contact-card{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:14px;display:flex;gap:12px;align-items:flex-start;transition:border-color .2s,background .2s}
.legal-contact-card:hover{border-color:rgba(247,127,0,.28);background:rgba(247,127,0,.04)}
.legal-contact-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(247,127,0,.12);border:1px solid rgba(247,127,0,.22)}
.legal-contact-icon--discord{background:rgba(88,101,242,.15);border-color:rgba(88,101,242,.28)}
.legal-contact-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.legal-contact-info strong{font-size:13px;font-weight:600;color:#fff;letter-spacing:.01em}
.legal-contact-info span{font-size:12px;color:rgba(255,255,255,.42);line-height:1.45}
.legal-contact-link{font-size:12px;color:#ff9500;font-weight:600;margin-top:4px;text-decoration:none;letter-spacing:.02em}
.legal-contact-link:hover{color:#f77f00;text-decoration:underline}
.legal-footer{padding:14px 22px;border-top:1px solid rgba(247,127,0,.1);background:rgba(0,0,0,.45);display:flex;gap:10px;justify-content:flex-end;flex-shrink:0}
.legal-footer .btn-primary{background:linear-gradient(135deg,#f77f00,#ff9500);border:none;box-shadow:0 6px 20px rgba(247,127,0,.25)}
.legal-footer .btn-primary:hover{box-shadow:0 8px 24px rgba(247,127,0,.38)}
.legal-footer .btn-secondary{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.75)}
.legal-footer .btn-secondary:hover{border-color:rgba(247,127,0,.25);color:#fff}

/* FAQ — voir faq-ui.css */

/* ═══════════════════════════════════════════════════
   DASHBOARD
   ═══════════════════════════════════════════════════ */
.dash-wrap{padding:100px 3rem 4rem;min-height:100vh;background:var(--bg);max-width:1400px;margin:0 auto}
.dash-nav{display:flex;gap:30px;border-bottom:1px solid var(--border);padding-bottom:15px;margin-bottom:25px;overflow-x:auto;scrollbar-width:none}
.dash-nav::-webkit-scrollbar{display:none}
.dash-tab{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:14px;font-weight:700;cursor:pointer;transition:0.2s;position:relative;white-space:nowrap;text-transform:uppercase;letter-spacing:0.5px}
.dash-tab:hover,.dash-tab.active{color:#fff}
.dash-tab.active::after{content:'';position:absolute;bottom:-16px;left:0;right:0;height:3px;background:var(--red);border-radius:3px 3px 0 0}
.dash-tab-count{background:rgba(255,255,255,0.1);padding:2px 8px;border-radius:10px;font-size:11px;color:#fff}
.dash-toolbar{display:flex;gap:15px;margin-bottom:30px;flex-wrap:wrap}
.dash-search{flex:1;display:flex;align-items:center;gap:10px;background:var(--s2);border:1px solid var(--border2);padding:12px 20px;border-radius:12px}
.dash-search input{background:none;border:none;color:#fff;width:100%;font-size:14px}
.dash-filter-btn{background:var(--s2);border:1px solid var(--border2);color:#fff;padding:0 20px;border-radius:12px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;transition:0.2s;cursor:pointer}
.dash-filter-btn:hover{background:var(--s3)}
.dash-empty{background:var(--s1);border-radius:20px;border:1px solid var(--border);padding:80px 20px;text-align:center}
.dash-empty-icon{font-size:60px;color:var(--s3);margin-bottom:20px}
.dash-empty-title{font-family:var(--ff-head);font-size:24px;font-weight:800;color:#fff;margin-bottom:10px}
.dash-empty-sub{color:var(--muted);font-size:14px;margin-bottom:30px}

/* ═══════════════════════════════════════════════════
   SETTINGS MODAL — refonte sobre (icônes SVG, sans emojis)
   ═══════════════════════════════════════════════════ */
.settings-modal{position:fixed;inset:0;z-index:9999;background:rgba(5,5,12,.78);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .28s var(--ease-out);padding:20px}
.settings-modal.open{opacity:1;pointer-events:all}
.settings-box{background:var(--s1);border:1px solid var(--border2);border-radius:20px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.55);transform:translateY(12px) scale(.98);transition:transform .32s var(--ease-out),opacity .28s var(--ease-out);overflow:hidden}
.settings-modal.open .settings-box{transform:translateY(0) scale(1)}
.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px 22px 18px;border-bottom:1px solid var(--border);flex-shrink:0}
.settings-title{font-family:var(--ff-head);font-size:18px;font-weight:700;display:flex;align-items:center;gap:14px;color:#fff;letter-spacing:-.02em}
.settings-title-sub{font-size:12px;color:var(--muted);font-weight:500;margin-top:3px;font-family:var(--ff-body);letter-spacing:0;text-transform:none}
.settings-title-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.05);border:1px solid var(--border2);color:var(--text2)}
.settings-title-icon .set-svg{width:18px;height:18px}
.settings-tabs{display:flex;gap:0;padding:0 18px;border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;flex-shrink:0}
.settings-tabs::-webkit-scrollbar{display:none}
.settings-tab{display:flex;align-items:center;gap:7px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);padding:13px 12px;margin-bottom:-1px;font-size:12px;font-weight:600;cursor:pointer;transition:color .2s,border-color .2s;font-family:var(--ff-body);white-space:nowrap}
.settings-tab:hover{color:var(--text2)}
.settings-tab.active{color:#fff;border-bottom-color:var(--red)}
.settings-tab.active::after{display:none}
.settings-tab-ico{display:flex;color:var(--muted);opacity:.85;transition:color .2s}
.settings-tab.active .settings-tab-ico{color:var(--red2);opacity:1}
.settings-tab-ico .set-svg{width:15px;height:15px}
.settings-body{flex:1;overflow-y:auto;padding:16px 18px 20px;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:var(--s4) transparent}
.settings-body::-webkit-scrollbar{width:5px}
.settings-body::-webkit-scrollbar-thumb{background:var(--s4);border-radius:3px}
.settings-pane{display:none;flex-direction:column;gap:12px;animation:settingsFade .28s ease}
.settings-pane.active{display:flex}
@keyframes settingsFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.settings-card{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:14px;padding:16px 18px;position:relative;transition:border-color .2s}
.settings-card:hover{border-color:rgba(255,255,255,.12)}
.settings-card-title{display:flex;align-items:center;gap:10px;font-family:var(--ff-head);font-size:13px;font-weight:700;color:#fff;margin-bottom:2px;letter-spacing:-.01em}
.settings-card-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text2)}
.settings-card-desc{font-size:12px;color:var(--muted);margin-bottom:14px;line-height:1.55}
.settings-profile-card{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.025);border-color:var(--border2)}
.settings-profile-avatar{width:52px;height:52px;border-radius:12px;overflow:hidden;border:1px solid var(--border2);flex-shrink:0}
.settings-profile-avatar img{width:100%;height:100%;object-fit:cover}
.settings-profile-name{font-family:var(--ff-head);font-size:14px;font-weight:700;color:#fff;letter-spacing:-.01em;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:none}
.settings-profile-role{display:inline-block;font-size:10px;font-weight:700;background:rgba(232,48,74,.1);border:1px solid rgba(232,48,74,.22);color:var(--red2);padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.06em}
.settings-mini-btn{display:flex;align-items:center;gap:7px;background:transparent;border:1px solid var(--border2);color:var(--text2);padding:8px 12px;border-radius:10px;font-size:11.5px;font-weight:600;cursor:pointer;transition:.18s;font-family:var(--ff-body);flex-shrink:0}
.settings-mini-btn:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.16);color:#fff}
.settings-row{display:flex;align-items:center;justify-content:space-between;gap:14px}
.settings-row-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.settings-row-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text2)}
.settings-row-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.settings-row-desc{font-size:11.5px;color:var(--muted);line-height:1.45}
.settings-divider{height:1px;background:var(--border);margin:13px 0}
.settings-switch{position:relative;width:44px;height:24px;cursor:pointer;flex-shrink:0}
.settings-switch input{opacity:0;width:0;height:0}
.settings-switch-track{position:absolute;inset:0;background:var(--s3);border-radius:999px;transition:.22s var(--ease-out);border:1px solid var(--border)}
.settings-switch-track::before{content:'';position:absolute;left:2px;top:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:.22s var(--ease-out);box-shadow:0 1px 4px rgba(0,0,0,.25)}
.settings-switch input:checked + .settings-switch-track{background:var(--red);border-color:transparent}
.settings-switch input:checked + .settings-switch-track::before{left:22px}
.settings-theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.settings-theme-card{position:relative;background:var(--s2);border:1px solid var(--border);border-radius:12px;padding:10px 8px;cursor:pointer;transition:border-color .2s,background .2s;text-align:center}
.settings-theme-card:hover{border-color:rgba(255,255,255,.16)}
.settings-theme-card.active{border-color:var(--c1,var(--red));background:rgba(255,255,255,.03);box-shadow:0 0 0 1px var(--c1,var(--red))}
.settings-theme-preview{width:100%;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--c1,#e8304a),var(--c2,#c02040));margin-bottom:8px}
.settings-theme-name{font-size:10.5px;font-weight:600;color:var(--text2);letter-spacing:.03em}
.settings-theme-card.active .settings-theme-name{color:#fff}
.settings-theme-check{position:absolute;top:6px;right:6px;width:18px;height:18px;border-radius:50%;background:var(--c1,var(--red));color:#fff;display:none;align-items:center;justify-content:center}
.settings-theme-card.active .settings-theme-check{display:flex}
.settings-theme-check .set-svg{width:10px;height:10px;stroke-width:3}
.settings-segmented{display:flex;background:var(--s2);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}
.settings-seg-btn{flex:1;background:transparent;border:none;color:var(--muted);padding:9px 10px;border-radius:8px;font-size:11.5px;font-weight:600;cursor:pointer;transition:.18s;font-family:var(--ff-body)}
.settings-seg-btn:hover{color:var(--text)}
.settings-seg-btn.active{background:var(--s3);color:#fff;box-shadow:inset 0 0 0 1px var(--border2)}
.settings-select{width:100%;background:var(--s2);border:1px solid var(--border2);color:#fff;padding:11px 16px;border-radius:10px;font-family:var(--ff-body);font-size:13px;font-weight:600;cursor:pointer;outline:none;transition:border-color .2s;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a8a6be' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.settings-select:focus{border-color:var(--red)}
.settings-vol-display{text-align:center;font-family:var(--ff-head);font-size:32px;font-weight:700;color:#fff;letter-spacing:-.03em}
.settings-quick-actions{display:flex;gap:6px;flex-wrap:wrap}
.settings-chip{background:var(--s2);border:1px solid var(--border);color:var(--text2);padding:7px 12px;border-radius:8px;font-size:11px;font-weight:600;cursor:pointer;transition:.18s;font-family:var(--ff-body)}
.settings-chip:hover{background:var(--s3);border-color:var(--border2);color:#fff}
.settings-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:6px}
.settings-stat{background:var(--s2);border:1px solid var(--border);border-radius:10px;padding:12px 6px;text-align:center}
.settings-stat-n{font-family:var(--ff-head);font-size:20px;font-weight:700;color:#fff;line-height:1}
.settings-stat-l{font-size:9.5px;color:var(--muted);margin-top:5px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.settings-action-list{display:flex;flex-direction:column;gap:6px}
.settings-action-btn{display:flex;align-items:center;gap:12px;width:100%;background:var(--s2);border:1px solid var(--border);padding:12px 14px;border-radius:11px;cursor:pointer;transition:.18s;color:var(--text);font-family:var(--ff-body)}
.settings-action-btn:hover{background:var(--s3);border-color:var(--border2)}
.settings-action-ico{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text2)}
.settings-action-danger:hover{background:rgba(232,48,74,.06);border-color:rgba(232,48,74,.25)}
.settings-action-chevron{color:var(--muted);flex-shrink:0;display:flex}
.settings-about-hero{text-align:center;padding:22px 16px;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:14px}
.settings-about-logo{font-family:var(--ff-head);font-size:28px;font-weight:700;color:#fff;letter-spacing:-.04em;margin-bottom:6px}
.settings-about-version{font-size:10.5px;color:var(--muted);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.settings-about-desc{font-size:12.5px;color:var(--text2);line-height:1.65;max-width:380px;margin:0 auto}
.settings-about-links{display:flex;flex-direction:column;gap:6px}
.settings-link-btn{display:flex;align-items:center;gap:12px;background:var(--s2);border:1px solid var(--border);padding:10px 14px;border-radius:11px;cursor:pointer;transition:.18s;text-decoration:none;color:var(--text)}
.settings-link-btn:hover{background:var(--s3);border-color:var(--border2)}
.settings-link-ico{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.settings-link-chevron{color:var(--muted);display:flex;flex-shrink:0}
.settings-footer{padding:14px 18px;border-top:1px solid var(--border);background:rgba(0,0,0,.18);display:flex;gap:10px;flex-shrink:0}
.settings-btn-ghost{display:inline-flex;align-items:center;gap:7px;background:transparent;border:1px solid var(--border2);color:var(--text2);padding:10px 16px;border-radius:10px;font-size:12.5px;font-weight:600;cursor:pointer;transition:.18s;font-family:var(--ff-body)}
.settings-btn-ghost:hover{background:rgba(255,255,255,.04);color:#fff}
.settings-save-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--red);color:#fff;border:none;padding:11px 20px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s,transform .2s;font-family:var(--ff-body)}
.settings-save-btn:hover{background:var(--red2);transform:translateY(-1px)}
.set-svg{display:block;flex-shrink:0}
.settings-card-icon .set-svg,.settings-row-icon .set-svg,.settings-action-ico .set-svg,.settings-link-ico .set-svg:not([width]){width:16px;height:16px}
.vol-ctrl{display:flex;align-items:center;gap:12px}
.vol-btn{width:40px;height:40px;border-radius:10px;background:var(--s2);border:1px solid var(--border2);color:var(--text2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s;flex-shrink:0}
.vol-btn:hover{background:var(--s3);border-color:rgba(255,255,255,.14);color:#fff}
.vol-slider{-webkit-appearance:none;flex:1;height:6px;background:linear-gradient(90deg,var(--red) var(--vol-pct,55%),var(--s3) var(--vol-pct,55%));border-radius:999px;outline:none}
.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 8px rgba(232,48,74,.6);border:3px solid var(--red);transition:.2s}
.vol-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════ */
@media(max-width:880px){
  .film-detail-layout{grid-template-columns:1fr;margin-top:-100px;gap:1.5rem}
  .film-poster-side{position:relative;top:0;max-width:240px;margin:0 auto}
  .film-info-side{padding-top:0;text-align:center}
  .film-tagline{border-left:none;padding-left:0}
  .film-meta-row,.film-genres-row,.film-actions-row{justify-content:center}
  .modal-hero{height:420px !important}
  .saga-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
  .episodes-grid-pro{grid-template-columns:1fr}
  .film-trailer-play-btn{width:64px;height:64px}
  .film-trailer-play-btn svg{width:22px;height:22px}
}

@media(max-width:780px){
  .footer-content{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-brand{grid-column:1/-1}
  .legal-contact-grid{grid-template-columns:1fr}
  .legal-box{max-height:95vh}
  .faq-container{grid-template-columns:1fr;gap:36px}
}

@media(max-width:768px){
  nav{padding:0 1rem;height:60px}
  .hero{height:70vh;min-height:480px;margin-top:0;padding-top:60px}
  .hero-title{font-size:38px;letter-spacing:-1.3px}
  .hero-title.hero-title-logo img{max-height:clamp(52px, 18vw, 100px);max-width:95%}
  .hero-title.hero-title-w500 img{max-height:clamp(96px, 32vw, 180px);max-width:126px;border-radius:10px}
  .hero-content{left:1.2rem;bottom:90px;max-width:calc(100% - 2.4rem)}
  .hero-desc{font-size:14px}
  .hero-dots{left:1.2rem;bottom:24px}
  .section{padding:.6rem 1rem 1.5rem}
  .studio-bar{padding:1rem;gap:10px}
  .studio-card{padding:14px 22px;min-width:120px;min-height:64px}
  .movies-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:18px 12px;padding:1rem}
  .card{flex:0 0 148px;width:148px}
  .card-img{height:222px}
  .card-trending{flex:0 0 168px!important;width:168px!important;margin-left:0!important}
  .card-trending .card-img{height:252px!important}
  .modal-body{padding:0 1.1rem 3rem}
  .modal-title{font-size:34px}
}

@media(max-width:560px){
  .settings-modal{padding:0}
  .settings-box{max-width:100%;max-height:100vh;height:100vh;border-radius:0}
  .settings-theme-grid{grid-template-columns:repeat(2,1fr)}
  .settings-stats-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:520px){
  .footer-content{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .legal-header{padding:16px 18px}
  .legal-body{padding:18px}
  .legal-footer{padding:14px 18px;flex-direction:column-reverse}
  .legal-footer .btn{width:100%;justify-content:center}
}

/* STAFF NAV BUTTON */
.nav-link-staff{font-size:13px;font-weight:700;color:var(--gold2);padding:6px 13px;border-radius:8px;border:1px solid rgba(245,166,35,.3);background:rgba(245,166,35,.08);transition:all .18s;white-space:nowrap;display:none}
.nav-link-staff:hover{background:rgba(245,166,35,.18);border-color:rgba(245,166,35,.6)}

/* ── SORTIES CETTE SEMAINE ── */
.releases-page{padding:90px 2.5rem 4rem;min-height:100vh;max-width:1400px;margin:0 auto}
.releases-title{font-family:var(--ff-head);font-size:30px;font-weight:800;letter-spacing:-1px;color:#fff;margin-bottom:8px}
.releases-subtitle{color:var(--text2);font-size:14px;margin-bottom:1.8rem}
.releases-nav{display:flex;align-items:center;gap:12px;margin-bottom:2rem;flex-wrap:wrap}
.releases-week-label{font-family:var(--ff-head);font-size:14px;font-weight:700;color:var(--text2);flex:1;text-align:center}
.releases-day-section{margin-bottom:2.5rem}
.releases-day-header{display:flex;align-items:center;gap:12px;margin-bottom:1.2rem;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06);flex-wrap:wrap}
.releases-day-name{font-family:var(--ff-head);font-size:18px;font-weight:800;color:#fff}
.releases-day-date{font-size:13px;color:var(--muted)}
.releases-today-badge{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:10px;font-weight:800;padding:3px 9px;border-radius:5px;text-transform:uppercase;box-shadow:0 4px 12px rgba(34,197,94,.35)}
.releases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:18px}
.releases-card{cursor:pointer;border-radius:12px;overflow:hidden;background:var(--s1);border:1px solid rgba(255,255,255,.05);transition:all .3s var(--ease-out);position:relative}
.releases-card:hover{transform:translateY(-7px);border-color:rgba(247,127,0,.3);box-shadow:0 22px 44px rgba(0,0,0,.6),0 0 28px rgba(247,127,0,.15)}
.releases-card-img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;transition:transform .4s}
.releases-card:hover .releases-card-img{transform:scale(1.05)}
.releases-card-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;color:#0a0a0f;font-size:14px;opacity:0;transition:.3s var(--ease-spring)}
.releases-card:hover .releases-card-play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.releases-card-over{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.8) 0%,transparent 50%);opacity:0;transition:.3s}
.releases-card:hover .releases-card-over{opacity:1}
.releases-card-info{padding:10px 11px 12px}
.releases-card-title{font-size:13px;font-weight:700;color:#fff;line-height:1.35;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.releases-card-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--muted)}
.releases-card-type{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.05);border-radius:4px;padding:2px 7px;font-size:10px;font-weight:700}
.releases-card-today{position:absolute;top:8px;left:8px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:10px;font-weight:800;padding:3px 8px;border-radius:5px;z-index:5;box-shadow:0 4px 12px rgba(34,197,94,.4)}
.releases-skel{border-radius:12px;aspect-ratio:2/3;background:linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);background-size:200% 100%;animation:sk 1.5s infinite}
 
/* ── CONFETTIS ── */
#confettiCanvas{position:fixed;inset:0;z-index:999998;pointer-events:none;display:none}
 
/* ── BARRE DE PROGRESSION ── */
.card-prog-bar{position:absolute;bottom:0;left:0;right:0;height:4px;background:rgba(0,0,0,.45);z-index:8}
.card-prog-fill{height:100%;background:linear-gradient(90deg,#f77f00,#ff9500);border-radius:0 2px 2px 0;box-shadow:0 0 8px rgba(247,127,0,.5)}
.card-prog-pct{position:absolute;bottom:9px;right:7px;background:rgba(0,0,0,.78);backdrop-filter:blur(8px);color:#fff;font-size:10px;font-weight:800;padding:2px 7px;border-radius:5px;z-index:9;opacity:0;transition:.2s;pointer-events:none}
.card:hover .card-prog-pct{opacity:1}
 
/* ── RESPONSIVE ── */
@media(max-width:768px){
  .releases-page{padding:75px 1rem 3rem}
  .releases-title{font-size:22px}
  .releases-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
  .releases-week-label{font-size:12px}
  .soiree-btn .soiree-label{display:none}
}
@media(max-width:480px){
  .releases-grid{grid-template-columns:repeat(2,1fr);gap:10px}
}

@media(max-width:600px){
  .film-detail-layout{
    grid-template-columns:1fr;
    padding:0 1rem;
    margin-top:-60px;
  }
  .film-poster-side{
    max-width:160px;
    margin:0 auto;
  }
  .film-title-big{
    font-size:1.8rem;
    text-align:center;
  }
  .film-actions-row{
    flex-direction:column;
  }
  .film-btn-watch,.film-btn-secondary{
    width:100%;
    justify-content:center;
  }
  .modal-hero{
    height:280px !important;
  }
  .src-bar{
    flex-wrap:wrap;
    gap:5px;
    padding:7px 10px;
  }
  .src-btn{
    font-size:11px;
    padding:4px 8px;
  }
  .episodes-grid-pro{
    grid-template-columns:1fr;
  }
  .saga-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

.studio-bg {
  position: fixed;  /* Changé de absolute à fixed */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background-size: cover;
  background-position: center top;
  opacity: 0.3;
  mask-image: linear-gradient(to bottom, black 40%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, black 40%, transparent 100%);
  pointer-events: none;
}

.avatar-grid img {
    border-radius: 50% !important; /* Force l'arrondi parfait comme Netflix */
    aspect-ratio: 1 / 1; /* S'assure que l'image ne soit pas ovale */
    object-fit: cover; /* Empêche l'image de s'aplatir */
    cursor: pointer;
    transition: transform 0.2s ease;
}

.avatar-grid img:hover {
    transform: scale(1.1); /* Petit effet de zoom stylé au survol */
}

/* ═══════════════════════════════════════════════════
   EDITEUR DE PROFIL PRINCIPAL (STYLE CINEFUSE)
   ═══════════════════════════════════════════════════ */
.pe-modal { position:fixed; inset:0; z-index:999999995; background:rgba(0,0,0,0.9); backdrop-filter:blur(20px); display:none; align-items:center; justify-content:center; padding:20px; font-family:var(--ff-body); }
.pe-container { width:100%; max-width:1000px; display:flex; flex-direction:column; gap:30px; }
.pe-header { display:flex; justify-content:space-between; align-items:center; }
.pe-title-box h2 { font-family:var(--ff-head); font-size:42px; font-weight:900; color:#fff; text-transform:uppercase; margin:0; letter-spacing:-1px; line-height:1; }
.pe-title-box p { font-size:12px; font-weight:700; color:rgba(255,255,255,0.4); text-transform:uppercase; letter-spacing:2px; margin-top:8px; }
.pe-save-btn { background:#fff; color:#000; font-family:var(--ff-head); font-size:14px; font-weight:800; text-transform:uppercase; letter-spacing:1px; padding:16px 32px; border-radius:12px; border:none; cursor:pointer; display:flex; align-items:center; gap:10px; transition:0.3s; }
.pe-save-btn:hover { background:var(--gold2); transform:translateY(-2px); }

.pe-body { display:flex; gap:30px; }
/* Colonne Gauche : Aperçu */
.pe-left { width:300px; flex-shrink:0; }
.pe-section-title { font-size:11px; font-weight:800; color:rgba(255,255,255,0.3); text-transform:uppercase; letter-spacing:2px; margin-bottom:16px; }
.pe-preview-card { background:linear-gradient(180deg, #16161c 0%, #0a0a0f 100%); border:1px solid rgba(255,255,255,0.05); border-radius:32px; padding:40px 20px; text-align:center; box-shadow:0 20px 50px rgba(0,0,0,0.5); }
.pe-preview-avatar-wrap { width:160px; height:160px; margin:0 auto 24px; position:relative; border-radius:50%; padding:4px; background:linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.02)); cursor:pointer; transition:0.3s; }
.pe-preview-avatar-wrap:hover { transform:scale(1.05); background:linear-gradient(135deg, var(--gold2), var(--red2)); }
.pe-preview-avatar { width:100%; height:100%; border-radius:50%; object-fit:cover; background:#000; }
.pe-preview-name { font-family:var(--ff-head); font-size:26px; font-weight:900; color:#fff; text-transform:uppercase; letter-spacing:-0.5px; margin-bottom:8px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pe-preview-role { font-size:11px; font-weight:800; color:rgba(255,255,255,0.4); text-transform:uppercase; letter-spacing:2px; }

/* Colonne Droite : Options */
.pe-right { flex:1; display:flex; flex-direction:column; gap:20px; }
.pe-tabs { display:flex; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05); border-radius:100px; padding:6px; gap:6px; }
.pe-tab { flex:1; padding:12px 0; text-align:center; font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,0.4); background:transparent; border:none; border-radius:100px; cursor:pointer; transition:0.3s; display:flex; justify-content:center; align-items:center; gap:8px; }
.pe-tab.active { background:#fff; color:#000; }
.pe-tab:hover:not(.active) { color:#fff; background:rgba(255,255,255,0.05); }

.pe-content-box { background:linear-gradient(180deg, #121218 0%, #0a0a0f 100%); border:1px solid rgba(255,255,255,0.05); border-radius:32px; padding:32px; flex:1; }
.pe-group { margin-bottom:32px; }
.pe-label { display:flex; align-items:center; gap:8px; font-size:11px; font-weight:800; color:rgba(255,255,255,0.4); text-transform:uppercase; letter-spacing:2px; margin-bottom:16px; }
.pe-input { width:100%; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08); color:#fff; font-family:var(--ff-head); font-size:20px; font-weight:800; padding:18px 24px; border-radius:16px; outline:none; transition:0.3s; }
.pe-input:focus { background:rgba(255,255,255,0.05); border-color:#fff; }

/* Palette et Typos (Visuel pour l'instant) */
.pe-colors { display:flex; gap:12px; flex-wrap:wrap; }
.pe-color { width:36px; height:36px; border-radius:12px; cursor:pointer; border:2px solid transparent; transition:0.2s; }
.pe-color:hover { transform:scale(1.1); }
.pe-color.active { border-color:#fff; transform:scale(1.1); box-shadow:0 0 15px rgba(255,255,255,0.3); }
.pe-fonts { display:grid; grid-template-columns:repeat(4, 1fr); gap:12px; }
.pe-font { background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08); padding:16px; border-radius:16px; text-align:center; color:rgba(255,255,255,0.5); font-size:12px; font-weight:800; text-transform:uppercase; cursor:pointer; transition:0.2s; }
.pe-font.active { border-color:#fff; color:#fff; }
.pe-font:hover:not(.active) { background:rgba(255,255,255,0.08); color:#fff; }
/* Permet à la décoration des sous-profils de déborder dans le gate */
#pgVipProfiles .pg-card .pg-avatar-box {
  overflow: visible !important;
  background: transparent !important;
}
#pgVipProfiles .pg-card:hover .pg-avatar-box {
  border-color: transparent !important;
}

/* ═══════════════════════════════════════════════════════════
   MOBILE — REFONTE COMPLÈTE (remplace l'ancien bloc mobile)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  body {
    padding-bottom: 70px !important;
    overflow-x: hidden !important;
  }

  /* ── NAVBAR HAUT ── */
  nav#mainNav {
    height: 56px !important;
    padding: 0 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    position: fixed !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    z-index: 100 !important;
    background: rgba(7,7,15,0.97) !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
  }
  .nav-links, .search-pill, .nav-link-staff { display: none !important; }
  .nav-left { flex: 1 !important; gap: 0 !important; }
  .logo { font-size: 22px !important; }
  .nav-right {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
  }
  .notif-bell {
    width: 36px !important; height: 36px !important;
    border-radius: 9px !important; display: flex !important;
  }
  .user-profile { display: flex !important; }
  .user-pill {
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    gap: 0 !important;
  }
  .user-pill span, .user-pill svg:last-child { display: none !important; }
  #userAvatar {
    width: 32px !important; height: 32px !important;
    border-radius: 50% !important; object-fit: cover !important;
    border: 2px solid rgba(255,255,255,0.2) !important;
    display: block !important;
  }
  .hamburger-btn {
    display: flex !important;
    width: 36px !important; height: 36px !important;
    border-radius: 9px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    color: #fff !important;
    align-items: center !important;
    justify-content: center !important;
    margin-left: 0 !important;
  }
  #discordLoginBtn, .discord-login-btn { display: none !important; }

  /* ── DROPDOWNS ── */
  .main-dropdown { top: 64px !important; right: 14px !important; width: 220px !important; }
  .premium-dropdown { top: 64px !important; right: 14px !important; width: 240px !important; }

  /* ── BARRE BAS — 3 onglets ── */
  #mobileBottomBar {
    display: flex !important;
    position: fixed !important;
    top: auto !important;
    bottom: 0 !important; left: 0 !important; right: 0 !important;
    height: 60px !important;
    padding-bottom: env(safe-area-inset-bottom) !important;
    background: #000 !important;
    border-top: 1px solid rgba(247, 127, 0, 0.35) !important;
    border-bottom: none !important;
    z-index: 99990 !important;
    justify-content: space-around !important;
    align-items: center !important;
  }
  .mobile-tab-btn {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 3px !important;
    background: none !important;
    border: none !important;
    color: rgba(255,255,255,0.45) !important;
    font-size: 10px !important;
    font-family: var(--ff-body) !important;
    font-weight: 600 !important;
    letter-spacing: 0.3px !important;
    padding: 0 !important;
    cursor: pointer !important;
    transition: color 0.2s !important;
  }
  .mobile-tab-btn svg {
    width: 20px !important; height: 20px !important;
    stroke-width: 1.8 !important;
    fill: none !important;
    stroke: currentColor !important;
  }
  .mobile-tab-btn.active { color: #f77f00 !important; }
  #mTabNotif, #mTabProfile { display: none !important; }
  .mobile-nav-bar { display: none !important; }

  /* ── HERO ── */
  .hero {
    height: 72vh !important;
    min-height: 420px !important;
    margin-top: 0 !important;
    padding-top: 56px !important;
  }
  .hero-content {
    left: 1rem !important; right: 1rem !important;
    bottom: 86px !important; max-width: 100% !important;
  }
  .hero-title {
    font-size: clamp(1.8rem, 7vw, 2.6rem) !important;
    letter-spacing: -0.8px !important;
  }
  .hero-desc { font-size: 13px !important; -webkit-line-clamp: 3 !important; }
  .hero-btns { gap: 8px !important; }
  .hero-btns .btn { padding: 10px 20px !important; font-size: 13px !important; }
  .hero-dots { left: 1rem !important; bottom: 22px !important; }

  /* ── SECTIONS & CAROUSELS ── */
  .section { padding: 0.5rem 1rem 1.2rem !important; }
  .section-title { font-size: clamp(1.25rem, 5vw, 1.5rem) !important; letter-spacing: 0.06em !important; }
  .scroll-row {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory !important;
  }
  .row-inner {
    scroll-padding-left: 1rem !important;
    padding: 16px 0 20px !important;
  }
  .card {
    flex: 0 0 140px !important; width: 140px !important;
    scroll-snap-align: start !important;
  }
  .card-img { height: 210px !important; }
  .skeleton { flex: 0 0 140px !important; height: 210px !important; }
  .card-trending{flex:0 0 150px!important;margin-left:0!important}
  .card-trending .card-img{height:225px!important}
  .card-rank-chip{padding:7px 10px!important;bottom:8px!important;left:8px!important;border-radius:12px!important}
  .card-rank-chip .card-rank-num{font-size:17px!important}

  /* ── STUDIO BAR ── */
  .studio-bar { padding: 0.8rem 1rem !important; gap: 8px !important; }
  .studio-card { min-width: 100px !important; min-height: 58px !important; padding: 10px 16px !important; }
  .studio-logo { width: 80px !important; height: 44px !important; }

/* ── CATALOGUE & GRILLES ──
   Les chips (Tout / Films / Séries…) sont décalées sous la navbar.
   On ajoute un padding-top sur la vue catalogue pour qu'elles
   apparaissent sous la barre fixe, et on force le scroll horizontal. ── */
#catalogueView {
  padding-top: 56px !important; /* hauteur navbar */
}
#catalogueView .grid-header {
  padding: 1rem 1rem 0.4rem !important;
}
#catalogueChips,
.filter-chips {
  display: flex !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  scroll-snap-type: x mandatory !important;
  gap: 8px !important;
  padding: 0.6rem 1rem 0.8rem !important;
  scrollbar-width: none !important;
}
#catalogueChips::-webkit-scrollbar,
.filter-chips::-webkit-scrollbar { display: none !important; }
#catalogueChips .chip,
.filter-chips .chip {
  flex-shrink: 0 !important;
  scroll-snap-align: start !important;
  white-space: nowrap !important;
}

  .movies-grid,
  #catalogueGrid,
  #moviesGrid,
  #studioGrid,
  #dashGrid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px 10px !important;
    padding: 1rem !important;
  }
  .releases-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }

  /* ── Chart 10 (nouveau gabarit) ── */
  .chart10{
    padding-top:calc(var(--nav-h) + 1.1rem)!important;
    padding-bottom:2.75rem!important;
  }
  .chart10-follow-heading{font-size:1.08rem!important}
  /* ── MODAL FILM ──
     Problème : bande grise visible entre le backdrop et le fondu.
     Cause : modal-hero-img est en position:fixed et sort du flux,
     donc le grad ne le couvre pas depuis le bord.
     Fix : on passe l'image en absolute dans un conteneur overflow:hidden,
     et on fait démarrer le gradient à 0% opacity depuis le haut. ── */
  .modal-hero {
    height: 280px !important;
    min-height: unset !important;
    overflow: hidden !important;
    position: relative !important;
  }
  .modal-hero-img {
    position: absolute !important;
    top: 0 !important; left: 0 !important;
    width: 100% !important; height: 100% !important;
    object-fit: cover !important;
    object-position: center 20% !important;
    /* On enlève le fixed sur mobile pour éviter le gap */
    transform: none !important;
  }
  /* Fondu sans bande : commence dès le pixel 0 */
  .modal-hero-grad {
    background: linear-gradient(180deg,
      transparent 0%,
      transparent 15%,
      rgba(7,7,15,0.55) 45%,
      rgba(7,7,15,0.88) 70%,
      var(--bg) 100%
    ) !important;
  }

  .film-detail-layout {
    grid-template-columns: 1fr !important;
    padding: 0 1rem !important;
    margin-top: -50px !important;
    gap: 1rem !important;
    text-align: center !important;
  }
  .film-poster-side {
    position: relative !important; top: auto !important;
    max-width: 130px !important; margin: 0 auto !important;
  }
  .film-poster-img { border-radius: 12px !important; }
  .poster-quick-actions { flex-direction: row !important; justify-content: center !important; }
  .film-title-big {
    font-size: clamp(1.5rem, 6vw, 2.4rem) !important;
    text-align: center !important;
  }
  .film-meta-row, .film-genres-row, .film-actions-row { justify-content: center !important; }
  .film-btn-watch, .film-btn-secondary {
    width: 100% !important; justify-content: center !important;
    font-size: 14px !important; padding: 13px 20px !important;
  }
  .film-actions-row { flex-direction: column !important; gap: 8px !important; }
  .modal-body { padding: 0 1rem 3rem !important; margin-top: -60px !important; }
  .saga-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
  .film-poster-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
  .film-poster-grid--lg { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .episodes-grid-pro { grid-template-columns: 1fr !important; }
  .film-trailer-play-btn { width: 60px !important; height: 60px !important; }
  .film-trailer-play-btn svg { width: 20px !important; height: 20px !important; }
  .src-bar { padding: 7px 10px !important; gap: 5px !important; flex-wrap: wrap !important; }
  .src-btn { font-size: 11px !important; padding: 4px 9px !important; }

  /* ── PLAYER ── */
  .player-topbar { padding: 10px 14px !important; }
  .player-title { font-size: 15px !important; }

  /* ── RECHERCHE ── */
  .search-top { padding: 1.2rem 1rem 0.8rem !important; }
  #searchInput { font-size: 22px !important; }
  .search-body { padding: 1.2rem 1rem !important; }
  .search-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 16px 10px !important; }

  /* ── INBOX NOTIFS ── */
  .notif-inbox {
    right: 0 !important; left: 0 !important; width: 100% !important;
    top: 56px !important;
    border-radius: 0 0 16px 16px !important;
    max-height: 70vh !important;
  }

  /* ── PROFIL GATE ── */
  #profileGate { padding: 2rem 1rem !important; gap: 0 !important; }
  .pg-title {
    font-size: clamp(1.8rem, 9vw, 3rem) !important;
    margin-bottom: 2rem !important; text-align: center !important;
  }
  #pgProfilesRow { display: flex !important; flex-direction: row !important; flex-wrap: wrap !important; gap: 20px !important; justify-content: center !important; }
  .pg-card { gap: 8px !important; }
  .pg-avatar-box { width: 100px !important; height: 100px !important; }
  .pg-name { font-size: 11px !important; letter-spacing: 0.5px !important; }

  /* ── SETTINGS ── */
  .settings-modal { padding: 0 !important; }
  .settings-box {
    max-width: 100% !important; height: 100vh !important;
    max-height: 100vh !important; border-radius: 0 !important;
  }
  .settings-theme-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .settings-stats-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* ── STAFF PANEL ── */
  .staff-panel { flex-direction: column !important; overflow: hidden !important; }
  .staff-topbar { height: 56px !important; padding: 0 1rem !important; gap: 10px !important; }
  .staff-logo { font-size: 16px !important; }
  .staff-badge { font-size: 9px !important; padding: 3px 8px !important; }
  #staffWelcome { display: none !important; }
  .staff-sidebar {
    width: 100% !important; min-width: 0 !important;
    flex-direction: row !important;
    overflow-x: auto !important; overflow-y: hidden !important;
    padding: 8px 12px !important;
    border-right: none !important;
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
    flex-shrink: 0 !important;
    scrollbar-width: none !important;
    gap: 6px !important; flex-wrap: nowrap !important;
    -webkit-overflow-scrolling: touch !important;
    background: rgba(5,5,12,0.8) !important;
  }
  .staff-sidebar::-webkit-scrollbar { display: none !important; }
  .staff-nav-item {
    flex-shrink: 0 !important; padding: 8px 14px !important;
    font-size: 12px !important; border-radius: 20px !important;
    white-space: nowrap !important; box-shadow: none !important;
    min-width: auto !important; gap: 6px !important;
  }
  .staff-nav-item.active {
    box-shadow: none !important;
    background: rgba(232,48,74,0.2) !important;
    border-color: rgba(232,48,74,0.4) !important;
  }
  .staff-nav-sep { display: none !important; }
  .staff-body { flex: 1 !important; overflow: hidden !important; flex-direction: column !important; }
  .staff-content { flex: 1 !important; padding: 1.2rem 1rem 5rem !important; overflow-y: auto !important; -webkit-overflow-scrolling: touch !important; }
  .staff-section-title { font-size: 22px !important; margin-bottom: 4px !important; }
  .staff-section-sub { font-size: 12px !important; margin-bottom: 20px !important; }
  .staff-cards { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; margin-bottom: 20px !important; }
  .staff-card { padding: 16px 14px !important; border-radius: 14px !important; }
  .staff-card-n { font-size: 28px !important; margin-bottom: 4px !important; }
  .staff-card-l { font-size: 11px !important; }
  .staff-panel-box { padding: 18px !important; border-radius: 14px !important; margin-bottom: 16px !important; }
  .staff-form-input, .staff-form-select, .staff-form-textarea {
    padding: 12px 14px !important; font-size: 14px !important; border-radius: 10px !important;
  }
  .staff-table-wrap { overflow-x: auto !important; -webkit-overflow-scrolling: touch !important; border-radius: 12px !important; }
  .staff-table { min-width: 500px !important; }
  .staff-table th, .staff-table td { padding: 10px 12px !important; font-size: 12px !important; }
  .staff-list-row { padding: 12px 14px !important; border-radius: 10px !important; gap: 10px !important; }
  .sp-btn { padding: 9px 14px !important; font-size: 12.5px !important; border-radius: 10px !important; }
  .sp-log { font-size: 11px !important; max-height: 180px !important; padding: 12px !important; border-radius: 10px !important; }
  #staffVipCodesList { grid-template-columns: 1fr !important; gap: 10px !important; }

  .faq-container{grid-template-columns:1fr !important;gap:2rem !important}

  /* ── DASHBOARD ── */
  .dash-wrap { padding: 76px 1rem 3rem !important; }

  /* ── RELEASES ── */
  .releases-page { padding: 76px 1rem 3rem !important; }
  .releases-nav { flex-wrap: nowrap !important; gap: 6px !important; }
  .releases-week-label { font-size: 11px !important; }

  /* ── TICKET ── */
  .ticket-box { width: calc(100% - 2rem) !important; max-height: 88vh !important; }

  /* ── LÉGALES ── */
  .legal-modal { padding: 10px !important; }
  .legal-box { max-height: 92vh !important; }
  .legal-body { padding: 16px !important; }
  .legal-contact-grid { grid-template-columns: 1fr !important; }

  /* ── FOOTER ── */
  .site-footer { padding: 3rem 1rem 1rem !important; }
  .footer-content { grid-template-columns: 1fr !important; gap: 1.5rem !important; }
  .footer-bottom { flex-direction: column !important; text-align: center !important; gap: 0.6rem !important; }

  /* ── DIVERS ── */
  .my-list-fab { display: none !important; }
  .notif-popup-wrap { left: 10px !important; right: 10px !important; max-width: 100% !important; }
  .center-alert-box { padding: 28px 20px !important; }
  .center-alert-timer { font-size: 48px !important; }

  /* ── FIX SOURCES PLAYER ── */
@media (max-width: 768px) {
  .src-bar {
    padding: 10px 1rem 80px !important; /* 80px = espace barre du bas */
    gap: 8px !important;
    flex-wrap: wrap !important;
    overflow-x: visible !important;
  }
  .player-wrap,
  #playerView,
  .player-container {
    padding-bottom: 80px !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   MODAL PROFIL — ADAPTATION MOBILE COMPLÈTE
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Tabs : scroll horizontal si nécessaire */
  #editMainProfileModal .pe-tabs {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
    flex-wrap: nowrap !important;
    padding: 4px !important;
    gap: 4px !important;
    border-radius: 14px !important;
  }
  #editMainProfileModal .pe-tabs::-webkit-scrollbar {
    display: none !important;
  }

  /* Chaque tab : taille fixe, ne rétrécit pas */
  #editMainProfileModal .pe-tab {
    flex: 0 0 auto !important;
    padding: 10px 14px !important;
    font-size: 11px !important;
    letter-spacing: 0.4px !important;
    white-space: nowrap !important;
    min-width: 0 !important;
    border-radius: 10px !important;
  }
  #editMainProfileModal .pe-tab svg {
    width: 12px !important;
    height: 12px !important;
    flex-shrink: 0 !important;
  }

}

  /* Conteneur principal */
  #editMainProfileModal {
    padding: 0 !important;
    align-items: flex-end !important;
    overflow-y: auto !important;
  }

  /* La boîte elle-même : plein écran en slide-up */
  #editMainProfileModal > div {
    max-width: 100% !important;
    width: 100% !important;
    border-radius: 20px 20px 0 0 !important;
    padding: 20px 16px 40px !important;
    max-height: 92vh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* Header : titre + bouton save empilés */
  #editMainProfileModal > div > div:first-child {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
    margin-bottom: 20px !important;
  }
  #editMainProfileModal h2 {
    font-size: 22px !important;
    letter-spacing: -0.5px !important;
  }
  #editMainProfileModal > div > div:first-child > div:last-child {
    width: 100% !important;
    flex-direction: row !important;
    gap: 10px !important;
  }
  #editMainProfileModal > div > div:first-child > div:last-child button {
    flex: 1 !important;
    justify-content: center !important;
    padding: 12px 0 !important;
    font-size: 13px !important;
  }

  /* Corps : colonne unique */
  #editMainProfileModal .pe-body,
  #editMainProfileModal > div > div.pe-body {
    flex-direction: column !important;
    gap: 16px !important;
  }

  /* Aperçu profil : compact et centré */
  #editMainProfileModal .pe-left {
    width: 100% !important;
  }
  #editMainProfileModal .pe-preview-card {
    padding: 20px 16px !important;
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    text-align: left !important;
    border-radius: 18px !important;
  }
  #editMainProfileModal .pe-preview-avatar-wrap {
    width: 70px !important;
    height: 70px !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
  }
  #editMainProfileModal .pe-preview-name {
    font-size: 18px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 180px !important;
  }
  #editMainProfileModal .pe-preview-role {
    font-size: 10px !important;
  }

  /* Partie droite : pleine largeur */
  #editMainProfileModal .pe-right {
    width: 100% !important;
  }

  /* Tabs : compactes */
  #editMainProfileModal .pe-tabs {
    padding: 4px !important;
    gap: 4px !important;
    border-radius: 14px !important;
  }
  #editMainProfileModal .pe-tab {
    padding: 10px 6px !important;
    font-size: 11px !important;
    gap: 5px !important;
    letter-spacing: 0.5px !important;
  }
  #editMainProfileModal .pe-tab svg {
    width: 13px !important;
    height: 13px !important;
  }

  /* Boîte de contenu */
  #editMainProfileModal .pe-content-box {
    padding: 20px 16px !important;
    border-radius: 18px !important;
  }
  #editMainProfileModal .pe-group {
    margin-bottom: 20px !important;
  }
  #editMainProfileModal .pe-input {
    font-size: 16px !important; /* évite le zoom iOS */
    padding: 14px 16px !important;
    border-radius: 12px !important;
  }

  /* Palette de couleurs */
  #editMainProfileModal .pe-colors {
    gap: 10px !important;
    flex-wrap: wrap !important;
  }
  #editMainProfileModal .pe-color {
    width: 32px !important;
    height: 32px !important;
    border-radius: 10px !important;
  }

  /* Grille de polices : 2 colonnes */
  #editMainProfileModal .pe-fonts {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }
  #editMainProfileModal .pe-font {
    padding: 12px 8px !important;
    font-size: 11px !important;
    border-radius: 10px !important;
  }

  /* Grille de décorations */
  #decoGrid {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 8px !important;
    max-height: 200px !important;
  }
}

/* Très petits écrans */
@media (max-width: 380px) {
  #editMainProfileModal .pe-tab {
    font-size: 10px !important;
    padding: 9px 4px !important;
  }
  #editMainProfileModal .pe-fonts {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  #decoGrid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

@media (max-width: 768px) {
  #editMainProfileModal {
    padding: 0 !important;
    align-items: flex-end !important;
    overflow-y: auto !important;
  }
  #editMainProfileModal > div {
    max-width: 100% !important;
    width: 100% !important;
    border-radius: 20px 20px 0 0 !important;
    padding: 16px 14px 32px !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  #editMainProfileModal .pe-body {
    flex-direction: column !important;
    gap: 12px !important;
  }
  #editMainProfileModal .pe-left { width: 100% !important; }
  #editMainProfileModal .pe-preview-card {
    padding: 14px 12px !important;
    border-radius: 14px !important;
    flex-direction: row !important;
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
  }
  #editMainProfileModal .pe-preview-avatar-wrap {
    width: 64px !important;
    height: 64px !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
  }
  #editMainProfileModal .pe-preview-name { font-size: 16px !important; }
  #editMainProfileModal .pe-right { width: 100% !important; }
  #editMainProfileModal .pe-content-box {
    padding: 16px 14px !important;
    border-radius: 14px !important;
  }
  #editMainProfileModal .pe-tabs {
    gap: 4px !important;
    padding: 4px !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
  }
  #editMainProfileModal .pe-tab {
    padding: 9px 10px !important;
    font-size: 11px !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
  }
  #decoGrid {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 8px !important;
    max-height: 220px !important;
    overflow-y: auto !important;
  }
}

/* legacy gateLoader — voir site-intro.css */
#gateLoader .loader-inner{display:contents}

/* ═══════════════════════════════════════════════════════════
   CIEL ÉTOILÉ EN ARRIÈRE-PLAN
   ═══════════════════════════════════════════════════════════ */
.starry-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: radial-gradient(ellipse at 30% 40%, #0a0a1a 0%, #03030a 100%);
  overflow: hidden;
}
.star {
  position: absolute;
  background: white;
  border-radius: 50%;
  opacity: 0;
  animation: twinkle 3s ease-in-out infinite;
}
@keyframes twinkle {
  0%, 100% { opacity: 0; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.2); }
}
.shooting {
  position: absolute;
  width: 100px;
  height: 2px;
  background: linear-gradient(90deg, white, transparent);
  opacity: 0;
  animation: shoot 8s linear infinite;
}
@keyframes shoot {
  0% { transform: translateX(0) translateY(0); opacity: 0; }
  10% { opacity: 1; }
  20% { opacity: 0; }
  100% { transform: translateX(-500px) translateY(200px); opacity: 0; }
}
/* CORRECTION CATALOGUE MOBILE - Tags visibles sous la navbar */
@media (max-width: 768px) {
  /* Décale TOUTE la vue catalogue vers le bas */
  #catalogueView {
    margin-top: 56px !important;
    padding-top: 0 !important;
  }
  
  /* Ajoute un petit espace en haut des chips */
  #catalogueChips,
  .filter-chips {
    padding-top: 12px !important;
    margin-top: 0 !important;
  }
  
  /* Ajuste la hauteur du conteneur des chips */
  .grid-header {
    margin-bottom: 0 !important;
  }
}
/* Décalage des tags catalogue pour les voir sous la barre de navigation */
#catalogueView .filter-chips:first-child,
#catalogueView #catalogueChips {
  margin-top: 65px !important;
  padding-top: 10px !important;
}
/* Titre animé du catalogue */
.catalogue-header-title {
  text-align: center;
  margin-bottom: 20px;
  padding-top: 10px;
}

.catalogue-glow-title {
  font-family: 'Syne', sans-serif;
  font-size: 28px;
  font-weight: 800;
  background: linear-gradient(135deg, #e8304a 0%, #f5a623 50%, #e8304a 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: titleShimmer 3s ease-in-out infinite;
  letter-spacing: -0.5px;
  display: inline-block;
}

@keyframes titleShimmer {
  0% {
    background-position: 0% center;
  }
  50% {
    background-position: 100% center;
  }
  100% {
    background-position: 0% center;
  }
}

.catalogue-sub {
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-top: 5px;
}

/* Ajustement pour mobile */
@media (max-width: 768px) {
  .catalogue-glow-title {
    font-size: 22px;
  }
}
/* Barre mobile : styles dans mobile-responsive.css (fixed bottom) */
/* CORRECTION STUDIOS — affiches poster-only */
#studioView .card {
  position: relative;
  z-index: 5;
  background: transparent;
}

#studioView .card-clip {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
}

/* Correction pour le fond des cartes studio */
.studio-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background-size: cover;
  background-position: center top;
  opacity: 0.25;
  pointer-events: none;
}

/* La grille des studios doit être au-dessus du fond */
#studioView .movies-grid {
  position: relative;
  z-index: 5;
}

/* Le header des studios aussi */
#studioView .grid-header {
  position: relative;
  z-index: 5;
}

/* Les chips de filtres */
#studioView .filter-chips {
  position: relative;
  z-index: 5;
}

/* Scroll vers le haut pour les studios */
#studioView {
  scroll-margin-top: 0;
  padding-top: 0;
}

.studio-scroll-target {
  scroll-margin-top: 0;
}

/* SOLUTION : DÉCALER LE CONTENU DES STUDIOS POUR VOIR LE TEXTE CACHÉ */

/* Ajoute un padding-top plus grand sur la vue studio pour que le contenu descende */
#studioView {
  padding-top: 110px !important;  /* Décale tout le contenu vers le bas */
}

/* Ajuste la position du header dans les studios */
#studioView .grid-header {
  margin-top: 20px;
  padding-top: 10px;
  position: relative;
  z-index: 20;
}

/* Pour le catalogue aussi si besoin */
#catalogueView {
  padding-top: 100px !important;
}

/* Version mobile */
@media (max-width: 768px) {
  #studioView {
    padding-top: 130px !important;
  }
  
  #catalogueView {
    padding-top: 110px !important;
  }
}
/* Animation dégradé animé pour Disney+ */
.studio-card[data-s="disney"] .studio-text,
.studio-card[data-s="disney"] .studio-logo {
  background: linear-gradient(135deg, #001a3a 0%, #0a4da4 50%, #00b4d8 100%);
  background-size: 200% 200%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: disneyGlow 3s ease-in-out infinite;
  font-weight: 800;
  letter-spacing: 1px;
}

@keyframes disneyGlow {
  0% {
    background-position: 0% 50%;
    filter: drop-shadow(0 0 5px rgba(0, 100, 200, 0.3));
  }
  50% {
    background-position: 100% 50%;
    filter: drop-shadow(0 0 15px rgba(0, 180, 216, 0.6));
  }
  100% {
    background-position: 0% 50%;
    filter: drop-shadow(0 0 5px rgba(0, 100, 200, 0.3));
  }
}

/* Effet au survol - plus prononcé */
.studio-card[data-s="disney"]:hover .studio-text,
.studio-card[data-s="disney"]:hover .studio-logo {
  animation: disneyGlowHover 0.8s ease-in-out infinite;
  transform: scale(1.05);
  transition: transform 0.3s ease;
}

@keyframes disneyGlowHover {
  0% {
    background-position: 0% 50%;
    filter: drop-shadow(0 0 8px rgba(0, 180, 216, 0.5));
  }
  100% {
    background-position: 100% 50%;
    filter: drop-shadow(0 0 20px rgba(0, 180, 216, 0.9));
  }
}
/* Dégradé animé Disney+ — utiliser class="studio-title-disney" sur le h2 */
.studio-title-disney {
  background: linear-gradient(135deg, #001a3a 0%, #0066cc 40%, #00b4d8 70%, #0066cc 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: disneyTextShine 2.5s linear infinite;
  font-weight: 800;
  letter-spacing: -0.5px;
}

@keyframes disneyTextShine {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

/* Version hover - plus intense */
.studio-title-disney:hover {
  animation: disneyTextHover 0.6s ease-in-out infinite;
  transform: scale(1.02);
  transition: transform 0.3s ease;
}

@keyframes disneyTextHover {
  0% {
    background-position: 0% 50%;
    filter: drop-shadow(0 0 5px rgba(0, 180, 216, 0.5));
  }
  100% {
    background-position: 100% 50%;
    filter: drop-shadow(0 0 15px rgba(0, 180, 216, 0.8));
  }
}
/* Dégradé animé pour Disney+ FORCÉ */
#studioTitle[data-studio="disney"] {
  background: linear-gradient(135deg, #001a3a, #0066cc, #00b4d8, #0066cc) !important;
  background-size: 200% auto !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  animation: disneyShine 2.5s linear infinite !important;
  font-weight: 800;
}

@keyframes disneyShine {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

/* ╔════════════════════════════════════════════════════════════════════════╗
 *  InterFilm UI — couches modernes React + statique (fin 2025 / 2026)
 * ╚════════════════════════════════════════════════════════════════════════╝ */

.page-shell {
  position: relative;
  isolation: isolate;
}

.page-shell-inner {
  position: relative;
  z-index: 1;
}

.page-shell::before {
  content: '';
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 0;
  opacity: 0.95;
  background:
    radial-gradient(ellipse 110% 70% at 50% -12%, rgba(232, 48, 74, 0.1), transparent 52%),
    radial-gradient(ellipse 80% 55% at 100% 18%, rgba(99, 102, 241, 0.055), transparent 48%),
    radial-gradient(ellipse 70% 50% at 0% 75%, rgba(245, 166, 35, 0.04), transparent 45%);
}

.link-as-btn {
  text-decoration: none;
}

.feature-strip-wrap {
  padding: clamp(1rem, 2.5vw, 1.75rem) clamp(1rem, 3vw, 2.75rem);
}

.feature-strip {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.65rem, 2vw, 1rem);
  justify-content: center;
  align-items: stretch;
  margin: 0;
  padding: 0;
}

.feature-chip {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 22px;
  border-radius: 999px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(15, 15, 28, 0.45));
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  max-width: 320px;
  transition:
    transform var(--transition-fast),
    box-shadow var(--transition-fast),
    border-color var(--transition-fast);
}

.feature-chip:hover {
  transform: translateY(-4px);
  border-color: rgba(232, 48, 74, 0.35);
  box-shadow: var(--shadow-lift);
}

.feature-chip-icon {
  font-size: 1.45rem;
  line-height: 1;
}

.feature-chip-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: left;
}

.feature-chip-title {
  font-family: var(--ff-head);
  font-weight: 800;
  font-size: 0.9rem;
  letter-spacing: -0.03em;
  color: #fff;
}

.feature-chip-desc {
  font-size: 0.78rem;
  color: var(--text2);
  line-height: 1.55;
}

.content-row-shell {
  margin: 0 clamp(0.85rem, 3vw, 2.75rem) clamp(1.25rem, 3.5vw, 2.75rem);
  padding: clamp(1.25rem, 2vw, 2rem) clamp(1rem, 2vw, 1.85rem);
  border-radius: 22px;
  background: linear-gradient(155deg, rgba(17, 17, 32, 0.78) 0%, rgba(10, 10, 22, 0.42) 100%);
  border: 1px solid rgba(255, 255, 255, 0.065);
  box-shadow:
    var(--shadow-soft),
    0 0 0 1px rgba(255, 255, 255, 0.02) inset;
  backdrop-filter: blur(22px) saturate(155%);
  -webkit-backdrop-filter: blur(22px) saturate(155%);
}

.content-row-accent {
  border-color: rgba(232, 48, 74, 0.12);
  box-shadow:
    var(--shadow-soft),
    0 0 60px rgba(232, 48, 74, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.section-inner {
  max-width: 1400px;
  margin-inline: auto;
}

.section-heading {
  margin: 0;
  font-family: var(--ff-head);
  font-size: clamp(1.35rem, 1.05rem + 1.35vw, 1.95rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #fff;
}

.section-eyebrow {
  margin: 0 0 0.35rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--muted);
}

.section-header-alt {
  margin-bottom: clamp(1rem, 2vw, 1.65rem);
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
}

.movies-grid-modern {
  gap: clamp(20px, 2.8vw, 36px);
  padding: 0 !important;
}

.page-catalog {
  padding-top: var(--nav-h);
}

.page-catalog-intro {
  margin-top: clamp(1rem, 3vw, 2rem);
  margin-bottom: var(--section-y);
}

.catalog-page-title {
  margin: 0 0 0.35rem;
  font-family: var(--ff-head);
  font-size: clamp(2rem, 1.65rem + 1.75vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.045em;
  color: #fff;
}

.catalog-page-subtitle {
  margin: 0;
  max-width: 520px;
  color: var(--text2);
  font-size: 0.94rem;
  line-height: 1.62;
}

.catalog-status {
  color: var(--muted);
}

.catalog-error-msg {
  color: var(--red2);
  line-height: 1.62;
}

.pagination-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: clamp(1.75rem, 3vw, 2.75rem) 0 1rem;
}

.pagination-page {
  font-weight: 800;
  color: var(--muted);
}

.btn {
  border-radius: 14px !important;
  transition:
    transform var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast),
    opacity var(--transition-fast) !important;
}

.btn-secondary {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.09),
    0 4px 22px rgba(0, 0, 0, 0.32);
}

.btn-primary:active,
.btn-secondary:active {
  transform: translateY(0) scale(0.99);
}

.card {
  border-radius: 14px !important;
}

.card-clip {
  border-radius: 14px !important;
  box-shadow:
    0 6px 18px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.card:hover {
  transform: translateY(-7px) scale(1.03) !important;
}

.card:hover .card-clip {
  box-shadow:
    0 28px 48px rgba(0, 0, 0, 0.72),
    0 0 0 2px rgba(255, 255, 255, 0.1),
    0 0 36px rgba(247, 127, 0, 0.2) !important;
}

.hero-content-modern .hero-desc {
  max-width: 560px !important;
  font-size: clamp(0.95rem, 0.9rem + 0.4vw, 1.125rem);
  line-height: 1.68;
}

.hero-badge-modern {
  text-transform: none !important;
  letter-spacing: 0.12em !important;
  padding: 10px 20px !important;
  border-radius: 999px !important;
  background: rgba(232, 48, 74, 0.12) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-color: rgba(232, 48, 74, 0.35) !important;
}

.glass-panel-strong {
  background: linear-gradient(165deg, rgba(20, 20, 40, 0.88), rgba(10, 10, 20, 0.55));
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-xl);
  backdrop-filter: blur(24px) saturate(155%);
  -webkit-backdrop-filter: blur(24px) saturate(155%);
  box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.auth-page-shell {
  padding-top: calc(var(--nav-h) + 1.75rem);
  padding-bottom: 3rem;
}

.auth-page-inner {
  padding-inline: clamp(1rem, 3vw, 1.5rem);
  max-width: 720px;
  margin-inline: auto;
}

.auth-page-header {
  margin-bottom: 1.5rem;
}

.auth-main-card {
  padding: clamp(1.35rem, 3vw, 2rem);
  margin-bottom: 1rem;
}

.auth-profile-row {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.auth-avatar {
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.15);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
}

.auth-username {
  font-family: var(--ff-head);
  font-weight: 800;
  font-size: clamp(1.125rem, 1rem + 0.5vw, 1.5rem);
  letter-spacing: -0.03em;
}

.auth-meta {
  margin-top: 0.35rem;
  font-size: 0.8125rem;
  color: var(--muted);
  line-height: 1.5;
}

.auth-actions {
  margin-top: 1.25rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.auth-hint {
  margin-top: 1rem;
  margin-bottom: 0;
  font-size: 0.75rem;
  color: var(--muted);
  line-height: 1.58;
}

.auth-hint code {
  word-break: break-all;
}

.auth-sub-block {
  margin-top: 1rem;
  padding: 1.25rem 1.5rem;
}

.auth-section-title {
  margin: 0 0 0.65rem;
  font-family: var(--ff-head);
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: -0.02em;
  color: #fff;
}

.auth-section-text {
  margin: 0 0 1rem;
  color: var(--text2);
  font-size: 0.9rem;
  line-height: 1.62;
}

.auth-probe {
  margin-top: 0.85rem;
  margin-bottom: 0;
  padding: 0.75rem 1rem;
  border-radius: 12px;
  font-size: 0.73rem;
  line-height: 1.52;
  color: var(--text2);
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.06);
  white-space: pre-wrap;
  word-break: break-word;
}

.site-footer {
  margin-top: clamp(3rem, 8vw, 5rem) !important;
  padding-inline: clamp(1rem, 3vw, 2.75rem) !important;
  background: linear-gradient(180deg, rgba(12, 12, 24, 0.55) 0%, rgba(4, 4, 10, 0.98) 100%) !important;
  backdrop-filter: blur(32px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(32px) saturate(160%) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.07) !important;
}

.footer-content {
  gap: clamp(2rem, 5vw, 3.5rem) !important;
}

.footer-links a,
.footer-links a:visited {
  color: inherit !important;
}

/* mobile-bottom-bar → mobile-responsive.css */

@media (max-width: 900px) {
  .footer-content {
    grid-template-columns: 1fr 1fr !important;
    gap: 2rem !important;
  }

  .content-row-shell {
    margin-inline: clamp(0.6rem, 2vw, 1rem);
  }
}

@media (max-width: 560px) {
  .footer-content {
    grid-template-columns: 1fr !important;
  }

  .feature-chip {
    max-width: 100%;
  }
}