:root{
  --bg:#0e1117; --panel:#161b22; --panel2:#1c2330; --border:#2a323d;
  --txt:#e6edf3; --muted:#8b949e; --accent:#3b82f6; --accent2:#2563eb;
  --ok:#3fb950; --fail:#f85149; --warn:#d29922; --skip:#8b949e;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);font:14px/1.5 system-ui,Segoe UI,Roboto,sans-serif}
a{color:var(--accent);text-decoration:none}
.hidden{display:none!important}
button{cursor:pointer;border:1px solid var(--border);background:var(--panel2);color:var(--txt);
  padding:8px 14px;border-radius:7px;font-size:14px;transition:.15s}
button:hover{border-color:var(--accent)}
button.primary{background:var(--accent2);border-color:var(--accent2)}
button.primary:hover{background:var(--accent)}
button:disabled{opacity:.5;cursor:not-allowed}
button.danger{background:#3a1d1d;border-color:#5a2a2a;color:#ffb4b0}
input,select{background:var(--bg);border:1px solid var(--border);color:var(--txt);
  padding:8px 10px;border-radius:7px;font-size:14px}
input:focus,select:focus{outline:none;border-color:var(--accent)}

/* Login */
.login-wrap{min-height:100vh;display:grid;place-items:center}
.login-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;
  padding:34px;width:340px;box-shadow:0 12px 40px rgba(0,0,0,.4)}
.login-card h1{font-size:18px;margin:0 0 4px}
.login-card p{color:var(--muted);margin:0 0 22px;font-size:13px}
.login-card label{display:block;font-size:12px;color:var(--muted);margin:12px 0 5px}
.login-card input{width:100%}
.login-card button{width:100%;margin-top:20px}
.err{color:var(--fail);font-size:13px;margin-top:12px;min-height:18px}

/* App shell */
header{display:flex;align-items:center;gap:14px;padding:12px 22px;background:var(--panel);
  border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}
header h1{font-size:15px;margin:0;font-weight:600}
header .target{color:var(--muted);font-size:12px;font-family:var(--mono)}
header .spacer{flex:1}
header .who{color:var(--muted);font-size:13px}
.main{display:grid;grid-template-columns:340px 1fr;gap:16px;padding:16px;max-width:1500px;margin:0 auto}
.card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px}
.card h2{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:0 0 14px}
.field{margin-bottom:12px}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}
.field select,.field input{width:100%}
.row{display:flex;gap:8px}

/* Live */
.statline{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.badge{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid var(--border)}
.badge.running{background:#172554;color:#93c5fd;border-color:#1e3a8a}
.badge.passed{background:#0f2a16;color:var(--ok);border-color:#1a4023}
.badge.failed{background:#2a1212;color:var(--fail);border-color:#4a1f1f}
.badge.error,.badge.cancelled{background:#2a2212;color:var(--warn);border-color:#4a3a1f}
.badge.idle{background:var(--panel2);color:var(--muted)}
.progress{height:9px;background:var(--bg);border-radius:6px;overflow:hidden;border:1px solid var(--border);margin:10px 0}
.progress > i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent2),var(--accent));transition:width .3s}
.counts{display:flex;gap:16px;font-size:13px;margin-bottom:10px}
.counts b{font-family:var(--mono)}
.counts .p{color:var(--ok)} .counts .f{color:var(--fail)} .counts .s{color:var(--skip)}
.log{background:#0a0d12;border:1px solid var(--border);border-radius:8px;padding:12px;
  font-family:var(--mono);font-size:12.5px;line-height:1.5;white-space:pre-wrap;word-break:break-word;
  height:430px;overflow:auto;color:#cdd9e5}

/* History */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--border)}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}
tbody tr:hover{background:var(--panel2);cursor:pointer}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px;vertical-align:middle}
.dot.passed{background:var(--ok)} .dot.failed{background:var(--fail)}
.dot.error,.dot.cancelled{background:var(--warn)} .dot.running{background:var(--accent)}
.pills{font-family:var(--mono);font-size:12px}
.pills .p{color:var(--ok)} .pills .f{color:var(--fail)} .pills .s{color:var(--skip)}
.muted{color:var(--muted)}
.tabs{display:flex;gap:6px;margin-bottom:12px}
.tabs button{padding:6px 12px;font-size:13px}
.tabs button.active{background:var(--accent2);border-color:var(--accent2)}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:grid;place-items:center;z-index:20}
.modal{background:var(--panel);border:1px solid var(--border);border-radius:12px;width:min(900px,92vw);
  max-height:86vh;display:flex;flex-direction:column;overflow:hidden}
.modal header{position:static}
.modal .body{padding:16px;overflow:auto}
@media(max-width:880px){.main{grid-template-columns:1fr}}

/* report / log action buttons in run modal */
.actions{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.btn-link{display:inline-block;padding:7px 12px;border:1px solid var(--border);border-radius:7px;
  background:var(--panel2);color:var(--txt);font-size:13px;transition:.15s}
.btn-link:hover{border-color:var(--accent)}
.btn-link.primary{background:var(--accent2);border-color:var(--accent2);color:#fff}
.btn-link.primary:hover{background:var(--accent)}

.rep{display:inline-block;margin-right:8px;font-size:12px;color:var(--accent)}
.rep:hover{text-decoration:underline}
