/* Штаб — дизайн-система (UI/UX Pro Max: Real-Time/Operations, Dark OLED, Fira). Один источник стиля. */
@import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500;600;700&family=Fira+Sans:wght@300;400;500;600;700&display=swap');

:root {
  color-scheme: dark;
  /* --- цвет (OLED operations) --- */
  --bg:        #0a0d12;
  --surface:   #121722;
  --surface-2: #0e131c;
  --elevated:  #18202c;
  --border:    #1e2632;
  --border-2:  #2a3340;
  --text:      #eaeef5;
  --muted:     #8b94a6;
  --muted-2:   #6c7585;
  --primary:   #3b82f6;   /* синий — данные/действия */
  --primary-2: #60a5fa;
  --accent:    #f59e0b;   /* янтарь — акцент/CTA */
  --green:     #22c55e;
  --amber:     #f0b429;
  --red:       #ef4646;
  --red-soft:  #ff7a85;
  /* --- типографика --- */
  --font:    'Fira Sans', -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-num:'Fira Code', ui-monospace, monospace;   /* числа/метрики — табличный, «точный» */
  --fs-sm: 12px; --fs-base: 15px; --fs-lg: 17px; --fs-xl: 20px;
  /* --- отступы/радиусы/тени --- */
  --sp-1: 6px; --sp-2: 10px; --sp-3: 14px; --sp-4: 18px;
  --r-sm: 8px; --r-md: 10px; --r-lg: 13px; --r-xl: 16px;
  --shadow: 0 10px 34px rgba(0,0,0,.45);
  --ring: 0 0 0 3px rgba(59,130,246,.45);
  --t: 180ms cubic-bezier(.4,0,.2,1);
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; background: var(--bg); color: var(--text); font-family: var(--font);
  font-size: var(--fs-base); line-height: 1.5; -webkit-font-smoothing: antialiased; }
.num, .nums .v, .kpi .v, .row .num { font-family: var(--font-num); font-feature-settings: "tnum" 1; }

/* фокус-стейты для клавиатуры/доступности */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible,
textarea:focus-visible, [tabindex]:focus-visible { outline: none; box-shadow: var(--ring); border-radius: var(--r-sm); }

/* --- шапка --- */
.app-header { position: sticky; top: 0; z-index: 6; display: flex; align-items: center; gap: var(--sp-2);
  padding: 13px 16px; background: linear-gradient(180deg, #131a26, var(--surface));
  border-bottom: 1px solid var(--border); padding-top: max(13px, env(safe-area-inset-top)); }
.app-header .logo { width: 30px; height: 30px; border-radius: 9px; flex: none;
  background: linear-gradient(135deg, var(--primary), #1e40af); display: flex; align-items: center;
  justify-content: center; color: #fff; font-weight: 800; }
.app-header b { font-size: var(--fs-lg); flex: 1; font-weight: 700; letter-spacing: -.2px; }
.app-header .role { font-size: var(--fs-sm); color: var(--muted); }

/* --- кнопки --- */
.btn { border: 0; border-radius: var(--r-md); background: var(--primary); color: #fff;
  font: 600 var(--fs-base) var(--font); cursor: pointer; padding: 12px; transition: filter var(--t), transform var(--t); }
.btn:hover { filter: brightness(1.08); } .btn:active { transform: translateY(1px); } .btn:disabled { opacity: .6; }
.btn-accent { background: var(--accent); color: #1a1206; }
.btn-ghost { background: none; border: 1px solid var(--border-2); color: var(--muted);
  border-radius: var(--r-sm); padding: 7px 11px; font-size: 13px; cursor: pointer; text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px; transition: color var(--t), border-color var(--t); }
.btn-ghost:hover { color: var(--text); border-color: var(--primary); }

/* SVG-иконки (Lucide-стиль, stroke) */
.ic { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2;
  stroke-linecap: round; stroke-linejoin: round; flex: none; }

/* --- поля --- */
.field { width: 100%; padding: 12px 13px; border-radius: var(--r-md); border: 1px solid var(--border-2);
  background: var(--surface-2); color: var(--text); font: var(--fs-base) var(--font);
  transition: border-color var(--t); }
.field:focus { border-color: var(--primary); }
.label { font-size: 13px; color: var(--muted); display: block; margin: var(--sp-3) 0 var(--sp-1); }

/* --- контейнеры --- */
.wrap { padding: var(--sp-3) 16px calc(78px + env(safe-area-inset-bottom)); }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-xl); }
.center-screen { min-height: 100dvh; display: flex; align-items: center; justify-content: center; }

/* --- KPI-плашки (operations) --- */
.kpi { display: flex; gap: var(--sp-2); padding: var(--sp-3) 0 var(--sp-2); }
.kpi .t { flex: 1; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 13px 10px; text-align: center; }
.kpi .t .v { font-size: 27px; font-weight: 700; line-height: 1; font-family: var(--font-num); }
.kpi .t .k { font-size: 10.5px; color: var(--muted-2); text-transform: uppercase; letter-spacing: .5px; margin-top: 6px; }
.kpi .t.ok .v { color: var(--green); } .kpi .t.warn .v { color: var(--amber); } .kpi .t.red .v { color: var(--red-soft); }

/* --- строка ТТ (статус-полоса слева) --- */
.row { display: flex; align-items: stretch; margin-bottom: 8px; background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; transition: border-color var(--t); }
.row:hover { border-color: var(--border-2); }
.row .bar { width: 5px; flex: none; }
.row .bar.green { background: var(--green); } .row .bar.amber { background: var(--amber); } .row .bar.red { background: var(--red); }
.row .body { flex: 1; display: flex; align-items: center; gap: var(--sp-3); padding: 12px var(--sp-3); min-width: 0; }
.row .nm { flex: 1; min-width: 0; }
.row .nm b { font-size: var(--fs-base); font-weight: 600; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.row .nm small { font-size: var(--fs-sm); color: var(--muted); }
.row .num { font-size: 21px; font-weight: 700; flex: none; }
.row .num small { font-size: 13px; color: var(--muted); font-weight: 400; }
.row .num.red { color: var(--red-soft); }

/* светофор-точка (где нужна) */
.dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.dot.green { background: var(--green); } .dot.amber { background: var(--amber); } .dot.red { background: var(--red); }

/* числовые показатели (компактные) */
.nums { display: flex; gap: var(--sp-3); text-align: center; flex: none; }
.nums > div { min-width: 40px; }
.nums .v { font-size: 16px; font-weight: 700; }
.nums .v.red { color: var(--red-soft); }
.nums .k { font-size: 10px; color: var(--muted-2); text-transform: uppercase; }

/* --- нижняя навигация (≤5, SVG) --- */
.tabbar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 7; display: flex;
  background: rgba(14,19,28,.92); backdrop-filter: blur(12px); border-top: 1px solid var(--border);
  padding-bottom: env(safe-area-inset-bottom); }
.tabbar a { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 9px 0;
  color: var(--muted-2); font-size: 10.5px; text-decoration: none; transition: color var(--t); }
.tabbar a.act { color: var(--primary-2); }
.tabbar a:hover { color: var(--text); }
.tabbar a .ic { width: 22px; height: 22px; }

/* утилиты */
.muted { color: var(--muted); }
.err { color: var(--red-soft); font-size: 13px; text-align: center; min-height: 18px; margin-top: var(--sp-2); }
.empty { color: var(--muted); text-align: center; padding: 40px 0; }
.badge { font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 20px; }
.badge.g { background: #0f3322; color: #46d68a; } .badge.y { background: #36300f; color: #f0c64b; } .badge.r { background: #371720; color: var(--red-soft); }

@media (prefers-reduced-motion: reduce) { * { transition: none !important; animation: none !important; } }
