/* DeskBridge Admin Console — design tokens + shell layout.
 * Palette inherited from the DeskBridge shared product palette (see docs/05).
 * No build step: this file is served byte-for-byte. */

:root {
  --db-green:  #0f3b2a;
  --db-green2: #15553d;
  --db-gold:   #b7832f;
  --db-ink:    #13211c;
  --db-paper:  #fbfdfb;
  --db-soft:   #eef5f1;
  --db-line:   #dfe8e3;
  --db-error:  #a13b2a;
  --db-muted:  #4a5b53;
  --db-rail:   220px;
  --db-flyout: 420px;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }

html, body {
  margin: 0; height: 100%;
  background: var(--db-paper); color: var(--db-ink);
  font: 15px/1.5 system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}
button { font: inherit; cursor: pointer; }
input, select, textarea { font: inherit; }
a { color: var(--db-green2); }

/* ── Shell grid ───────────────────────────────────────────── */
.shell { display: grid; grid-template-columns: var(--db-rail) 1fr; height: 100vh; }
.shell.flyout-open { grid-template-columns: var(--db-rail) 1fr var(--db-flyout); }

.nav {
  background: var(--db-green); color: #eaf3ee;
  display: flex; flex-direction: column; padding: 16px 10px; gap: 4px;
}
.nav .brand { display: flex; align-items: center; gap: 10px; margin: 4px 8px 18px; }
.nav .brand img { width: 28px; height: 28px; border-radius: 6px; }
.nav .brand b { font-size: 16px; letter-spacing: .2px; }
.nav button {
  background: transparent; color: #cfe3d8; border: 0; text-align: left;
  padding: 9px 12px; border-radius: 7px; width: 100%;
}
.nav button:hover { background: var(--db-green2); color: #fff; }
.nav button.active { background: var(--db-gold); color: #1c1306; font-weight: 600; }
.nav .spacer { flex: 1; }
.nav .who { font-size: 12px; color: #9fc0b1; padding: 8px 12px; }

.main { display: flex; flex-direction: column; min-width: 0; }
.cmdbar {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 18px; border-bottom: 1px solid var(--db-line); background: #fff;
}
.cmdbar input.search {
  flex: 1; max-width: 520px; padding: 8px 12px;
  border: 1px solid var(--db-line); border-radius: 8px; background: var(--db-soft);
}
.cmdbar .actions { margin-left: auto; display: flex; gap: 8px; }
.view { padding: 18px; overflow: auto; }

/* ── Flyout (the signature component) ─────────────────────── */
.flyout {
  border-left: 1px solid var(--db-line); background: #fff;
  display: flex; flex-direction: column; overflow: hidden;
}
.flyout header { padding: 16px 18px; border-bottom: 1px solid var(--db-line); }
.flyout header h2 { margin: 0; font-size: 18px; }
.flyout .tabs { display: flex; gap: 2px; padding: 0 12px; border-bottom: 1px solid var(--db-line); flex-wrap: wrap; }
.flyout .tabs button { background: transparent; border: 0; padding: 10px 12px; color: var(--db-muted); border-bottom: 2px solid transparent; }
.flyout .tabs button.active { color: var(--db-green); border-bottom-color: var(--db-gold); font-weight: 600; }
.flyout .panel { padding: 16px 18px; overflow: auto; }

/* ── Common bits ──────────────────────────────────────────── */
.btn { background: var(--db-green); color: #fff; border: 0; padding: 8px 14px; border-radius: 8px; }
.btn:hover { background: var(--db-green2); }
.btn.ghost { background: var(--db-soft); color: var(--db-green); border: 1px solid var(--db-line); }
.btn.danger { background: var(--db-error); }
table.db { width: 100%; border-collapse: collapse; }
table.db th, table.db td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--db-line); }
table.db tbody tr:hover { background: var(--db-soft); cursor: pointer; }
.status-badge { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; }
.status-badge::before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: var(--db-muted); }
.status-badge.dot-green::before { background: #2e7d4f; }
.status-badge.dot-yellow::before { background: #c79a22; }
.status-badge.dot-red::before { background: var(--db-error); }
.help-btn { border: 1px solid var(--db-line); background: var(--db-soft); color: var(--db-green); border-radius: 50%; width: 18px; height: 18px; line-height: 1; padding: 0; font-size: 12px; margin-left: 6px; }
.banner { padding: 12px 14px; border-radius: 8px; background: var(--db-soft); border: 1px solid var(--db-line); margin-bottom: 14px; }
.banner.warn { background: #fdf5e6; border-color: #e6cf9a; }
.banner.error { background: #fbece8; border-color: #e6b3a8; color: var(--db-error); }
.toast { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); background: var(--db-ink); color: #fff; padding: 10px 16px; border-radius: 8px; z-index: 50; }
.toast.error { background: var(--db-error); }
.muted { color: var(--db-muted); }
.placeholder { color: var(--db-muted); padding: 40px; text-align: center; border: 1px dashed var(--db-line); border-radius: 10px; }
.modal-overlay { position: fixed; inset: 0; background: rgba(19,33,28,.4); display: grid; place-items: center; z-index: 40; }
.modal { background: #fff; border-radius: 12px; padding: 22px; width: min(520px, 92vw); }
label { display: block; margin: 12px 0 4px; font-size: 13px; color: var(--db-green); }
input.f, select.f, textarea.f { width: 100%; padding: 8px 10px; border: 1px solid var(--db-line); border-radius: 6px; background: var(--db-soft); }
input.f:focus, select.f:focus, textarea.f:focus { outline: 2px solid var(--db-green); }

/* ── Login ────────────────────────────────────────────────── */
.login-shell { display: grid; place-items: center; height: 100vh; }
.login-card { background: #fff; border: 1px solid var(--db-line); border-radius: 14px; padding: 28px; width: min(380px, 92vw); }
.login-card .brand { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.login-card .brand img { width: 34px; height: 34px; }
