/* AIFUSION FMS — оболочка приложения: БОКОВОЙ САЙДБАР + раскладка «Диспетчер».
 * Палитра общая с редактором (style.css). Тёмная тема, нейтрально по умолчанию,
 * цвет = исключение (промышленный HMI / ISA-101). */

:root {
  --bg: #1b1e24; --bg2: #23272f; --bg3: #2b3038; --border: #343a45;
  --fg: #d8dce3; --fg-dim: #8b919c; --accent: #409eff;
  --ok: #67c23a; --warn: #e6a23c; --danger: #f56c6c;
}
* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; font: 14px/1.5 system-ui, -apple-system, "Segoe UI", sans-serif; background: var(--bg); color: var(--fg); }

/* ─────────────── Боковой сайдбар (на всех страницах с навигацией) ─────────────── */
body:has(#af-side) { padding-left: 64px; }
#af-side {
  position: fixed; left: 0; top: 0; bottom: 0; width: 64px;
  background: var(--bg2); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; z-index: 1000;
}
.af-side-logo { height: 46px; display: flex; align-items: center; justify-content: center; color: var(--accent); font-size: 19px; border-bottom: 1px solid var(--border); }
.af-side-nav { flex: 1; display: flex; flex-direction: column; padding: 8px 0; }
.af-side-item {
  position: relative; display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 10px 2px; color: var(--fg-dim); text-decoration: none; font-size: 10px; text-align: center;
}
.af-side-item .ic { font-size: 19px; line-height: 1; }
.af-side-item:hover { color: var(--fg); background: var(--bg3); }
.af-side-item.active { color: #fff; }
.af-side-item.active::before { content: ''; position: absolute; left: 0; top: 6px; bottom: 6px; width: 3px; background: var(--accent); border-radius: 0 3px 3px 0; }
.af-side-item.active .ic { color: var(--accent); }
.af-side-lock { position: absolute; top: 6px; right: 9px; font-size: 9px; }
.af-side-user { border-top: 1px solid var(--border); padding: 10px 4px; display: flex; flex-direction: column; align-items: center; gap: 7px; }
.af-side-ava { width: 30px; height: 30px; border-radius: 50%; background: var(--bg3); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 13px; }
.af-side-ava.admin { border-color: var(--warn); color: var(--warn); }
.af-side-ava.user { border-color: var(--accent); color: var(--accent); }
.af-side-logout { background: none; border: none; color: var(--fg-dim); cursor: pointer; font-size: 17px; padding: 0; }
.af-side-logout:hover { color: var(--danger); }

/* ─────────────── Раскладка «Диспетчер» (стартовая) ─────────────── */
.disp { height: 100vh; display: grid; grid-template-rows: 46px 1fr; }
.disp-top { display: flex; align-items: center; gap: 18px; padding: 0 16px; background: var(--bg2); border-bottom: 1px solid var(--border); }
.disp-top .t-title { font-weight: 600; }
.disp-top .spacer { flex: 1; }
.disp-stat { display: flex; align-items: center; gap: 7px; color: var(--fg-dim); font-size: 13px; white-space: nowrap; }
.disp-stat b { color: var(--fg); }
.dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; background: var(--fg-dim); flex: none; }
.dot.ok { background: var(--ok); } .dot.warn { background: var(--warn); } .dot.bad { background: var(--danger); }
.demo-badge { font-size: 11px; color: var(--warn); border: 1px solid var(--warn); border-radius: 10px; padding: 1px 9px; }
.disp-main { display: grid; grid-template-columns: 272px 1fr; min-height: 0; }
.disp-rail { border-right: 1px solid var(--border); display: flex; flex-direction: column; min-height: 0; }
.disp-rail h3 { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--fg-dim); margin: 0; padding: 12px 14px 8px; }
.fleet { list-style: none; margin: 0; padding: 0; overflow: auto; flex: 1; }
.fleet li { display: flex; align-items: center; gap: 10px; padding: 9px 14px; border-bottom: 1px solid var(--border); }
.fleet .fl-meta { flex: 1; min-width: 0; }
.fleet .fl-name { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fleet .fl-sub { font-size: 11px; color: var(--fg-dim); }
.fleet .fl-ic { font-size: 16px; width: 18px; text-align: center; flex: none; }
.disp-rail-foot { border-top: 1px solid var(--border); padding: 11px 14px; display: flex; gap: 18px; color: var(--fg-dim); font-size: 12px; }
.disp-rail-foot b { color: var(--fg); font-size: 14px; }
.disp-mapwrap { display: grid; grid-template-rows: 1fr 42px; min-height: 0; position: relative; }
#disp-map { min-height: 0; background: var(--bg); }
.disp-bottom { display: flex; align-items: center; gap: 24px; padding: 0 16px; background: var(--bg2); border-top: 1px solid var(--border); color: var(--fg-dim); font-size: 13px; }
.disp-bottom b { color: var(--fg); }
.map-empty { position: absolute; inset: 0 0 42px 0; display: none; align-items: center; justify-content: center; flex-direction: column; gap: 10px; color: var(--fg-dim); pointer-events: none; }
.map-empty a { pointer-events: auto; }

/* ─────────────── Контент-страницы (Справочники / Настройки) ─────────────── */
.af-page { max-width: 1180px; margin: 0 auto; padding: 22px 20px 40px; }
.af-page h1 { font-size: 20px; margin: 4px 0 4px; }
.af-page .af-sub { color: var(--fg-dim); margin: 0 0 20px; }
.af-page h2 { font-size: 12px; text-transform: uppercase; letter-spacing: .06em; color: var(--fg-dim); margin: 26px 0 10px; }
.af-grid { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
.af-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 16px; text-decoration: none; color: var(--fg); display: block; }
a.af-card:hover { border-color: var(--accent); }
.af-card .af-ic { font-size: 22px; }
.af-card .af-ttl { font-weight: 600; margin: 8px 0 4px; font-size: 15px; }
.af-card .af-desc { color: var(--fg-dim); font-size: 13px; }
.af-card.disabled { opacity: .55; }
.af-card .af-tag { display: inline-block; margin-top: 10px; font-size: 11px; color: var(--fg-dim); border: 1px solid var(--border); border-radius: 8px; padding: 1px 7px; }
.af-tag.ro { color: var(--warn); border-color: var(--warn); }
.af-kpi { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px; }
.af-kpi .v { font-size: 26px; font-weight: 700; } .af-kpi .v.dim { color: var(--fg-dim); }
.af-kpi .k { color: var(--fg-dim); font-size: 12px; text-transform: uppercase; letter-spacing: .05em; }
.af-note { background: var(--bg3); border: 1px solid var(--border); border-left: 3px solid var(--warn); border-radius: 8px; padding: 10px 14px; color: var(--fg-dim); font-size: 13px; margin: 14px 0; }
.af-empty { color: var(--fg-dim); font-style: italic; padding: 14px 0; }
.af-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.af-table th, .af-table td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border); }
.af-table th { color: var(--fg-dim); text-transform: uppercase; font-size: 11px; letter-spacing: .04em; }
.af-pill { font-size: 11px; padding: 2px 8px; border-radius: 10px; border: 1px solid var(--border); color: var(--fg-dim); }

/* ─────────────── Логин ─────────────── */
.af-login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 20px; }
.af-login { width: 340px; background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; padding: 26px 24px; }
.af-brand { font-size: 20px; letter-spacing: .02em; }
.af-brand .af-logo { color: var(--accent); margin-right: 4px; } .af-brand b { color: var(--accent); }
.af-login .af-sub { color: var(--fg-dim); margin: 4px 0 18px; font-size: 13px; }
.af-login label { display: block; color: var(--fg-dim); font-size: 12px; margin: 12px 0 4px; }
.af-login input { width: 100%; padding: 9px 11px; background: var(--bg); border: 1px solid var(--border); border-radius: 7px; color: var(--fg); font-size: 14px; }
.af-login input:focus { outline: 1px solid var(--accent); }
.af-login button { width: 100%; margin-top: 18px; padding: 10px; background: var(--accent); border: none; border-radius: 7px; color: #fff; font-size: 15px; font-weight: 600; cursor: pointer; }
.af-login button:hover { filter: brightness(1.08); }
.af-err { color: var(--danger); font-size: 13px; margin-top: 12px; min-height: 1em; }
.af-hint-creds { color: var(--fg-dim); font-size: 12px; margin-top: 16px; line-height: 1.7; }
