*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f6fb; --ink:#1a1d29; --muted:#8b90a0; --line:rgba(20,24,40,.08);
  --line2:rgba(20,24,40,.16); --card:#fff; --accent:#6c4cff;
  --g-views:linear-gradient(135deg,#7c4dff,#b18cff);
  --g-comments:linear-gradient(135deg,#ff4d8d,#ff9ab5);
  --g-likes:linear-gradient(135deg,#00bcd4,#5fd9e6);
  --g-posts:linear-gradient(135deg,#ff8a00,#ffc24d);
  --g-er:linear-gradient(135deg,#1fc28a,#5ee0ac);
  --g-followers:linear-gradient(135deg,#5667e0,#8a97ff);
  --shadow:0 8px 30px rgba(40,42,80,.08);
  --shadow-sm:0 3px 14px rgba(40,42,80,.06);
}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Inter,sans-serif;background:var(--bg);color:var(--ink);min-height:100vh}

/* ---------- Password gate ---------- */
#gate{position:fixed;inset:0;background:radial-gradient(1200px 600px at 70% -10%,#eadcff 0,#f5f6fb 55%);display:flex;align-items:center;justify-content:center;z-index:100}
.gate-card{background:#fff;border-radius:20px;padding:2.6rem 2.1rem;width:340px;text-align:center;box-shadow:var(--shadow)}
.gate-card h2{font-size:18px;font-weight:650;margin-bottom:.4rem}
.gate-card p{font-size:12.5px;color:var(--muted);margin-bottom:1.5rem}
.gate-card input{width:100%;padding:12px 14px;border:1px solid var(--line2);border-radius:11px;font-size:14px;font-family:inherit;outline:none;text-align:center;letter-spacing:1px;transition:border-color .15s}
.gate-card input:focus{border-color:var(--accent)}
.gate-card button{width:100%;margin-top:.9rem;padding:12px;border:none;border-radius:11px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s}
.gate-card button:hover{opacity:.9}
.gate-err{color:#e6395a;font-size:12px;margin-top:.7rem;min-height:16px}

/* ---------- Layout ---------- */
#app{display:none;padding:1.6rem 1.1rem 3rem;max-width:1380px;margin:0 auto}
.topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.1rem;flex-wrap:wrap}
h1{font-size:22px;font-weight:700;letter-spacing:-.3px}
.subtitle{font-size:13px;color:var(--muted);margin-top:2px}
.upd{display:flex;align-items:center;gap:.7rem;font-size:12px;color:var(--muted)}
.refresh-btn{display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:#fff;border:none;border-radius:10px;padding:9px 15px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s}
.refresh-btn:hover{opacity:.88}
.refresh-btn.spin svg{animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:6px;background:#fff;border-radius:13px;padding:5px;width:fit-content;box-shadow:var(--shadow-sm);margin-bottom:1.4rem}
.tab-btn{background:transparent;border:none;padding:9px 20px;border-radius:9px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;transition:all .15s}
.tab-btn.active{background:var(--accent);color:#fff}
.sheet{display:none}
.sheet.active{display:block}

/* ---------- KPI cards ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:1.4rem}
.kpi{position:relative;border-radius:18px;padding:16px 18px;color:#fff;overflow:hidden;box-shadow:var(--shadow-sm);min-height:104px}
.kpi.views{background:var(--g-views)} .kpi.comments{background:var(--g-comments)}
.kpi.likes{background:var(--g-likes)} .kpi.posts{background:var(--g-posts)}
.kpi.er{background:var(--g-er)} .kpi.followers{background:var(--g-followers)}
.kpi .k-label{font-size:12px;font-weight:600;opacity:.92}
.kpi .k-val{font-size:27px;font-weight:750;margin-top:6px;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.kpi .k-delta{font-size:12px;font-weight:600;margin-top:3px;opacity:.95}
.kpi .k-spark{position:absolute;right:0;bottom:0;width:96px;height:42px;opacity:.55}

/* ---------- Cards / panels ---------- */
.card{background:var(--card);border-radius:18px;padding:1.3rem 1.4rem;box-shadow:var(--shadow-sm);margin-bottom:1.4rem}
.card-h{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.card-title{font-size:15px;font-weight:650}
.card-sub{font-size:12px;color:var(--muted);margin-top:2px}

/* ---------- Segmented controls ---------- */
.seg{display:inline-flex;border:1px solid var(--line2);border-radius:9px;overflow:hidden;background:#fff}
.seg button{background:transparent;border:none;border-right:1px solid var(--line);padding:7px 14px;font-size:12.5px;cursor:pointer;color:#666;font-family:inherit;white-space:nowrap;font-weight:600;transition:background .12s,color .12s}
.seg button:last-child{border-right:none}
.seg button.active{background:var(--ink);color:#fff}
.seg-row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
.controls{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}

/* ---------- Chart boxes ---------- */
.chart{width:100%;height:380px}
.chart.sm{height:300px}
.grid-2{display:grid;grid-template-columns:1.15fr .85fr;gap:14px}
@media(max-width:880px){.grid-2{grid-template-columns:1fr}}

/* ---------- Top posts ---------- */
.top-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.tp{display:flex;gap:11px;align-items:center;border:1px solid var(--line);border-radius:14px;padding:11px 12px;transition:box-shadow .15s}
.tp:hover{box-shadow:var(--shadow-sm)}
.tp .ava{width:40px;height:40px;border-radius:11px;object-fit:cover;flex:0 0 auto;background:#eee}
.tp .tp-main{min-width:0;flex:1}
.tp .tp-nick{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tp .tp-sub{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px;margin-top:1px}
.tp .tp-val{font-weight:750;font-size:16px;font-variant-numeric:tabular-nums}
.tp svg{width:13px;height:13px;flex:0 0 auto}

/* ---------- Feed table ---------- */
.filters{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}
.dd{position:relative}
.dd-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line2);background:#fff;border-radius:9px;padding:8px 12px;font-size:13px;cursor:pointer;font-family:inherit;color:#333;min-width:150px;justify-content:space-between}
.dd-panel{position:absolute;top:calc(100% + 5px);left:0;background:#fff;border:1px solid var(--line2);border-radius:12px;box-shadow:var(--shadow);padding:.55rem;z-index:30;width:270px;max-height:340px;overflow:auto;display:none}
.dd-panel.open{display:block}
.dd-search{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:12.5px;font-family:inherit;margin-bottom:.45rem;outline:none}
.dd-item{display:flex;align-items:center;gap:9px;padding:7px;border-radius:7px;font-size:12.5px;cursor:pointer}
.dd-item:hover{background:#f3f3f8}
.dd-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.dd-actions{display:flex;justify-content:space-between;padding:5px 4px 2px;border-top:1px solid var(--line);margin-top:5px}
.dd-actions a{font-size:11.5px;color:#666;cursor:pointer}
.dd-actions a:hover{color:var(--ink);text-decoration:underline}
.date-in{border:1px solid var(--line2);background:#fff;border-radius:9px;padding:7px 11px;font-size:13px;font-family:inherit;color:#333}
.clear-flt{font-size:12px;color:#666;background:none;border:none;cursor:pointer;text-decoration:underline;font-family:inherit;padding:6px}

.tbl-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:14px}
table.feed{border-collapse:collapse;width:100%;font-size:12.5px;min-width:920px}
table.feed thead th{position:sticky;top:0;background:#fafafc;color:#777;font-weight:600;text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);white-space:nowrap;font-size:11.5px;z-index:2}
table.feed th.sortable{cursor:pointer;user-select:none}
table.feed th.sortable:hover{color:var(--ink)}
.sort-ar{color:#bbb;font-size:9px;margin-left:3px}
th.sorted .sort-ar{color:var(--ink)}
table.feed td{padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap;vertical-align:middle}
table.feed tbody tr{cursor:pointer}
table.feed tbody tr:hover{background:#faf9ff}
table.feed tbody tr:last-child td{border-bottom:none}
td.num{color:#bbb;font-variant-numeric:tabular-nums}
td.numv{font-variant-numeric:tabular-nums;text-align:right}
td.viv{font-weight:700;font-variant-numeric:tabular-nums}
.delta-up{color:#1fa971;font-weight:600} .delta-zero{color:#aaa}
.ava{width:28px;height:28px;border-radius:50%;object-fit:cover;flex:0 0 auto;border:2px solid #ddd;background:#eee}
.nick-cell{display:inline-flex;align-items:center;gap:8px}
a.nick{font-weight:600;text-decoration:none}
a.nick:hover{text-decoration:underline}
.soc-cell{display:inline-flex;align-items:center;gap:6px;color:#555}
.soc-cell svg{width:14px;height:14px;flex:0 0 auto}
a.plink{display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;border-radius:6px;color:#aaa;text-decoration:none;margin-left:2px}
a.plink:hover{color:var(--ink);background:rgba(0,0,0,.05)}
.pill{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}
.info{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;border:1px solid #bbb;color:#999;font-size:9px;font-style:italic;font-weight:700;cursor:help;margin-left:4px;vertical-align:middle}
.kpi .info{border-color:rgba(255,255,255,.65);color:#fff;opacity:.9}
.card-title .info,.k-label .info{vertical-align:middle}
.tip-box{position:fixed;display:none;background:var(--ink);color:#fff;font-size:11.5px;line-height:1.5;padding:9px 12px;border-radius:9px;width:240px;z-index:200;box-shadow:var(--shadow);pointer-events:none;text-align:left}
.pager{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;font-size:12.5px;color:#666}
.pager .pg-btns{display:flex;gap:6px}
.pager button{border:1px solid var(--line2);background:#fff;border-radius:8px;padding:6px 12px;font-size:12.5px;cursor:pointer;font-family:inherit;color:#333}
.pager button:disabled{opacity:.4;cursor:default}

/* ---------- Heatmap (people) ---------- */
.heat-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px;margin-bottom:1.6rem}
table.heat{border-collapse:separate;border-spacing:0;font-size:12px;width:max-content;min-width:100%}
table.heat th,table.heat td{padding:8px 9px;text-align:center;white-space:nowrap;font-variant-numeric:tabular-nums}
table.heat thead th{background:#fafafc;color:#888;font-weight:600;font-size:11px;position:sticky;top:0;border-bottom:1px solid var(--line)}
table.heat th.amb-h,table.heat td.amb-c{position:sticky;left:0;background:#fff;z-index:3;text-align:left;width:220px;min-width:220px;max-width:220px}
table.heat thead th.amb-h{z-index:5;background:#fafafc}
table.heat td.amb-c{padding:7px 12px}
.amb-c .row-amb{display:flex;align-items:center;gap:9px}
.amb-c .ava{width:24px;height:24px}
.amb-c a{text-decoration:none;font-weight:600;font-size:12px}
.amb-c a:hover{text-decoration:underline}
table.heat th.total-h,table.heat td.total-c{position:sticky;left:220px;z-index:2}
table.heat td.total-c{font-weight:700;background:#fbfbfe;color:#222;border-left:1px solid var(--line)}
table.heat thead th.total-h{z-index:4;background:#fafafc;border-left:1px solid var(--line)}
table.heat tr.totals-row td{border-bottom:2px solid var(--line2);font-weight:700;background:#f3f1fe;color:#222}
.heat-cell{font-variant-numeric:tabular-nums}

/* ---------- Podium ---------- */
.podium{display:flex;align-items:flex-end;gap:5px;width:100%;margin-top:.4rem}
.pf-item{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0}
.pf-info{text-align:center;padding-bottom:6px;width:100%}
.pf-medal{font-size:16px;line-height:1.4}
.pf-count{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pf-name{font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
.pf-name a{text-decoration:none}
.pf-bar{width:100%;border-radius:7px 7px 0 0;display:flex;align-items:center;justify-content:center;min-height:18px}
.pf-place{font-size:12px;font-weight:600;color:rgba(255,255,255,.85)}

/* ---------- Modal ---------- */
#modal{position:fixed;inset:0;background:rgba(20,24,40,.45);display:none;align-items:center;justify-content:center;z-index:120;padding:1rem}
#modal.open{display:flex}
.modal-card{background:#fff;border-radius:18px;padding:1.4rem;width:min(680px,96vw);box-shadow:var(--shadow)}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}
.modal-head h3{font-size:15px;font-weight:650}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:#999;line-height:1}
#modalChart{width:100%;height:300px}
.modal-empty{color:var(--muted);font-size:13px;text-align:center;padding:2rem 0}
.people-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-top:1.4rem}
.pcard{border:1px solid var(--line);border-radius:15px;padding:13px 14px}
.pcard-h{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.pcard-h .ava{width:34px;height:34px}
.pcard-h .nm{font-weight:650;font-size:13px}
.pcard-stats{display:flex;gap:14px;font-size:12px;color:#555}
.pcard-stats b{display:block;font-size:15px;color:var(--ink);font-variant-numeric:tabular-nums}

/* ---------- Settings / admin ---------- */
.set-form{display:flex;flex-direction:column;gap:14px;max-width:480px}
.set-field{display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:13px;color:#444}
.set-field>span{flex:0 0 auto}
.set-input{border:1px solid var(--line2);border-radius:9px;padding:8px 11px;font-size:13px;font-family:inherit;color:#333;outline:none;background:#fff}
.set-input:focus{border-color:var(--accent)}
select.set-input{cursor:pointer}
input.set-input[type=number]{width:90px;text-align:right}
#setTz{width:210px}
.set-time{display:flex;align-items:center;gap:6px}
.set-time b{color:#888}
.set-actions{display:flex;align-items:center;gap:12px;margin-top:4px}
.set-status{font-size:12.5px;color:var(--muted)}
.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:9px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s}
.btn-primary:hover{opacity:.9}
.toggle{width:44px;height:25px;border-radius:20px;border:none;background:#d2d4de;position:relative;cursor:pointer;transition:background .15s;flex:0 0 auto}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:19px;height:19px;border-radius:50%;background:#fff;transition:left .15s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on{background:var(--accent)}
.toggle.on::after{left:22px}

.acct-table{min-width:700px}
.acct-table td{vertical-align:middle}
.acct-handle{color:#555}
.acct-handle.empty{color:#ccc}
.status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;user-select:none}
.status-badge.active{background:rgba(31,169,113,.14);color:#1a9a67}
.status-badge.paused{background:rgba(0,0,0,.06);color:#999}
.row-actions{display:flex;gap:6px;justify-content:flex-end}
.icon-btn{border:1px solid var(--line2);background:#fff;border-radius:8px;padding:5px 10px;font-size:13px;cursor:pointer;color:#555;font-family:inherit}
.icon-btn:hover{background:#f3f3f8;color:var(--ink)}
.icon-btn.danger:hover{background:#fdecef;color:#e6395a;border-color:#f5c6cf}

#personModal{position:fixed;inset:0;background:rgba(20,24,40,.45);display:none;align-items:center;justify-content:center;z-index:130;padding:1rem}
#personModal.open{display:flex}
.pm-form{display:flex;flex-direction:column;gap:12px}
.pm-form .set-input{width:250px}

/* ===== журнал сбора / баннер / цели / расход ===== */
/* баннер последнего сбора */
.run-banner{border-radius:14px;padding:11px 16px;font-size:13px;margin-bottom:1.4rem;box-shadow:var(--shadow-sm);display:flex;align-items:center;flex-wrap:wrap;gap:4px}
.run-banner.ok{background:rgba(31,169,113,.10);color:#187a52;border:1px solid rgba(31,169,113,.22)}
.run-banner.warn{background:rgba(240,160,20,.12);color:#9a6a00;border:1px solid rgba(240,160,20,.28);cursor:pointer}
.run-banner b{font-weight:750}
.run-link{margin-left:6px;text-decoration:underline;font-weight:600;cursor:pointer}

/* цели */
.goals-box{display:flex;flex-direction:column;gap:12px;margin-bottom:6px}
.goal{display:flex;flex-direction:column;gap:6px}
.goal-top{display:flex;justify-content:space-between;font-size:13px;color:#444;font-weight:600}
.goal-num{color:var(--muted);font-variant-numeric:tabular-nums}
.goal-num b{color:var(--ink)}
.goal-bar{height:9px;border-radius:6px;background:#eef0f6;overflow:hidden}
.goal-bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,#7c4dff,#b18cff);transition:width .4s}
.goal-bar i.done{background:linear-gradient(90deg,#1fc28a,#5ee0ac)}

/* сравнение период-к-периоду */
.compare-row{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}
.compare-h{grid-column:1/-1;font-size:12px;color:var(--muted);font-weight:600}
.cmp-item{background:#fafafc;border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.cmp-val{font-size:20px;font-weight:750;letter-spacing:-.3px;font-variant-numeric:tabular-nums}
.cmp-label{font-size:12px;color:var(--muted);margin:2px 0 4px}
.cmp{font-size:12px;font-weight:600}
.cmp.up{color:#1a9a67}
.cmp.down{color:#d34d4d}
.cmp.flat{color:#aaa}

/* статус сбора в таблице аккаунтов */
.lc{display:inline-block;font-size:11.5px;font-weight:600;white-space:nowrap}
.lc.ok{color:#1a9a67}
.lc.warn{color:#9a6a00}
.lc.bad{color:#d34d4d}
.lc.none{color:#aaa}
tr.row-problem{background:rgba(240,160,20,.06)}
tr.row-problem:hover{background:rgba(240,160,20,.10)}

/* расход */
.usage-line{font-size:14px;color:var(--ink);margin-bottom:14px}
.usage-line b{font-weight:750}
.usage-tot{font-size:12px;color:var(--muted)}

/* журнал прогонов */
.runs-table td.collected{font-weight:600;color:#1a9a67}
.runs-table td.collected.warn{color:#9a6a00}

/* ===== переключатель темы ===== */
.theme-btn{background:var(--card);border:1px solid var(--line2);border-radius:10px;width:36px;height:34px;font-size:15px;cursor:pointer;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}
.theme-btn:hover{border-color:var(--accent)}

/* ===== ТЁМНАЯ ТЕМА ===== */
[data-theme="dark"]{
  --bg:#0e1016; --ink:#e8eaf2; --muted:#9aa0b2;
  --line:rgba(255,255,255,.09); --line2:rgba(255,255,255,.18);
  --card:#181b24; --accent:#8b6dff;
  --shadow:0 10px 34px rgba(0,0,0,.55); --shadow-sm:0 3px 14px rgba(0,0,0,.4);
}
[data-theme="dark"] #gate{background:radial-gradient(1200px 600px at 70% -10%,#241a4d 0,#0e1016 55%)}
[data-theme="dark"] .gate-card,
[data-theme="dark"] .tabs,
[data-theme="dark"] .seg,
[data-theme="dark"] .dd-btn,
[data-theme="dark"] .dd-panel,
[data-theme="dark"] .date-in,
[data-theme="dark"] .pager button,
[data-theme="dark"] .set-input,
[data-theme="dark"] .icon-btn,
[data-theme="dark"] .modal-card{background:var(--card);color:var(--ink)}
[data-theme="dark"] .gate-card input{background:#20232e;color:var(--ink)}
[data-theme="dark"] .seg button,
[data-theme="dark"] .dd-btn,
[data-theme="dark"] .date-in,
[data-theme="dark"] .pager,
[data-theme="dark"] .pager button,
[data-theme="dark"] .clear-flt,
[data-theme="dark"] .dd-actions a,
[data-theme="dark"] .soc-cell,
[data-theme="dark"] .acct-handle,
[data-theme="dark"] .pcard-stats,
[data-theme="dark"] .set-field,
[data-theme="dark"] .goal-top{color:var(--muted)}
/* кнопки на акценте — текст белый даже в тёмной теме */
[data-theme="dark"] .refresh-btn{background:var(--accent);color:#fff}
[data-theme="dark"] .seg button.active{background:var(--accent);color:#fff}
/* таблицы */
[data-theme="dark"] table.feed thead th,
[data-theme="dark"] table.heat thead th,
[data-theme="dark"] table.heat thead th.amb-h,
[data-theme="dark"] table.heat thead th.total-h{background:#20232e;color:var(--muted)}
[data-theme="dark"] table.heat th.amb-h,
[data-theme="dark"] table.heat td.amb-c{background:var(--card)}
[data-theme="dark"] table.heat td.total-c{background:#1d2029;color:var(--ink)}
[data-theme="dark"] table.heat tr.totals-row td{background:#241f38;color:var(--ink)}
[data-theme="dark"] table.feed tbody tr:hover{background:rgba(255,255,255,.04)}
[data-theme="dark"] .dd-item:hover,
[data-theme="dark"] .icon-btn:hover{background:rgba(255,255,255,.07);color:var(--ink)}
[data-theme="dark"] a.plink:hover{background:rgba(255,255,255,.08)}
/* мелочи */
[data-theme="dark"] .cmp-item,
[data-theme="dark"] .goal-bar{background:#20232e}
[data-theme="dark"] .tp .ava,
[data-theme="dark"] .ava{background:#2a2e3a;border-color:#3a3e4a}
[data-theme="dark"] .toggle{background:#3a3e4a}
[data-theme="dark"] .toggle::after{background:#e8eaf2}
[data-theme="dark"] .status-badge.paused{background:rgba(255,255,255,.08);color:var(--muted)}
[data-theme="dark"] .info{border-color:var(--line2);color:var(--muted)}
[data-theme="dark"] .modal-close{color:var(--muted)}
[data-theme="dark"] .set-time b{color:var(--muted)}
/* баннер последнего сбора — поярче на тёмном */
[data-theme="dark"] .run-banner.ok{background:rgba(31,169,113,.16);color:#5fd9a6}
[data-theme="dark"] .run-banner.warn{background:rgba(240,160,20,.16);color:#e8b65a}
[data-theme="dark"] .icon-btn.danger:hover{background:rgba(230,57,90,.18);color:#ff708c;border-color:rgba(230,57,90,.4)}
[data-theme="dark"] .tip-box{background:#272b36;color:#e8eaf2}

/* ===== видео-превью + подпись в ленте ===== */
.vid-cell{display:flex;align-items:center;gap:8px;max-width:270px}
.vthumb{width:40px;height:54px;border-radius:7px;object-fit:cover;background:#eee;flex:0 0 auto;display:block}
.vthumb.ph{display:inline-block}
.vcap{font-size:11.5px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}

/* ===== стоимость (CPV) в ленте ===== */
.cost-in{width:80px;border:1px solid var(--line2);border-radius:7px;padding:4px 7px;font-size:12px;font-family:inherit;text-align:right;background:#fff;color:#333;outline:none}
.cost-in:focus{border-color:var(--accent)}

/* ===== продажи (WB) ===== */
.wb-note{font-size:12.5px;color:var(--muted);background:#fafafc;border:1px solid var(--line);border-radius:11px;padding:9px 13px;margin-bottom:1rem}
.sales-table{min-width:760px}
.promo{display:inline-block;background:rgba(108,76,255,.12);color:var(--accent);border-radius:6px;padding:1px 7px;font-size:11px;font-weight:600}

/* ===== артикулы в карточке блогера ===== */
.pm-articles{border-top:1px solid var(--line);margin-top:12px;padding-top:10px}
.art-list{display:flex;flex-direction:column;gap:6px}
.art-row{display:flex;align-items:center;gap:8px;font-size:12.5px;background:#f7f7fb;border:1px solid var(--line);border-radius:9px;padding:6px 10px}
.art-row .icon-btn{margin-left:auto;padding:3px 8px}
.art-empty{font-size:12px;color:var(--muted)}
.art-add{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.art-add .set-input{flex:1 1 120px;width:auto}
.art-hint{font-size:11.5px;color:var(--muted);margin-top:6px}

/* ===== модалка ввода продаж ===== */
#salesModal{position:fixed;inset:0;background:rgba(20,24,40,.45);display:none;align-items:center;justify-content:center;z-index:130;padding:1rem}
#salesModal.open{display:flex}

/* ===== тёмная тема: новые элементы ===== */
[data-theme="dark"] .cost-in{background:#20232e;color:var(--ink)}
[data-theme="dark"] .art-row,
[data-theme="dark"] .wb-note{background:#20232e}
[data-theme="dark"] .vthumb{background:#2a2e3a}
[data-theme="dark"] .vcap{color:var(--muted)}
[data-theme="dark"] .promo{background:rgba(139,109,255,.2);color:#b9a6ff}
