/* Onyx Cloud — operator panel stylesheet.
 *
 * This file ports the design tokens and component contract from
 * docs/ui-design.md verbatim so a customer flipping between the LAN admin UI
 * (internal/localapi/ui/index.html) and the cloud panel sees the same
 * Slate-chrome + Signal-Green palette, the same spacing scale, and the same
 * .btn/.input/.panel/.badge/.dot class vocabulary.
 *
 * Rule 8 (CLAUDE.md): no new colors, no purple, no dark surfaces, no big-
 * letter hero tiles. If a class isn't already in the box CSS, it lives below
 * as a panel-only addition (login card, audit payload row).
 */

/* ---------- Design tokens (verbatim from docs/ui-design.md §2) ---------- */
:root {
  --bg-page:        #eef1f5;
  --bg-surface:     #ffffff;
  --bg-surface-2:   #f7f9fb;
  --bg-sidebar:     #1f2733;
  --bg-sidebar-2:   #283242;
  --bg-topbar:      #2a3441;
  --bg-hover:       #eaeef3;

  --border:         #d4dae2;
  --border-strong:  #b9c2cd;
  --border-sidebar: #34404f;

  --text:           #1d2733;
  --text-muted:     #5b6776;
  --text-faint:     #8a95a3;
  --text-on-dark:   #e7ecf2;
  --text-on-dark-muted: #9aa6b4;

  --green:          #1f9d57;
  --green-hover:    #198049;
  --green-soft:     #e4f5ec;
  --green-on:       #ffffff;

  --ok:             #1f9d57;
  --ok-soft:        #e4f5ec;
  --warn:           #c47f17;
  --warn-soft:      #fbf1dd;
  --down:           #c8372d;
  --down-soft:      #fae6e4;

  --focus:          0 0 0 3px rgba(31,157,87,.28);

  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 20px; --sp-6: 24px; --sp-8: 32px; --sp-10: 40px;

  --r-xs: 2px;  --r-sm: 3px;  --r-md: 4px;  --r-pill: 999px;

  --shadow-1: 0 1px 2px rgba(20,30,45,.06);
  --shadow-pop: 0 6px 18px rgba(20,30,45,.14);

  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               "Helvetica Neue", Arial, sans-serif;
  --font-mono: "SF Mono", "JetBrains Mono", "Roboto Mono", ui-monospace,
               Menlo, Consolas, monospace;

  --fs-h1:     20px;  --lh-h1: 28px;  --fw-h1: 600;
  --fs-h2:     15px;  --lh-h2: 22px;  --fw-h2: 600;
  --fs-label:  11px;  --lh-label: 14px; --fw-label: 600;
  --fs-body:   13px;  --lh-body: 19px;  --fw-body: 400;
  --fs-sm:     12px;  --lh-sm: 16px;
  --fs-mono:   12.5px; --lh-mono: 18px;
}

* { box-sizing: border-box; }
html, body {
  margin: 0;
  background: var(--bg-page);
  color: var(--text);
  font: var(--fw-body) var(--fs-body)/var(--lh-body) var(--font-sans);
  -webkit-font-smoothing: antialiased;
}
code, .mono, td.mono, dd.mono { font-family: var(--font-mono); font-size: var(--fs-mono); }
.section-label {
  font-size: var(--fs-label); font-weight: var(--fw-label);
  letter-spacing: .06em; text-transform: uppercase; color: var(--text-muted);
}

/* ---------- App shell ---------- */
.app    { display: grid; grid-template-columns: 200px 1fr; grid-template-rows: 48px 1fr; height: 100vh; }
.topbar { grid-column: 1 / 3; }
.sidebar{ overflow-y: auto; }
.main   { overflow-y: auto; padding: var(--sp-6); }
.content{ max-width: 1320px; }

/* ---------- Top bar ---------- */
.topbar {
  display: flex; align-items: center; gap: var(--sp-4);
  background: var(--bg-topbar); color: var(--text-on-dark);
  padding: 0 var(--sp-4); border-bottom: 1px solid var(--border-sidebar);
}
.topbar__brand { display: flex; align-items: center; gap: var(--sp-2); font-weight: 600; letter-spacing: .02em; }
.topbar__mark {
  width: 18px; height: 18px; border-radius: var(--r-sm);
  background: var(--green); box-shadow: inset 0 0 0 2px rgba(255,255,255,.18);
}
.topbar__spacer { margin-left: auto; }
.topbar__sys { display: flex; align-items: center; gap: var(--sp-3); font-size: var(--fs-sm); color: var(--text-on-dark-muted); }
.topbar__sep { color: var(--border-sidebar); }
.topbar__logout { margin: 0; }

/* ---------- Sidebar (flat, no collapsible groups — the cloud panel has 3 items) ---------- */
.sidebar { background: var(--bg-sidebar); color: var(--text-on-dark-muted); padding: var(--sp-2) 0; }
.nav-item {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  color: var(--text-on-dark-muted); text-decoration: none;
  font-size: var(--fs-body); border-left: 3px solid transparent;
}
.nav-item:hover { background: var(--bg-sidebar-2); color: var(--text-on-dark); }
.nav-item.active {
  color: #ffffff; background: var(--bg-sidebar-2);
  border-left-color: var(--green);
  font-weight: 600;
}

/* ---------- Page header ---------- */
.page-header { display: flex; align-items: center; margin-bottom: var(--sp-4); }
.page-title  { font-size: var(--fs-h1); font-weight: var(--fw-h1); margin: 0; }
.page-header .panel__actions { margin-left: auto; display: flex; gap: var(--sp-2); align-items: center; }

/* ---------- Panel / card ---------- */
.panel { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-md); box-shadow: var(--shadow-1); margin-bottom: var(--sp-4); }
.panel__head {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border);
}
.panel__title { font-size: var(--fs-h2); font-weight: var(--fw-h2); margin: 0; }
.panel__actions { margin-left: auto; display: flex; gap: var(--sp-2); align-items: center; }
.panel__body { padding: var(--sp-4); }
.panel__body--flush { padding: 0; }

/* ---------- Card grid (used on /boxes/{id}) ---------- */
.card-grid { display: grid; grid-template-columns: minmax(280px, 1fr) 2fr; gap: var(--sp-4); margin-bottom: var(--sp-4); }
@media (max-width: 980px) { .card-grid { grid-template-columns: 1fr; } }

/* ---------- Dense data table ---------- */
.dtable { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); }
.dtable thead th {
  position: sticky; top: 0; background: var(--bg-surface-2);
  text-align: left; font: var(--fw-label) var(--fs-label)/1 var(--font-sans);
  letter-spacing: .05em; text-transform: uppercase; color: var(--text-muted);
  padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid var(--border-strong);
}
.dtable td { padding: 6px var(--sp-3); border-bottom: 1px solid var(--border); white-space: nowrap; vertical-align: middle; }
.dtable tbody tr:hover { background: var(--bg-hover); }
.dtable td.mono { font-family: var(--font-mono); font-size: var(--fs-mono); color: var(--text); }
.dtable td.num  { text-align: right; font-variant-numeric: tabular-nums; }
.dtable .col-actions { text-align: right; }
.dtable--zebra tbody tr:nth-child(even) { background: var(--bg-surface-2); }

/* ---------- kv list ---------- */
.kv { display: grid; grid-template-columns: auto 1fr; gap: 6px var(--sp-3); margin: 0; }
.kv dt { font-size: var(--fs-sm); color: var(--text-muted); }
.kv dd { margin: 0; font-size: var(--fs-body); text-align: right; }
.kv dd.mono { font-family: var(--font-mono); font-size: var(--fs-mono); }

/* ---------- Form / input ---------- */
.form-row { display: grid; grid-template-columns: 180px 1fr; align-items: center; gap: var(--sp-3); padding: var(--sp-2) 0; }
.form-row--stacked { grid-template-columns: 1fr; gap: var(--sp-2); }
.form-row > label { font-size: var(--fs-sm); font-weight: 600; color: var(--text-muted); }
.input, .select {
  width: 100%; padding: 7px var(--sp-3);
  font: 400 var(--fs-body)/1.2 var(--font-sans);
  color: var(--text); background: var(--bg-surface);
  border: 1px solid var(--border); border-radius: var(--r-sm);
}
.input.mono, .conf-text { font-family: var(--font-mono); }
.input:focus, .select:focus, .conf-text:focus { outline: none; border-color: var(--green); box-shadow: var(--focus); }
.input::placeholder { color: var(--text-faint); }

.conf-text {
  width: 100%; min-height: 220px;
  font-family: var(--font-mono); font-size: var(--fs-mono);
  background: var(--bg-surface-2);
  border: 1px solid var(--border); border-radius: var(--r-sm);
  padding: var(--sp-2);
  white-space: pre;
}

.add-row { display: flex; gap: var(--sp-3); align-items: end; flex-wrap: wrap; }
.field   { display: flex; flex-direction: column; gap: 4px; min-width: 140px; }
.field .section-label { line-height: 1; }

.action-row { display: flex; gap: var(--sp-3); align-items: center; margin-top: var(--sp-3); }
.revoke-form { margin-top: var(--sp-4); padding-top: var(--sp-3); border-top: 1px solid var(--border); display: flex; gap: var(--sp-3); align-items: center; }

/* ---------- Status badge + dot ---------- */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 2px 8px; border-radius: var(--r-pill);
  font-size: var(--fs-label); font-weight: 600; letter-spacing: .03em; text-transform: uppercase;
  border: 1px solid transparent;
}
.badge--ok      { color: #14613a; background: var(--ok-soft);   border-color: #bfe6d0; }
.badge--down    { color: #8f261f; background: var(--down-soft); border-color: #efc4c0; }
.badge--warn    { color: #855210; background: var(--warn-soft); border-color: #ecd6a8; }
.badge--neutral { color: var(--text-muted); background: var(--bg-surface-2); border-color: var(--border); }

.dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; flex: 0 0 8px; margin-right: 6px; vertical-align: middle; }
.dot--ok      { background: var(--ok); }
.dot--down    { background: var(--down); }
.dot--warn    { background: var(--warn); }
.dot--off     { background: var(--border-strong); }
.dot--neutral { background: var(--border-strong); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px var(--sp-3); font: 600 var(--fs-sm)/1 var(--font-sans);
  border-radius: var(--r-sm); border: 1px solid var(--border-strong);
  background: var(--bg-surface); color: var(--text); cursor: pointer;
  text-decoration: none;
}
.btn:hover { background: var(--bg-hover); }
.btn:focus-visible { outline: none; box-shadow: var(--focus); }
.btn:disabled { opacity: .5; cursor: not-allowed; }

.btn--primary { background: var(--green); border-color: var(--green); color: var(--green-on); }
.btn--primary:hover { background: var(--green-hover); border-color: var(--green-hover); }

.btn--secondary { /* = default .btn */ }

.btn--danger { background: var(--bg-surface); border-color: #e2b4b0; color: var(--down); }
.btn--danger:hover { background: var(--down-soft); }
.btn--danger.btn--solid { background: var(--down); border-color: var(--down); color: #fff; }

.btn--sm { padding: 3px var(--sp-2); font-size: var(--fs-label); }

/* topbar logout button needs a lighter outline against the dark bar */
.topbar__sys .btn { background: rgba(255,255,255,.07); color: var(--text-on-dark); border-color: rgba(255,255,255,.15); }
.topbar__sys .btn:hover { background: rgba(255,255,255,.14); }

/* ---------- Alerts ---------- */
.alert {
  display: flex; gap: var(--sp-2); align-items: flex-start;
  padding: var(--sp-3) var(--sp-4); border: 1px solid var(--border);
  border-left-width: 3px; border-radius: var(--r-sm); font-size: var(--fs-sm); background: var(--bg-surface);
  margin-bottom: var(--sp-4);
}
.alert--ok    { border-left-color: var(--ok);   background: var(--ok-soft); }
.alert--warn  { border-left-color: var(--warn); background: var(--warn-soft); }
.alert--error { border-left-color: var(--down); background: var(--down-soft); }
.alert--info  { border-left-color: var(--green); background: var(--green-soft); }
.alert__title { font-weight: 600; }

.fresh-token { align-items: center; }
.fresh-token > div { flex: 1; }
.fresh-token__value {
  display: block; font-size: 14px; padding: 6px 8px;
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--r-sm); margin: var(--sp-2) 0;
  word-break: break-all;
}

/* ---------- Empty state + hints ---------- */
.empty { padding: var(--sp-6); color: var(--text-muted); text-align: center; font-size: var(--fs-sm); }
.hint  { font-size: var(--fs-sm); color: var(--text-faint); }
.hint--inline { display: inline; }

/* ---------- Audit payload cell ---------- */
.audit-payload {
  font-family: var(--font-mono); font-size: var(--fs-mono);
  color: var(--text-muted);
  white-space: pre-wrap; word-break: break-all;
  max-width: 720px;
}

/* ---------- Login page (standalone, no chrome) ---------- */
.login-body { background: var(--bg-page); }
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--sp-4); }
.login-card { width: 360px; max-width: 100%; padding: var(--sp-6); margin-bottom: 0; }
.login-brand { display: flex; align-items: center; gap: var(--sp-2); justify-content: center; padding-bottom: var(--sp-3); font-weight: 600; letter-spacing: .04em; }
.login-brand__text { color: var(--text); }
.login-title { font-size: var(--fs-h2); font-weight: 600; text-align: center; margin: 0 0 var(--sp-4); color: var(--text-muted); }
.login-submit { width: 100%; margin-top: var(--sp-2); padding: 9px var(--sp-3); justify-content: center; }
