/* ════════════════════════════════════════════════════════════
   GWAFLIX · components.css — boutons, posters, modale, cartes
   ════════════════════════════════════════════════════════════ */

/* ─── Boutons ─── */
.btn { --py:.75rem; --px:1.5rem; display:inline-flex; align-items:center; justify-content:center; gap:.5rem; padding:var(--py) var(--px); font-weight:600; font-size:.94rem; border-radius:7px; border:1px solid transparent; cursor:pointer; transition:all .18s var(--ease); white-space:nowrap; }
.btn-primary { background:var(--red); color:#fff; box-shadow:0 1px 0 rgba(255,255,255,.18) inset, 0 8px 24px -8px rgba(229,9,20,.7); }
.btn-primary:hover { background:var(--red-hot); color:#fff; transform:translateY(-2px); box-shadow:0 1px 0 rgba(255,255,255,.25) inset,0 14px 34px -10px rgba(229,9,20,.85); }
.btn-glass { background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.2); backdrop-filter:blur(14px) saturate(1.6); -webkit-backdrop-filter:blur(14px) saturate(1.6); }
.btn-glass:hover { background:rgba(255,255,255,.2); border-color:rgba(255,255,255,.35); color:#fff; }
.btn-ghost { background:rgba(255,255,255,.06); color:var(--txt); border-color:var(--line); backdrop-filter:blur(8px); }
.btn-ghost:hover { background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.18); }
.btn-line { background:transparent; color:var(--dim); }
.btn-line:hover { color:var(--txt); }
.btn-lg { --py:1rem; --px:2.1rem; font-size:1.02rem; }
.btn-sm { --py:.5rem; --px:1.05rem; font-size:.85rem; }
.btn.is-closed { opacity:.5; cursor:not-allowed; }

/* ─── Cartes feature ─── */
.card { background:linear-gradient(180deg,var(--bg-2),var(--bg-1)); border:1px solid var(--line); border-radius:14px; padding:2rem; transition:transform .22s var(--ease), border-color .22s, box-shadow .22s; }
.card:hover { transform:translateY(-4px); border-color:rgba(229,9,20,.45); box-shadow:0 20px 50px -20px rgba(229,9,20,.4); }
.card-ic { width:56px; height:56px; border-radius:14px; display:grid; place-items:center; margin-bottom:1.3rem; background:radial-gradient(circle at 30% 30%, rgba(229,9,20,.18), rgba(229,9,20,.05)); border:1px solid rgba(229,9,20,.25); }
.card-ic img { width:30px; height:30px; }
.card h3 { font-size:1.2rem; margin-bottom:.55rem; }
.card p { color:var(--dim); font-size:.96rem; }

/* ─── Poster (rangées catalogue) ─── */
.poster { flex:0 0 clamp(130px,13vw,185px); display:block; color:inherit; background:none; border:none; padding:0; cursor:pointer; text-align:left; transition:transform .28s var(--ease); will-change:transform; }
.poster-img-wrap { position:relative; border-radius:10px; overflow:hidden; aspect-ratio:2/3; background:var(--bg-3); box-shadow:0 4px 14px rgba(0,0,0,.4); }
.poster img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.poster-overlay { position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.85)); display:flex; align-items:flex-end; justify-content:flex-end; padding:.6rem; opacity:0; transition:opacity .25s; }
.poster-info-ic { width:34px; height:34px; border-radius:50%; background:rgba(0,0,0,.6); border:1px solid rgba(255,255,255,.6); color:#fff; display:grid; place-items:center; backdrop-filter:blur(4px); }
.poster-info-ic svg { display:block; }
.poster:hover { transform:scale(1.07) translateY(-6px); z-index:5; }
.poster:hover .poster-overlay { opacity:1; }
.poster:hover img { transform:scale(1.08); }
.poster-meta { padding:.6rem .15rem 0; }
.poster-title { display:block; font-size:.9rem; font-weight:600; color:var(--txt); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.poster-year { display:block; font-size:.78rem; color:var(--mute); margin-top:.1rem; }

/* ─── Modale fiche info ─── */
.modal-backdrop { position:fixed; inset:0; z-index:1000; background:rgba(0,0,0,.78); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; padding:2rem 1rem; opacity:0; visibility:hidden; transition:opacity .25s, visibility .25s; }
.modal-backdrop.open { opacity:1; visibility:visible; }
.modal-card { position:relative; width:min(720px,100%); max-height:90vh; overflow-y:auto; background:var(--bg-1); border:1px solid var(--line); border-radius:16px; box-shadow:0 30px 80px rgba(0,0,0,.7); transform:scale(.94) translateY(12px); transition:transform .3s var(--ease); }
.modal-backdrop.open .modal-card { transform:none; }
.modal-close { position:absolute; top:1rem; right:1rem; z-index:3; width:40px; height:40px; border-radius:50%; background:rgba(0,0,0,.6); color:#fff; border:none; cursor:pointer; font-size:1.1rem; backdrop-filter:blur(8px); display:grid; place-items:center; transition:background .15s; }
.modal-close:hover { background:var(--red); }
.modal-hero { position:relative; height:300px; background-size:cover; background-position:center; border-radius:16px 16px 0 0; }
.modal-hero-veil { position:absolute; inset:0; background:linear-gradient(0deg,var(--bg-1) 2%,transparent 60%),linear-gradient(90deg,rgba(14,14,17,.6),transparent 60%); }
.modal-hero-title { position:absolute; left:1.8rem; bottom:1.1rem; right:1.8rem; }
.modal-kind { display:inline-block; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ember); font-weight:700; margin-bottom:.4rem; }
.modal-hero-title h3 { font-family:"Bebas Neue",sans-serif; font-size:2.6rem; line-height:.95; color:#fff; text-shadow:0 2px 16px rgba(0,0,0,.8); }
.modal-body { padding:1.4rem 1.8rem 1.8rem; }
.modal-meta { display:flex; align-items:center; gap:.55rem; flex-wrap:wrap; color:var(--dim); font-size:.92rem; margin-bottom:1rem; }
.modal-meta .dot { color:var(--mute); }
.m-rating { border:1px solid var(--mute); border-radius:3px; padding:0 .35rem; font-size:.8rem; }
.modal-overview { color:var(--txt); line-height:1.6; margin-bottom:1.1rem; font-size:.98rem; }
.modal-dim { color:var(--mute); font-style:italic; }
.modal-genres { display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1.5rem; }
.m-genre { font-size:.8rem; color:var(--dim); background:var(--bg-3); border:1px solid var(--line); border-radius:20px; padding:.25rem .8rem; }
.modal-actions { display:flex; gap:.7rem; flex-wrap:wrap; }
.modal-note { margin-top:1rem; font-size:.82rem; color:var(--mute); }
@media (max-width:540px){ .modal-hero { height:210px; } .modal-hero-title h3 { font-size:2rem; } .modal-body { padding:1.2rem 1.2rem 1.5rem; } .modal-actions .btn { flex:1; } }

/* ─── Bannière inscriptions fermées ─── */
.closed-banner { display:flex; flex-direction:column; gap:.4rem; background:rgba(229,9,20,.12); border:1px solid rgba(229,9,20,.4); border-radius:10px; padding:1rem 1.3rem; margin:0 auto 1.6rem; max-width:520px; text-align:center; font-size:.95rem; color:var(--txt); }
.closed-banner strong { color:var(--ember); font-size:1.02rem; }
.closed-banner span { color:var(--dim); font-size:.9rem; }
.closed-banner a { color:var(--ember); }

/* ─── Rangée TENDANCES numérotée (style Netflix Top 10) ─── */
.row-top10 .row-track { gap: 4px; padding: 34px 8px 34px; align-items: flex-end; overflow-y: visible; }
.poster-num {
  flex: 0 0 auto;
  display: flex; align-items: flex-end;
  position: relative;
  cursor: pointer; background: none; border: none; padding: 0;
  margin-right: clamp(4px, 1vw, 14px);
  transition: transform .28s var(--ease);
}
.poster-num:hover { transform: scale(1.05) translateY(-6px); z-index: 5; }
/* le chiffre prend sa place À GAUCHE, l'affiche est à côté (pas par-dessus) */
.poster-num .rank {
  flex: 0 0 auto;
  font-family: "Bebas Neue", sans-serif;
  font-size: clamp(110px, 13vw, 190px); line-height: .7;
  color: #0d0d10;
  -webkit-text-stroke: 2px var(--red);
  text-stroke: 2px var(--red);
  margin-right: -.12em;
  user-select: none; pointer-events: none;
  position: relative; z-index: 0;
  text-shadow: 0 0 30px rgba(229,9,20,.25);
}
.poster-num .pn-img {
  position: relative; z-index: 1;
  width: clamp(120px, 12vw, 165px); aspect-ratio: 2/3;
  border-radius: 8px; overflow: hidden; flex: 0 0 auto;
  box-shadow: 0 8px 28px rgba(0,0,0,.6);
}
.poster-num .pn-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; display: block; }
.poster-num:hover .pn-img img { transform: scale(1.08); }
.poster-num .pn-overlay {
  position: absolute; inset: 0; z-index: 2;
  background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,.85));
  display: flex; align-items: flex-end; justify-content: flex-end; padding: .5rem;
  opacity: 0; transition: opacity .25s;
}
.poster-num:hover .pn-overlay { opacity: 1; }
.poster-num .poster-info-ic { width: 30px; height: 30px; font-size: .9rem; }


/* ─── Garde-fou couleurs de texte des boutons (anti-héritage de lien) ─── */
a.btn-primary, a.btn-primary:hover, a.btn-primary:visited { color:#fff !important; }
a.btn-glass, a.btn-glass:hover, a.btn-glass:visited { color:#fff !important; }
a.btn-ghost, a.btn-ghost:hover, a.btn-ghost:visited { color:var(--txt) !important; }
a.btn-line, a.btn-line:visited { color:var(--dim) !important; }
a.btn-line:hover { color:var(--txt) !important; }

/* ════════════════════════════════════════════════════════════
   SECTION APPAREILS — cartes avec vrais logos
   ════════════════════════════════════════════════════════════ */
.grid-dev { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:1.3rem; }
.dev-card {
  display:flex; flex-direction:column;
  background:linear-gradient(180deg,var(--bg-2),var(--bg-1));
  border:1px solid var(--line); border-radius:16px;
  padding:1.8rem; min-height:230px;
  transition:transform .25s var(--ease), border-color .25s, box-shadow .25s;
}
.dev-card:hover { transform:translateY(-5px); border-color:rgba(229,9,20,.4); box-shadow:0 18px 44px -22px rgba(229,9,20,.45); }
.dev-logos { display:flex; gap:1rem; align-items:center; flex-wrap:wrap; margin-bottom:1.4rem; min-height:40px; }
.dev-logos img { width:32px; height:32px; object-fit:contain; opacity:1; transition:transform .2s; }
.dev-card:hover .dev-logos img { opacity:1; }
.dev-logos img:hover { transform:scale(1.15); }
.dev-info { flex:1; }
.dev-info h3 { font-size:1.15rem; margin-bottom:.4rem; }
.dev-info p { color:var(--dim); font-size:.9rem; }
.dev-action { margin-top:1.2rem; color:var(--ember); font-size:.9rem; font-weight:600; transition:color .15s; }
.dev-action:hover { color:var(--red-hot); }
.dev-links { margin-top:1.2rem; display:flex; gap:.6rem; flex-wrap:wrap; }
.dev-links a { font-size:.82rem; font-weight:600; color:var(--txt); background:var(--bg-3); border:1px solid var(--line); border-radius:8px; padding:.45rem .85rem; transition:all .15s; }
.dev-links a:hover { border-color:rgba(229,9,20,.5); color:#fff; background:rgba(229,9,20,.12); }
.dev-note { text-align:center; margin-top:2.5rem; color:var(--mute); font-size:.9rem; display:flex; align-items:center; justify-content:center; gap:.4rem; flex-wrap:wrap; }
.dev-jelly { width:18px; height:18px; vertical-align:middle; }

/* ─── CTA sous le catalogue (centré) ─── */
.catalogue-cta {
  margin-top: 2.5rem;
  display: flex; flex-direction: column; align-items: center; text-align: center;
}
.catalogue-cta p { color: var(--dim); font-size: 1.05rem; margin-bottom: 1.3rem; max-width: 48ch; }
.catalogue-cta .btn { align-self: center; }
.modal-noinfo { color:var(--mute); font-size:.9rem; font-style:italic; }

/* ════════════════════════════════════════════════════════════
   PAGE INSCRIPTIONS FERMÉES
   ════════════════════════════════════════════════════════════ */
.closed-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:8rem 1.5rem 4rem; position:relative; isolation:isolate; }
.closed-page::before { content:""; position:absolute; inset:0; z-index:-1; background:radial-gradient(ellipse 50% 50% at 50% 40%, rgba(229,9,20,.12), transparent 70%); }
.closed-inner { text-align:center; max-width:560px; }
.closed-icon { width:90px; height:90px; margin:0 auto 1.5rem; }
.closed-page h1 { font-size:clamp(2.4rem,6vw,4rem); margin-bottom:1.2rem; }
.closed-text { color:var(--dim); font-size:1.12rem; line-height:1.7; margin-bottom:2rem; }
.closed-mail { margin-top:1.4rem; color:var(--mute); font-size:.95rem; }
.closed-mail-link { color:var(--ember); }
.closed-back { display:inline-block; margin-top:2.5rem; color:var(--mute); font-size:.9rem; }
.closed-back:hover { color:var(--txt); }

/* ════════════════════════════════════════════════════════════
   POPUP AVERTISSEMENT AVANT INSCRIPTION
   ════════════════════════════════════════════════════════════ */
.warn-backdrop { position:fixed; inset:0; z-index:2000; background:rgba(0,0,0,.8); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; padding:1.5rem; opacity:0; visibility:hidden; transition:opacity .25s, visibility .25s; }
.warn-backdrop.open { opacity:1; visibility:visible; }
.warn-card { width:min(480px,100%); background:var(--bg-1); border:1px solid var(--line); border-radius:18px; padding:2.4rem 2rem 2rem; text-align:center; box-shadow:0 30px 80px rgba(0,0,0,.7); transform:scale(.94) translateY(12px); transition:transform .3s var(--ease); }
.warn-backdrop.open .warn-card { transform:none; }
.warn-icon { width:64px; height:64px; margin:0 auto 1.3rem; display:grid; place-items:center; border-radius:50%; background:radial-gradient(circle,rgba(229,9,20,.2),rgba(229,9,20,.05)); border:1px solid rgba(229,9,20,.3); }
.warn-icon svg { width:32px; height:32px; }
.warn-card h3 { font-family:"Bebas Neue",sans-serif; font-size:1.9rem; margin-bottom:.8rem; color:var(--txt); letter-spacing:.01em; }
.warn-card p { color:var(--dim); font-size:.98rem; line-height:1.65; margin-bottom:1rem; }
.warn-card .warn-sub { font-size:.86rem; color:var(--mute); margin-bottom:1.8rem; }
.warn-actions { display:flex; gap:.8rem; flex-direction:column; }
.warn-actions .btn { width:100%; }
.warn-cancel { background:none; border:none; color:var(--mute); cursor:pointer; font-size:.9rem; padding:.6rem; transition:color .15s; }
.warn-cancel:hover { color:var(--txt); }
