/* ============================================================
   The Missing Buttons — design system v2 "Pulse × Aurora"
   Aurora: ambient soft gradients, glass surfaces.
   Pulse:  Onest type, 2px borders, coral CTA, violet accents.
   ============================================================ */

:root {
  --bg:          #F7F5F1;
  --card:        #FFFFFF;
  --card-solid:  #FFFFFF;
  --soft:        #F1EEE8;
  --ink:         #17140F;
  --ink-soft:    #6E675D;
  --line:        #E7E2D9;
  --line-strong: #D8D2C6;

  --coral:       #F4503A;   /* primary actions */
  --coral-deep:  #D8402C;
  --coral-tint:  #FDE9E5;
  --violet:      #17140F;   /* secondary accent: ink (screenshot system) */
  --violet-deep: #000000;
  --violet-tint: #EDEAE3;

  --live:        #0C9D61;
  --live-tint:   #E2F6ED;
  --build:       #6C4CF1;
  --build-tint:  #EFEAFE;

  --radius:      18px;
  --radius-sm:   12px;

  --body: "Onest", system-ui, sans-serif;
  --display: "Onest", system-ui, sans-serif;
  --mono: "Spline Sans Mono", ui-monospace, monospace;

  /* legacy aliases kept so existing page styles keep working */
  --paper: var(--soft);
  --patch: var(--coral);
  --patch-deep: var(--coral-deep);
  --patch-tint: var(--coral-tint);
}

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

body {
  font-family: var(--body);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
/* Aurora ambient canvas */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(640px 420px at 50% -8%, rgba(244,80,58,0.05), transparent 70%);
}

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

a { color: var(--violet); 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-weight: 800; font-size: 1.08rem; letter-spacing: -0.015em;
  color: var(--ink); display: inline-flex; align-items: center; gap: 10px;
}
.brand:hover { text-decoration: none; }
.brand img { border-radius: 8px; width: 26px; height: 26px; }
.nav-links { display: flex; gap: 24px; font-size: 0.92rem; font-weight: 700; align-items: center; }
.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: 800; font-size: 0.93rem;
  border-radius: 14px; padding: 12px 24px; cursor: pointer;
  border: 2px solid transparent; display: inline-block; letter-spacing: -0.01em;
}
.btn:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--violet); outline-offset: 2px;
}
.btn-primary { background: var(--coral); color: #fff; box-shadow: 0 10px 24px -12px rgba(255,90,80,0.55); }
.btn-primary:hover { background: var(--coral-deep); text-decoration: none; }
.btn-primary:disabled { background: var(--line-strong); color: #fff; box-shadow: none; cursor: default; }
.btn-ghost { background: var(--card-solid); color: var(--ink); border-color: var(--line-strong); }
.btn-ghost:hover { border-color: var(--violet); color: var(--violet); text-decoration: none; }
.btn-sm { padding: 8px 16px; font-size: 0.85rem; }

/* ---------- form fields ---------- */
label { display: block; font-size: 0.8rem; font-weight: 800; margin-bottom: 6px; letter-spacing: 0.01em; }
input[type="text"], input[type="password"], input[type="email"], input[type="search"],
select, textarea {
  width: 100%; padding: 12px 14px; font-size: 0.95rem;
  font-family: var(--body); font-weight: 500;
  border: 2px solid var(--line); border-radius: var(--radius-sm);
  background: var(--card-solid); color: var(--ink);
  transition: border-color 0.15s;
}
input:hover, select:hover, textarea:hover { border-color: var(--line-strong); }
input:focus, select:focus, textarea:focus { border-color: var(--violet); outline: none; }
.mono-input { font-family: var(--mono); font-size: 0.88rem; }
.field { margin-bottom: 16px; }
.field .sub { font-size: 0.78rem; color: var(--ink-soft); margin-top: 6px; }
.field .sub code { font-family: var(--mono); }

/* ---------- cards ---------- */
.card {
  background: var(--card);
  border: 2px solid var(--line); border-radius: var(--radius); padding: 24px;
  box-shadow: 0 2px 10px rgba(30,27,46,0.04);
  transition: transform 0.16s, box-shadow 0.16s, border-color 0.16s;
}

/* ---------- status badges ---------- */
.badge {
  font-family: var(--mono); font-size: 0.7rem; font-weight: 500;
  padding: 3px 11px; 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: 2px dashed var(--line-strong); padding: 1px 10px; }

/* ---------- messages ---------- */
.msg { display: none; margin-top: 14px; font-size: 0.88rem; font-weight: 600; padding: 13px 15px; border-radius: var(--radius-sm); }
.msg.error { background: #FDEBEA; color: #A33530; }
.msg.busy  { background: var(--violet-tint); color: var(--violet-deep); }
.msg.ok    { background: var(--live-tint); color: var(--live); }

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

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