:root {
  --bg: #0f1115;
  --panel: #161a22;
  --panel-2: #1d222d;
  --border: #262d3a;
  --text: #e6e9ef;
  --muted: #8a92a3;
  --accent: #5b8def;
  --accent-2: #7ba2ff;
  --good: #3ec28f;
  --warn: #e6a23c;
  --bad: #e85c5c;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  line-height: 1.5;
}

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

.topnav {
  display: flex; align-items: center; gap: 24px;
  padding: 12px 24px;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
}
.topnav .brand a { color: var(--text); font-weight: 700; font-size: 16px; }
.topnav .links { display: flex; gap: 16px; flex: 1; }
.topnav .links a { color: var(--muted); }
.topnav .links a:hover { color: var(--text); text-decoration: none; }
.topnav .logout { display: flex; align-items: center; gap: 8px; }
.topnav .logout span { color: var(--muted); }

.container { max-width: 1100px; margin: 24px auto; padding: 0 24px 64px; }

h1 { font-size: 22px; margin: 8px 0 16px; }
h2 { font-size: 16px; margin: 0 0 12px; }

.header-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 16px; }

.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 16px;
}
.card.narrow { max-width: 480px; }
.card.row { display: flex; gap: 12px; }
.card.success { border-color: var(--good); }
.card.error { border-color: var(--bad); color: var(--bad); }
.card.danger { border-color: rgba(232, 92, 92, 0.35); }
.card.warn { border-left: 3px solid var(--warn); }
.card.info { border-left: 3px solid var(--accent); }
.card.notice-success { border-left: 3px solid var(--good); }
.card.notice-error { border-left: 3px solid var(--bad); color: var(--text); }

.step-card {
  background: var(--panel-2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 12px;
  margin-bottom: 12px;
}
.step-card summary { cursor: pointer; }
.step-card[open] summary { margin-bottom: 8px; }

.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; margin-bottom: 16px; }
.stat { padding: 16px; }
.stat-label { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.04em; }
.stat-value { font-size: 26px; font-weight: 600; margin-top: 6px; }

label { display: block; margin-bottom: 12px; color: var(--muted); font-size: 13px; }
input, select, textarea {
  width: 100%;
  background: var(--panel-2);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  font-size: 14px;
  font-family: inherit;
  margin-top: 4px;
}
input:focus, select:focus, textarea:focus { border-color: var(--accent); outline: none; }
textarea { resize: vertical; }

button, .button {
  background: var(--panel-2);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 14px;
  font-size: 14px;
  cursor: pointer;
  display: inline-block;
}
button:hover, .button:hover { border-color: var(--accent); }
button.primary, .button.primary { background: var(--accent); border-color: var(--accent); color: white; }
button.primary:hover, .button.primary:hover { background: var(--accent-2); border-color: var(--accent-2); }
button.danger { color: var(--bad); border-color: var(--bad); }
button.danger:hover { background: var(--bad); color: white; }

.error { color: var(--bad); padding: 8px 12px; border: 1px solid var(--bad); border-radius: 6px; margin-bottom: 12px; }
.warning { color: var(--warn); padding: 8px 12px; border: 1px solid var(--warn); border-radius: 6px; margin-bottom: 12px; }
.muted { color: var(--muted); }

table.data { width: 100%; border-collapse: collapse; background: var(--panel); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
table.data th, table.data td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--border); font-size: 13px; }
table.data th { background: var(--panel-2); color: var(--muted); font-weight: 500; text-transform: uppercase; letter-spacing: 0.04em; font-size: 11px; }
table.data tr:last-child td { border-bottom: 0; }
table.data.compact th, table.data.compact td { padding: 8px 10px; font-size: 12px; }

.badge { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; }
.badge-active   { background: rgba(62, 194, 143, 0.15); color: var(--good); }
.badge-pending  { background: rgba(230, 162, 60, 0.15); color: var(--warn); }
.badge-blocked  { background: rgba(232, 92, 92, 0.15); color: var(--bad); }
.badge-archived { background: rgba(138, 146, 163, 0.15); color: var(--muted); }
.mini-status {
  display: inline-block;
  min-width: 44px;
  padding: 2px 8px;
  margin-right: 6px;
  border-radius: 999px;
  border: 1px solid var(--border);
  text-align: center;
  font-size: 11px;
  text-transform: uppercase;
}
.mini-status.good {
  color: var(--good);
  border-color: rgba(62, 194, 143, 0.35);
  background: rgba(62, 194, 143, 0.12);
}
.mini-status.muted {
  color: var(--muted);
}

ul.kv { list-style: none; padding: 0; margin: 0; }
ul.kv li { display: flex; justify-content: space-between; padding: 6px 0; border-bottom: 1px solid var(--border); font-size: 13px; }
ul.kv li:last-child { border-bottom: 0; }
ul.kv li span { color: var(--muted); }
ul.kv li strong { text-align: right; }
.token { word-break: break-all; }

pre { background: var(--panel-2); border: 1px solid var(--border); border-radius: 6px; padding: 12px; overflow: auto; font-size: 12px; }
code { font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace; }

fieldset { border: 1px solid var(--border); border-radius: 6px; padding: 12px; margin: 12px 0; }
legend { color: var(--muted); padding: 0 6px; }

.filters { display: flex; gap: 12px; flex-wrap: wrap; align-items: end; margin-bottom: 16px; }
.filters label { margin-bottom: 0; min-width: 160px; }
.actions-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 12px; }
.triple-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; margin-bottom: 16px; }
