/* ============================================================================
   AubeTV — lecteur de chaînes en direct. Identité « régie / salle de projection » :
   sombre mais éditorial. Serif Fraunces en titres, JetBrains Mono pour les
   timecodes, palette signée (ambre piste, phosphore antenne, rouge signal).
   ========================================================================== */
:root {
  --bg:#08080b; --bg-2:#0e0e13; --bg-3:#16161d; --bg-4:#1e1e26;
  --rule:#25252e; --rule-soft:#1a1a21;
  --ink:#f1ede1; --ink-soft:#b8b3a6; --ink-mute:#76746d;
  --amber:#e0a23c; --amber-2:#c4842f; --phosphor:#4ea993; --signal:#cf4838;
  --serif:'Fraunces','Cormorant Garamond',Georgia,serif;
  --sans:'Inter',-apple-system,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --maxw:1320px; --tile-w:230px;
}
* { box-sizing:border-box; }
/* IMPORTANT : l'attribut HTML `hidden` doit TOUJOURS l'emporter. Sinon une classe
   qui pose `display:flex/inline-flex` (ex. .player-error, .sound-btn) écrase la règle
   navigateur `[hidden]{display:none}` (même spécificité, author après UA) et l'élément
   reste visible quoi que fasse le JS. Ce bug rendait l'overlay « Signal indisponible »
   et le bouton son toujours affichés. */
[hidden] { display: none !important; }
html { scroll-behavior:smooth; }
body {
  margin:0; font-family:var(--sans); font-size:15px; line-height:1.55; color:var(--ink);
  background:radial-gradient(120% 80% at 100% -10%,#12121a 0,transparent 55%),
             radial-gradient(90% 70% at -10% 0%,#12100c 0,transparent 50%),var(--bg);
  min-height:100vh; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
a { color:inherit; text-decoration:none; }
img { display:block; }
button { font-family:inherit; cursor:pointer; }
::selection { background:var(--amber); color:#1a1206; }

.serif { font-family:var(--serif); font-weight:600; letter-spacing:-.015em; line-height:1.04; }
.mono { font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; }
.eyebrow {
  font-family:var(--mono); font-size:10.5px; text-transform:uppercase; letter-spacing:.26em;
  color:var(--ink-mute); margin:0 0 .55rem; display:inline-flex; align-items:center; gap:.5em;
}
.eyebrow::before { content:""; width:22px; height:1px; background:var(--amber); display:inline-block; }

/* tally « à l'antenne » */
.tally { width:7px; height:7px; border-radius:50%; background:var(--signal); display:inline-block; }
.tally--on { animation:pulse 2s infinite; }
@keyframes pulse {
  0%{ box-shadow:0 0 0 0 rgba(207,72,56,.55); } 70%{ box-shadow:0 0 0 6px rgba(207,72,56,0); }
  100%{ box-shadow:0 0 0 0 rgba(207,72,56,0); }
}

/* ----------------------------------------------------------------- topbar */
.regie {
  position:sticky; top:0; z-index:50; display:grid; grid-template-columns:auto auto 1fr auto;
  align-items:center; gap:26px; padding:12px clamp(16px,4vw,40px);
  background:linear-gradient(180deg,rgba(8,8,11,.96),rgba(8,8,11,.82));
  backdrop-filter:blur(10px); border-bottom:1px solid var(--rule);
}
.brand { display:inline-flex; align-items:center; gap:11px; }
.brand-mire { border-radius:9px; box-shadow:0 2px 14px rgba(0,0,0,.5); }
.brand-word { font-family:var(--serif); font-weight:600; font-size:22px; letter-spacing:-.02em; }
.brand-tv { color:var(--amber); }
.nav { display:flex; align-items:center; gap:4px; }
.nav a {
  position:relative; padding:8px 13px; border-radius:8px; font-size:13.5px; font-weight:500;
  color:var(--ink-soft); display:inline-flex; align-items:center; gap:7px; transition:.14s;
}
.nav a:hover { color:var(--ink); background:var(--bg-3); }
body[data-page="home"] [data-nav="home"], body[data-page="watch"] [data-nav="home"],
body[data-page="grid"] [data-nav="home"], body[data-page="ma_liste"] [data-nav="ma_liste"] { color:var(--ink); }
.search { position:relative; justify-self:end; min-width:200px; max-width:340px; width:28vw; }
.search input {
  width:100%; padding:9px 14px; border-radius:999px; background:var(--bg-2);
  border:1px solid var(--rule); color:var(--ink); font-family:var(--sans); font-size:13px; outline:none; transition:.15s;
}
.search input::placeholder { color:var(--ink-mute); }
.search input:focus { border-color:var(--amber-2); background:var(--bg-3); }
.search-pop {
  position:absolute; top:calc(100% + 8px); left:0; right:0; z-index:60; background:var(--bg-2);
  border:1px solid var(--rule); border-radius:12px; box-shadow:0 18px 50px rgba(0,0,0,.55);
  overflow:hidden; max-height:60vh; overflow-y:auto;
}
.search-pop a { display:grid; grid-template-columns:34px 1fr auto; gap:10px; align-items:center; padding:8px 12px; border-bottom:1px solid var(--rule-soft); }
.search-pop a:last-child { border-bottom:0; }
.search-pop a:hover { background:var(--bg-3); }
.search-pop .sp-logo { width:34px; height:26px; object-fit:contain; border-radius:4px; background:var(--bg-3); }
.search-pop .sp-swatch { width:26px; height:26px; border-radius:5px; }
.search-pop .sp-title { font-size:13px; }
.search-pop .sp-meta { font-family:var(--mono); font-size:10px; color:var(--ink-mute); }
.search-pop .sp-empty { padding:14px; font-family:var(--mono); font-size:11px; color:var(--ink-mute); }
.clock {
  justify-self:end; color:var(--phosphor); font-weight:500; font-size:13px; letter-spacing:.12em;
  padding:5px 10px; border:1px solid var(--rule); border-radius:7px; background:var(--bg-2);
  font-variant-numeric:tabular-nums;
}

.stage { max-width:var(--maxw); margin:0 auto; padding:0 clamp(16px,4vw,40px) 70px; }

/* ----------------------------------------------------------------- boutons */
.btn {
  display:inline-flex; align-items:center; gap:9px; padding:11px 20px; border-radius:10px;
  border:1px solid transparent; font-size:14px; font-weight:600; color:var(--ink);
  background:var(--bg-3); transition:transform .12s,background .15s,border-color .15s;
}
.btn:hover { transform:translateY(-1px); }
.btn .ico { font-size:12px; }
.btn--play { background:var(--amber); color:#1a1206; }
.btn--play:hover { background:#efb152; }
.btn--ghost { background:rgba(255,255,255,.04); border-color:var(--rule); }
.btn--ghost:hover { background:var(--bg-3); border-color:var(--ink-mute); }

/* ----------------------------------------------------------------- page head */
.page-head { margin:30px 0 18px; }
.page-title { font-size:clamp(30px,4.5vw,50px); margin:0; }
.page-count { color:var(--ink-mute); margin:.7rem 0 0; }
.page-count a, .toggle-geo { color:var(--amber); }
.page-actions { display:flex; align-items:center; gap:16px; margin-top:.7rem; flex-wrap:wrap; }
.toggle-geo { font-family:var(--mono); font-size:11px; }

/* ----------------------------------------------------------------- puces catégories */
.cat-chips { display:flex; flex-wrap:wrap; gap:8px; margin:0 0 26px; }
.cat-chip {
  display:inline-flex; align-items:center; gap:7px; padding:7px 14px; border-radius:999px;
  background:linear-gradient(180deg,hsl(var(--hue) 40% 16% / .5),var(--bg-2));
  border:1px solid var(--rule); font-size:13px; font-weight:500; transition:.14s;
}
.cat-chip:hover { border-color:hsl(var(--hue) 60% 50% / .6); transform:translateY(-1px); }
.cat-chip .mono { color:var(--ink-mute); font-size:10px; }
.cat-chip--pays { background:var(--bg-2); }
.cat-chip--pays:hover { border-color:var(--amber-2); }
.chips-label { margin:20px 0 9px; display:block; }
.chips-label:first-of-type { margin-top:6px; }

/* ----------------------------------------------------------------- rails */
.rail { margin:34px 0; }
.rail-head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:14px; }
.rail-title { font-size:clamp(20px,2.4vw,27px); margin:0; }
.rail-ctrls { display:flex; align-items:center; gap:8px; }
.rail-more { font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.14em; color:var(--ink-mute); }
.rail-more:hover { color:var(--amber); }
.rail-arrow {
  width:34px; height:34px; border-radius:8px; border:1px solid var(--rule); background:var(--bg-2);
  color:var(--ink-soft); font-size:18px; display:grid; place-items:center; transition:.14s;
}
.rail-arrow:hover { background:var(--bg-3); color:var(--ink); border-color:var(--ink-mute); }
.rail-track {
  display:flex; gap:16px; overflow-x:auto; scroll-behavior:smooth; scroll-snap-type:x proximity;
  padding:4px 2px 12px; scrollbar-width:thin; scrollbar-color:var(--rule) transparent;
}
.rail-track::-webkit-scrollbar { height:8px; }
.rail-track::-webkit-scrollbar-thumb { background:var(--rule); border-radius:8px; }

/* ----------------------------------------------------------------- tuile chaîne */
.ch { flex:0 0 var(--tile-w); width:var(--tile-w); scroll-snap-align:start; }
.grid .ch { flex:none; width:auto; }
.ch-tile {
  position:relative; display:grid; place-items:center; aspect-ratio:16/9; border-radius:12px;
  overflow:hidden; border:1px solid rgba(255,255,255,.07);
  background:radial-gradient(120% 140% at 20% 12%,hsl(var(--hue) 55% 30% / .55),transparent 60%),
             linear-gradient(155deg,hsl(var(--hue) 30% 15%),hsl(var(--hue) 22% 8%));
  transition:transform .16s,box-shadow .16s,border-color .16s;
}
.ch-tile::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.04) 0 1px,transparent 1px 3px);
  mix-blend-mode:overlay; opacity:.5;
}
.ch-tile:hover { transform:translateY(-3px); box-shadow:0 16px 34px rgba(0,0,0,.5); border-color:hsl(var(--hue) 60% 50% / .5); }
.ch-logo { position:relative; z-index:1; max-width:66%; max-height:60%; object-fit:contain; filter:drop-shadow(0 3px 10px rgba(0,0,0,.6)); }
.ch-fallback {
  position:absolute; z-index:0; font-family:var(--serif); font-weight:600; font-size:34px;
  color:hsl(var(--hue) 45% 72%); letter-spacing:.02em; opacity:.9;
}
.ch-tile.no-logo .ch-fallback { z-index:1; }
.ch-live {
  position:absolute; top:9px; left:9px; z-index:2; display:flex; align-items:center; gap:5px;
  font-family:var(--mono); font-size:9px; letter-spacing:.16em; color:#fff; padding:3px 7px;
  border-radius:5px; background:rgba(207,72,56,.85);
}
.chip { font-family:var(--mono); font-size:9.5px; text-transform:uppercase; letter-spacing:.14em; padding:3px 7px; border-radius:5px; }
.chip--geo { position:absolute; bottom:9px; left:9px; z-index:2; background:rgba(8,8,11,.7); color:var(--amber); border:1px solid var(--amber-2); }
.ch-play {
  position:absolute; z-index:2; width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:rgba(8,8,11,.5); color:#fff; font-size:15px; opacity:0; transform:scale(.8); transition:.16s;
  backdrop-filter:blur(3px); border:1px solid rgba(255,255,255,.2);
}
.ch-tile:hover .ch-play { opacity:1; transform:scale(1); }
.fav {
  position:absolute; top:8px; right:8px; z-index:3; width:30px; height:30px; border-radius:50%;
  background:rgba(8,8,11,.62); border:1px solid rgba(255,255,255,.16); color:var(--ink);
  display:grid; place-items:center; font-size:17px; backdrop-filter:blur(3px); transition:.14s;
}
.fav:hover { background:var(--bg-4); transform:scale(1.06); }
.fav[data-fav="1"] { background:var(--amber); color:#1a1206; border-color:var(--amber); }
.fav[data-fav="0"] .fav-on { display:none; }
.fav[data-fav="1"] .fav-add { display:none; }
.fav--btn { position:static; width:auto; height:auto; border-radius:10px; padding:11px 18px; font-size:13.5px; font-weight:600; background:rgba(255,255,255,.04); border-color:var(--rule); }
.fav--btn[data-fav="1"] { background:rgba(224,162,60,.16); color:var(--amber); border-color:var(--amber-2); }
.ch--geo .ch-tile { opacity:.86; }
.ch-meta { padding:10px 2px 0; }
.ch-name { display:block; font-size:14px; font-weight:600; color:var(--ink); }
.ch-name:hover { color:var(--amber); }
.ch-sub { display:block; color:var(--ink-mute); margin-top:3px; font-size:10.5px; }

/* ----------------------------------------------------------------- grille */
.grid { display:grid; gap:22px 18px; grid-template-columns:repeat(auto-fill,minmax(195px,1fr)); }

/* ----------------------------------------------------------------- filtres */
.filters { display:flex; flex-direction:column; gap:12px; margin-bottom:24px; padding:16px 18px; background:var(--bg-2); border:1px solid var(--rule); border-radius:14px; }
.filter-grp { display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.filter-lbl { color:var(--ink-mute); width:54px; flex:0 0 54px; text-transform:uppercase; letter-spacing:.16em; font-size:9.5px; }
.fchip { font-size:12px; padding:6px 12px; border-radius:999px; background:rgba(255,255,255,.03); border:1px solid var(--rule); color:var(--ink-soft); transition:.13s; display:inline-flex; gap:6px; align-items:center; }
.fchip .mono { color:var(--ink-mute); font-size:9.5px; }
.fchip:hover { color:var(--ink); border-color:var(--ink-mute); }
.fchip.on { background:var(--amber); color:#1a1206; border-color:var(--amber); font-weight:600; }
.fchip.on .mono { color:#5a3c10; }

/* ----------------------------------------------------------------- lecteur (watch) */
.watch { display:grid; grid-template-columns:1fr 330px; gap:22px; margin:22px 0 10px; align-items:start; }
.player-col { min-width:0; }
.player {
  position:relative; aspect-ratio:16/9; background:#000; border-radius:16px; overflow:hidden;
  border:1px solid var(--rule); box-shadow:0 24px 60px rgba(0,0,0,.55);
}
.player video { width:100%; height:100%; object-fit:contain; background:#000; display:block; }
.player-tag {
  position:absolute; top:14px; left:14px; z-index:3; display:flex; align-items:center; gap:7px;
  font-family:var(--mono); font-size:10px; letter-spacing:.18em; color:#fff; padding:5px 10px;
  border-radius:6px; background:rgba(207,72,56,.82); pointer-events:none;
}
.sound-btn {
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:4;
  display:inline-flex; align-items:center; gap:13px; padding:16px 26px; border-radius:16px;
  background:var(--amber); color:#1a1206; border:none; font-weight:800; font-size:17px;
  box-shadow:0 14px 46px rgba(0,0,0,.6); cursor:pointer; animation:soundpulse 2s ease-in-out infinite;
}
.sound-btn:hover { background:#efb152; }
.sound-ico { font-size:25px; line-height:1; }
.sound-txt { display:flex; flex-direction:column; line-height:1.15; text-align:left; }
.sound-txt small { font-weight:600; font-size:11px; opacity:.78; }
@keyframes soundpulse {
  0%, 100% { transform:translate(-50%,-50%) scale(1); }
  50%      { transform:translate(-50%,-50%) scale(1.045); }
}
.player-error {
  position:absolute; inset:0; z-index:5; display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:8px; text-align:center; padding:20px;
  background:radial-gradient(80% 80% at 50% 45%,rgba(20,20,26,.92),rgba(8,8,11,.97));
}
.player-error img { opacity:.85; margin-bottom:6px; }
.player-error .serif { font-size:24px; margin:0; }
.player-error .mono { color:var(--ink-mute); margin:0; max-width:46ch; }
.err-actions { display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; justify-content:center; }

.now-bar { display:flex; align-items:center; justify-content:space-between; gap:16px; margin:16px 2px 0; flex-wrap:wrap; }
.now-ch { display:flex; align-items:center; gap:14px; min-width:0; }
.now-logo { width:60px; height:46px; object-fit:contain; background:var(--bg-3); border:1px solid var(--rule); border-radius:8px; padding:5px; }
.now-title { font-size:clamp(22px,3vw,32px); margin:0; }
.now-sub { color:var(--ink-soft); margin:4px 0 0; }
.geo-warn { color:var(--amber); }

/* ----------------------------------------------------------------- contrôles lecteur */
.player-ctrls { position:absolute; top:12px; right:12px; z-index:3; display:flex; gap:8px; }
.pbtn {
  width:38px; height:38px; border-radius:9px; background:rgba(8,8,11,.6); border:1px solid rgba(255,255,255,.16);
  color:var(--ink); font-size:16px; display:grid; place-items:center; backdrop-filter:blur(4px); transition:.14s;
}
.pbtn:hover { background:var(--bg-4); border-color:var(--ink-mute); transform:translateY(-1px); }
.pbtn.off { opacity:.42; }

/* commentaires volants (danmaku) */
.danmaku { position:absolute; inset:0; z-index:2; overflow:hidden; pointer-events:none; }
.bullet {
  position:absolute; left:100%; white-space:nowrap; font-family:var(--sans); font-weight:700;
  font-size:clamp(16px,2.2vw,24px); text-shadow:0 2px 8px rgba(0,0,0,.95), 0 0 2px rgba(0,0,0,.9);
  animation:fly 9s linear forwards; will-change:transform;
}
@keyframes fly { to { transform:translateX(calc(-1 * var(--travel, 120%))); } }
.player.is-fs .bullet { font-size:clamp(22px,2.6vw,34px); }

/* tchat live */
.chat { display:flex; flex-direction:column; border:1px solid var(--rule); border-radius:14px; background:var(--bg-2); margin-bottom:16px; overflow:hidden; }
.chat-head { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:12px 14px 9px; }
.chat-head .eyebrow { margin:0; }
.chat-pseudo { width:108px; flex:0 0 auto; background:var(--bg-3); border:1px solid var(--rule); color:var(--ink); border-radius:7px; padding:5px 9px; font-family:var(--mono); font-size:11px; outline:none; }
.chat-pseudo:focus { border-color:var(--amber-2); }
.chat-msgs { display:flex; flex-direction:column; gap:8px; max-height:40vh; min-height:120px; overflow-y:auto; padding:6px 14px 10px; scrollbar-width:thin; scrollbar-color:var(--rule) transparent; }
.chat-empty { color:var(--ink-mute); margin:8px 0; }
.msg { font-size:13px; line-height:1.4; word-break:break-word; }
.msg-who { font-weight:700; font-size:12px; margin-right:4px; }
.chat-form { display:flex; gap:8px; padding:10px 12px; border-top:1px solid var(--rule); }
.chat-input { flex:1; min-width:0; background:var(--bg-3); border:1px solid var(--rule); color:var(--ink); border-radius:9px; padding:9px 12px; font-family:var(--sans); font-size:13px; outline:none; }
.chat-input:focus { border-color:var(--amber-2); }
.chat-send { flex:0 0 40px; width:40px; border-radius:9px; background:var(--amber); color:#1a1206; border:none; font-size:14px; font-weight:700; }
.chat-send:hover { background:#efb152; }

/* ----------------------------------------------------------------- zapping */
.zap {
  border:1px solid var(--rule); border-radius:14px; background:var(--bg-2); padding:14px;
  max-height:78vh; overflow-y:auto; position:sticky; top:78px; scrollbar-width:thin; scrollbar-color:var(--rule) transparent;
}
.zap .eyebrow { margin:6px 2px 10px; }
.zap-list { display:flex; flex-direction:column; gap:4px; margin-bottom:14px; }
.zap-item { display:flex; align-items:center; gap:11px; padding:8px; border-radius:10px; transition:background .13s; }
.zap-item:hover { background:var(--bg-3); }
.zap-item.on { background:linear-gradient(90deg,hsl(var(--hue) 40% 20% / .5),transparent); border:1px solid var(--rule); }
.zap-logo { position:relative; flex:0 0 46px; width:46px; height:34px; border-radius:6px; overflow:hidden; background:var(--bg-3); display:grid; place-items:center; border:1px solid var(--rule-soft); }
.zap-logo img { max-width:84%; max-height:80%; object-fit:contain; position:relative; z-index:1; }
.zap-fallback { position:absolute; font-family:var(--serif); font-weight:600; font-size:13px; color:hsl(var(--hue) 45% 70%); }
.zap-logo.nl img { display:none; }
.zap-info { min-width:0; flex:1; }
.zap-name { display:block; font-size:13px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.zap-cat { display:block; color:var(--ink-mute); font-size:9.5px; margin-top:1px; }
.zap-empty { color:var(--ink-mute); padding:4px 2px; }

/* ----------------------------------------------------------------- vide / footer */
.empty { text-align:center; padding:60px 20px; display:flex; flex-direction:column; align-items:center; gap:8px; }
.empty img { opacity:.9; margin-bottom:14px; filter:drop-shadow(0 8px 24px rgba(0,0,0,.5)); }
.empty .serif { font-size:26px; margin:0; }
.empty .mono { color:var(--ink-mute); margin:0 0 12px; max-width:50ch; }
.catalogue-foot { text-align:center; color:var(--ink-mute); margin:46px 0 0; font-size:10.5px; letter-spacing:.08em; }
.colophon { max-width:var(--maxw); margin:0 auto; padding:26px clamp(16px,4vw,40px) 46px; border-top:1px solid var(--rule); }
.colophon-row { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px; }
.refresh-btn { background:var(--bg-2); border:1px solid var(--rule); color:var(--ink-soft); padding:7px 13px; border-radius:8px; font-size:11px; letter-spacing:.08em; transition:.14s; }
.refresh-btn:hover { color:var(--ink); border-color:var(--ink-mute); }
.refresh-btn:disabled { opacity:.6; cursor:progress; }
.colophon-fine { color:var(--ink-mute); margin:14px 0 0; font-size:10px; max-width:80ch; }

/* ----------------------------------------------------------------- responsive */
@media (max-width:980px) {
  .watch { grid-template-columns:1fr; }
  .zap { position:static; max-height:none; }
  .zap-list { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); }
}
@media (max-width:860px) {
  .regie { grid-template-columns:auto 1fr auto; gap:14px; row-gap:10px; }
  .nav { order:3; grid-column:1 / -1; }
  .search { width:auto; min-width:0; flex:1; }
  .clock { display:none; }
  :root { --tile-w:188px; }
}
