/* GuardDex TestBench - Dark terminal theme */
:root {
  --bg:         #0d1117;
  --bg2:        #161b22;
  --bg3:        #21262d;
  --border:     #30363d;
  --text:       #c9d1d9;
  --text-muted: #8b949e;
  --pass:       #3fb950;
  --fail:       #f85149;
  --warn:       #d29922;
  --skip:       #8b949e;
  --info:       #58a6ff;
  --crit:       #ff4444;
  --accent:     #238636;
  --accent-h:   #2ea043;
  --radius:     6px;
  --font-mono:  'Courier New', Courier, monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 14px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a { color: var(--info); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Navbar ───────────────────────────────────────────────────────────────── */
header {
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
}
.navbar {
  max-width: 1200px;
  margin: 0 auto;
  padding: .7rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.brand {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--text);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.brand em { color: var(--pass); font-style: normal; }
.brand-icon { font-size: 1.4rem; }
.nav-links { display: flex; gap: 1.2rem; }
.nav-links a { color: var(--text-muted); font-size: .9rem; }
.nav-links a:hover, .nav-links a.active { color: var(--text); text-decoration: none; }

/* ── Layout ───────────────────────────────────────────────────────────────── */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1.5rem;
  flex: 1;
}
.layout-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  align-items: start;
}
@media (max-width: 800px) { .layout-two-col { grid-template-columns: 1fr; } }

/* ── Card ─────────────────────────────────────────────────────────────────── */
.card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.2rem 1.4rem;
}
.card h2 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 1rem;
  padding-bottom: .6rem;
  border-bottom: 1px solid var(--border);
}

/* ── Page header ──────────────────────────────────────────────────────────── */
.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 1.4rem;
}
.page-header h1 { font-size: 1.4rem; font-weight: 700; }
.page-header .sub { color: var(--text-muted); font-size: .85rem; margin-top: .2rem; }
.header-actions { display: flex; gap: .7rem; align-items: center; }

/* ── Forms ────────────────────────────────────────────────────────────────── */
.form-label {
  display: block;
  font-size: .85rem;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: .4rem;
}
.form-input {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  padding: .5rem .8rem;
  font-size: .9rem;
  font-family: var(--font-mono);
  transition: border-color .15s;
}
.form-input:focus { outline: none; border-color: var(--info); }

/* Suite picker grid */
.suite-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
  margin-bottom: 1.2rem;
}
.suite-card {
  display: grid;
  grid-template-columns: auto 1.8rem auto;
  grid-template-rows: auto auto;
  gap: 0 .4rem;
  align-items: center;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .6rem .8rem;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.suite-card:hover { border-color: var(--info); }
.suite-card input[type="checkbox"] {
  grid-row: 1 / 3;
  width: 14px; height: 14px;
  accent-color: var(--pass);
}
.suite-icon {
  grid-row: 1;
  font-size: 1.1rem;
  line-height: 1;
}
.suite-label {
  grid-row: 1;
  font-weight: 600;
  font-size: .9rem;
}
.suite-desc {
  grid-column: 2 / 4;
  grid-row: 2;
  font-size: .78rem;
  color: var(--text-muted);
  margin-top: .15rem;
}

.form-actions {
  display: flex;
  gap: .7rem;
  align-items: center;
  justify-content: flex-end;
}

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .4rem .9rem;
  border-radius: var(--radius);
  font-size: .85rem;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s, border-color .15s;
}
.btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.btn-primary:hover { background: var(--accent-h); text-decoration: none; }
.btn-ghost {
  background: transparent;
  color: var(--text-muted);
  border-color: var(--border);
}
.btn-ghost:hover { color: var(--text); border-color: var(--text-muted); text-decoration: none; }
.btn.small { padding: .25rem .6rem; font-size: .78rem; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* ── Tables ───────────────────────────────────────────────────────────────── */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
}
.data-table th {
  color: var(--text-muted);
  font-size: .78rem;
  font-weight: 600;
  text-align: left;
  padding: .5rem .7rem;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.data-table td {
  padding: .5rem .7rem;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.data-table tr:hover td { background: var(--bg3); }
.data-table .center { text-align: center; }

/* ── Badges ───────────────────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  padding: .15rem .45rem;
  border-radius: 4px;
  text-transform: uppercase;
}
.badge-done, .badge-pass    { background: rgba(63,185,80,.15); color: var(--pass); border: 1px solid rgba(63,185,80,.3); }
.badge-fail                 { background: rgba(248,81,73,.15); color: var(--fail); border: 1px solid rgba(248,81,73,.3); }
.badge-running              { background: rgba(88,166,255,.15); color: var(--info); border: 1px solid rgba(88,166,255,.3); }
.badge-error                { background: rgba(248,81,73,.15); color: var(--crit); border: 1px solid rgba(248,81,73,.3); }

/* Count spans */
.cnt       { font-weight: 700; }
.cnt.pass  { color: var(--pass); }
.cnt.fail  { color: var(--fail); }
.cnt.skip  { color: var(--skip); }
.cnt.warn  { color: var(--warn); }
.muted     { color: var(--text-muted); }
.small     { font-size: .8rem; }
.mono      { font-family: var(--font-mono); }
.truncate  { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Summary bar ──────────────────────────────────────────────────────────── */
.summary-bar {
  display: flex;
  align-items: center;
  gap: .5rem;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .8rem 1.2rem;
  margin-bottom: 1rem;
}
.cnt-big {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
}
.cnt-big.pass  { color: var(--pass); }
.cnt-big.fail  { color: var(--fail); }
.cnt-big.warn  { color: var(--warn); }
.cnt-big.skip  { color: var(--skip); }
.cnt-big.total { color: var(--text); }
.cnt-label {
  font-size: .75rem;
  color: var(--text-muted);
  margin-right: .8rem;
  margin-top: .3rem;
  text-transform: uppercase;
}
.run-status {
  margin-left: auto;
  font-size: .85rem;
  color: var(--text-muted);
}
.pct {
  margin-left: auto;
  font-size: 1.2rem;
  font-weight: 700;
}
.pct.pass { color: var(--pass); }
.pct.fail { color: var(--fail); }
.pct.warn { color: var(--warn); }

/* ── Progress bar ─────────────────────────────────────────────────────────── */
.progress-wrap {
  height: 4px;
  background: var(--bg3);
  border-radius: 2px;
  margin-bottom: 1.2rem;
  overflow: hidden;
}
.progress-bar {
  height: 100%;
  background: var(--info);
  border-radius: 2px;
  transition: width .4s ease;
}
.progress-bar.done { background: var(--pass); }

/* ── Spinner ──────────────────────────────────────────────────────────────── */
.spinner {
  width: 18px;
  height: 18px;
  border: 2px solid var(--border);
  border-top-color: var(--info);
  border-radius: 50%;
  animation: spin .7s linear infinite;
  flex-shrink: 0;
}
.spinner-sm {
  display: inline-block;
  width: 12px;
  height: 12px;
  border: 2px solid var(--border);
  border-top-color: var(--info);
  border-radius: 50%;
  animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Suite header ─────────────────────────────────────────────────────────── */
.suite-header {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .6rem 1rem;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius) var(--radius) 0 0;
  margin-top: 1rem;
  font-size: .9rem;
}
.suite-hdr-icon { font-size: 1.2rem; }
.suite-hdr-name { font-weight: 700; }
.suite-hdr-desc { color: var(--text-muted); font-size: .82rem; }

/* ── Result rows ──────────────────────────────────────────────────────────── */
.result-list {
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  overflow: hidden;
}
.result-row {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: .4rem .9rem;
  border-bottom: 1px solid var(--border);
  font-size: .84rem;
  transition: background .1s;
}
.result-row:last-child { border-bottom: none; }
.result-row:hover { background: var(--bg3); }

.result-icon { font-size: 1rem; flex-shrink: 0; width: 1.1rem; text-align: center; }
.result-name { flex-shrink: 0; min-width: 180px; font-size: .82rem; color: var(--text-muted); }
.result-msg  { flex: 1; }
.result-dur  { flex-shrink: 0; font-size: .78rem; }

.st-pass .result-icon { color: var(--pass); }
.st-fail .result-icon { color: var(--fail); }
.st-warn .result-icon { color: var(--warn); }
.st-skip .result-icon { color: var(--skip); }
.st-info .result-icon { color: var(--info); }
.st-fail { background: rgba(248,81,73,.04); }
.st-warn { background: rgba(210,153,34,.04); }

.vuln-badge {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  padding: .1rem .35rem;
  border-radius: 3px;
  background: rgba(248,81,73,.2);
  color: var(--fail);
  border: 1px solid rgba(248,81,73,.4);
  flex-shrink: 0;
}

/* ── Done banner ──────────────────────────────────────────────────────────── */
.done-banner {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: rgba(63,185,80,.1);
  border: 1px solid rgba(63,185,80,.3);
  border-radius: var(--radius);
  padding: .9rem 1.2rem;
  margin-top: 1.2rem;
  font-weight: 600;
}
.done-banner.hidden { display: none; }

/* ── Vulnerability cards ──────────────────────────────────────────────────── */
.vuln-list { display: flex; flex-direction: column; gap: .8rem; margin-top: .5rem; }
.vuln-card {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .9rem 1.1rem;
  border-left: 4px solid var(--border);
}
.vuln-card.sev-critical { border-left-color: var(--crit); }
.vuln-card.sev-high     { border-left-color: var(--fail); }
.vuln-card.sev-medium   { border-left-color: var(--warn); }
.vuln-card.sev-low      { border-left-color: var(--info); }

.vuln-header { display: flex; align-items: center; gap: .7rem; margin-bottom: .5rem; }
.vuln-type   { font-weight: 700; font-size: .95rem; }
.sev-badge {
  font-size: .7rem; font-weight: 700; padding: .15rem .45rem;
  border-radius: 3px; text-transform: uppercase;
}
.sev-badge.sev-critical { background: rgba(255,68,68,.2); color: var(--crit); border: 1px solid rgba(255,68,68,.3); }
.sev-badge.sev-high     { background: rgba(248,81,73,.2); color: var(--fail); border: 1px solid rgba(248,81,73,.3); }
.sev-badge.sev-medium   { background: rgba(210,153,34,.2); color: var(--warn); border: 1px solid rgba(210,153,34,.3); }
.sev-badge.sev-low      { background: rgba(88,166,255,.2); color: var(--info); border: 1px solid rgba(88,166,255,.3); }

.vuln-desc    { font-size: .88rem; margin-bottom: .35rem; }
.vuln-payload { color: var(--warn); margin-bottom: .3rem; word-break: break-all; }
.vuln-rec     { font-size: .85rem; color: var(--pass); }
.vuln-ep      { margin-top: .3rem; }

/* ── Footer ───────────────────────────────────────────────────────────────── */
footer {
  border-top: 1px solid var(--border);
  text-align: center;
  padding: .7rem;
  color: var(--text-muted);
  font-size: .75rem;
}
