/* Astracode admin — minimal stylesheet, no framework. */
:root {
  --bg: #0b0d12;
  --panel: #14171f;
  --border: #232734;
  --text: #e8eaef;
  --muted: #8b93a7;
  --accent: #ff7a1a; /* nebula orange — see CONCEPT.md */
  --error: #ff5d5d;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--text); font: 14px/1.5 system-ui, -apple-system, "Segoe UI", sans-serif; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
code { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 12px; color: var(--muted); }
small { color: var(--muted); font-weight: normal; }

.topbar {
  display: flex; align-items: center; gap: 24px;
  padding: 12px 24px;
  background: var(--panel); border-bottom: 1px solid var(--border);
}
.topbar .brand { font-weight: 600; color: var(--text); }
.topbar nav { display: flex; gap: 16px; flex: 1; }
.topbar .logout { display: flex; align-items: center; gap: 12px; margin: 0; }
.topbar .logout .email { color: var(--muted); }

main { max-width: 1100px; margin: 24px auto; padding: 0 24px; }
section { background: var(--panel); border: 1px solid var(--border); border-radius: 8px; padding: 20px 24px; margin-bottom: 24px; }
h1 { margin-top: 0; }
h2 { margin-top: 24px; border-bottom: 1px solid var(--border); padding-bottom: 6px; }

table { width: 100%; border-collapse: collapse; }
table.kv th { text-align: left; color: var(--muted); font-weight: 500; padding: 6px 12px 6px 0; width: 200px; vertical-align: top; }
table.kv td { padding: 6px 0; }

table.list { margin-top: 12px; }
table.list th, table.list td { text-align: left; padding: 8px 12px; border-bottom: 1px solid var(--border); }
table.list th { color: var(--muted); font-weight: 500; font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; }
table.list .empty { text-align: center; color: var(--muted); padding: 24px; }

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

form { display: flex; flex-direction: column; gap: 12px; max-width: 360px; }
form.inline { display: inline-flex; flex-direction: row; gap: 8px; margin: 0; max-width: none; }
form.inline-row { display: flex; flex-direction: row; gap: 8px; margin: 8px 0 16px; max-width: none; flex-wrap: wrap; align-items: center; }
form.filter-row { display: flex; flex-direction: row; gap: 8px; margin: 8px 0 16px; max-width: none; flex-wrap: wrap; align-items: center; }
label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; color: var(--muted); }
input, select { background: var(--bg); color: var(--text); border: 1px solid var(--border); border-radius: 6px; padding: 8px 10px; font: inherit; }
input:focus, select:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
button { background: var(--accent); color: #0b0d12; border: 0; border-radius: 6px; padding: 8px 14px; font-weight: 600; cursor: pointer; }
button:hover { filter: brightness(1.08); }
pre { background: var(--bg); border: 1px solid var(--border); border-radius: 6px; padding: 12px; overflow-x: auto; font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 12px; color: var(--text); }

.login { max-width: 400px; margin: 48px auto; }
.error { color: var(--error); }
