:root{
  --bg:#0f1115; --panel:#171a21; --panel2:#1d212b; --line:#272c38;
  --fg:#e6e9ef; --muted:#8b93a7; --accent:#6ea8fe; --ok:#5fd08a; --warn:#ff7a7a;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--fg);
  font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h2{margin:18px 0 10px;font-size:20px}
h3{margin:22px 0 8px;font-size:15px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

header{display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  padding:12px 22px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.brand a{font-weight:700;color:var(--fg);font-size:16px}
nav{display:flex;gap:16px}
nav a{color:var(--muted);font-weight:500}
nav a:hover{color:var(--fg);text-decoration:none}
header .status{margin-left:auto;display:flex;align-items:center;gap:12px}

main{max-width:1080px;margin:0 auto;padding:8px 22px 40px}
footer{max-width:1080px;margin:0 auto;padding:20px 22px;border-top:1px solid var(--line)}

.muted{color:var(--muted)}
.small{font-size:12.5px}
.ok{color:var(--ok)} .warn{color:var(--warn)}

.btn{background:var(--accent);color:#0b1020;border:0;border-radius:7px;
  padding:7px 13px;font-weight:600;cursor:pointer}
.btn:hover{filter:brightness(1.08)}
.btn:disabled{opacity:.5;cursor:default}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin:18px 0}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px}
.card .num{font-size:30px;font-weight:700}
.card .lbl{color:var(--muted);font-size:13px;margin-top:2px}

table{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
th,td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em;background:var(--panel2)}
tr:last-child td{border-bottom:0}
tr.off{opacity:.5}

.badge{padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600}
.badge.run{background:rgba(110,168,254,.16);color:var(--accent)}
.tag{display:inline-block;padding:2px 8px;border-radius:6px;background:var(--panel2);border:1px solid var(--line);font-size:12px}
.tag.t-rss{color:#ffb86b} .tag.t-telegram{color:#6ea8fe} .tag.t-medium{color:#5fd08a}
.tag.t-html{color:var(--muted)} .tag.t-reference,.tag.t-archive,.tag.t-scholar{color:#7a7f8c}

.dot{width:16px;height:16px;border-radius:50%;border:0;cursor:pointer;padding:0}
.dot.on{background:var(--ok)} .dot.offdot{background:#444b5a}

.filters{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 16px}
.filters input,.filters select{background:var(--panel);color:var(--fg);
  border:1px solid var(--line);border-radius:7px;padding:7px 10px}
.filters input[type=search]{min-width:220px}

.flash{max-width:1080px;margin:12px auto 0;padding:0 22px;display:flex;flex-direction:column;gap:6px}
.msg{padding:9px 13px;border-radius:8px}
.msg.ok{background:rgba(95,208,138,.14);color:var(--ok)}
.msg.warn{background:rgba(255,122,122,.14);color:var(--warn)}

ul.items{list-style:none;padding:0;margin:0}
ul.items li{padding:11px 0;border-bottom:1px solid var(--line)}
ul.items .meta{color:var(--muted);font-size:12.5px;margin-top:3px}
ul.feed .ttl{font-size:15px;font-weight:600}
ul.feed .sum{color:var(--muted);margin:3px 0}

.pager{display:flex;gap:16px;align-items:center;justify-content:center;margin:22px 0}

/* читалка поста */
.reader{max-width:720px}
.reader h1{font-size:26px;line-height:1.25;margin:6px 0 10px}
.reader .meta{color:var(--muted);font-size:13px;margin-bottom:22px}
.reader .body{font-size:16px;line-height:1.7}
.reader .body p{margin:0 0 16px}
.reader .drop{margin-top:34px;padding-top:18px;border-top:1px solid var(--line)}
.reader .note{background:var(--panel2);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:6px;padding:9px 12px;color:var(--muted);font-size:13px;margin-bottom:18px}
.summary{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--ok);
  border-radius:8px;padding:14px 16px;margin:6px 0 22px}
.summary-head{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--ok);margin-bottom:8px}
.summary ul{margin:0;padding-left:20px}
.summary li{margin:5px 0;line-height:1.55}
.summary-ask{display:flex;align-items:center;gap:10px;margin:6px 0 22px}

/* страница входа */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:30px;
  width:320px;display:flex;flex-direction:column;gap:14px}
.login-logo{font-size:18px;font-weight:700;text-align:center;margin-bottom:6px}
.login input[type=password]{background:var(--bg);color:var(--fg);border:1px solid var(--line);
  border-radius:8px;padding:11px 13px;font-size:15px}
.login .btn{padding:11px;font-size:15px}

/* лента-карточки текстов */
.cards-feed{display:flex;flex-direction:column;gap:2px}
.post{padding:16px 0;border-bottom:1px solid var(--line)}
.post .ttl{font-size:16px;font-weight:600;display:inline-block;margin-bottom:4px}
.post .meta{color:var(--muted);font-size:12.5px;margin-bottom:8px}
.post-body{font-size:14.5px;line-height:1.65;color:#cfd4df}
.post-body p{margin:0 0 12px}
.more-btn{background:none;border:0;color:var(--accent);cursor:pointer;padding:4px 0;font:inherit;font-size:13px}
.more-btn:hover{text-decoration:underline}

/* прогресс саммари */
.summary-progress{display:flex;align-items:center;gap:9px;color:var(--muted)}
.spinner{width:15px;height:15px;border:2px solid var(--line);border-top-color:var(--accent);
  border-radius:50%;display:inline-block;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* рекомендация удалить источник */
.rec-del{display:inline-block;margin-top:4px;font-size:11.5px;color:var(--warn);
  background:rgba(255,122,122,.1);border:1px solid rgba(255,122,122,.3);border-radius:5px;padding:1px 6px}

/* кнопки «перестать тянуть» */
.btn.danger{background:transparent;color:var(--warn);border:1px solid var(--warn)}
.btn.danger:hover{background:rgba(255,122,122,.12)}
.linklike{background:none;border:0;color:var(--muted);cursor:pointer;padding:0;font:inherit;font-size:12.5px}
.linklike.danger:hover{color:var(--warn);text-decoration:underline}
.drop-inline{display:inline}
.nowrap{white-space:nowrap}
ul.feed .meta .drop-inline{margin-left:2px}
