/* Fabrika tracker — warm blueprint paper theme, matching the landing page. */
:root {
  --ink: #172029;
  --ink-soft: #F8F3EB;
  --paper: #EDE6D7;
  --paper-dim: #55606B;
  --steel: #2B5F75;
  --steel-light: #3C6678;
  --molten: #E8552B;
  --line: #D7CEBD;
  --ok: #3F7A4E;
  --warn: #B07A1E;
  --fail: #B03A2B;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: 'Spline Sans', system-ui, sans-serif;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.mono { font-family: 'Spline Sans Mono', monospace; }
.wrap { max-width: 880px; margin: 0 auto; padding: 0 24px 80px; }

/* top bar */
.bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 20px 24px; max-width: 880px; margin: 0 auto;
}
.brand {
  font-family: 'Archivo', sans-serif; font-weight: 900; font-size: 18px;
  letter-spacing: -0.02em; display: flex; align-items: center; gap: 9px;
  color: var(--ink); text-decoration: none;
}
.brand .dot { width: 10px; height: 10px; background: var(--molten); display: inline-block; }
.bar .meta { font-family: 'Spline Sans Mono', monospace; font-size: 12px; color: var(--steel-light); }

h1 {
  font-family: 'Archivo', sans-serif; font-weight: 800; font-size: 28px;
  letter-spacing: -0.02em; margin: 26px 0 6px;
}
.sub { color: var(--paper-dim); font-size: 15px; margin-bottom: 26px; }

/* cards & sections */
.card {
  border: 1px solid var(--line); background: var(--ink-soft);
  padding: 18px 20px; margin-bottom: 14px;
}
.card h3 { font-family: 'Archivo', sans-serif; font-size: 16px; margin-bottom: 8px; }
.section-label {
  font-family: 'Spline Sans Mono', monospace; font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--steel-light);
  margin: 22px 0 8px;
}

/* dashboard list */
.build-row {
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
  border: 1px solid var(--line); background: var(--ink-soft);
  padding: 14px 16px; margin-bottom: 10px; cursor: pointer; text-align: left;
  width: 100%; font: inherit; color: inherit;
}
.build-row:hover { border-color: var(--steel); }
.build-row .preview { flex: 1; font-size: 15px; }
.build-row .when { font-family: 'Spline Sans Mono', monospace; font-size: 11.5px; color: var(--paper-dim); white-space: nowrap; }

.badge {
  font-family: 'Spline Sans Mono', monospace; font-size: 11px; letter-spacing: 0.06em;
  padding: 3px 9px; white-space: nowrap;
  background: var(--steel); color: var(--paper);
}
.badge.done { background: var(--molten); }

/* forms */
textarea, input[type="text"], input[type="password"] {
  width: 100%; border: 1px solid var(--line); background: #fff;
  font: inherit; font-size: 14.5px; color: var(--ink); padding: 10px 12px;
}
textarea { min-height: 84px; resize: vertical; }
textarea:focus, input:focus { outline: 2px solid var(--steel); outline-offset: -1px; }
label.field-label {
  display: block; font-family: 'Spline Sans Mono', monospace; font-size: 11.5px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--steel-light);
  margin: 14px 0 5px;
}
.hint { font-size: 12.5px; color: var(--paper-dim); margin-top: 4px; }

button.btn {
  font-family: 'Spline Sans Mono', monospace; font-size: 13.5px; font-weight: 600;
  background: var(--molten); color: var(--paper); border: 2px solid var(--molten);
  padding: 10px 20px; cursor: pointer; margin-top: 12px;
}
button.btn:hover:not(:disabled) { background: transparent; color: var(--molten); }
button.btn:disabled { opacity: 0.45; cursor: not-allowed; }
button.btn.ghost { background: transparent; color: var(--ink); border-color: var(--line); }
button.btn.ghost:hover:not(:disabled) { border-color: var(--ink); }
button.btn.small { padding: 6px 12px; font-size: 12px; margin-top: 0; }

/* status bits */
.error-box {
  border: 1px solid var(--fail); color: var(--fail); background: #fff;
  padding: 10px 14px; font-size: 14px; margin: 12px 0;
}
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  background: var(--ink); color: var(--paper); padding: 10px 18px;
  font-family: 'Spline Sans Mono', monospace; font-size: 13px; z-index: 10;
}
.gate {
  border-left: 3px solid var(--molten); background: var(--ink-soft);
  padding: 12px 16px; margin: 16px 0; font-size: 14px;
}
.gate.pass { border-left-color: var(--ok); }
.gate ul { margin: 6px 0 0 18px; }
.draft-tag {
  font-family: 'Spline Sans Mono', monospace; font-size: 10.5px; letter-spacing: 0.06em;
  color: var(--warn); text-transform: uppercase; margin-left: 8px;
}
.confirmed-tag { color: var(--ok); }
.status-pass { color: var(--ok); font-weight: 600; }
.status-warn { color: var(--warn); font-weight: 600; }
.status-fail { color: var(--fail); font-weight: 600; }
.check-row { display: flex; gap: 10px; align-items: baseline; padding: 7px 0; border-bottom: 1px solid var(--line); font-size: 14px; }
.check-row:last-child { border-bottom: none; }
.check-row .note { color: var(--paper-dim); font-size: 13px; }
.checklist label { display: flex; gap: 10px; align-items: center; font-size: 14.5px; padding: 6px 0; cursor: pointer; }
.spec-read dt {
  font-family: 'Spline Sans Mono', monospace; font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--steel-light); margin-top: 12px;
}
.spec-read dd { margin: 3px 0 0 0; font-size: 14.5px; white-space: pre-wrap; }
.spec-read ul { margin: 3px 0 0 18px; font-size: 14.5px; }
.loading { color: var(--paper-dim); font-size: 14px; padding: 20px 0; }
.center-note { text-align: center; color: var(--paper-dim); padding: 40px 0; }
pre.handoff { white-space: pre-wrap; font-size: 13px; background: #fff; border: 1px solid var(--line); padding: 14px; }
.crumb { font-family: 'Spline Sans Mono', monospace; font-size: 12px; color: var(--steel-light); text-decoration: none; }
.crumb:hover { color: var(--molten); }
