:root {
  --bg: #0f1418;
  --panel: #161d24;
  --text: #e7edf3;
  --muted: #9fb0c0;
  --accent: #2ad0a6;
  --danger: #ff6b6b;
  --warning: #ffc078;
  --border: #23303b;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "IBM Plex Sans", system-ui, sans-serif;
  background: radial-gradient(circle at 20% 0%, #1e2a34, #0f1418 45%);
  color: var(--text);
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  border-bottom: 1px solid var(--border);
  background: rgba(10, 14, 18, 0.9);
  position: sticky;
  top: 0;
  z-index: 5;
}

.brand {
  font-weight: 700;
  letter-spacing: 0.5px;
}

nav a {
  color: var(--muted);
  text-decoration: none;
  margin-right: 16px;
}

nav a:hover { color: var(--text); }

.logout button {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 6px 10px;
  border-radius: 6px;
}

.top-actions {
  display: flex;
  align-items: center;
  gap: 14px;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--border);
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  color: var(--muted);
}

.status-pill .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #6b7280;
}

.status-pill.ok .dot { background: #2ad0a6; }
.status-pill.ok { color: #b6f2d6; border-color: #1b3a2f; }
.status-pill.bad .dot { background: #ff6b6b; }
.status-pill.bad { color: #ffb3b3; border-color: #3b1d1d; }

.container {
  padding: 24px;
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
}

.card {
  background: var(--panel);
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 12px;
}

.table {
  display: grid;
  gap: 8px;
}

.row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}

.row.head {
  font-weight: 600;
  color: var(--muted);
}

.mono { font-family: "IBM Plex Mono", monospace; font-size: 12px; }
.muted { color: var(--muted); font-size: 12px; }
.stacked { display: flex; flex-direction: column; line-height: 1.1; }
.pill {
  display: inline-block;
  border: 1px solid var(--border);
  background: #111820;
  color: var(--text);
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 11px;
}
.pill.event { border-color: #254057; color: #c9e8ff; background: #12202d; }
.pill.status { border-color: #3a3a3a; color: #d8d8d8; background: #1b1b1b; }
.pill.status-ok, .pill.status-closed { border-color: #1b3a2f; color: #b6f2d6; background: #13281f; }
.pill.status-error, .pill.status-rejected { border-color: #3b1d1d; color: #ffb3b3; background: #2a1414; }
.pill.status-queued { border-color: #3a3420; color: #ffe7b2; background: #2a2514; }
.pill.event-fill { border-color: #1f3d57; color: #b7e4ff; background: #142739; }
.pill.event-trailing-move { border-color: #214a3a; color: #b8f0dc; background: #163127; }
.pill.event-position-closed { border-color: #3f3a20; color: #ffefbd; background: #2b2715; }
.pill.event-webhook-received, .pill.event-webhook-processed { border-color: #3b2f50; color: #dacbff; background: #241c35; }
.pill.event-reconcile-run { border-color: #4b2e1f; color: #ffd2b3; background: #311f15; }
.pager {
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--muted);
}
.pager a {
  color: var(--accent);
  text-decoration: none;
}
button.primary.ghost {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
  margin-left: 8px;
}

.config-form .grid-2 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}

label {
  display: flex;
  flex-direction: column;
  font-size: 13px;
  color: var(--muted);
}

input {
  background: #0f1418;
  border: 1px solid var(--border);
  color: var(--text);
  padding: 8px;
  border-radius: 8px;
  margin-top: 6px;
}

.hint {
  font-size: 12px;
  color: var(--muted);
  margin-top: 22px;
}

button.primary {
  margin-top: 16px;
  background: var(--accent);
  border: none;
  color: #051513;
  padding: 10px 16px;
  font-weight: 600;
  border-radius: 8px;
}

button.primary:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.flash { margin-bottom: 12px; }
.flash-item { padding: 8px 10px; border-radius: 6px; margin-bottom: 6px; }
.flash-item.success { background: #1d3b2d; color: #b6f2d6; }
.flash-item.danger { background: #3b1d1d; color: #ffb3b3; }

.login {
  display: grid;
  place-items: center;
  min-height: 100vh;
}

.login-card {
  background: var(--panel);
  padding: 24px;
  border-radius: 12px;
  border: 1px solid var(--border);
  width: min(360px, 90vw);
}

.login-card h1 { margin-top: 0; }

@media (max-width: 720px) {
  .row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .top-actions { flex-wrap: wrap; justify-content: flex-end; }
  nav { display: flex; flex-wrap: wrap; gap: 6px; }
}
