/* Rustle Console — simplistic UI over the locked brand tokens (Rosé Pine Moon).
   Everything colors/typography comes from /assets/tokens.css; this file is layout. */

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--base);
  color: var(--text);
  font-family: var(--font-body);
  font-size: var(--t-body);
  line-height: 1.6;
}

main { max-width: 1040px; margin: 0 auto; padding: var(--sp-7) var(--sp-5) var(--sp-9); }

h1 { font-family: var(--font-display); font-weight: 500; font-size: var(--t-h3); margin: var(--sp-5) 0; }
h2 { font-family: var(--font-body); font-weight: 600; font-size: var(--t-lead); margin: 0 0 var(--sp-4); }

.mono { font-family: var(--font-mono); font-size: var(--t-label); }
.dim { color: var(--subtle); }
.empty { color: var(--subtle); }
.eyebrow {
  font-family: var(--font-mono); font-size: var(--t-eyebrow);
  letter-spacing: .16em; text-transform: uppercase; color: var(--iris); margin: 0;
}
.lead { color: var(--subtle); font-size: var(--t-lead); }

/* top bar */
.topbar {
  display: flex; align-items: center; gap: var(--sp-6);
  padding: var(--sp-4) var(--sp-6);
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}
.brand { font-family: var(--font-mono); font-weight: 600; color: var(--text); text-decoration: none; }
.brand-dim { color: var(--muted); }
.topbar nav { display: flex; gap: var(--sp-5); flex: 1; }
.topbar nav a {
  color: var(--subtle); text-decoration: none;
  font-family: var(--font-mono); font-size: var(--t-label);
}
.topbar nav a:hover { color: var(--text); }
.who { display: flex; align-items: center; gap: var(--sp-4); }

/* cards */
.card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  padding: var(--sp-6);
  margin-bottom: var(--sp-6);
  box-shadow: var(--shadow-card);
}
.login-card { max-width: 420px; margin: 12vh auto; text-align: center; }
.login-card .btn { margin-top: var(--sp-5); }

/* tables */
table { width: 100%; border-collapse: collapse; }
th {
  text-align: left; font-family: var(--font-mono); font-size: var(--t-eyebrow);
  letter-spacing: .12em; text-transform: uppercase; color: var(--muted);
  padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid var(--line-strong);
}
td { padding: var(--sp-3); border-bottom: 1px solid var(--line); vertical-align: middle; }
td a { color: var(--iris); text-decoration: none; }
td a:hover { text-decoration: underline; }

/* status chips — foam: delivered, gold: in flight/retrying, love: failed */
.chip {
  font-family: var(--font-mono); font-size: var(--t-micro);
  padding: 2px var(--sp-2); border-radius: var(--r-chip);
  border: 1px solid var(--line-strong); color: var(--subtle);
}
.chip.confirmed { color: var(--foam); border-color: var(--foam); }
.chip.claimed { color: var(--gold); border-color: var(--gold); }
.chip.failed { color: var(--love); border-color: var(--love); }

/* forms */
form.stack { display: flex; flex-direction: column; gap: var(--sp-4); align-items: flex-start; }
.row { display: flex; gap: var(--sp-5); align-items: flex-end; flex-wrap: wrap; margin: var(--sp-3) 0; }
label { display: flex; flex-direction: column; gap: var(--sp-1); font-size: var(--t-label); color: var(--subtle); }
input, select {
  background: var(--overlay); color: var(--text);
  border: 1px solid var(--line-strong); border-radius: var(--r-btn);
  padding: var(--sp-2) var(--sp-3); font-size: var(--t-body);
}
input:focus, select:focus { outline: 2px solid var(--iris-soft); border-color: var(--iris); }
input.wide { min-width: 420px; }
input.narrow { width: 90px; }

.btn {
  font-family: var(--font-body); font-weight: 600; font-size: var(--t-label);
  background: var(--overlay); color: var(--text);
  border: 1px solid var(--line-strong); border-radius: var(--r-btn);
  padding: var(--sp-2) var(--sp-4); cursor: pointer; text-decoration: none; display: inline-block;
}
.btn.primary { background: var(--iris); color: var(--on-iris); border-color: var(--iris); }
.btn.ghost { background: transparent; }
.btn:hover { filter: brightness(1.08); }

.flash {
  border: 1px solid var(--gold); border-radius: var(--r-card);
  background: var(--iris-soft); padding: var(--sp-3) var(--sp-4);
}
code, .secret { font-family: var(--font-mono); background: var(--overlay); padding: 2px 6px; border-radius: var(--r-chip); }
pre.payload { overflow-x: auto; background: var(--base); padding: var(--sp-4); border-radius: var(--r-card); }
