*{box-sizing:border-box}body{margin:0;background:#08111d;color:#edf3ff;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif}.app{max-width:1580px;margin:0 auto;padding:34px 28px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.topbar h1{font-size:34px;letter-spacing:.5px;margin:0}.topbar p{margin:6px 0 0;color:#8fa0b8}.status{display:flex;gap:10px;align-items:center}.pill{padding:9px 14px;border-radius:999px;border:1px solid #29364b;background:#111b2b}.pill.ok{color:#50e3a4;border-color:#1e7251}.pill.ko{color:#ff9696;border-color:#783434}.btn,.icon-btn,.tab,.subtab{border:1px solid #2b374b;background:#172235;color:#edf3ff;border-radius:14px;padding:12px 18px;cursor:pointer;font-weight:650}.btn:hover,.icon-btn:hover,.tab:hover,.subtab:hover{background:#223149}.btn.primary{background:linear-gradient(135deg,#7bd5ff,#9b79ff);border:0;color:#06101e}.login-card{max-width:520px;margin:90px auto;background:#101a2a;border:1px solid #253249;border-radius:28px;padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.32)}.login-card h2{margin:0 0 8px}.muted{color:#99a8bd}.login-form{display:grid;gap:16px;margin-top:20px}.login-form label{display:grid;gap:8px;color:#b9c5d7}.login-form input,.search,.select{width:100%;background:#080f1b;color:#edf3ff;border:1px solid #1f2b3f;border-radius:14px;padding:14px 16px;outline:none}.login-form input:focus,.search:focus,.select:focus{border-color:#5aaee8}.msg{color:#ffb3b3;min-height:24px}.player-layout{display:grid;grid-template-columns:410px 1fr;gap:22px}.sidebar,.content{background:#101a2a;border:1px solid #233149;border-radius:24px;padding:18px}.tabs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px}.tab.active,.subtab.active{background:linear-gradient(135deg,#7bd5ff,#9b79ff);border:0;color:#06101e}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.panel-head h2{margin:0;font-size:22px}.icon-btn{width:44px;height:44px;padding:0;border-radius:16px}.search,.select{margin-bottom:14px}.select.small{width:auto;min-width:150px;margin:0}.subtabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.list{height:630px;overflow:auto;padding-right:6px}.item{display:flex;align-items:center;gap:12px;margin-bottom:9px;padding:11px;border-radius:18px;background:#182235;border:1px solid transparent;cursor:pointer}.item:hover,.item.active{border-color:#4c95c9;background:#1a3045}.logo{width:48px;height:48px;border-radius:14px;background:#283447;display:flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto}.logo img{width:100%;height:100%;object-fit:contain}.logo span{font-weight:900;color:#dbe8ff}.meta{min-width:0;flex:1}.meta strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:15px}.meta small{display:block;color:#95a5bd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px}.star{background:transparent;border:0;color:#ffd75c;font-size:18px;cursor:pointer}.video-wrap{position:relative;background:#3e4142;border-radius:22px;overflow:hidden;min-height:540px}video{display:block;width:100%;height:540px;background:#3e4142;object-fit:contain}.empty-player{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#d9e2ef;text-align:center;background:rgba(20,22,24,.4)}.empty-player.hidden{display:none}.now{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:16px;background:#172235;border:1px solid #27354d;border-radius:18px;padding:14px 16px}.now h2{font-size:22px;margin:0}.now p{margin:5px 0 0;color:#9aacbf}.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.note{margin-top:14px;background:#172235;border:1px solid #27354d;border-radius:16px;padding:12px 14px;color:#c8d3e2}.loading,.empty-list,.error{padding:22px;color:#aebbd0;text-align:center}.error{color:#ffb3b3}.series-box{margin-top:18px;background:#0f1827;border:1px solid #25344e;border-radius:20px;padding:16px}.series-box.hidden{display:none}.series-box h3{margin:0 0 12px}.episodes h4{margin:20px 0 10px;color:#dbe8ff}.episode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.episode{background:#172235;color:#edf3ff;border:1px solid #2b374b;border-radius:14px;padding:12px;text-align:left;cursor:pointer}.episode:hover{border-color:#5aaee8;background:#20304a}.episode strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.episode small{color:#98a7bc}@media(max-width:960px){.app{padding:18px}.player-layout{grid-template-columns:1fr}.list{height:420px}.topbar{align-items:flex-start;gap:12px}.now{align-items:flex-start;flex-direction:column}video,.video-wrap{height:auto;min-height:260px}.video-wrap video{height:360px}}

.result-info{font-size:13px;color:#91a4bc;margin:-5px 0 12px 2px}
.load-more,.end-list{width:100%;margin:8px 0 0;padding:14px;border-radius:16px;border:1px solid #2b374b;background:#172235;color:#edf3ff;font-weight:800;cursor:pointer}
.load-more:hover{background:#223149}
.end-list{cursor:default;color:#9dafc5;text-align:center;background:#111b2b}
.btn.small-btn{padding:8px 12px;border-radius:12px;font-size:13px}
.epg-box{margin-top:18px;background:#0f1827;border:1px solid #25344e;border-radius:20px;padding:16px}
.epg-box.hidden{display:none}
.epg-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.epg-head h3{margin:0}
.epg-list{display:grid;gap:10px}
.epg-item{display:grid;grid-template-columns:110px 1fr;gap:12px;padding:12px;border-radius:16px;border:1px solid #283852;background:#142033}
.epg-item.current{border-color:#5aaee8;background:#17304a}
.epg-time{font-weight:900;color:#8fd3ff}
.epg-meta strong{display:block}
.epg-meta p{margin:5px 0 0;color:#aebbd0;line-height:1.35}
@media(max-width:700px){.epg-item{grid-template-columns:1fr}.epg-time{font-size:13px}}

.play-status{display:inline-flex;align-items:center;padding:10px 13px;border-radius:999px;background:#0d271d;border:1px solid #1e7251;color:#65e8ac;font-weight:850;white-space:nowrap}


.section-hint{font-size:12px;color:#6f86a3;margin:-4px 0 14px 2px}
.sidebar{display:flex;flex-direction:column}
.list.live-list{height:630px;overflow:auto;padding-right:6px;display:block}
.list.media-grid{height:630px;overflow:auto;padding-right:4px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-content:start}
.poster-card{position:relative;display:flex;flex-direction:column;min-width:0;cursor:pointer;background:#182235;border:1px solid #22344b;border-radius:18px;overflow:hidden;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}
.poster-card:hover,.poster-card.active{transform:translateY(-2px) scale(1.02);border-color:#63b4f4;box-shadow:0 10px 28px rgba(0,0,0,.28)}
.poster-thumb{aspect-ratio:2/3;width:100%;background:linear-gradient(180deg,#20324b,#0f1827);display:flex;align-items:center;justify-content:center;overflow:hidden}
.poster-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.poster-thumb.no-thumb span,.episode-thumb span{font-size:36px;font-weight:900;color:#dbe8ff}
.poster-info{padding:12px}
.poster-info strong{display:block;font-size:14px;line-height:1.28;min-height:36px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.poster-info small{display:block;margin-top:6px;color:#95a5bd;line-height:1.25;min-height:32px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.poster-star{position:absolute;top:10px;right:10px;z-index:2;width:34px;height:34px;border-radius:999px;background:rgba(8,15,27,.74);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08)}
.actions .btn,.actions .play-status{height:44px}
.video-wrap{box-shadow:inset 0 0 0 1px rgba(255,255,255,.03)}
.note{line-height:1.45}
.episodes h4{font-size:18px;margin:24px 0 12px}
.episode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}
.episode{display:flex;flex-direction:column;gap:10px;padding:0;overflow:hidden;background:#172235;color:#edf3ff;border:1px solid #2b374b;border-radius:16px;text-align:left;cursor:pointer}
.episode:hover{border-color:#5aaee8;background:#20304a;transform:translateY(-1px)}
.episode-thumb{aspect-ratio:16/9;background:linear-gradient(180deg,#20324b,#0f1827);display:flex;align-items:center;justify-content:center;overflow:hidden}
.episode-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.episode strong,.episode small{padding:0 12px 0 12px}
.episode strong{padding-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.episode small{padding-bottom:12px;color:#98a7bc}
.topbar{padding:4px 2px}
@media (max-width:1350px){.list.media-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:960px){.list.media-grid{grid-template-columns:repeat(3,minmax(0,1fr));height:460px}}
@media (max-width:680px){.list.media-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.actions{width:100%}.actions .btn{flex:1 1 auto}.actions .play-status{width:100%;justify-content:center}}


.player-layout.tv-mode{display:grid;grid-template-columns:410px 1fr;gap:22px}
.player-layout.catalog-mode{display:grid;grid-template-columns:1fr;gap:20px}
.player-layout.catalog-mode .content{order:1}
.player-layout.catalog-mode .sidebar{order:2;padding-top:16px}
.player-layout.catalog-mode .video-wrap{min-height:0;height:auto;background:#0f1827;border:1px solid #25344e}
.player-layout.catalog-mode video{height:420px;background:#0a111b}
.player-layout.catalog-mode .list.media-grid{height:auto;max-height:none;overflow:visible;grid-template-columns:repeat(6,minmax(0,1fr));gap:18px}
.player-layout.catalog-mode .sidebar{background:#0f1827;border:1px solid #223149}
.player-layout.catalog-mode .content{background:transparent;border:0;padding:0}
.player-layout.catalog-mode .note,.player-layout.catalog-mode .epg-box{display:none}
.catalog-info{position:relative;overflow:hidden;border-radius:28px;border:1px solid #2a3850;background:#111b2b;min-height:360px;margin-top:18px}
.catalog-info.hidden{display:none}
.catalog-backdrop{position:absolute;inset:0;background-size:cover;background-position:center center;filter:blur(10px);transform:scale(1.08);opacity:.32}
.catalog-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,12,21,.92) 0%, rgba(9,14,24,.84) 45%, rgba(10,16,28,.72) 100%)}
.catalog-grid{position:relative;z-index:1;display:grid;grid-template-columns:260px 1fr;gap:26px;align-items:center;padding:28px}
.catalog-poster{width:100%;max-width:260px;aspect-ratio:2/3;border-radius:24px;overflow:hidden;background:linear-gradient(180deg,#223149,#101a2a);box-shadow:0 18px 48px rgba(0,0,0,.35)}
.catalog-poster img{width:100%;height:100%;object-fit:cover;display:block}
.poster-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:900;color:#dbe8ff;letter-spacing:1px}
.catalog-kicker{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(113,187,255,.12);color:#98d7ff;border:1px solid rgba(113,187,255,.25);font-weight:800;margin-bottom:12px}
.catalog-copy h3{font-size:42px;line-height:1.05;margin:0 0 14px;max-width:780px}
.catalog-badges{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.catalog-badge{display:inline-flex;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#edf3ff;font-weight:700}
.catalog-badge.hidden{display:none}
.catalog-description{font-size:16px;line-height:1.6;color:#d0d9e7;max-width:900px;margin:0}
.player-layout.catalog-mode .now{margin-top:18px;background:#101a2a}
.player-layout.catalog-mode .section-hint{font-size:13px;color:#8fa8c8}
.player-layout.catalog-mode .tabs{max-width:420px}
.player-layout.catalog-mode .panel-head{margin-top:4px}
.player-layout.catalog-mode .list .load-more,.player-layout.catalog-mode .list .end-list{grid-column:1/-1}
.player-layout.catalog-mode .result-info{margin-bottom:8px}
.player-layout.catalog-mode .poster-card{border-radius:20px}
.player-layout.catalog-mode .poster-thumb{aspect-ratio:2/3.05}
.player-layout.catalog-mode .poster-info strong{font-size:15px;min-height:38px}
.player-layout.catalog-mode .poster-info small{min-height:36px}
@media (max-width:1600px){.player-layout.catalog-mode .list.media-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}
@media (max-width:1340px){.player-layout.catalog-mode .list.media-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.catalog-grid{grid-template-columns:220px 1fr}.catalog-copy h3{font-size:34px}}
@media (max-width:980px){.player-layout.catalog-mode .list.media-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.catalog-grid{grid-template-columns:1fr}.catalog-poster{max-width:220px}.catalog-copy h3{font-size:28px}}
@media (max-width:680px){.player-layout.catalog-mode .list.media-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.catalog-grid{padding:20px}.catalog-copy h3{font-size:24px}.player-layout.catalog-mode video{height:240px}}

/* v2.0 : le bandeau catalogue vide est supprimé.
   Quand les détails apparaissent après un clic, ils sont plus compacts. */
.catalog-info{min-height:260px}
.catalog-grid{grid-template-columns:170px 1fr;padding:22px;gap:22px}
.catalog-poster{max-width:170px;border-radius:18px}
.catalog-copy h3{font-size:32px;margin-bottom:10px}
.catalog-description{font-size:15px;line-height:1.5}
@media (max-width:980px){
  .catalog-grid{grid-template-columns:130px 1fr}
  .catalog-poster{max-width:130px}
  .catalog-copy h3{font-size:24px}
}
@media (max-width:680px){
  .catalog-grid{grid-template-columns:1fr}
  .catalog-poster{display:none}
}

.play-status{max-width:220px;overflow:hidden;text-overflow:ellipsis}


/* v2.2 : plein écran cinéma avec vraies bandes noires */
.video-wrap,
.video-wrap video,
video {
  background:#000 !important;
}

video {
  object-fit:contain;
}

.video-wrap:fullscreen,
.video-wrap:-webkit-full-screen,
.video-wrap:-moz-full-screen,
.video-wrap:-ms-fullscreen {
  background:#000 !important;
  border-radius:0 !important;
}

.video-wrap:fullscreen video,
.video-wrap:-webkit-full-screen video,
.video-wrap:-moz-full-screen video,
.video-wrap:-ms-fullscreen video,
video:fullscreen,
video:-webkit-full-screen,
video:-moz-full-screen,
video:-ms-fullscreen {
  width:100% !important;
  height:100% !important;
  background:#000 !important;
  object-fit:contain !important;
}

.video-wrap:fullscreen .empty-player,
.video-wrap:-webkit-full-screen .empty-player,
.video-wrap:-moz-full-screen .empty-player,
.video-wrap:-ms-fullscreen .empty-player {
  background:#000 !important;
}


/* v2.3 : comptes utilisateurs */
.pill.soft{background:#102033;color:#9fd6ff;border-color:#315f86}
.account-card{max-width:960px}
.account-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:22px}
.account-grid .login-form{background:#0c1524;border:1px solid #25344e;border-radius:22px;padding:18px}
.account-grid h3{margin:0 0 4px;font-size:20px}
.security-note{margin:18px 0 0;color:#8fa0b8;line-height:1.45}
@media(max-width:820px){.account-grid{grid-template-columns:1fr}.status{flex-wrap:wrap}}


/* v2.5 : barre durée légère, sans casser la lecture native */
.cinema-progress{
  margin-top:12px;
  padding:12px 14px;
  border-radius:16px;
  background:#080b10;
  border:1px solid rgba(255,255,255,.08);
  color:#edf3ff;
}
.cinema-progress.hidden{display:none}
.cinema-row{
  display:grid;
  grid-template-columns:70px 1fr 80px;
  gap:12px;
  align-items:center;
  font-variant-numeric:tabular-nums;
  font-weight:800;
}
.cinema-seek{
  width:100%;
  accent-color:#ffffff;
}
.cinema-hint{
  margin-top:6px;
  color:#9dacbf;
  font-size:12px;
}
.video-wrap,
.video-wrap video,
video {
  background:#000 !important;
}
video {
  object-fit:contain;
}


/* v2.6 : retour aux contrôles natifs uniquement */
.cinema-progress{display:none !important}


/* v2.7 : choix pistes MKV */
.track-box{
  margin-top:14px;
  background:#0f1827;
  border:1px solid #25344e;
  border-radius:20px;
  padding:16px;
}
.track-box.hidden{display:none}
.track-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.track-head h3{
  margin:0;
  font-size:18px;
}
.track-head span{
  color:#91a4bc;
  font-size:13px;
}
.track-controls{
  display:grid;
  grid-template-columns:1fr 1fr auto;
  gap:12px;
  align-items:end;
}
.track-controls label{
  display:grid;
  gap:7px;
  color:#b9c5d7;
  font-size:13px;
}
.track-controls .select{
  margin:0;
}
.track-msg{
  margin-top:10px;
  color:#9dacbf;
  font-size:13px;
}
@media(max-width:780px){
  .track-controls{grid-template-columns:1fr}
}


/* v2.8 : pistes MKV visibles directement dans la barre d'actions */
.track-inline{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  padding:6px;
  border-radius:16px;
  background:#0b1422;
  border:1px solid #28415f;
}
.track-inline.hidden{display:none}
.track-select{
  width:auto;
  min-width:155px;
  max-width:240px;
  margin:0 !important;
  padding:10px 12px;
  border-radius:12px;
  font-size:13px;
}
.track-apply{
  padding:10px 12px;
  border-radius:12px;
}
.track-msg-inline{
  color:#9dacbf;
  font-size:12px;
  max-width:100px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
@media(max-width:900px){
  .track-inline{
    width:100%;
  }
  .track-select{
    flex:1 1 180px;
    max-width:none;
  }
  .track-msg-inline{
    max-width:none;
  }
}


/* v2.9 : les sous-titres image PGS/VobSub sont sélectionnables et seront incrustés */
.track-msg-inline{min-width:62px}

/* v3.0 : live HTTPS proxy */
