:root{
  --bg:#f5f6f8; --panel:#ffffff; --ink:#14161a; --muted:#7a8290;
  --line:#e9ecf1; --brand:#e23d28; --blue:#299be2; --yellow:#f5c733;
  --green:#22a06b; --red:#e2483d; --radius:16px;
  --shadow:0 1px 2px rgba(20,22,26,.04),0 8px 24px rgba(20,22,26,.05);
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Inter,Arial,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;font-size:14px;line-height:1.45}
h1{font-size:22px;margin:0;letter-spacing:-.01em}
h2{font-size:14px;margin:0;font-weight:650;letter-spacing:-.01em}
a{color:inherit;text-decoration:none;cursor:pointer}
code{background:#eef1f6;padding:2px 7px;border-radius:6px;font-size:12px;
  font-family:'SF Mono',Menlo,Consolas,monospace;color:#2b3140}
.muted{color:var(--muted)} .small{font-size:12px}
.ic{width:18px;height:18px;flex:none;display:inline-block;vertical-align:middle}

/* ---------- login ---------- */
.login-body{display:grid;place-items:center;min-height:100vh;
  background:radial-gradient(1000px 460px at 50% -12%,#fff,transparent),var(--bg)}
.login-card{background:var(--panel);padding:40px;border-radius:22px;
  box-shadow:var(--shadow);width:372px;border:1px solid var(--line)}
.login-brand{display:flex;align-items:center;margin-bottom:22px}
.login-brand img{height:46px}
.login-card h1{margin:2px 0 4px}
.login-card form{display:grid;gap:14px;margin-top:22px}

/* ---------- layout ---------- */
.layout{display:grid;grid-template-columns:238px 1fr;min-height:100vh}
.sidebar{background:#ffffff;border-right:1px solid var(--line);color:#3a4150;
  display:flex;flex-direction:column;padding:20px 14px;gap:6px}
.brand{display:flex;align-items:center;padding:6px 8px 20px}
.brand-logo{height:38px;display:block}
.sidebar nav{display:flex;flex-direction:column;gap:3px;flex:1;margin-top:2px}
.nav-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:10px;
  color:#5b6472;font-weight:550;transition:.15s}
.nav-item .ic{width:18px;height:18px;color:#98a1af}
.nav-item:hover{background:#f4f6f9;color:var(--ink)}
.nav-item:hover .ic{color:#5b6472}
.nav-item.active{background:#f0f2f6;color:var(--ink);font-weight:650}
.nav-item.active .ic{color:var(--brand)}
.sidebar-foot{border-top:1px solid var(--line);padding-top:14px;display:flex;flex-direction:column;gap:9px}
.icon-row{display:inline-flex;align-items:center;gap:8px;justify-content:center}
.content{padding:26px 32px;max-width:1180px}

/* ---------- sections ---------- */
.section{display:none;animation:fade .22s ease}
.section.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.page-head p{margin:4px 0 0}
.head-actions{display:flex;gap:10px;align-items:center}

/* ---------- cards ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow);margin-bottom:18px;display:flex;flex-direction:column;gap:13px}
.card.no-pad{padding:0;overflow:hidden;gap:0}
.card-head{display:flex;justify-content:space-between;align-items:center}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:960px){.grid-2{grid-template-columns:1fr}.layout{grid-template-columns:1fr}}

/* ---------- stat row ---------- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow)}
.stat .n{font-size:25px;font-weight:800;letter-spacing:-.02em}
.stat .l{color:var(--muted);font-size:12px;margin-top:3px}
@media(max-width:960px){.stat-row{grid-template-columns:1fr 1fr}}

/* ---------- lists ---------- */
.list{display:flex;flex-direction:column}
.list-item{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line)}
.list-item:last-child{border-bottom:none}
.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background:#e7eaf0;flex:none}
.li-main{flex:1;min-width:0}
.li-name{font-weight:600;display:flex;align-items:center;gap:8px}
.li-sub{color:var(--muted);font-size:12px}
.pill{padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}
.pill.blue{background:#e7f3fc;color:#1c6aa0}
.pill.yellow{background:#fdf4d6;color:#8a6d12}
.pill.gray{background:#eef1f6;color:#5b6472}
.pill.green{background:#e2f5ec;color:#1a7a52}
.pill.red{background:#fdeaea;color:#b23a30}

/* ---------- table ---------- */
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:11px;color:var(--muted);font-weight:650;text-transform:uppercase;
  letter-spacing:.04em;padding:13px 14px;border-bottom:1px solid var(--line);background:#fafbfc}
.table td{padding:10px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover td{background:#fafbfc}

/* ---------- forms ---------- */
label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:550}
.input,.textarea,input,select,textarea{font-family:var(--font);font-size:14px;
  border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:#fff;color:var(--ink);width:100%}
.input:focus,textarea:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #299be220}
.textarea{resize:vertical;line-height:1.55;font-family:var(--font)}
.search-box{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:10px;padding:0 12px}
.search-box .ic{color:var(--muted)}
.search-box input{border:none;padding:9px 0;width:220px}
.search-box input:focus{outline:none;box-shadow:none}

/* ---------- buttons ---------- */
.btn{border:1px solid transparent;border-radius:10px;padding:9px 14px;font-weight:600;
  font-size:13px;cursor:pointer;background:#eef1f6;color:var(--ink);transition:.15s;font-family:var(--font)}
.btn:hover{filter:brightness(.98);transform:translateY(-1px)}
.btn.primary{background:var(--ink);color:#fff}
.btn.success{background:var(--green);color:#fff}
.btn.danger{background:var(--red);color:#fff}
.btn.ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn.block{width:100%}
.btn.small{padding:7px 10px;font-size:12px}
.btn .ic{width:16px;height:16px}
.row{display:flex;gap:10px;flex-wrap:wrap}
.row.end{justify-content:flex-end;margin-top:14px}
.icon-btn{background:#fff;border:1px solid var(--line);cursor:pointer;padding:6px;border-radius:9px;
  color:#5b6472;display:inline-flex;transition:.15s;margin-left:4px}
.icon-btn:hover{background:#f4f6f9;color:var(--ink)}
.icon-btn.danger:hover{background:#fdeaea;color:var(--red);border-color:#f6cfca}

/* ---------- templates ---------- */
.style-picker{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:8px 13px;border:1px solid var(--line);border-radius:999px;cursor:pointer;
  font-weight:600;font-size:13px;transition:.15s}
.chip:hover{border-color:#c7ced8}
.chip.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.preview{width:100%;border-radius:12px;border:1px solid var(--line);margin-top:2px}

/* ---------- placeholders / slack preview ---------- */
.ph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.ph{display:flex;gap:10px;align-items:baseline}
.ph span{color:var(--muted);font-size:12px}
/* searchable combobox */
.combo{position:relative}
.combo-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);
  max-height:280px;overflow:auto;z-index:30;display:none}
.combo-list.show{display:block}
.combo-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;font-size:14px}
.combo-item:hover{background:#f4f6f9}
.combo-item img{width:26px;height:26px;border-radius:50%;object-fit:cover;background:#e7eaf0;flex:none}

/* bot avatar preview */
.dp-row{display:flex;gap:16px;align-items:flex-start}
.dp-preview{width:96px;height:96px;border-radius:16px;object-fit:cover;border:1px solid var(--line);
  background:#fafbfc;flex:none}
.dp-controls{flex:1;display:flex;flex-direction:column;gap:10px}

/* pagination */
.pager{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:2px}
.pager .page-info{font-size:13px;color:var(--muted)}
.pager button{border:1px solid var(--line);background:#fff;border-radius:9px;padding:7px 12px;
  cursor:pointer;font-weight:600;font-size:13px;color:var(--ink)}
.pager button:hover:not(:disabled){background:#f4f6f9}
.pager button:disabled{opacity:.45;cursor:not-allowed}

.emoji-bar{display:flex;flex-wrap:wrap;gap:6px}
.emoji-chip{border:1px solid var(--line);background:#fff;border-radius:8px;padding:4px 9px;
  cursor:pointer;font-size:15px;line-height:1.1;transition:.12s}
.emoji-chip:hover{background:#f4f6f9;transform:translateY(-1px)}
.slack-label{font-size:11px;color:var(--muted);font-weight:650;text-transform:uppercase;
  letter-spacing:.05em;margin-top:2px}
.slack{border:1px solid var(--line);border-radius:12px;padding:14px;background:#fff;display:flex;gap:11px}
.slack-av{width:38px;height:38px;border-radius:9px;background:#fff;border:1px solid var(--line);
  object-fit:contain;padding:3px;flex:none}
.slack-body{flex:1;min-width:0}
.slack-head{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.slack-name{font-weight:800;font-size:14px}
.slack-app{background:#e7eaf0;color:#5b6472;font-size:9px;font-weight:800;padding:1px 5px;
  border-radius:4px;text-transform:uppercase;letter-spacing:.03em}
.slack-time{color:var(--muted);font-size:12px}
.slack-text{white-space:pre-wrap;line-height:1.5;font-size:14px;word-break:break-word}
.slack-mention{background:#e8f2ff;color:#1264a3;border-radius:4px;padding:0 3px;font-weight:600}
.slack-img{margin-top:9px;max-width:360px;width:100%;border-radius:10px;border:1px solid var(--line)}

/* ---------- status pill / bot ---------- */
#bot-status-pill .pill{font-size:13px;padding:6px 14px}
.state-label .pill{font-size:14px;padding:6px 14px}
.bot-control{display:flex;flex-direction:column;gap:12px}
hr{border:none;border-top:1px solid var(--line);margin:2px 0}

/* ---------- alerts / toast ---------- */
.alert{padding:10px 12px;border-radius:10px;font-size:13px}
.alert.error{background:#fdeaea;color:#b23a30}
.toast{position:fixed;top:18px;right:18px;background:var(--ink);color:#fff;padding:12px 16px;
  border-radius:11px;box-shadow:var(--shadow);opacity:0;transform:translateY(-8px);
  transition:.25s;pointer-events:none;z-index:50;font-size:13px;font-weight:550}
.toast.show{opacity:1;transform:none}
.toast.err{background:var(--red)}

/* ---------- modal ---------- */
.modal-backdrop{position:fixed;inset:0;background:rgba(10,12,16,.5);display:none;
  place-items:center;z-index:40;padding:20px;backdrop-filter:blur(2px)}
.modal-backdrop.show{display:grid}
.modal{background:#fff;border-radius:20px;padding:26px;width:640px;max-width:100%;
  box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px;max-height:90vh;overflow:auto}
.modal .grid-2{gap:12px}
