:root{
  --bg:#0b0f1a; --bg2:#0e1424; --card:#141b2e; --card2:#1a2238;
  --line:#243049; --txt:#e8edf7; --muted:#8a97b3; --muted2:#5f6c89;
  --accent:#6c8cff; --accent2:#8a6cff; --green:#37d29a; --red:#ff5f6d;
  --amber:#ffb14a; --shadow:0 10px 30px rgba(0,0,0,.35);
  --radius:16px; --radius-sm:11px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--txt); -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(900px 500px at 12% -8%, rgba(108,140,255,.14), transparent 60%),
    radial-gradient(800px 500px at 108% 8%, rgba(138,108,255,.12), transparent 55%);
}
a{color:inherit;text-decoration:none}
.hidden{display:none!important}
.muted{color:var(--muted);font-size:13px;font-weight:500}

/* ---------- LOGIN ---------- */
.login-body{min-height:100vh;display:grid;place-items:center;position:relative;overflow:hidden}
.login-bg{
  position:fixed;inset:0;
  background:
    radial-gradient(1100px 600px at 15% -10%, rgba(108,140,255,.30), transparent 60%),
    radial-gradient(900px 600px at 110% 110%, rgba(138,108,255,.28), transparent 55%),
    linear-gradient(180deg,#080b14,#0b0f1a);
}
.login-card{
  position:relative;width:min(92vw,400px);background:rgba(20,27,46,.78);
  backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:22px;
  padding:34px 30px;box-shadow:var(--shadow);
}
.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.login-logo-mark{
  width:48px;height:48px;border-radius:14px;display:grid;place-items:center;
  font-weight:800;font-size:18px;color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 8px 20px rgba(108,140,255,.45);
}
.login-logo-text{display:flex;flex-direction:column}
.login-title{font-weight:700;font-size:19px}
.login-sub{font-size:12.5px;color:var(--muted)}
.login-form{display:flex;flex-direction:column;gap:16px;margin-top:6px}
.field{display:flex;flex-direction:column;gap:7px}
.field-label{font-size:12.5px;color:var(--muted);font-weight:600;letter-spacing:.2px}
.field input{
  background:#0d1322;border:1px solid var(--line);color:var(--txt);
  border-radius:12px;padding:13px 14px;font-size:15px;outline:none;transition:.15s;
}
.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,140,255,.18)}
.login-foot{margin-top:22px;text-align:center;color:var(--muted2);font-size:12px}
.lock{filter:grayscale(.2)}

/* ---------- BUTTONS ---------- */
.btn{
  border:1px solid var(--line);background:var(--card2);color:var(--txt);
  border-radius:12px;padding:11px 16px;font-size:14px;font-weight:600;
  cursor:pointer;transition:.15s;font-family:inherit;
}
.btn:hover{transform:translateY(-1px);border-color:#33415f}
.btn:active{transform:translateY(0)}
.btn-block{width:100%;padding:14px}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;color:#fff;box-shadow:0 8px 20px rgba(108,140,255,.35)}
.btn-success{background:linear-gradient(135deg,#27c08a,#1f9e95);border:none;color:#04221a}
.btn-danger{background:linear-gradient(135deg,#ff6470,#ff4d6d);border:none;color:#2a0710}
.btn-ghost{background:transparent}
.btn-mini{padding:6px 10px;font-size:12px;border-radius:9px}

.alert{border-radius:12px;padding:11px 14px;font-size:13.5px;margin-bottom:14px}
.alert-error{background:rgba(255,95,109,.12);border:1px solid rgba(255,95,109,.4);color:#ffb3ba}

/* ---------- TOPBAR ---------- */
.topbar{
  position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;background:rgba(11,15,26,.85);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:800;font-size:14px;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2))}
.brand-text{font-weight:700;font-size:16px}
.conn{font-size:12px;margin-left:4px;transition:color .4s ease}
.conn-ok{color:var(--green);animation:connpulse 2.4s ease-in-out infinite}
.conn-bad{color:var(--red)} .conn-wait{color:var(--amber)}
@keyframes connpulse{0%,100%{opacity:1}50%{opacity:.45}}
.topbar-right{display:flex;align-items:center;gap:12px}
.clock{color:var(--muted);font-variant-numeric:tabular-nums;font-size:13.5px}
.user-chip{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:6px 11px;font-size:13px;font-weight:600}

/* ---------- LAYOUT ---------- */
.wrap{max-width:1180px;margin:0 auto;padding:22px 18px 60px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.cols{grid-template-columns:1fr}}
@media(max-width:560px){.kpi-grid{grid-template-columns:1fr}}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:border-color .2s,transform .2s}
.card:hover{border-color:#2c3a59}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-head h2{margin:0;font-size:15px;font-weight:700}

.kpi-card{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.kpi-label{color:var(--muted);font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.kpi-value{font-size:30px;font-weight:800;margin-top:6px;line-height:1}
.kpi-of{font-size:16px;color:var(--muted);font-weight:600;margin-left:4px}
.kpi-foot{color:var(--muted);font-size:12.5px;margin-top:8px}
.kpi-server{font-size:22px}

/* ---------- SERVER GAUGES ---------- */
.gauges{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:center}
.gauge{position:relative;width:100%;max-width:170px;aspect-ratio:1;margin:0 auto}
.gauge canvas{display:block;width:100%!important;height:100%!important}
.gauge-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.gauge-c span{font-size:26px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.gauge-c small{color:var(--muted);font-size:11px;font-weight:700;margin-top:5px;text-transform:uppercase;letter-spacing:.7px}
.gauge-foot{color:var(--muted);font-size:12.5px;margin-top:16px;text-align:center;line-height:1.7}
@media(max-width:560px){.gauges{grid-template-columns:1fr;gap:6px}.gauge{max-width:150px}}

/* controls */
.controls{display:flex;gap:10px;flex-wrap:wrap}
.control-hint{color:var(--muted);font-size:12.5px;margin-top:12px;line-height:1.5}
.toast{margin-top:12px;border-radius:10px;padding:10px 13px;font-size:13px}
.toast-ok{background:rgba(55,210,154,.12);border:1px solid rgba(55,210,154,.4);color:#86f0c8}
.toast-err{background:rgba(255,95,109,.12);border:1px solid rgba(255,95,109,.4);color:#ffb3ba}

/* events */
.events{list-style:none;margin:0;padding:0;max-height:260px;overflow:auto}
.events li{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
.events li:last-child{border-bottom:none}
.ev-time{color:var(--muted2);font-variant-numeric:tabular-nums;white-space:nowrap}
.ev-kind{font-size:11px;font-weight:700;padding:1px 7px;border-radius:6px;background:var(--card2);color:var(--muted);height:fit-content}
.ev-kind.auth{color:#9db4ff}.ev-kind.control{color:#ffd08a}.ev-kind.system{color:#86f0c8}

/* bots grid */
.bots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.bot{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px}
.bot-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.bot-name{font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.dot.online{background:var(--green);box-shadow:0 0 8px var(--green)}
.dot.stale{background:var(--amber)}
.dot.offline{background:var(--red)}
.bot-user{color:var(--muted);font-size:12px;margin-bottom:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bot-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.bs{background:#0d1322;border:1px solid var(--line);border-radius:9px;padding:7px 9px}
.bs-l{color:var(--muted);font-size:11px}
.bs-v{font-weight:700;font-size:14px;margin-top:2px}
.bot-actions{display:flex;gap:7px}
.badge{font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:6px}
.badge.on{background:rgba(55,210,154,.15);color:#86f0c8}
.badge.off{background:rgba(255,95,109,.15);color:#ffb3ba}
.badge.stale{background:rgba(255,177,74,.15);color:#ffd08a}

/* banner */
.banner{border-radius:var(--radius-sm);padding:13px 16px;font-size:13.5px;font-weight:600;margin-bottom:18px}
.banner-warn{background:rgba(255,177,74,.12);border:1px solid rgba(255,177,74,.45);color:#ffd08a}

.page-foot{text-align:center;color:var(--muted2);font-size:12px;margin-top:24px}

/* modal */
.modal{position:fixed;inset:0;background:rgba(5,8,15,.6);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:50}
.modal-box{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px;width:min(92vw,400px);box-shadow:var(--shadow)}
.modal-title{font-weight:700;font-size:16px;margin-bottom:10px}
.modal-text{color:var(--muted);font-size:14px;line-height:1.55;margin-bottom:18px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px}

/* ---------- TABS (навигация дашборд/нейросеть) ---------- */
.tabs{display:flex;gap:6px;margin-left:18px}
.tab{background:transparent;border:1px solid transparent;color:var(--muted);
  font:600 13.5px 'Inter',sans-serif;padding:8px 16px;border-radius:10px;cursor:pointer;transition:.15s}
.tab:hover{color:var(--txt);background:rgba(255,255,255,.04)}
.tab-active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 6px 18px rgba(108,140,255,.35)}

/* ---------- FORM FIELDS (нейросеть) ---------- */
.sub-h{font-size:14px;font-weight:700;margin:0}
.fld-label{display:block;color:var(--muted);font-size:12.5px;font-weight:600;margin:12px 0 6px}
.fld-area,.fld-input{width:100%;background:var(--bg2);border:1px solid var(--line);
  color:var(--txt);border-radius:11px;padding:11px 13px;font:500 13.5px 'Inter',sans-serif;
  resize:vertical;transition:.15s;outline:none}
.fld-area:focus,.fld-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,140,255,.18)}
.fld-mono{font-family:ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;font-size:12.5px;line-height:1.5}
.fld-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}
.fld-col{flex:1;min-width:160px}

/* toggles */
.toggles{display:flex;flex-wrap:wrap;gap:14px;margin:16px 0 4px}
.switch{display:flex;align-items:center;gap:9px;color:var(--txt);font-size:13px;font-weight:600;cursor:pointer;user-select:none}
.switch input{display:none}
.switch span{width:40px;height:22px;border-radius:22px;background:#2a3550;position:relative;transition:.2s;flex:none}
.switch span::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s}
.switch input:checked + span{background:linear-gradient(135deg,var(--accent),var(--accent2))}
.switch input:checked + span::after{transform:translateX(18px)}

/* списки блоков / самообучения */
.blocks-list,.pending-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:10px;max-height:480px;overflow:auto}
.block-item{display:flex;gap:12px;align-items:flex-start;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.block-text{flex:1;font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word;color:var(--txt)}
.pending-item{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.pending-meta{color:var(--muted2);font-size:11.5px;font-weight:600;margin-bottom:6px}
.pending-q,.pending-a{font-size:13px;line-height:1.5;margin-bottom:4px;word-break:break-word}
.pending-a{color:var(--muted)}
.pending-actions{display:flex;gap:8px;margin-top:8px}

::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:#2a3550;border-radius:8px}
::-webkit-scrollbar-track{background:transparent}
