/* Дизайн-токены и базовые компоненты — общие для всех модулей */
:root{
  --bg:#f6f7f9;
  --bg-elev:#ffffff;
  --bg-soft:#f1f3f6;
  --border:#e5e8ed;
  --border-strong:#d6dae1;
  --text:#0e1320;
  --text-muted:#5a6478;
  --text-subtle:#8a93a4;
  --text-faint:#b6bcc8;

  --primary:#1d4ed8;
  --primary-hover:#1740b8;
  --primary-soft:#e8efff;
  --primary-soft-2:#dbe5ff;

  --success:#0f8a4a;
  --success-soft:#e3f5ec;
  --warning:#b25e00;
  --warning-soft:#fdf1dd;
  --danger:#c4322c;
  --danger-soft:#fbe7e6;
  --info:#1976a8;
  --info-soft:#e1f1fa;

  --shadow-xs:0 1px 0 rgba(14,19,32,.04);
  --shadow-sm:0 1px 2px rgba(14,19,32,.06), 0 1px 1px rgba(14,19,32,.04);
  --shadow-md:0 4px 12px rgba(14,19,32,.08), 0 1px 2px rgba(14,19,32,.04);
  --shadow-lg:0 16px 40px rgba(14,19,32,.14), 0 2px 6px rgba(14,19,32,.06);

  --radius:10px;
  --sidebar-w:248px;
  --sidebar-w-collapsed:64px;
  --topbar-h:64px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:'Manrope',system-ui,sans-serif;font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
button{font-family:inherit}
a{color:inherit;text-decoration:none}

.app{
  display:block;
  min-height:100vh;
}

/* ── Sidebar ─────────────────────────────────────────── */
.sidebar{
  background:#fbfbfc;
  color:var(--text);
  position:fixed;top:0;left:0;height:100vh;
  width:var(--sidebar-w);
  display:flex;flex-direction:column;
  border-right:1px solid var(--border);
  overflow:hidden;
  z-index:40;
  transition:width .26s cubic-bezier(.4,0,.2,1);
}
.app.sb-collapsed .sidebar{width:var(--sidebar-w-collapsed)}
.brand{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;border-bottom:1px solid var(--border);
  height:var(--topbar-h);background:#fff;position:relative;
}
.brand-mark{
  width:36px;height:36px;border-radius:9px;
  background:linear-gradient(135deg,#3b82f6,#1d4ed8);
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18),0 2px 6px rgba(29,78,216,.25);
  flex-shrink:0;
}
.brand-text{
  overflow:hidden;white-space:nowrap;flex:1;min-width:0;
  transition:opacity .18s ease,max-width .26s cubic-bezier(.4,0,.2,1);
  max-width:200px;opacity:1;
}
.brand-name{font-weight:700;font-size:14px}
.brand-sub{font-size:11px;color:var(--text-subtle);margin-top:1px}

.sb-toggle{
  width:32px;height:32px;border-radius:8px;
  background:#fff;border:1px solid var(--border);
  display:grid;place-items:center;
  color:var(--text-muted);cursor:pointer;flex-shrink:0;
  transition:all .15s ease;
}
.sb-toggle:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}
.sb-toggle svg{transition:transform .26s cubic-bezier(.4,0,.2,1)}
.app.sb-collapsed .sb-toggle svg{transform:rotate(180deg)}
.app.sb-collapsed .brand{flex-direction:column;gap:8px;padding:12px 10px;height:auto;justify-content:center}
.app.sb-collapsed .brand-text{max-width:0;opacity:0}
.app.sb-collapsed .sb-toggle{width:36px;height:24px;border-radius:6px}

.nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:14px 10px}
.nav::-webkit-scrollbar{width:6px}
.nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}
.nav::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}

.nav-group{margin-bottom:10px}
.nav-title{
  font-size:10.5px;letter-spacing:1px;text-transform:uppercase;
  color:var(--text-subtle);padding:8px 10px 6px;font-weight:700;
  white-space:nowrap;overflow:hidden;
  transition:opacity .18s ease,padding .26s ease,height .26s ease;
}
.app.sb-collapsed .nav-title{
  font-size:0;height:1px;padding:0;margin:8px 10px;
  background:var(--border);letter-spacing:0;color:transparent;
}

.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:8px;
  color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;
  transition:background .15s,color .15s,box-shadow .15s;
  user-select:none;position:relative;white-space:nowrap;
}
.nav-item:hover{background:#fff;color:var(--text);box-shadow:var(--shadow-xs)}
.nav-item.active{background:#fff;color:var(--primary);font-weight:600;box-shadow:var(--shadow-sm)}
.nav-item.active::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;
  border-radius:0 3px 3px 0;background:var(--primary);
}
.nav-item .nav-ico{
  width:18px;height:18px;display:grid;place-items:center;
  color:var(--text-subtle);transition:color .15s;flex-shrink:0;
}
.nav-item:hover .nav-ico{color:var(--text-muted)}
.nav-item.active .nav-ico{color:var(--primary)}
.nav-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;transition:opacity .18s ease}
.badge-num{
  margin-left:auto;background:var(--bg-soft);color:var(--text-muted);
  font-size:11px;padding:1px 7px;border-radius:999px;font-weight:600;
  border:1px solid var(--border);flex-shrink:0;transition:opacity .18s ease;
}
.nav-item.active .badge-num{background:var(--primary-soft);color:var(--primary);border-color:var(--primary-soft-2)}
.nav-caret{
  width:14px;height:14px;display:grid;place-items:center;
  color:var(--text-faint);margin-left:auto;
  transition:transform .2s ease,opacity .18s ease;flex-shrink:0;
}
.nav-item.has-children.open .nav-caret{transform:rotate(90deg);color:var(--text-muted)}
.nav-item.has-children .badge-num{margin-left:auto;margin-right:6px}

.nav-children{
  overflow:hidden;
  transition:max-height .26s cubic-bezier(.4,0,.2,1),opacity .18s ease;
  max-height:0;opacity:0;
}
.nav-children.open{max-height:500px;opacity:1}
.nav-sub{
  display:flex;align-items:center;gap:10px;
  padding:7px 10px 7px 30px;border-radius:7px;
  color:var(--text-muted);font-size:12.5px;font-weight:500;cursor:pointer;
  transition:all .15s ease;position:relative;white-space:nowrap;margin:1px 0;
}
.nav-sub::before{content:"";position:absolute;left:18px;top:0;bottom:0;width:1px;background:var(--border)}
.nav-sub::after{content:"";position:absolute;left:18px;top:50%;width:8px;height:1px;background:var(--border)}
.nav-sub:hover{background:#fff;color:var(--text)}
.nav-sub:hover::after{background:var(--primary)}
.nav-sub.active{background:var(--primary-soft);color:var(--primary);font-weight:600}
.nav-sub.active::after{background:var(--primary)}
.nav-sub .sub-dot{width:4px;height:4px;border-radius:99px;background:currentColor;flex-shrink:0;opacity:.5}
.nav-sub.active .sub-dot{opacity:1}
.nav-sub .badge-num{margin-left:auto;font-size:10.5px;padding:0px 6px}

/* ── Collapsed sidebar ─────────────────────────────── */
.app.sb-collapsed .nav{padding:14px 8px}
.app.sb-collapsed .nav-item{justify-content:center;padding:10px;gap:0}
.app.sb-collapsed .nav-label,
.app.sb-collapsed .nav-item .badge-num,
.app.sb-collapsed .nav-caret{opacity:0;width:0;margin:0;padding:0;pointer-events:none;position:absolute}
.app.sb-collapsed .nav-item.active{background:var(--primary-soft);box-shadow:none}
.app.sb-collapsed .nav-item.active::before{display:none}
.app.sb-collapsed .nav-children{display:none}

/* Tooltip for collapsed items without children */
.app.sb-collapsed .nav-item[data-label]:not(.has-children):hover::after{
  content:attr(data-label);
  position:fixed;
  left:calc(var(--sidebar-w-collapsed) + 10px);
  background:#0e1320;color:#fff;
  font-size:12px;font-weight:500;
  padding:6px 10px;border-radius:6px;
  white-space:nowrap;z-index:200;
  pointer-events:none;
  box-shadow:var(--shadow-md);
}

/* ── Flyout popover ────────────────────────────────── */
.nav-flyout{
  position:fixed;background:#fff;
  border:1px solid var(--border);border-radius:10px;
  box-shadow:var(--shadow-lg);padding:6px;min-width:200px;z-index:200;
  animation:flyIn .15s cubic-bezier(.4,0,.2,1);
}
@keyframes flyIn{from{transform:translateX(-6px);opacity:0}to{transform:translateX(0);opacity:1}}
.nav-flyout .fly-title{
  font-size:11.5px;color:var(--text-muted);font-weight:700;
  padding:6px 10px;border-bottom:1px solid var(--border);margin-bottom:4px;
  display:flex;align-items:center;gap:8px;
}
.nav-flyout .fly-title b{color:var(--text);font-weight:700;font-size:13px}
.nav-flyout .fly-item{
  display:flex;align-items:center;gap:10px;
  padding:7px 10px;border-radius:6px;
  color:var(--text);font-size:13px;font-weight:500;cursor:pointer;
}
.nav-flyout .fly-item:hover{background:var(--bg-soft);color:var(--primary)}
.nav-flyout .fly-item.active{background:var(--primary-soft);color:var(--primary);font-weight:600}
.nav-flyout .fly-item .badge-num{margin-left:auto;font-size:10.5px;padding:1px 6px}

/* ── Sidebar footer ────────────────────────────────── */
.sidebar-foot{
  padding:14px;border-top:1px solid var(--border);
  background:#fff;display:flex;align-items:center;gap:10px;
  transition:padding .26s ease;
}
.rs-user{display:flex;align-items:center;gap:10px;min-width:0;width:100%}
.rs-user .a{width:32px;height:32px;border-radius:99px;
  background:linear-gradient(135deg,#3b82f6,#1d4ed8);
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:11px;flex-shrink:0}
.rs-user .brand-text{min-width:0}
.rs-user .nm{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rs-user .rl{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.app.sb-collapsed .sidebar-foot{padding:10px;justify-content:center}
.app.sb-collapsed .rs-user .brand-text{max-width:0;opacity:0}

/* ── Main layout ───────────────────────────────────── */
.main{display:flex;flex-direction:column;min-width:0;
  margin-left:var(--sidebar-w);
  transition:margin-left .26s cubic-bezier(.4,0,.2,1);
}
.app.sb-collapsed .main{margin-left:var(--sidebar-w-collapsed)}
.topbar{position:sticky;top:0;height:var(--topbar-h);background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 28px;gap:18px;z-index:30}
.crumbs{display:flex;align-items:center;gap:6px;color:var(--text-subtle);font-size:12.5px}
.crumbs .current{color:var(--text);font-weight:600}
.crumbs .sep{color:var(--text-faint)}
.crumbs a{cursor:pointer}
.crumbs a:hover{color:var(--primary)}
.spacer{flex:1}
.crumbs{flex-shrink:0}
.topbar-actions{flex-shrink:0}
.topbar-actions{display:flex;gap:10px;align-items:center}
.icon-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);
  background:#fff;display:grid;place-items:center;cursor:pointer;color:var(--text-muted)}
.icon-btn:hover{border-color:var(--border-strong);color:var(--text);box-shadow:var(--shadow-sm)}
.env-pill{padding:6px 12px;border-radius:999px;background:var(--success-soft);
  color:var(--success);font-size:12px;font-weight:600;border:1px solid #c8ead6}

/* ── Search field (shared: topbar + home hero) ─────── */
.search-hero{position:relative;background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:6px 6px 6px 18px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-md);
  transition:all .15s}
.search-hero:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}
.search-hero .ico{color:var(--text-subtle);flex-shrink:0}
.search-hero input{flex:1;border:0;outline:none;font-size:14.5px;background:transparent;
  font-family:inherit;color:var(--text);min-width:0}
.search-hero input::placeholder{color:var(--text-faint)}
.search-hero .kbd{display:inline-flex;align-items:center;gap:3px;padding:3px 7px;border-radius:5px;
  background:var(--bg-soft);font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-muted);
  border:1px solid var(--border)}
.search-hero .ai-btn{background:var(--primary);color:#fff;border:0;border-radius:9px;
  padding:9px 14px;font-weight:700;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;
  transition:all .15s;font-family:inherit}
.search-hero .ai-btn:hover{background:var(--primary-hover)}

/* ── Topbar search wrapper ─────────────────────────── */
.topbar-search{flex:1;display:flex;justify-content:center;align-items:center;padding:0 16px}
.ts-wrap{position:relative;width:100%;max-width:480px}
.ts-drop{
  display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:#fff;border:1px solid var(--border);border-radius:12px;
  box-shadow:var(--shadow-lg);z-index:500;overflow:hidden;
  animation:flyIn .15s cubic-bezier(.4,0,.2,1);
}
.ts-drop.open{display:block}
.ts-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;cursor:pointer;transition:background .1s;
  border-bottom:1px solid var(--border);
}
.ts-item:last-of-type{border-bottom:none}
.ts-item:hover{background:var(--bg-soft)}
.ts-kind-ico{
  width:28px;height:28px;border-radius:7px;
  display:grid;place-items:center;flex-shrink:0;
  font-size:10.5px;font-weight:700;
}
.ts-info{flex:1;min-width:0}
.ts-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ts-sub{font-size:11.5px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.ts-empty{padding:16px 14px;text-align:center;font-size:13px;color:var(--text-muted)}
.ts-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 14px;border-top:1px solid var(--border);background:#fafbfc;
}
.ts-all{font-size:12px;font-weight:600;color:var(--primary);cursor:pointer}
.ts-all:hover{text-decoration:underline}
.ts-hint{font-size:11px;color:var(--text-faint)}

.content{padding:24px 28px;display:flex;flex-direction:column;gap:18px}

/* skeleton */
.skeleton{background:linear-gradient(90deg,#eef0f4,#f6f7f9 50%,#eef0f4);
  background-size:200% 100%;animation:sk 1.4s infinite;border-radius:6px;display:inline-block}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* tables */
table.dt{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
.dt thead th{text-align:left;font-size:11.5px;font-weight:600;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.5px;padding:11px 16px;background:#fafbfc;
  border-bottom:1px solid var(--border)}
.dt tbody td{padding:13px 16px;border-bottom:1px solid var(--border)}
.dt tbody tr:hover{background:#f7f9fc}

/* metric cards */
.health-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.metric{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:18px;cursor:pointer;transition:all .15s}
.metric:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.m-title{font-size:12.5px;color:var(--text-muted);font-weight:600;margin-bottom:10px}
.m-val{font-size:28px;font-weight:800;letter-spacing:-.5px}
.m-val .unit{font-size:14px;color:var(--text-muted);font-weight:600;margin-left:4px}
.m-meta{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:12px;color:var(--text-muted)}
.delta{display:inline-flex;align-items:center;gap:3px;font-weight:700;font-size:11.5px;padding:2px 6px;border-radius:5px}
.delta.up{color:var(--success);background:var(--success-soft)}
.delta.down{color:var(--danger);background:var(--danger-soft)}
.delta.flat{color:var(--text-muted);background:var(--bg-soft)}

.hero{padding:32px 28px;background:linear-gradient(180deg,#fff,#fafbfc);border-bottom:1px solid var(--border)}
.hero h1{font-size:28px;font-weight:800;letter-spacing:-.5px;margin:0}
.hero h1 .accent{color:var(--primary)}
.hero p.lead{color:var(--text-muted);font-size:14px;margin-top:8px;max-width:560px}
.greeting-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.live{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--success);
  background:var(--success-soft);border:1px solid #c8ead6;padding:3px 8px;border-radius:999px;font-weight:700}
.live .dot{width:5px;height:5px;border-radius:99px;background:var(--success)}

/* ── Toast ─────────────────────────────────────────── */
.dg-toast-wrap{position:fixed;right:24px;bottom:24px;z-index:999;display:flex;flex-direction:column;gap:10px}
.dg-toast{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 14px;box-shadow:var(--shadow-lg);min-width:280px;max-width:380px;display:flex;align-items:flex-start;gap:10px}
.dg-toast .ti{width:24px;height:24px;border-radius:6px;display:grid;place-items:center;flex-shrink:0;margin-top:1px}
.dg-toast.success .ti{background:var(--success-soft);color:var(--success)}
.dg-toast.warn .ti{background:var(--warning-soft);color:var(--warning)}
.dg-toast.error .ti{background:var(--danger-soft);color:var(--danger)}
.dg-toast.info .ti{background:var(--info-soft);color:var(--info)}
.dg-toast .tt{font-size:13px;font-weight:700}
.dg-toast .tm{font-size:11.5px;color:var(--text-muted);margin-top:2px}
.dg-toast .tx{margin-left:auto;cursor:pointer;color:var(--text-faint);background:none;border:0}

[v-cloak]{display:none}
