:root {
  --bg:#0b0d10; --bg-soft:#12151a; --surface:#161a20; --text:#e7eaf0; --muted:#9aa3b2;
  --primary:#5b8cff; --primary-600:#3d6ef0; --danger:#ff5d6c; --border:#232935; --card:#0f1318;
  --shadow:0 10px 30px rgba(0,0,0,.35);
}
:root[data-theme="light"]{
  --bg:#f6f7fb; --bg-soft:#fff; --surface:#fff; --text:#0f1220; --muted:#5e6675;
  --primary:#3d6ef0; --primary-600:#2e5be6; --danger:#e5465b; --border:#e7e9ee; --card:#fff;
  --shadow:0 8px 20px rgba(17,24,39,.08);
}

/* базовые */
*{box-sizing:border-box}
html,body{height:100%; width:100%; overflow-x:hidden}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}
img,video{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 12px}

/* навбар */
.nav{position:sticky;top:0;z-index:20;background:rgba(15,19,24,.7);
  backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border)}
.nav__inner{display:flex;align-items:center;gap:16px;min-height:60px}
.brand{font-weight:700;color:var(--text);text-decoration:none;font-size:20px}
.nav .search{display:flex;gap:8px;flex:1}
.search input{flex:1;min-width:160px;padding:.6rem .8rem;border-radius:10px;border:1px solid var(--border);
  background:var(--bg-soft);color:var(--text)}
.nav__actions{display:flex;gap:8px}

/* кнопки */
.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.55rem .9rem;border-radius:10px;
  border:1px solid transparent;text-decoration:none;cursor:pointer;font-weight:600;transition:.2s}
.btn--primary{background:var(--primary);color:#fff}.btn--primary:hover{background:var(--primary-600)}
.btn--ghost{background:transparent;border-color:var(--border);color:var(--text)}
.btn--danger{background:var(--danger);color:#fff}
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);
  background:var(--bg-soft);color:var(--text)}
.btn--sm{padding:.3rem .6rem;font-size:.9em}

/* заголовки/фильтры */
.page-head{display:flex;align-items:center;justify-content:space-between;margin:24px 0 8px}
.chips{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.chip{padding:.45rem .7rem;border:1px solid var(--border);color:var(--text);text-decoration:none;border-radius:999px;background:var(--bg-soft)}
.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}
.switch{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.9rem}
.switch input{width:18px;height:18px}

/* сетка каталога + карточки */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
@media (max-width:1200px){.grid{grid-template-columns:repeat(9,1fr)}}
@media (max-width:900px){.grid{grid-template-columns:repeat(6,1fr)}}
@media (max-width:640px){.grid{grid-template-columns:repeat(4,1fr)}}
.card{grid-column:span 4;background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);max-width:1100px;margin:0 auto}
.card__media{position:relative;display:block;aspect-ratio:2/3;background:#000}
.card__media img{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;filter:contrast(1.03) saturate(1.05)}
.badge{position:absolute;left:10px;top:10px;background:rgba(0,0,0,.6);border:1px solid var(--border);padding:.25rem .5rem;border-radius:999px;font-size:.75rem;color:#fff}
.card__body{padding:14px}
.card__title{margin:0 0 6px;font-size:1rem;line-height:1.35}
.card__title a{color:var(--text);text-decoration:none}
.card__title a:hover{color:var(--primary)}
.meta{display:flex;gap:8px;flex-wrap:wrap;margin:4px 0 8px}
.meta__item{color:var(--muted);font-size:.9rem;border:1px solid var(--border);padding:.1rem .5rem;border-radius:999px}
.rating{font-weight:700;font-size:.85rem;border-radius:8px;padding:.18rem .45rem}
.rating.kp{background:#ff8f3d1a;color:#ff9b4f;border:1px solid #ff9b4f33}
.rating.imdb{background:#ffe14d1a;color:#ffe14d;border:1px solid #ffe14d33}
.card__desc{color:var(--muted);font-size:.95rem;min-height:2.5em}
.card__actions{display:flex;gap:8px;margin-top:10px}

/* универсальная «шапка карточки подробностей»: постер + инфо */
.media-grid{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}
.media-grid__poster{display:flex;justify-content:center;align-items:flex-start;overflow:hidden}
.media-grid__poster img{display:block;width:100%;max-width:220px;height:auto;border-radius:12px;object-fit:cover;box-shadow:0 2px 12px rgba(0,0,0,.25)}
.media-grid__meta p{margin:6px 0;color:var(--muted)}
@media (max-width:768px){
  .media-grid{grid-template-columns:1fr}
  .media-grid__poster img{max-width:180px;margin-bottom:16px}
}
@media (max-width:480px){ .media-grid__poster img{max-height:60vh} }

/* общий плеер */
.player{width:100%;border-radius:12px;border:1px solid var(--border);background:#000}
.player--small{height:260px}

/* алерты / пустые */
.alert{padding:.6rem .8rem;border-radius:10px;border:1px solid var(--border);background:var(--surface)}
.alert--success{border-color:#3dd97040;color:#3dd970}
.alert--danger{border-color:#ff5d6c40;color:#ff7c89}
.empty{padding:24px;border:1px dashed var(--border);border-radius:12px;color:var(--muted);background:var(--bg-soft)}
.muted{color:var(--muted)}

/* формы/таблицы (админ) */
.input{padding:.6rem .8rem;border-radius:10px;border:1px solid var(--border);background:var(--bg-soft);color:var(--text);width:100%}
.form__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.form__item{display:flex;flex-direction:column;gap:.3rem}
.form__item span{font-weight:500;opacity:.8}
.form__item input{padding:.6rem .8rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-soft);color:var(--text);width:100%}
.form__actions{display:flex;gap:.8rem;margin-top:1rem}
.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}
hr.my-4{border-color:var(--border);opacity:.4}.my-4{margin:1.5rem 0}

.table{width:100%;display:flex;flex-direction:column;border-radius:12px;background:var(--surface);overflow:hidden;margin-top:1rem}
.table__head,.table__row{display:flex;align-items:center;padding:.6rem 1rem;border-bottom:1px solid var(--border)}
.table__head{font-weight:600;background:rgba(255,255,255,.05)}
.table__row:last-child{border-bottom:none}
.c{padding-right:.5rem}.c--w10{flex:0 0 10%}.c--w20{flex:0 0 20%}.c--w25{flex:0 0 25%}.c--w35{flex:0 0 35%}.ta-right{text-align:right}

/* модалки (общие) */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000}
.hidden{display:none}
.modal__box{background:#111;padding:20px 24px;border-radius:14px;width:min(560px,90vw);box-shadow:var(--shadow)}
.modal__title{font-weight:600;margin-bottom:8px}
.progress{background:#222;border-radius:10px;height:10px;margin-top:8px;overflow:hidden}
.progress__bar{background:#6b8cff;height:10px;transition:width .1s}
.modal__meta{font-size:12px;margin-top:8px;color:var(--muted)}
