:root{
  --bg:#0d1117; --surface:#161b22; --surface2:#1c2230; --border:#2a3343;
  --text:#e6edf3; --muted:#8b97a7; --accent:#3b82f6; --accent2:#2563eb;
  --ok:#22c55e; --warn:#f59e0b; --off:#6b7280; --danger:#ef4444; --radius:12px;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.5}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
.small{font-size:.85em}
.err{background:rgba(239,68,68,.15);border:1px solid var(--danger);color:#fca5a5;
  padding:10px 14px;border-radius:8px;margin:12px 0}

/* topbar */
.topbar{display:flex;justify-content:space-between;align-items:center;
  padding:14px 24px;background:var(--surface);border-bottom:1px solid var(--border)}
.brand{font-weight:700;font-size:1.15rem;color:var(--text)}
.logout{color:var(--muted);font-size:.9rem}
.container{max-width:920px;margin:0 auto;padding:24px}

/* login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--surface);padding:36px;border-radius:var(--radius);
  border:1px solid var(--border);width:320px;text-align:center}
.login-card h1{margin:0 0 4px}
.login-card input,.login-card button{width:100%;margin-top:14px}

/* inputs */
input,textarea,select,button{font:inherit}
input,textarea,select{background:var(--surface2);border:1px solid var(--border);
  color:var(--text);padding:10px 12px;border-radius:8px;width:100%}
textarea{resize:vertical}
button,.btn-sm,.btn-danger{cursor:pointer;border:none;border-radius:8px;
  background:var(--accent);color:#fff;padding:10px 18px;font-weight:600}
button:hover{background:var(--accent2)}
button:disabled{opacity:.5;cursor:not-allowed}
.btn-sm{padding:6px 12px;font-size:.85rem;display:inline-block}
.btn-danger{background:var(--danger)}
.danger{color:var(--danger)}

.page-head{display:flex;justify-content:space-between;align-items:center;
  margin:24px 0 14px}
.page-head h1,.page-head h2{margin:0}

/* add bot */
.plan-bar{display:flex;gap:18px;align-items:center;background:var(--surface);
  border:1px solid var(--border);border-radius:10px;padding:10px 16px;margin:12px 0}
.add-bot{display:flex;gap:10px;margin:16px 0}
.add-bot input{flex:1}
.add-bot button{white-space:nowrap}

/* bot grid */
.bot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.bot-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;display:block;color:var(--text)}
.bot-card:hover{border-color:var(--accent);text-decoration:none}
.bot-card-head{display:flex;justify-content:space-between;align-items:center}
.bot-name{font-weight:700}
.bot-card-stat{margin-top:10px;color:var(--muted);font-size:.9rem}

.badge{font-size:.72rem;padding:2px 8px;border-radius:20px;font-weight:600}
.badge.ok{background:rgba(34,197,94,.18);color:#4ade80}
.badge.warn{background:rgba(245,158,11,.18);color:#fbbf24}
.badge.off{background:rgba(107,114,128,.2);color:#9ca3af}

/* subnav */
.subnav{border-bottom:1px solid var(--border);margin-bottom:8px}
.subnav-title{font-size:1.2rem;font-weight:700;margin-bottom:10px}
.subnav-tabs{display:flex;gap:4px;flex-wrap:wrap}
.subnav-tabs a{padding:8px 14px;color:var(--muted);border-radius:8px 8px 0 0}
.subnav-tabs a.active{color:var(--text);background:var(--surface);border:1px solid var(--border);border-bottom:none}

/* stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.stat-val{font-size:1.9rem;font-weight:700}
.stat-label{color:var(--muted);font-size:.85rem;margin-top:4px}

/* messages */
.msg-list{display:flex;flex-direction:column;gap:10px}
.msg{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 14px;max-width:80%}
.msg.out{align-self:flex-end;background:var(--surface2);border-color:var(--accent2)}
.msg-meta{display:flex;justify-content:space-between;gap:12px;font-size:.85rem;margin-bottom:4px}
.msg-text{white-space:pre-wrap;word-break:break-word}
.reply-form{display:flex;gap:10px;margin-top:16px}
.reply-form input{flex:1}

/* tables */
.tbl{width:100%;border-collapse:collapse;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.tbl th,.tbl td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}
.tbl th{color:var(--muted);font-weight:600;font-size:.85rem}
.tbl tr:last-child td{border-bottom:none}

/* forms */
.broadcast-form,.reply-form,form{display:flex;flex-direction:column;gap:12px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>*{flex:1;min-width:160px}
.row label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:var(--muted)}
.check{display:flex;align-items:center;gap:8px}
.check input{width:auto}
.btn-text{color:var(--muted);font-size:.85rem;margin-top:4px}
form button{align-self:flex-start}

@media(max-width:600px){.msg{max-width:100%}}
