:root{
  --bg:#f6f7fb;
  --card:#ffffff;
  --ink:#0f172a;
  --muted:#64748b;
  --line:#e5e7eb;

  --pass:#16a34a;
  --fail:#ef4444;
  --armed:#f59e0b;
  --idle:#94a3b8;
  --unknown:#64748b;
}

*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}
.wrap{max-width:1280px;margin:18px auto;padding:0 14px}

.topGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr 1.2fr 1.2fr;
  gap:14px;
  align-items:stretch;
}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
  box-shadow: 0 1px 2px rgba(15,23,42,.06);
}

.h{font-size:18px;font-weight:700;margin:0 0 4px 0}
.h2{font-size:16px;font-weight:700}
.sub{font-size:12px;color:var(--muted);margin-bottom:10px;line-height:1.25}
.muted{font-size:12px;color:var(--muted);margin-left:10px}

.pillRow{display:flex;gap:8px;flex-wrap:wrap}
.pill{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  font-size:12px;
  line-height:1;
  background:#fff;
}
.pill.pass{border-color:rgba(22,163,74,.35);background:rgba(22,163,74,.08);color:var(--pass)}
.pill.fail{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08);color:var(--fail)}
.pill.armed{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.10);color:var(--armed)}
.pill.idle{border-color:rgba(148,163,184,.5);background:rgba(148,163,184,.12);color:#334155}
.pill.unknown{border-color:rgba(100,116,139,.35);background:rgba(100,116,139,.10);color:var(--unknown)}

.stepRow{display:flex;gap:8px;flex-wrap:wrap}
.step{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  font-size:12px;
}
.dot{
  width:18px;height:18px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;font-size:11px;color:#0f172a;
  border:1px solid var(--line);
  background:#fff;
}
.step.ok .dot{border-color:rgba(22,163,74,.35);background:rgba(22,163,74,.10)}
.step.bad .dot{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.10)}
.step.mid .dot{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.12)}
.stepLabel{white-space:nowrap}

.topStrip{
  display:grid;
  grid-template-columns: .55fr .45fr;
  gap:10px;
}
.stripBox{
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px;
  background:linear-gradient(180deg,#fff,#fbfcff);
}
.stripTitle{font-size:12px;color:var(--muted);margin-bottom:6px}
.stripValue{font-size:20px;font-weight:800;letter-spacing:.2px}
.bar{height:10px;border-radius:999px;border:1px solid var(--line);background:#fff;margin-top:8px;overflow:hidden}
.barFill{height:100%;width:0%;background:linear-gradient(90deg, rgba(22,163,74,.25), rgba(22,163,74,.55));transition:width .35s ease}
.feed{
  font-size:12px;
  color:#0f172a;
  max-height:92px;
  overflow:auto;
  padding-right:6px;
}
.feedLine{display:flex;gap:8px;align-items:center;margin:4px 0}
.badge{min-width:34px;text-align:center;border-radius:999px;border:1px solid var(--line);padding:2px 8px;font-weight:700}
.badge.pass{border-color:rgba(22,163,74,.35);background:rgba(22,163,74,.08);color:var(--pass)}
.badge.fail{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08);color:var(--fail)}
.badge.unknown{border-color:rgba(100,116,139,.35);background:rgba(100,116,139,.10);color:var(--unknown)}
.reason{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px}

.tableCard{
  margin-top:14px;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  box-shadow: 0 1px 2px rgba(15,23,42,.06);
}
.tableHead{
  padding:12px 14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid var(--line);
  background:#fff;
}
.btn{
  border:1px solid var(--line);
  background:#fff;
  border-radius:10px;
  padding:8px 10px;
  font-weight:700;
  cursor:pointer;
}
.btn:hover{background:#f8fafc}

.tableWrap{width:100%;overflow:auto}
table{width:100%;border-collapse:collapse;min-width:980px}
thead th{
  text-align:left;
  font-size:12px;
  color:var(--muted);
  padding:10px 12px;
  border-bottom:1px solid var(--line);
  background:#fbfcff;
  position:sticky;
  top:0;
  z-index:2;
}
tbody td{
  padding:12px;
  border-bottom:1px solid var(--line);
  vertical-align:top;
  font-size:13px;
}
tr.activeRow{outline:2px solid rgba(22,163,74,.35);outline-offset:-2px;background:rgba(22,163,74,.04)}
tr.frozenRow{background:rgba(239,68,68,.03)}
.loading{color:var(--muted);padding:18px}

.kd{font-variant-numeric:tabular-nums}
.small{font-size:12px;color:var(--muted)}
.gateCol{display:flex;flex-direction:column;gap:6px}
.gateLine{display:flex;gap:8px;align-items:center}
.gateTag{
  width:28px;
  color:var(--muted);
  font-size:12px;
}
.gatePill{cursor:help}
.thomasLine{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.thomasChip{border:1px solid rgba(245,158,11,.35);background:rgba(245,158,11,.10);color:#7c2d12;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}

@media (max-width: 1180px){
  .topGrid{grid-template-columns:1fr; }
  .topStrip{grid-template-columns:1fr}
}
