/* ===== Блокировки (Spotlight) ===== */
.blk-wrap{ --b-acc:#29a3ab; --b-acc2:#5fe3ff; --b-blue:#2b7fff; --b-card:rgba(255,255,255,.035); --b-bd:rgba(255,255,255,.06); --b-hi:rgba(41,163,171,.45); --b-head:#eafcff; --b-muted:#9fb2c0; display:block; }
.blk-wrap *{ box-sizing:border-box; }

/* hero */
.blk-hero{ display:flex; align-items:center; gap:18px; background:var(--b-card); border:1px solid var(--b-bd); border-radius:20px; padding:26px 30px; margin-top:14px; box-shadow:0 18px 50px rgba(0,0,0,.3); }
.blk-hero-ic{ width:64px; height:64px; flex-shrink:0; border-radius:18px; display:flex; align-items:center; justify-content:center; background:linear-gradient(120deg,#ff5050,#c0392b); box-shadow:0 10px 30px rgba(192,57,43,.4); }
.blk-hero-ic svg{ width:32px; height:32px; fill:#fff; }
.blk-hero-tx{ flex:1; min-width:0; }
.blk-eyebrow{ display:inline-block; font-size:13px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; background:linear-gradient(120deg,var(--b-acc2),var(--b-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:6px; }
.blk-title{ margin:0; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:clamp(26px,3.4vw,40px); font-weight:800; color:var(--b-head); letter-spacing:-.01em; }
.blk-title span{ background:linear-gradient(120deg,var(--b-acc2),var(--b-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.blk-sub{ margin:6px 0 0; color:var(--b-muted); font-size:15px; }
.blk-stat{ flex-shrink:0; text-align:center; padding:0 10px; }
.blk-stat-num{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:34px; font-weight:800; background:linear-gradient(120deg,var(--b-acc2),var(--b-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.blk-stat-lbl{ font-size:12px; color:var(--b-muted); }

/* bar: tabs + search */
.blk-bar{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin:22px 0 16px; }
.blk-tabs{ display:flex; gap:8px; flex-wrap:wrap; }
.blk-tab{ display:inline-flex; align-items:center; gap:8px; padding:10px 18px; border-radius:12px; background:var(--b-card); border:1px solid var(--b-bd); color:var(--b-muted); font-size:14px; font-weight:600; cursor:pointer; transition:.2s; }
.blk-tab i{ font-style:normal; font-size:12px; padding:1px 8px; border-radius:999px; background:rgba(255,255,255,.07); color:var(--b-muted); }
.blk-tab:hover{ color:var(--b-head); border-color:var(--b-hi); }
.blk-tab.active{ background:linear-gradient(120deg,var(--b-acc),var(--b-blue)); color:#fff; border-color:transparent; box-shadow:0 6px 18px rgba(43,127,255,.3); }
.blk-tab.active i{ background:rgba(255,255,255,.2); color:#fff; }
.blk-search{ display:flex; align-items:center; gap:9px; background:var(--b-card); border:1px solid var(--b-bd); border-radius:12px; padding:0 14px; height:42px; min-width:220px; }
.blk-search svg{ width:15px; height:15px; fill:var(--b-muted); flex-shrink:0; }
.blk-search input{ background:none; border:none; outline:none; color:var(--b-head); font-size:14px; width:100%; }
.blk-search input::placeholder{ color:#5e7585; }

/* table */
.blk-table{ background:var(--b-card); border:1px solid var(--b-bd); border-radius:20px; overflow:hidden; box-shadow:0 18px 50px rgba(0,0,0,.3); }
.blk-thead, .blk-row{ display:grid; grid-template-columns:1.4fr .8fr 1.6fr .9fr .9fr 1fr .9fr; gap:14px; align-items:center; padding:14px 22px; }
.blk-thead{ background:rgba(255,255,255,.02); border-bottom:1px solid var(--b-bd); font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#5e7585; }
.blk-row{ border-bottom:1px solid rgba(255,255,255,.04); animation:blkIn .35s ease; transition:background .2s; }
.blk-row:last-child{ border-bottom:none; }
.blk-row:hover{ background:rgba(41,163,171,.05); }
.blk-player{ display:flex; align-items:center; gap:11px; min-width:0; }
.blk-av{ width:36px; height:36px; flex-shrink:0; border-radius:11px; display:flex; align-items:center; justify-content:center; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-weight:700; color:#fff; background:linear-gradient(135deg,#1f8a91,#2b6fff); font-size:15px; }
.blk-pname{ font-weight:600; color:var(--b-head); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.blk-badge{ display:inline-flex; align-items:center; gap:6px; padding:5px 11px; border-radius:999px; font-size:12px; font-weight:700; }
.blk-badge svg{ width:13px; height:13px; fill:currentColor; }
.blk-badge-ban{ background:rgba(255,80,80,.14); color:#ff7676; }
.blk-badge-mute{ background:rgba(244,164,64,.14); color:#f4a440; }
.blk-badge-gag{ background:rgba(138,79,255,.16); color:#b080ff; }
.blk-reason{ color:var(--b-muted); font-size:13.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.blk-admin{ color:var(--b-acc2); font-weight:600; font-size:13.5px; }
.blk-dur{ color:var(--b-head); font-size:13.5px; }
.blk-date{ color:var(--b-muted); font-size:13px; }
.blk-status{ display:inline-flex; align-items:center; padding:5px 12px; border-radius:999px; font-size:12px; font-weight:700; }
.blk-active{ background:rgba(61,220,132,.14); color:#3ddc84; }
.blk-expired{ background:rgba(255,255,255,.06); color:#7a8a98; }
.blk-empty{ display:flex; flex-direction:column; align-items:center; gap:12px; padding:50px 20px; color:#5e7585; font-size:15px; }
.blk-empty svg{ width:40px; height:40px; fill:#3a4a58; }
@keyframes blkIn{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }

/* адаптив: на узких скрываем часть колонок, потом превращаем в карточки */
@media (max-width:980px){
  .blk-thead, .blk-row{ grid-template-columns:1.4fr .8fr .9fr 1fr .9fr; }
  .blk-col-reason, .blk-col-date{ display:none; }
}
@media (max-width:680px){
  .blk-thead{ display:none; }
  .blk-row{ grid-template-columns:1fr 1fr; gap:8px 14px; padding:16px 18px; }
  .blk-player{ grid-column:1 / -1; }
  .blk-admin::before{ content:'Админ: '; color:#5e7585; }
  .blk-dur::before{ content:'Срок: '; color:#5e7585; }
}

/* ===== Модалка: досье наказания ===== */
.blk-clickable{ cursor:pointer; }
.blk-modal{ position:fixed; inset:0; z-index:9998; display:flex; align-items:center; justify-content:center; padding:20px;
  background:rgba(5,8,14,.62); backdrop-filter:blur(7px); -webkit-backdrop-filter:blur(7px);
  opacity:0; visibility:hidden; transition:opacity .25s, visibility .25s; }
.blk-modal.open{ opacity:1; visibility:visible; }
.blk-modal-box{ position:relative; width:100%; max-width:440px; background:#11161f; border:1px solid rgba(255,255,255,.08); border-radius:22px;
  box-shadow:0 40px 100px rgba(0,0,0,.6); transform:translateY(14px) scale(.97); transition:transform .3s cubic-bezier(.2,.9,.3,1); max-height:92vh; overflow:hidden auto; }
.blk-modal.open .blk-modal-box{ transform:none; }
.blk-modal-x{ position:absolute; top:14px; right:14px; z-index:3; width:34px; height:34px; border-radius:50%; border:none; cursor:pointer;
  background:rgba(0,0,0,.35); color:#fff; font-size:20px; line-height:1; transition:.2s; backdrop-filter:blur(4px); }
.blk-modal-x:hover{ background:rgba(0,0,0,.6); transform:rotate(90deg); }

/* шапка-баннер (цвет по типу) */
.blk-banner{ position:relative; padding:30px 24px 22px; text-align:center; overflow:hidden;
  background:linear-gradient(160deg,rgba(255,80,80,.30),rgba(120,20,20,.05)); }
.blk-t-mute .blk-banner{ background:linear-gradient(160deg,rgba(244,164,64,.30),rgba(120,70,10,.05)); }
.blk-t-gag .blk-banner{ background:linear-gradient(160deg,rgba(138,79,255,.32),rgba(60,20,120,.05)); }
.blk-banner::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px); background-size:26px 26px; opacity:.5; }
.blk-banner-av{ position:relative; width:74px; height:74px; margin:0 auto 12px; border-radius:20px; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-family-1,"Unbounded"),sans-serif; font-weight:800; font-size:30px; color:#fff;
  background:rgba(0,0,0,.35); border:2px solid rgba(255,255,255,.18); box-shadow:0 12px 30px rgba(0,0,0,.4); }
.blk-banner-name{ position:relative; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:22px; font-weight:800; color:#fff; letter-spacing:-.01em;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.blk-banner-tags{ position:relative; display:flex; align-items:center; justify-content:center; gap:8px; margin-top:12px; }
.blk-banner .blk-badge{ background:rgba(0,0,0,.3); color:#fff; }
.blk-banner .blk-badge svg{ fill:#fff; }

/* строки-детали */
.blk-info{ padding:8px 22px; }
.blk-info-row{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.blk-info-row:last-child{ border-bottom:none; }
.blk-info-row > span{ display:inline-flex; align-items:center; gap:9px; font-size:13px; color:#7a8a98; flex-shrink:0; }
.blk-info-row > span svg{ width:15px; height:15px; fill:#5e7585; }
.blk-info-row b{ font-size:14px; font-weight:700; color:#e7edf2; text-align:right; min-width:0; overflow:hidden; text-overflow:ellipsis; }
.blk-info-row .blk-accent{ color:#5fe3ff; }
.blk-info-reason{ flex-direction:column; align-items:stretch; gap:8px; }
.blk-info-reason > span{ justify-content:flex-start; }
.blk-info-reason b{ text-align:left; white-space:normal; line-height:1.5; }

/* кнопки */
.blk-modal-actions{ display:grid; grid-template-columns:1fr auto auto; gap:8px; padding:14px 22px 22px; }
.blk-mbtn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:13px 16px; border-radius:13px; cursor:pointer; font-weight:700; font-size:13.5px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); color:#e7edf2; transition:.2s; white-space:nowrap; }
.blk-mbtn:hover{ background:rgba(255,255,255,.1); }
.blk-mbtn svg{ width:15px; height:15px; fill:currentColor; }
.blk-mbtn-buy{ background:linear-gradient(120deg,#f4ca80,#e0a83a); border:none; color:#1a1206; }
.blk-mbtn-buy:hover{ filter:brightness(1.07); transform:translateY(-1px); }
.blk-mbtn-buy i{ font-style:normal; padding:2px 9px; border-radius:999px; background:rgba(0,0,0,.18); font-size:12px; }
@media (max-width:440px){ .blk-modal-actions{ grid-template-columns:1fr; } }
