:root{
  --c-text:#181431;--c-text-soft:#5B5B6B;--c-text-muted:#818181;
  --c-bg:#FFFFFF;--c-bg-gray:#F6F7F9;--c-bg-dark:#0F1B33;--c-line:#E5E7EB;
  --c-accent:#0D75B2;--c-accent-d:#0B6396;--c-accent-soft:#DDEAF5;
  --c-green:#1f9d57;--c-red:#c0392b;--c-warn:#b8730a;
  --f:'Roboto',system-ui,-apple-system,Segoe UI,Arial,sans-serif;
  --r:16px;--r-sm:6px;--sh:0 4px 16px rgba(15,27,51,.07);--sh-sm:0 1px 2px rgba(13,117,178,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--f);background:var(--c-bg-gray);color:var(--c-text);font-size:15px;line-height:1.55}
a{color:var(--c-accent);text-decoration:none}a:hover{color:var(--c-accent-d)}
code,.mono{font-family:ui-monospace,Consolas,monospace;font-size:13px}

.topbar{background:#fff;border-bottom:1px solid var(--c-line);position:sticky;top:0;z-index:6;box-shadow:var(--sh-sm)}
.topbar-inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;gap:20px;padding:11px clamp(20px,4vw,48px)}
.brand{display:flex;align-items:center;gap:10px;color:var(--c-text)}
.brand-logo{height:32px}
.brand-mark{font-weight:500;font-size:18px}.brand-mark b{color:var(--c-accent);font-weight:700}
.brand-sub{font-size:12px;color:var(--c-text-muted);padding-left:10px;border-left:1px solid var(--c-line)}
.topbar .sp{flex:1}
.topbar a.nav{color:var(--c-text-soft);font-weight:500;padding:7px 12px;border-radius:9px}
.topbar a.nav:hover{background:var(--c-bg-gray);color:var(--c-text)}

.tbar{background:#fff;border-bottom:1px solid var(--c-line)}
.tbar-inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;gap:4px;flex-wrap:wrap;padding:8px clamp(20px,4vw,48px)}
.tbar .back{color:var(--c-text-muted);margin-right:8px}
.tbar .who{font-weight:700;margin-right:12px}
.tbar a{padding:7px 12px;border-radius:9px;color:var(--c-text-soft);font-weight:500;font-size:14px}
.tbar a:hover{background:var(--c-bg-gray);color:var(--c-text)}
.tbar a.on{background:var(--c-accent-soft);color:var(--c-accent-d)}

.wrap{max-width:1440px;margin:0 auto;padding:26px clamp(20px,4vw,48px) 60px}
h1{font-size:23px;font-weight:700;margin:4px 0 18px}
h2{font-size:12px;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin:0 0 12px}
.muted{color:var(--c-text-muted)}

.card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r);padding:18px;margin-bottom:16px;box-shadow:var(--sh-sm)}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.row-between{display:flex;justify-content:space-between;align-items:center;gap:10px}
.right{text-align:right;white-space:nowrap}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.stat-label{color:var(--c-text-muted);font-size:13px}.stat-value{font-size:26px;font-weight:700;margin:3px 0}

.field{margin-bottom:12px;display:flex;flex-direction:column;gap:5px}
label{color:var(--c-text-soft);font-size:13px;font-weight:500}
input,textarea,select{width:100%;background:#fff;border:1px solid var(--c-line);color:var(--c-text);
  border-radius:var(--r-sm);padding:9px 11px;font-size:14px;font-family:var(--f)}
input:focus,textarea:focus{outline:none;border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-soft)}
textarea.code{font-family:ui-monospace,Consolas,monospace;font-size:13px;resize:vertical}

button,.btn,.btn-secondary{border:0;cursor:pointer;border-radius:var(--r-sm);padding:9px 16px;font-size:14px;
  font-weight:600;font-family:var(--f);background:var(--c-accent);color:#fff}
button:hover,.btn:hover{background:var(--c-accent-d)}
.btn-secondary{background:var(--c-bg-gray);color:var(--c-text)}
.btn-sm{padding:5px 10px;font-size:13px;border-radius:8px;background:var(--c-bg-gray);color:var(--c-text);font-weight:500}
.btn-danger{background:#fbe9e7;color:var(--c-red)}.btn-danger:hover{background:var(--c-red);color:#fff}
.btn-warn{background:var(--c-warn);color:#fff}
.inline{display:inline}

.tbl{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--c-line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm)}
.tbl th,.tbl td{padding:11px 14px;border-bottom:1px solid var(--c-line);text-align:left;vertical-align:middle}
.tbl th{background:var(--c-accent-soft);color:var(--c-accent-d);font-size:12px;text-transform:uppercase;font-weight:600}
.tbl tr:last-child td{border-bottom:0}.tbl tbody tr:hover{background:var(--c-bg-gray)}

.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600}
.badge.run{background:#e9f7ef;color:var(--c-green)}
.badge.stop{background:#fdecea;color:var(--c-red)}
.badge.none{background:#eef0f4;color:var(--c-text-muted)}

.flash{padding:11px 14px;border-radius:10px;margin-bottom:14px;border:1px solid;font-size:14px}
.flash.ok{background:#e9f7ef;border-color:#bfe6cf;color:var(--c-green)}
.flash.err{background:#fdecea;border-color:#f5c6c0;color:var(--c-red)}

.tabs{display:flex;gap:2px;flex-wrap:wrap;border-bottom:1px solid var(--c-line);margin-bottom:18px}
.tab{background:none;border:0;border-bottom:2px solid transparent;border-radius:0;padding:10px 14px;
  color:var(--c-text-soft);font-weight:500;font-size:14px;cursor:pointer;margin-bottom:-1px}
.tab.on{color:var(--c-accent);border-bottom-color:var(--c-accent)}
.tab-panel{display:none}.tab-panel.on{display:block}

.logs{background:var(--c-bg-dark);border-radius:var(--r);padding:15px;overflow:auto;max-height:65vh;
  font-family:ui-monospace,Consolas,monospace;font-size:12.5px;color:#c7d6ee;white-space:pre-wrap}

.login-card{max-width:360px;margin:10vh auto 0;box-shadow:var(--sh)}
.login-brand{font-size:23px;font-weight:500}.login-brand b{color:var(--c-accent);font-weight:700}

/* чат */
.chatwrap{display:flex;flex-direction:column;height:calc(100vh - 230px);min-height:380px;background:#fff;border:1px solid var(--c-line);border-radius:var(--r);overflow:hidden}
#clog{flex:1;overflow:auto;padding:16px;display:flex;flex-direction:column;gap:9px}
.msg{max-width:78%;padding:10px 13px;border-radius:14px;white-space:pre-wrap;line-height:1.45}
.msg.me{align-self:flex-end;background:var(--c-accent);color:#fff;border-bottom-right-radius:4px}
.msg.bot{align-self:flex-start;background:var(--c-bg-gray);border:1px solid var(--c-line);border-bottom-left-radius:4px}
.cbar{display:flex;gap:8px;padding:12px;border-top:1px solid var(--c-line)}
.cbar textarea{flex:1;resize:none;height:44px}
