:root {
  --bg: #0e0e11;
  --bg-card: #1a1a20;
  --bg-card-hover: #23232b;
  --text: #e8e8ea;
  --muted: #9a9aa4;
  --accent: #a970ff;       /* twitch-фиолетовый */
  --live: #eb0400;
  --border: #2a2a32;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font: 16px/1.5 -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

a { color: inherit; text-decoration: none; }
.muted { color: var(--muted); }

.site-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1.2rem;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: rgba(14, 14, 17, 0.92);
  backdrop-filter: blur(8px);
  z-index: 10;
}
.site-nav { display: flex; align-items: center; gap: 1rem; min-width: 0; }
.brand { display: flex; align-items: center; flex: 0 0 auto; }
.brand-logo {
  width: 32px; height: 32px; border-radius: 50%; display: block;
  object-fit: cover; border: 1px solid var(--border);
}
.nav-link { color: var(--muted); font-size: .95rem; font-weight: 600; }
.nav-link:hover { color: var(--text); }
.nav-link.active { color: var(--text); }
.live-badge {
  color: #fff; background: var(--live); padding: 0.3rem 0.7rem;
  border-radius: 999px; font-size: 0.85rem; font-weight: 600;
  max-width: 60vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.65; } }

.container { max-width: 1200px; margin: 0 auto; padding: 1.2rem; }

.count { margin: 0 0 1rem; }

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.1rem;
}
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  transition: background 0.15s, transform 0.15s;
}
.card:hover { background: var(--bg-card-hover); transform: translateY(-2px); }
.thumb { position: relative; aspect-ratio: 16 / 9; background: #000; }
.thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dur {
  position: absolute; right: 6px; bottom: 6px;
  background: rgba(0,0,0,0.8); color: #fff;
  padding: 1px 6px; border-radius: 4px; font-size: 0.8rem;
}
.meta { padding: 0.6rem 0.75rem 0.8rem; }
.card-title {
  font-weight: 600; margin-bottom: 0.25rem;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.sub { font-size: 0.85rem; }
.game { color: var(--accent); }

.pager {
  display: flex; align-items: center; justify-content: space-between;
  margin: 2rem 0 1rem;
}
.pager a { color: var(--accent); }

.empty { text-align: center; padding: 4rem 1rem; }

/* watch */
.container.watch-page { max-width: none; padding-top: 0; }
.side-toggle {
  display: flex; align-items: center; gap: .45rem; flex: 0 0 auto; width: 100%;
  padding: .55rem .8rem; border: none; border-bottom: 1px solid var(--border);
  background: transparent; color: var(--accent); font: inherit; font-size: .9rem;
  font-weight: 600; text-align: left; cursor: pointer;
}
.side-toggle:hover { background: var(--bg-card-hover); }
.side-toggle-chev { display: inline-block; transition: transform .15s; }
.watch-side.collapsed .side-toggle { border-bottom: none; justify-content: center; padding: .55rem; }
.watch-side.collapsed .side-toggle-label { display: none; }
.watch-side.collapsed .side-toggle-chev { transform: rotate(180deg); }
/* свёрнуто — вертикальная полоса превью записей */
.watch-side.collapsed .vod-item { padding: 0; }
.watch-side.collapsed .vod-item-title,
.watch-side.collapsed .vod-item-date { display: none; }
.watch-side.collapsed .vod-thumb {
  display: block; width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: 6px;
}
.watch-side.collapsed .vod-item.active .vod-thumb { outline: 2px solid var(--accent); outline-offset: -2px; }
.player {
  background: #000; border-radius: 12px; overflow: hidden; margin-bottom: 1rem;
  position: relative;   /* база для оверлеев (live-ended) */
  aspect-ratio: 16 / 9; max-height: 80vh;   /* стабильная высота — не зависит от загрузки видео */
}
.player video { width: 100%; height: 100%; object-fit: contain; display: block; }
.watch-title { font-size: 1.4rem; margin: 0.5rem 0; }
.watch-meta { display: flex; flex-wrap: wrap; gap: 0.9rem; font-size: 0.9rem; }
.download { color: var(--accent); }

/* video.js — заполняет .player, тема под акцент */
.player .video-js { width: 100%; height: 100%; }
.video-js .vjs-tech { object-fit: contain; }
.video-js .vjs-control-bar { background: rgba(14, 14, 17, .72); }
.video-js .vjs-play-progress,
.video-js .vjs-volume-level { background-color: var(--accent); }
.video-js .vjs-play-progress::before { color: var(--accent); }
.video-js .vjs-load-progress { background: rgba(169, 112, 255, .28); }
.video-js .vjs-big-play-button { background: rgba(26, 26, 32, .7); border-color: var(--accent); }
.video-js:hover .vjs-big-play-button,
.video-js .vjs-big-play-button:focus { background-color: var(--accent); border-color: var(--accent); }
.video-js .vjs-control:hover,
.video-js .vjs-control:focus { color: var(--accent); }

/* раскладка watch (как twitch): [ список | видео+описание | чат ];
   список и чат — во всю высоту экрана и скроллятся независимо, видео не на всю высоту */
.watch-layout { display: flex; gap: 1rem; align-items: stretch; height: calc(100vh - var(--hdr, 64px)); }
.watch-main { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; overflow-y: auto; }
.watch-main .player { flex: 0 0 auto; }

.watch-side {
  flex: 0 0 240px; display: flex; flex-direction: column; min-height: 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; overflow: hidden;
}
.watch-side.collapsed { flex: 0 0 84px; }   /* узкая полоса превью во всю высоту */
.vod-list {
  flex: 1 1 auto; overflow-y: auto; display: flex; flex-direction: column; gap: .25rem;
  padding: .3rem;
}
.vod-item { display: block; padding: .45rem .5rem; border-radius: 8px; line-height: 1.3; }
.vod-item:hover { background: var(--bg-card-hover); }
.vod-item.active { background: var(--bg-card-hover); outline: 1px solid var(--accent); }
.vod-thumb { display: none; }   /* в развёрнутом — текстовый список; превью только в свёрнутом */
.vod-item-title {
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  font-size: .85rem;
}
.vod-item-date { display: block; font-size: .72rem; margin-top: .15rem; }

.chat {
  flex: 0 0 340px; display: flex; flex-direction: column; min-height: 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; overflow: hidden;
}
.chat-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: .5rem .8rem; border-bottom: 1px solid var(--border);
  font-weight: 600; font-size: .9rem; flex: 0 0 auto;
}
.chat-follow {
  font-weight: 400; font-size: .8rem; color: var(--muted); cursor: pointer;
  display: flex; align-items: center; gap: .3rem;
}
.chat-log { flex: 1 1 auto; overflow-y: auto; padding: .5rem .6rem; font-size: .88rem; line-height: 1.45; }
.chat-msg { margin: .1rem 0; overflow-wrap: anywhere; }
.chat-msg .t { color: var(--muted); font-size: .72rem; margin-right: .35rem; font-variant-numeric: tabular-nums; }
.chat-msg .u { font-weight: 600; }
.chat-msg .u::after { content: ":"; color: var(--muted); font-weight: 400; }
.chat-msg .emote { height: 1.7em; vertical-align: middle; margin: -3px 1px; }
.chat-note { padding: .5rem .2rem; }
.live-dot { color: var(--live); font-weight: 600; animation: pulse 2s infinite; }
.viewers { color: var(--muted); white-space: nowrap; }
.viewers b { color: var(--text); font-weight: 600; }
.live-ended {
  position: absolute; inset: 0; z-index: 5;   /* поверх контролов video.js */
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.8); text-align: center; padding: 1rem;
}
.le-title { font-size: 1.3rem; font-weight: 700; margin-bottom: .6rem; }
.le-card .download { font-size: 1.05rem; }

@media (max-width: 1024px) {
  .watch-layout { flex-direction: column; height: auto; }   /* стек: страница скроллится */
  .watch-main { order: -1; overflow: visible; }             /* видео + описание сверху */
  .chat { flex: 1 1 auto; max-height: 60vh; order: 0; }
  .watch-side { flex: 1 1 auto; max-height: 45vh; order: 1; }  /* список — внизу */
}

.site-footer {
  text-align: center; color: var(--muted); font-size: 0.85rem;
  padding: 2rem 1rem; border-top: 1px solid var(--border); margin-top: 2rem;
}
.site-footer a { color: var(--accent); }

/* ---------- admin ---------- */
.admin h2 { font-size: 1.05rem; margin: 1.5rem 0 0.6rem; }
.small { font-size: 0.8rem; }
.rec-panel {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 1rem 1.2rem; margin: 1rem 0 1.5rem;
}
.rec-panel h2 { margin-top: 0; }
.rec-live { color: var(--live); font-weight: 700; letter-spacing: .03em; }
.rec-title { font-size: 1.1rem; margin: .3rem 0 .8rem; }
.rec-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: .8rem; margin: .4rem 0;
}
.rec-grid > div { font-size: .95rem; }
.rec-grid .muted { font-size: .8rem; }

.adm-table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.adm-table th { text-align: left; color: var(--muted); font-weight: 500; padding: .4rem .5rem; border-bottom: 1px solid var(--border); }
.adm-table td { padding: .4rem .5rem; border-bottom: 1px solid var(--border); vertical-align: middle; }
.adm-thumb { width: 96px; aspect-ratio: 16/9; object-fit: cover; border-radius: 5px; background: #000; display: block; }
.row-hidden { opacity: .55; }
.row-bad { background: rgba(235,4,0,.06); }
.adm-actions { display: flex; gap: .4rem; }
.adm-actions form { margin: 0; }

.btn {
  background: transparent; color: var(--text); border: 1px solid var(--border);
  border-radius: 7px; padding: .35rem .7rem; font-size: .85rem; cursor: pointer;
}
.btn:hover { background: var(--bg-card-hover); }
.btn-danger { color: #ff6b6b; border-color: #5a2a2a; }
.btn-danger:hover { background: #2a1515; }

.tag-hidden, .tag-pub, .tag-bad { font-size: .75rem; padding: 1px 7px; border-radius: 999px; white-space: nowrap; }
.tag-hidden { background: #3a3a20; color: #d8d87a; }
.tag-pub { background: #14331f; color: #6fce8f; }
.tag-bad { background: var(--live); color: #fff; }

.adm-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px; padding: .8rem 1.2rem 1.1rem; margin: 1rem 0; }
.adm-card h2 { margin-top: .3rem; }
.adm-form { display: flex; gap: .6rem; align-items: center; flex-wrap: wrap; margin: 0; }
.adm-form input[type=text] { flex: 1; min-width: 240px; background: var(--bg); color: var(--text); border: 1px solid var(--border); border-radius: 7px; padding: .45rem .6rem; }
.adm-form input[type=number] { width: 90px; background: var(--bg); color: var(--text); border: 1px solid var(--border); border-radius: 7px; padding: .45rem .6rem; }
.adm-preview { max-width: 320px; border-radius: 8px; display: block; margin-bottom: .7rem; }
