/* hub.stnzn — тема в духе 3X-UI / Ant Design: тёмный сайдбар, светлый плотный контент.
   Грузится ПОСЛЕ Bootstrap, поэтому переопределения работают. */

:root {
    --primary: #1677ff;
    --primary-hover: #4096ff;
    --bg: #f0f2f5;
    --card: #ffffff;
    --border: #f0f0f0;
    --border-strong: #d9d9d9;
    --text: #1f1f1f;
    --text-2: #595959;
    --muted: #8c8c8c;
    --sider: #001529;
    --sider-2: #000c17;
    --sider-text: rgba(255, 255, 255, .65);
    --head: #ffffff;
    --r: 8px;
    --r-sm: 6px;
    --sider-w: 224px;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: 14px;
}

/* ---------- Layout ---------- */
.app-sider {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: var(--sider-w);
    background: var(--sider);
    display: flex;
    flex-direction: column;
    z-index: 1030;
    overflow-y: auto;
}
.app-main { margin-left: 0; min-height: 100vh; transition: margin .2s; }
body.has-sider .app-main { margin-left: var(--sider-w); }

.app-header {
    position: sticky; top: 0; z-index: 1020;
    height: 56px;
    background: var(--head);
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; gap: 14px;
    padding: 0 20px;
}
.app-header .page-title { font-size: 16px; font-weight: 600; color: var(--text); }
.app-header .spacer { flex: 1; }
.app-content { padding: 20px; max-width: 1500px; }

/* ---------- Sidebar ---------- */
.sider-logo {
    height: 56px; display: flex; align-items: center; gap: 9px;
    padding: 0 18px; color: #fff; font-weight: 600; font-size: 16px;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
}
.sider-logo i { color: var(--primary); font-size: 20px; }
.sider-menu { padding: 8px 0; flex: 1; }
.menu-group-title {
    color: rgba(255, 255, 255, .3); font-size: 11px; text-transform: uppercase;
    letter-spacing: .04em; padding: 12px 20px 4px;
}
.menu-item {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 20px; color: var(--sider-text); text-decoration: none;
    font-size: 14px; border-left: 3px solid transparent; transition: all .15s;
}
.menu-item i { font-size: 16px; width: 18px; text-align: center; }
.menu-item:hover { color: #fff; background: rgba(255, 255, 255, .06); }
.menu-item.active {
    color: #fff; background: var(--primary);
    border-left-color: #fff;
}
.sider-user {
    border-top: 1px solid rgba(255, 255, 255, .08);
    padding: 12px 18px; color: var(--sider-text); font-size: 13px;
}
.sider-user .name { color: #fff; font-weight: 500; }
.sider-user .role { color: rgba(255, 255, 255, .4); font-size: 12px; }

/* ---------- Cards ---------- */
.card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    box-shadow: 0 1px 2px rgba(0, 0, 0, .03);
}
.card-header {
    background: #fafafa;
    border-bottom: 1px solid var(--border);
    font-weight: 600; font-size: 13px; color: var(--text-2);
    padding: 10px 16px;
    border-radius: var(--r) var(--r) 0 0;
}
.card-body { padding: 16px; }

/* ---------- Tables (плотные, Ant small) ---------- */
.table { font-size: 13px; margin: 0; color: var(--text); }
.table > :not(caption) > * > * { padding: 8px 12px; }
.table thead th {
    background: #fafafa; color: var(--text-2);
    font-weight: 600; border-bottom: 1px solid var(--border); white-space: nowrap;
}
.table tbody td { border-bottom: 1px solid var(--border); vertical-align: middle; }
.table-hover tbody tr:hover > * { background: #fafafa; }
.table a { color: var(--primary); text-decoration: none; }
.table a:hover { text-decoration: underline; }

/* ---------- Кнопки ---------- */
.btn { border-radius: var(--r-sm); font-size: 13px; font-weight: 500; }
.btn-sm { padding: 3px 10px; font-size: 12.5px; }
.btn-primary { background: var(--primary); border-color: var(--primary); }
.btn-primary:hover { background: var(--primary-hover); border-color: var(--primary-hover); }
.btn-outline-secondary { color: var(--text-2); border-color: var(--border-strong); }
.btn-outline-secondary:hover { background: #fafafa; color: var(--text); border-color: var(--border-strong); }

/* ---------- Ant-теги (переопределяем bootstrap .badge.bg-*) ---------- */
.badge {
    font-weight: 500; font-size: 12px; border-radius: 4px;
    padding: 2px 8px; line-height: 1.4; border: 1px solid transparent;
}
.badge.bg-success { background: #f6ffed !important; color: #389e0d !important; border-color: #b7eb8f; }
.badge.bg-secondary { background: #fafafa !important; color: #595959 !important; border-color: #d9d9d9; }
.badge.bg-warning { background: #fffbe6 !important; color: #d48806 !important; border-color: #ffe58f; }
.badge.bg-info { background: #e6fffb !important; color: #08979c !important; border-color: #87e8de; }
.badge.bg-danger { background: #fff1f0 !important; color: #cf1322 !important; border-color: #ffa39e; }
.badge.bg-dark { background: #f0f5ff !important; color: #2f54eb !important; border-color: #adc6ff; }

/* ---------- Формы ---------- */
.form-control, .form-select {
    border-radius: var(--r-sm); border-color: var(--border-strong);
    font-size: 13px; color: var(--text);
}
.form-control:focus, .form-select:focus {
    border-color: var(--primary); box-shadow: 0 0 0 2px rgba(22, 119, 255, .1);
}
.form-label { font-size: 13px; color: var(--text-2); font-weight: 500; margin-bottom: 4px; }
.col-form-label { font-size: 13px; color: var(--text-2); }

/* ---------- Stat-карточки дашборда ---------- */
.stat {
    background: var(--card); border: 1px solid var(--border); border-radius: var(--r);
    padding: 16px 18px; display: flex; align-items: center; gap: 14px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, .03);
}
.stat .ico {
    width: 42px; height: 42px; border-radius: 10px; flex: none;
    display: flex; align-items: center; justify-content: center; font-size: 20px;
    background: #e6f4ff; color: var(--primary);
}
.stat .num { font-size: 22px; font-weight: 600; line-height: 1.1; }
.stat .lbl { font-size: 12px; color: var(--muted); }
.stat.warn .ico { background: #fff1f0; color: #cf1322; }
.stat.warn .num { color: #cf1322; }

/* ---------- Прочее ---------- */
.alert { border-radius: var(--r-sm); font-size: 13px; border: 1px solid transparent; }
.alert-danger { background: #fff1f0; border-color: #ffccc7; color: #cf1322; }
.alert-success { background: #f6ffed; border-color: #b7eb8f; color: #389e0d; }
.page-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.pagination { --bs-pagination-border-radius: var(--r-sm); font-size: 13px; }
.pagination .page-link { color: var(--text-2); }
.pagination .active .page-link { background: var(--primary); border-color: var(--primary); }
.dropdown-menu { font-size: 13px; border-color: var(--border); border-radius: var(--r-sm); box-shadow: 0 4px 16px rgba(0, 0, 0, .08); }

/* ---------- Шапка списка (тулбар) ---------- */
.page-head {
    display: flex; justify-content: space-between; align-items: center;
    gap: 14px; margin-bottom: 16px; flex-wrap: wrap;
}
.page-head h1 { font-weight: 600; margin: 0; }
.count {
    display: inline-block; font-size: 12.5px; font-weight: 500; color: var(--text-2);
    background: #eef0f2; border-radius: 20px; padding: 1px 10px; vertical-align: middle; margin-left: 4px;
}
.toolbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.toolbar .form-select, .toolbar .form-control { width: auto; height: 32px; }
.toolbar .form-select { min-width: 160px; }
.toolbar input[type="search"] { min-width: 210px; }
.toolbar .btn { height: 32px; display: inline-flex; align-items: center; gap: 5px; }

/* мобильный сайдбар */
.sider-toggle { display: none; background: none; border: none; font-size: 22px; color: var(--text-2); cursor: pointer; }
.sider-backdrop { display: none; position: fixed; inset: 0; background: rgba(0, 0, 0, .35); z-index: 1025; }
@media (max-width: 991px) {
    body.has-sider .app-main { margin-left: 0; }
    .app-sider { transform: translateX(-100%); transition: transform .2s; }
    body.sider-open .app-sider { transform: translateX(0); }
    body.sider-open .sider-backdrop { display: block; }
    .sider-toggle { display: inline-block; }
}
