:root {
  --bg: #0f1419; --panel: #1a2029; --panel2: #222a35; --line: #2f3946;
  --fg: #e6edf3; --muted: #8b98a8; --accent: #4c8dff; --good: #35c46b;
  --bad: #ef5c5c; --warn: #e0a83a;
}
* { box-sizing: border-box; }
body { margin: 0; font: 14px/1.5 system-ui, "Segoe UI", Roboto, sans-serif;
  background: var(--bg); color: var(--fg); }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
h1 { font-size: 22px; margin: 0 0 16px; }
h2 { font-size: 15px; margin: 0 0 10px; color: var(--muted); text-transform: uppercase;
  letter-spacing: .04em; }

/* topbar */
.topbar { display: flex; align-items: center; gap: 24px; padding: 0 20px;
  background: var(--panel); border-bottom: 1px solid var(--line); height: 52px; }
.topbar .brand { font-weight: 700; color: #fff; }
.topbar nav { display: flex; gap: 4px; flex: 1; }
.topbar nav a { padding: 6px 12px; border-radius: 6px; color: var(--muted); }
.topbar nav a:hover { background: var(--panel2); text-decoration: none; }
.topbar nav a.active { color: #fff; background: var(--panel2); }
.userbox { display: flex; align-items: center; gap: 12px; }
.userbox .who { color: var(--muted); }
.userbox .role { background: var(--panel2); padding: 1px 7px; border-radius: 10px;
  font-size: 11px; text-transform: uppercase; }
.userbox .logout { color: var(--muted); }
.content { max-width: 1180px; margin: 0 auto; padding: 24px 20px 60px; }

/* login */
.login-body { display: grid; place-items: center; min-height: 100vh; }
.login-card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 32px; width: 340px; display: flex; flex-direction: column; gap: 14px; }
.login-card h1 { margin: 0; text-align: center; }
.login-card .sub { text-align: center; color: var(--muted); margin: -8px 0 6px; }
.login-card label, .filters label, .inline-form label { display: flex; flex-direction: column;
  gap: 4px; font-size: 12px; color: var(--muted); }
input, select { background: var(--panel2); border: 1px solid var(--line); color: var(--fg);
  padding: 8px 10px; border-radius: 6px; font-size: 14px; }
input:focus, select:focus { outline: none; border-color: var(--accent); }
button { background: var(--accent); color: #fff; border: none; padding: 9px 16px;
  border-radius: 6px; font-size: 14px; cursor: pointer; }
button:hover { filter: brightness(1.08); }
button.small { padding: 4px 10px; font-size: 12px; background: var(--panel2);
  border: 1px solid var(--line); }
.hint { color: var(--muted); font-size: 12px; text-align: center; margin: 4px 0 0; }
.sub { color: var(--muted); }

/* alerts */
.alert { padding: 10px 14px; border-radius: 8px; margin-bottom: 16px; }
.alert.error { background: rgba(239,92,92,.14); border: 1px solid var(--bad); color: #ffbcbc; }
.alert.ok { background: rgba(53,196,107,.14); border: 1px solid var(--good); color: #b6f2cd; }

/* cards */
.cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-bottom: 24px; }
.card { background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 16px; }
.card .num { font-size: 26px; font-weight: 700; }
.card .lbl { color: var(--muted); font-size: 12px; text-transform: uppercase; }
.card.good .num { color: var(--good); }
.card.bad .num { color: var(--bad); }

/* charts */
.charts { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.chart-box { background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 16px; }

/* filters */
.filters { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; margin-bottom: 18px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 14px; }
.filters button { align-self: flex-end; }
.btn-clear { align-self: flex-end; padding: 9px 12px; color: var(--muted); }
.btn-view { display: inline-block; padding: 4px 10px; border: 1px solid var(--line);
  border-radius: 6px; color: var(--accent); font-size: 12px; white-space: nowrap; }
.btn-view:hover { border-color: var(--accent); }

/* panels + forms */
.panel { background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 16px; margin-bottom: 20px; }
.inline-form { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; }
.row-form { margin: 0; }

/* tables */
table.grid { width: 100%; border-collapse: collapse; background: var(--panel);
  border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.grid th, .grid td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--line);
  font-size: 13px; }
.grid th { color: var(--muted); text-transform: uppercase; font-size: 11px; letter-spacing: .03em; }
.grid tbody tr:hover, .grid tr:hover { background: var(--panel2); }
.grid .ts { color: var(--muted); white-space: nowrap; font-variant-numeric: tabular-nums; }
.grid .empty { text-align: center; color: var(--muted); padding: 24px; }
.detail-cell { max-width: 520px; overflow-wrap: anywhere; }
.count { color: var(--muted); font-size: 15px; font-weight: 400; }
.tag { background: var(--warn); color: #000; padding: 0 6px; border-radius: 8px; font-size: 11px; }

/* status pills */
.pill { padding: 2px 9px; border-radius: 10px; font-size: 12px; text-transform: capitalize; }
.pill.passed, .pill.pass { background: rgba(53,196,107,.18); color: var(--good); }
.pill.failed, .pill.fail, .pill.error { background: rgba(239,92,92,.18); color: var(--bad); }
.pill.in_progress, .pill.running, .pill.warning { background: rgba(224,168,58,.18); color: var(--warn); }
.pill.skip, .pill.info { background: var(--panel2); color: var(--muted); }
.row-failed td { background: rgba(239,92,92,.05); }

/* detail dl */
dl.detail { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px 24px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 16px; margin-bottom: 24px; }
dl.detail dt { color: var(--muted); font-size: 12px; }
dl.detail dd { margin: 0 0 6px; }
.crumbs { margin: 0 0 8px; }

/* pager */
.pager { display: flex; gap: 16px; align-items: center; margin-top: 16px; }
.pager .disabled { color: var(--line); }
.pager .pageinfo { color: var(--muted); }

@media (max-width: 860px) {
  .cards { grid-template-columns: repeat(2, 1fr); }
  .charts { grid-template-columns: 1fr; }
}
