/* =========================
   Entracte Streaming – STYLE GLOBAL
   ========================= */

/* Variables globales */
:root {
  --ent-primary: #2a7bc2;
  --ent-secondary: #6f42c1;
  --ent-accent: #FFA500;
  --ent-bg: #0a0d12;
  --ent-card: #0f1520;
  --ent-dark: #0b0f15;
  --ent-muted: #a7b1c2;
  --ent-border: rgba(255,255,255,.06);
  --ent-yellow: #FFD45A;
  --ent-red: #FF6B6B;
}

/* Global */
* { box-sizing: border-box; }

/* === Sticky Footer GLOBAL === */
html, body {
  height: 100%;
  margin: 0;
  padding: 0;
}
body {
  background: var(--ent-bg);
  color: #eaf0f7;
  font-family: 'Quicksand', system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, 'Helvetica Neue', Arial, sans-serif;

  display: flex;           /* ⬅️ footer sticky */
  flex-direction: column;  /* ⬅️ footer collé en bas */
  min-height: 100vh;       /* ⬅️ indispensable */
}

main, main.wrap, .wrap {
  flex: 1 0 auto;          /* ⬅️ permet au footer de descendre */
}

footer.footer {
  margin-top: auto;        /* ⬅️ pousse en bas naturellement */
}
/* === FIN Sticky Footer === */

a { color:#fff; text-decoration:none; }
a:hover { opacity:.9; }

/* Boutons */
.btn-main {
  display:inline-flex; align-items:center; gap:.5rem;
  background:linear-gradient(135deg,var(--ent-primary),var(--ent-secondary));
  border:0; color:#fff!important;
  padding:.6rem 1rem; border-radius:999px;
  box-shadow:0 10px 24px rgba(42,123,194,.25);
  transition:transform .15s ease, filter .15s ease;
}
.btn-main:hover { transform:translateY(-1px); filter:brightness(1.05); }

.btn-ghost {
  border:1px solid var(--ent-border);
  padding:.55rem 1rem; border-radius:999px; color:#fff;
}

/* Header / Nav */
.header {
  position:sticky; top:0; z-index:20;
  background:rgba(10,13,18,.6);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--ent-border);
}
.header .brand img { height:46px; }
.nav-link { color:#cfd6e4 !important; }

/* Badge palier/role */
.tier-badge {
  display:inline-block;
  font-weight:700;
  letter-spacing:.02em;
  padding:.25rem .55rem;
  border-radius:999px;
  font-size:.78rem;
  border:1px solid var(--ent-border);
  background:rgba(0,0,0,.35);
  color:#eaf0f7;
}
.tier-badge.t-basic { background:rgba(111,111,111,.25); }
.tier-badge.t-premium { background:linear-gradient(135deg,#2a7bc2,#6f42c1); }
.tier-badge.t-ultimate { background:linear-gradient(135deg,#ffb703,#fb8500); color:#1a1a1a; }
.tier-badge.t-admin { background:linear-gradient(135deg,#22c55e,#16a34a); color:#071b0a; }

/* Hero */
.hero {
  position:relative;
  min-height: 62vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:url('../images/posters/movie-collection.jpg') center/cover no-repeat;
  margin-top: 0;
}
.hero::before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(10,13,18,.75), rgba(10,13,18,.85));
}
.hero .inner {
  position:relative;
  z-index:1;
  text-align:center;
  max-width:900px;
  padding:3rem 1rem;
}
.hero h1 {
  font-weight:800;
  letter-spacing:.3px;
  margin-bottom:.8rem;
}
.hero p {
  color:#d5deea;
  margin-bottom:1.4rem;
}

/* Sections */
.section { padding:48px 0; }
.section h2 { margin:0; }
.section-head {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:12px; gap:14px; flex-wrap:nowrap;
}
.section-sub { color:#e0e8f5c7; font-size:.95rem; margin-top:4px; }
.actions { margin-left:auto; flex:0 0 auto; }

/* GRILLES DE CARTES */
.grid {
  display: grid;
  gap: 20px;

  /* Desktop dynamique */
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

/* Très grands écrans */
@media (min-width: 1600px) {
  .grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  }
}

/* Mobile */
@media (max-width: 575px) {
  .grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media(min-width:992px){
  .grid{ grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); }
}

.grid.compact {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 20px;
}
@media (min-width: 1400px) {
  .grid.compact {
    grid-template-columns: repeat(6, 1fr);
  }
}
@media (max-width: 991px) {
  .grid.compact {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 575px) {
  .grid.compact {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* === Cartes grand format === */
.card {
  position: relative;
  background-color: var(--ent-card);
  border: 1px solid var(--ent-border);
  border-radius: 14px;
  overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease;
}
.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, .4);
}
.card .poster {
  width: 100%;
  aspect-ratio: 2 / 3;
  object-fit: cover;
  display: block;
  background: #0b101a;
}
.card .card-body {
  padding: 12px 14px 20px;
  color: #fff;
  text-align: center;
  background: var(--ent-card);
}
.card .title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 4px;
  color: #fff;
}
.card .year {
  display: block;
  font-size: 0.85rem;
  color: var(--ent-muted);
}
.card .tag {
  position: absolute;
  right: 8px;
  bottom: 8px;
  background: rgba(0, 0, 0, 0.65);
  border: 1px solid var(--ent-border);
  color: #fff;
  padding: 4px 8px;
  border-radius: 8px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

/* Countdown normal */
.card .countdown {
  position: absolute;
  top: 8px;
  left: 8px;
  background: rgba(180,180,180,0.9);
  color: #000;
  font-size: 0.85rem;
  font-weight: 600;
  border-radius: 8px;
  padding: 3px 6px;
}

.card .countdown.yellow {
  background: rgba(255,212,90,0.9);
  color: #2a2a2a;
}

.card .countdown.red {
  background: rgba(255,107,107,0.9);
  color: #fff;
}

/* Soon (violet) */
.card .countdown.soon {
  background: linear-gradient(135deg, var(--ent-primary), var(--ent-secondary));
  color: #fff;
  border: 1px solid rgba(255,255,255,0.12);
}

/* --- Cartes petit format --- */
.card-min {
  position: relative;
  background-color: var(--ent-card);
  border: 1px solid var(--ent-border);
  border-radius: 16px;
  overflow: hidden;
}
.card-min .poster {
  width: 100%;
  aspect-ratio: 2 / 2.8;
  object-fit: cover;
  display: block;
  background: #0b101a;
}
.card-min .card-body {
  padding: 14px 16px;
  color: #fff;
  background: var(--ent-card);
  text-align: left;
}
.card-min .title {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 4px;
  color: #fff;
}
.card-min .year {
  display: block;
  font-size: 0.85rem;
  color: var(--ent-muted);
}
.card-min .countdown {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(180,180,180,0.9);
  color: #000;
  font-size: 0.85rem;
  font-weight: 600;
  border-radius: 10px;
  padding: 4px 7px;
}
.card-min .countdown.yellow {
  background: rgba(255,212,90,0.9);
  color: #2a2a2a;
}
.card-min .countdown.red {
  background: rgba(255,107,107,0.9);
  color: #fff;
}
.card-min .countdown.soon {
  background: linear-gradient(135deg, var(--ent-primary), var(--ent-secondary));
  color: #fff;
  border: 1px solid rgba(255,255,255,0.12);
}

/* Footer */
.footer {
  border-top:1px solid var(--ent-border);
  padding:26px 0;
  color:#aab4c5;
  background:#0b0f15;
}

/* Marquee */
.marquee { overflow:hidden; position:relative; }
.marquee .track {
  display:flex; gap:12px; will-change:transform;
  animation: scroll-linear 60s linear infinite;
}
.marquee:hover .track{ animation-play-state:paused; }
@keyframes scroll-linear {
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

/* Helpers */
.cta-banner {
  background:linear-gradient(135deg, rgba(42,123,194,.25), rgba(111,66,193,.25));
  border:1px solid var(--ent-border);
  border-radius:16px;
}

/* Catalog & divers */
.pill {
  position:absolute; right:8px; bottom:8px;
  border:1px solid var(--ent-border);
  border-radius:999px; padding:.15rem .5rem;
  font-size:.72rem; color:#cfe3ff;
  background:rgba(0,0,0,.35);
}
.filters {
  display:flex; gap:10px; flex-wrap:wrap; align-items:center;
  background:#0b0f15; border:1px solid var(--ent-border);
  border-radius:12px; padding:10px; margin-bottom:14px;
}
.filters label { margin:0; font-size:.9rem; color:#cfe3ff; }
.filters select {
  background:#0f1520; color:#eaf0f7;
  border:1px solid var(--ent-border); border-radius:10px;
  padding:.35rem .6rem; outline:none;
}

/* Pagination */
.pagination { display:flex; gap:8px; flex-wrap:wrap; }
.page-link {
  background:#0b0f15; border:1px solid var(--ent-border);
  padding:.45rem .75rem; border-radius:10px; color:#eaf0f7;
}
.page-link:hover { background:#0f1520; }
.page-link.active {
  background:linear-gradient(135deg,var(--ent-primary),var(--ent-secondary));
  border-color:transparent;
}
.page-link.disabled { opacity:.45; pointer-events:none; }

/* Nav active */
.navbar-nav .nav-link.active {
  opacity:1; position:relative;
}
.navbar-nav .nav-link.active::after {
  content:""; position:absolute; left:0; right:0; bottom:-6px;
  height:2px; border-radius:2px;
  background:linear-gradient(90deg,var(--ent-primary),var(--ent-secondary));
}