/* DevQueue — dispatch console
   Palette
     --ink        #0d0f12  base background (near-black, faint blue)
     --panel      #15181d  raised surfaces
     --line       #262b33  hairline borders
     --text       #e7e9ec  primary text
     --muted      #8b929c  secondary text
     --signal     #f5a623  the one accent: signal amber (dispatch/queue)
     --good       #57c08a  preview-ready / success
   Type
     display/body : system humanist sans, tight tracking on headings
     mono         : machine identifiers — repos, run ids, branches, statuses
*/

:root {
  --ink: #0d0f12;
  --panel: #15181d;
  --panel-2: #1b1f26;
  --line: #262b33;
  --text: #e7e9ec;
  --muted: #8b929c;
  --signal: #f5a623;
  --signal-dim: #5a4a23;
  --good: #57c08a;
  --bad: #e06c75;
  --mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  background: var(--ink);
  color: var(--text);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

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

.wrap { max-width: 920px; margin: 0 auto; padding: 0 20px; }

/* ── top bar ───────────────────────────────────────────────────────────── */
.topbar {
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #101317, var(--ink));
  position: sticky; top: 0; z-index: 10;
}
.topbar .wrap {
  display: flex; align-items: center; gap: 20px;
  height: 58px;
}
.brand {
  font-family: var(--mono);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--text);
  display: flex; align-items: center; gap: 9px;
}
.brand .dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--signal);
  box-shadow: 0 0 10px var(--signal);
}
.brand:hover { text-decoration: none; }
.nav { display: flex; gap: 18px; margin-left: auto; align-items: center; }
.nav a { color: var(--muted); font-size: 14px; }
.nav a:hover { color: var(--text); text-decoration: none; }
.nav form { margin: 0; }
.linkbtn {
  background: none; border: 0; color: var(--muted);
  font: inherit; font-size: 14px; cursor: pointer; padding: 0;
}
.linkbtn:hover { color: var(--text); }

/* ── headings ──────────────────────────────────────────────────────────── */
main { padding: 34px 0 80px; }
h1 {
  font-size: 22px; font-weight: 650; letter-spacing: -0.01em;
  margin: 0 0 4px;
}
.subhead { color: var(--muted); font-size: 14px; margin: 0 0 26px; }
.row-between { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; }

/* ── buttons ───────────────────────────────────────────────────────────── */
.btn {
  display: inline-block;
  background: var(--signal); color: #1a1206;
  font-weight: 600; font-size: 14px;
  border: 0; border-radius: 7px;
  padding: 9px 15px; cursor: pointer;
}
.btn:hover { filter: brightness(1.07); text-decoration: none; }
.btn.ghost {
  background: transparent; color: var(--text);
  border: 1px solid var(--line);
}
.btn.ghost:hover { border-color: var(--muted); }
.btn.danger { background: transparent; color: var(--bad); border: 1px solid var(--line); }

/* ── panels & lists ────────────────────────────────────────────────────── */
.panel {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 10px; padding: 18px 20px;
}
.ticket-list { display: flex; flex-direction: column; gap: 10px; }
.ticket-card {
  display: block;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 10px; padding: 14px 16px;
  transition: border-color .12s ease;
}
.ticket-card:hover { border-color: #36404d; text-decoration: none; }
.ticket-card .tc-top { display: flex; align-items: center; gap: 12px; }
.ticket-card .tc-title { font-weight: 600; color: var(--text); flex: 1; }
.ticket-card .tc-repo { font-family: var(--mono); font-size: 12.5px; color: var(--muted); margin-top: 5px; }

/* ── status pills + lifecycle rail ─────────────────────────────────────── */
.status {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .03em;
  text-transform: uppercase;
  padding: 3px 8px; border-radius: 5px;
  border: 1px solid var(--line); color: var(--muted);
  white-space: nowrap;
}
.status.queued      { color: var(--muted); }
.status.dispatched  { color: var(--signal); border-color: var(--signal-dim); background: rgba(245,166,35,.06); }
.status.pr_open     { color: #7aa2f7; border-color: #2c3a5e; background: rgba(122,162,247,.06); }
.status.preview_ready { color: var(--good); border-color: #2c5040; background: rgba(87,192,138,.07); }
.status.failed      { color: var(--bad); border-color: #5e2c2c; background: rgba(224,108,117,.06); }

.rail { display: flex; align-items: center; gap: 0; margin: 22px 0 26px; flex-wrap: wrap; }
.rail .step {
  font-family: var(--mono); font-size: 11.5px; text-transform: uppercase; letter-spacing: .03em;
  color: var(--muted); padding: 4px 0;
}
.rail .step.done { color: var(--text); }
.rail .step.active { color: var(--signal); }
.rail .sep { width: 26px; height: 1px; background: var(--line); margin: 0 10px; }
.rail .sep.done { background: #3a4350; }

/* ── definition grid ───────────────────────────────────────────────────── */
.kv { display: grid; grid-template-columns: 150px 1fr; gap: 10px 16px; margin: 0; }
.kv dt { color: var(--muted); font-size: 13px; }
.kv dd { margin: 0; }
.mono { font-family: var(--mono); font-size: 13px; }
.tag-reg {
  font-family: var(--mono); font-size: 11px; color: var(--signal);
  border: 1px solid var(--signal-dim); border-radius: 4px; padding: 1px 6px;
}

/* ── forms ─────────────────────────────────────────────────────────────── */
.field { margin-bottom: 16px; }
.field label { display: block; font-size: 13px; color: var(--muted); margin-bottom: 6px; }
input[type=text], input[type=password], textarea, select {
  width: 100%;
  background: var(--panel-2); color: var(--text);
  border: 1px solid var(--line); border-radius: 7px;
  padding: 10px 12px; font: inherit;
}
textarea { min-height: 96px; resize: vertical; font-family: var(--mono); font-size: 13px; }
input:focus, textarea:focus, select:focus { outline: 2px solid var(--signal); outline-offset: 0; border-color: transparent; }
.hint { font-size: 12.5px; color: var(--muted); margin-top: 5px; }
.inline { display: flex; gap: 10px; align-items: center; }

/* ── event log ─────────────────────────────────────────────────────────── */
.log { border-top: 1px solid var(--line); margin-top: 8px; }
.log-item { display: flex; gap: 14px; padding: 11px 0; border-bottom: 1px solid var(--line); }
.log-time { font-family: var(--mono); font-size: 12px; color: var(--muted); white-space: nowrap; min-width: 132px; }
.log-kind {
  font-family: var(--mono); font-size: 11px; text-transform: uppercase;
  color: var(--muted); min-width: 96px;
}
.log-kind.dispatched { color: var(--signal); }
.log-kind.pr_open { color: #7aa2f7; }
.log-kind.preview_ready { color: var(--good); }
.log-kind.warning, .log-kind.failed { color: var(--bad); }
.log-msg { color: var(--text); font-size: 13.5px; }

/* ── misc ──────────────────────────────────────────────────────────────── */
.empty {
  border: 1px dashed var(--line); border-radius: 10px;
  padding: 38px 20px; text-align: center; color: var(--muted);
}
.empty .btn { margin-top: 14px; }
.notice {
  border: 1px solid var(--signal-dim); background: rgba(245,166,35,.06);
  color: var(--text); border-radius: 8px; padding: 12px 14px; font-size: 13.5px; margin-bottom: 20px;
}
.callout-link { font-family: var(--mono); font-size: 13px; word-break: break-all; }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--line); font-size: 13.5px; }
th { color: var(--muted); font-weight: 500; font-size: 12.5px; }
td .mono { font-size: 12.5px; }

/* login */
.login-shell { min-height: 80vh; display: flex; align-items: center; justify-content: center; }
.login-card { width: 100%; max-width: 360px; }
.login-card .brand { justify-content: center; margin-bottom: 20px; font-size: 16px; }

@media (max-width: 620px) {
  .kv { grid-template-columns: 1fr; gap: 2px 0; }
  .kv dt { margin-top: 10px; }
  .log-item { flex-direction: column; gap: 2px; }
  .log-time { min-width: 0; }
}

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; }
}
