:root {
  --bg: #0f1117;
  --surface: #181b24;
  --surface-2: #1f2330;
  --text: #e8eaf0;
  --muted: #8b90a0;
  --accent: #ff6b35;
  --primary: #4f7cff;
  --ok: #3ecf8e;
  --radius: 12px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "Segoe UI", system-ui, -apple-system, sans-serif;
  line-height: 1.5;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; }

/* ---------- Шапка ---------- */

.topbar {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 12px 24px;
  background: rgba(24, 27, 36, .92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid #262a38;
  position: sticky;
  top: 0;
  z-index: 10;
}

.topbar-row { display: flex; align-items: center; gap: 20px; flex: 1; }

.logo { font-size: 22px; font-weight: 800; letter-spacing: -0.5px; }
.logo span { color: var(--accent); }

.searchbar { display: flex; flex: 2; max-width: 480px; gap: 8px; }
.searchbar input {
  flex: 1;
  min-width: 0;
  padding: 10px 14px;
  border-radius: var(--radius);
  border: 1px solid #2c3040;
  background: var(--surface-2);
  color: var(--text);
  font-size: 16px; /* не даёт iOS зумить при фокусе */
}
.searchbar input:focus { outline: none; border-color: var(--primary); }

.searchbar button,
.btn {
  padding: 10px 18px;
  border-radius: var(--radius);
  border: 1px solid #2c3040;
  background: var(--surface-2);
  color: var(--text);
  font-size: 15px;
  cursor: pointer;
  display: inline-block;
  min-height: 42px;
}
.btn:hover, .searchbar button:hover { border-color: var(--primary); }
.btn-primary { background: var(--primary); border-color: var(--primary); font-weight: 600; }
.btn-accent { background: var(--accent); border-color: var(--accent); font-weight: 600; }
.btn-lg { padding: 14px 26px; font-size: 17px; }

.topbar nav { display: flex; gap: 16px; margin-left: auto; align-items: center; }
.topbar nav a { color: var(--muted); padding: 6px 0; }
.topbar nav a:hover { color: var(--text); }
.tg-ok { color: var(--ok) !important; }

main { max-width: 1080px; margin: 0 auto; padding: 28px 24px 64px; }
footer { text-align: center; color: var(--muted); font-size: 13px; padding: 24px; }

/* ---------- Общие ---------- */

.muted { color: var(--muted); }
.small { font-size: 13px; }
.alert {
  background: #3a2230;
  border: 1px solid #6b3048;
  color: #ffb3c0;
  padding: 12px 16px;
  border-radius: var(--radius);
  margin: 16px 0;
}

.badge {
  display: inline-block;
  font-size: 12px;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--surface-2);
  border: 1px solid #2c3040;
  margin: 4px 4px 0 0;
}
.badge-new { background: #33230f; border-color: var(--accent); color: var(--accent); }
.badge-ok { background: #12291f; border-color: var(--ok); color: var(--ok); }

/* ---------- Герой на главной ---------- */

.hero { text-align: center; padding: 56px 16px; }
.hero-gradient {
  background:
    radial-gradient(ellipse 70% 90% at 50% -10%, rgba(79, 124, 255, .25), transparent),
    radial-gradient(ellipse 40% 60% at 85% 10%, rgba(255, 107, 53, .12), transparent);
  border-radius: 20px;
}
.hero h1 { font-size: 34px; line-height: 1.25; margin-top: 0; }
.hero p { color: var(--muted); max-width: 560px; margin: 16px auto 28px; }
.hero-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---------- Карточки «мои сериалы» / поиск ---------- */

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 20px;
  margin-top: 20px;
}
.card {
  background: var(--surface);
  border: 1px solid #262a38;
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform .15s, border-color .15s;
}
.card:hover { transform: translateY(-3px); border-color: var(--primary); }
.card img { width: 100%; aspect-ratio: 2/3; object-fit: cover; display: block; }
.card-body { padding: 14px; }
.card-body h3 { margin: 0 0 4px; font-size: 16px; }
.card-body p { margin: 4px 0; }

.progress {
  height: 6px;
  border-radius: 999px;
  background: var(--surface-2);
  overflow: hidden;
  margin: 8px 0 4px;
}
.progress-fill { height: 100%; background: linear-gradient(90deg, var(--primary), var(--ok)); }

/* ---------- Популярное (ряды постеров) ---------- */

.popular { margin-top: 40px; }
.popular h2 { margin-bottom: 14px; }
.poster-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 16px;
}
.poster-card { display: flex; flex-direction: column; gap: 2px; }
.poster-wrap {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid #262a38;
  transition: transform .15s, border-color .15s;
}
.poster-card:hover .poster-wrap { transform: translateY(-3px); border-color: var(--primary); }
.poster-wrap img { width: 100%; aspect-ratio: 2/3; object-fit: cover; display: block; }
.rating {
  position: absolute;
  top: 8px; left: 8px;
  background: rgba(15, 17, 23, .85);
  color: var(--ok);
  font-size: 12px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 999px;
}
.poster-title {
  font-size: 14px;
  font-weight: 600;
  margin-top: 8px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ---------- Страница сериала ---------- */

.show-header { display: flex; gap: 28px; align-items: flex-start; }
.show-header .poster { width: 220px; border-radius: var(--radius); flex-shrink: 0; }
.show-header h1 { margin-top: 0; }
.actions { display: flex; gap: 12px; align-items: center; margin: 18px 0; flex-wrap: wrap; }
.actions form { margin: 0; }

.stats { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.stat {
  background: var(--surface);
  border: 1px solid #262a38;
  border-radius: var(--radius);
  padding: 10px 18px;
  text-align: center;
}
.stat b { display: block; font-size: 18px; }
.stat span { font-size: 12px; color: var(--muted); }
.stat-new { border-color: var(--accent); }
.stat-new b { color: var(--accent); }

/* ---------- Плеер ---------- */

.player-section { margin-top: 32px; scroll-margin-top: 120px; }
.player-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.player-toolbar select {
  padding: 10px 12px;
  border-radius: var(--radius);
  border: 1px solid #2c3040;
  background: var(--surface-2);
  color: var(--text);
  font-size: 16px;
  max-width: 100%;
}
.player-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: #000;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid #262a38;
}
.player-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* ---------- Список серий ---------- */

.season { margin-top: 36px; }
.season h2 { border-bottom: 1px solid #262a38; padding-bottom: 8px; }
.episodes { list-style: none; margin: 0; padding: 0; }
.episode {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px;
  border-radius: 8px;
}
.episode:hover { background: var(--surface); }
.episode.future { opacity: .55; }
.episode.watched .ep-name, .episode.watched .ep-num { color: var(--muted); text-decoration: line-through; }
.episode form { margin: 0; }
.check {
  width: 32px; height: 32px;
  border-radius: 8px;
  border: 1.5px solid #3a3f52;
  background: var(--surface-2);
  color: var(--ok);
  font-size: 16px;
  cursor: pointer;
  line-height: 1;
  flex-shrink: 0;
}
.check:disabled { opacity: .4; cursor: default; }
.episode.watched .check { border-color: var(--ok); }
.ep-play {
  width: 32px; height: 32px;
  border-radius: 8px;
  border: 1.5px solid #3a3f52;
  background: var(--surface-2);
  color: var(--primary);
  font-size: 12px;
  cursor: pointer;
  line-height: 1;
  flex-shrink: 0;
}
.ep-play:hover { border-color: var(--primary); }
.ep-num { font-family: ui-monospace, monospace; color: var(--muted); width: 42px; flex-shrink: 0; }
.ep-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.ep-date { font-size: 13px; white-space: nowrap; }
.upto button {
  background: none; border: none; color: var(--muted);
  font-size: 12px; cursor: pointer; padding: 6px;
}
.upto button:hover { color: var(--text); }

/* «до этой» показываем по наведению только там, где есть мышь */
@media (hover: hover) {
  .episode:not(:hover) .upto { visibility: hidden; }
}

/* ---------- Мобильная вёрстка ---------- */

@media (max-width: 720px) {
  .topbar { flex-direction: column; align-items: stretch; gap: 10px; padding: 10px 14px; }
  .topbar-row { justify-content: space-between; }
  .topbar nav { margin-left: 0; gap: 14px; }
  .searchbar { max-width: none; }

  main { padding: 18px 14px 56px; }

  .hero { padding: 36px 12px; }
  .hero h1 { font-size: 25px; }
  .hero-actions .btn { width: 100%; }

  /* мои сериалы — компактные карточки в 2 колонки */
  .cards { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .card-body { padding: 10px; }
  .card-body h3 { font-size: 14px; }

  /* популярное — горизонтальная лента со свайпом */
  .poster-row {
    display: flex;
    overflow-x: auto;
    gap: 12px;
    padding-bottom: 8px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .poster-row::-webkit-scrollbar { display: none; }
  .poster-card { flex: 0 0 130px; scroll-snap-align: start; }

  /* страница сериала */
  .show-header { flex-direction: row; gap: 14px; }
  .show-header .poster { width: 110px; }
  .show-header h1 { font-size: 21px; }
  .show-header > div > p:not(.muted) { display: none; } /* описание прячем, экономим экран */
  .actions .btn { flex: 1; text-align: center; }
  .actions form { flex: 1; display: flex; }
  .actions form .btn { width: 100%; }

  .stats { gap: 8px; }
  .stat { padding: 8px 12px; flex: 1; min-width: 90px; }
  .stat b { font-size: 15px; }

  .player-toolbar { align-items: stretch; flex-direction: column; gap: 8px; }
  .player-toolbar select { width: 100%; }
  .player-section { scroll-margin-top: 150px; }

  /* серии: дата уходит под название */
  .episode { flex-wrap: wrap; row-gap: 2px; padding: 10px 6px; }
  .ep-name { flex-basis: calc(100% - 140px); }
  .ep-date { order: 5; flex-basis: 100%; padding-left: 130px; }
  .upto { visibility: visible; }
}

@media (max-width: 380px) {
  .poster-card { flex-basis: 112px; }
  .cards { grid-template-columns: repeat(2, 1fr); }
}
