/* ============================================================
   The Missing Buttons — design system
   Palette: graphite ink on cool paper, safety-orange "patch" accent.
   Type: Archivo (display) / Instrument Sans (body) / Spline Sans Mono (data)
   ============================================================ */

:root {
  --paper:        #F5F6F8;
  --card:         #FFFFFF;
  --ink:          #1B1F26;
  --ink-soft:     #5A6472;
  --line:         #DDE1E7;
  --line-strong:  #C3C9D2;
  --patch:        #E8551E;   /* safety orange — the one bold thing */
  --patch-deep:   #C24315;
  --patch-tint:   #FDEDE5;
  --live:         #14803C;
  --live-tint:    #E3F3E8;
  --build:        #B97718;
  --build-tint:   #FBF1DF;
  --radius:       10px;
  --body:    "Instrument Sans", system-ui, sans-serif;
  --display: "Archivo", var(--body);
  --mono:    "Spline Sans Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; margin: 0; }

body {
  font-family: var(--body);
  background: var(--paper);
  color: var(--ink);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

.wrap { max-width: 1040px; margin: 0 auto; padding: 0 24px; }

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

/* ---------- top nav ---------- */
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 0;
}
.brand {
  font-family: var(--display);
  font-weight: 800; font-size: 1.12rem; letter-spacing: -0.01em;
  color: var(--ink); display: inline-flex; align-items: center; gap: 9px;
}
.brand:hover { text-decoration: none; }
.brand .glyph {
  width: 20px; height: 20px; border: 2px dashed var(--patch);
  border-radius: 5px; display: inline-block; position: relative;
}
.brand .glyph::after {
  content: ""; position: absolute; inset: 3px;
  background: var(--patch); border-radius: 2px;
}
.nav-links { display: flex; gap: 26px; font-size: 0.92rem; font-weight: 500; }
.nav-links a { color: var(--ink-soft); }
.nav-links a:hover { color: var(--ink); text-decoration: none; }

/* ---------- buttons ---------- */
.btn {
  font-family: var(--body); font-weight: 600; font-size: 0.95rem;
  border-radius: 8px; padding: 11px 22px; cursor: pointer;
  border: 1px solid transparent; display: inline-block;
}
.btn:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--patch); outline-offset: 2px;
}
.btn-primary { background: var(--patch); color: #fff; }
.btn-primary:hover { background: var(--patch-deep); text-decoration: none; }
.btn-primary:disabled { background: var(--line-strong); color: #fff; cursor: default; }
.btn-ghost {
  background: transparent; color: var(--ink);
  border-color: var(--line-strong);
}
.btn-ghost:hover { border-color: var(--ink); text-decoration: none; }
.btn-sm { padding: 7px 14px; font-size: 0.85rem; }

/* ---------- form fields ---------- */
label { display: block; font-size: 0.82rem; font-weight: 600; margin-bottom: 6px; }
input[type="text"], input[type="password"], input[type="email"], input[type="search"],
select, textarea {
  width: 100%; padding: 11px 13px; font-size: 0.95rem;
  font-family: var(--body);
  border: 1px solid var(--line-strong); border-radius: 8px;
  background: var(--card); color: var(--ink);
}
.mono-input { font-family: var(--mono); font-size: 0.9rem; }
.field { margin-bottom: 16px; }
.field .sub { font-size: 0.78rem; color: var(--ink-soft); margin-top: 5px; }
.field .sub code { font-family: var(--mono); }

/* ---------- cards ---------- */
.card {
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 24px;
}

/* ---------- status badges ---------- */
.badge {
  font-family: var(--mono); font-size: 0.72rem; font-weight: 500;
  padding: 3px 10px; border-radius: 999px; white-space: nowrap;
}
.badge.live      { background: var(--live-tint);  color: var(--live); }
.badge.build     { background: var(--build-tint); color: var(--build); }
.badge.requested { background: transparent; color: var(--ink-soft); border: 1px dashed var(--line-strong); }

/* ---------- messages ---------- */
.msg { display: none; margin-top: 14px; font-size: 0.88rem; padding: 12px 14px; border-radius: 8px; }
.msg.error { background: #FBEAEA; color: #8C2F2F; }
.msg.busy  { background: var(--patch-tint); color: var(--patch-deep); }
.msg.ok    { background: var(--live-tint); color: var(--live); }

/* ---------- footer ---------- */
footer {
  margin-top: 72px; padding: 28px 0 48px;
  border-top: 1px solid var(--line);
  font-size: 0.8rem; color: var(--ink-soft);
}

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