:root {
  --bg: #0e1117;
  --panel: #161a22;
  --panel-2: #1b2330;
  --text: #e6edf3;
  --muted: #9da7b3;
  --accent: #7aa2f7;
  --accent-2: #4fd1c5;
  --danger: #ff6b6b;
  --ok: #22c55e;
  --warning: #f59e0b;
  --border: #2a2f3a;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica Neue, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color: var(--text);
  background: var(--bg);
}

#app { display: flex; min-height: 100vh; }

.sidebar {
  width: 280px;
  background: var(--panel);
  border-right: 1px solid var(--border);
  padding: 16px;
  position: sticky;
  top: 0;
  height: 100vh;
}
.sidebar.hidden { display: none; }
.brand { font-weight: 700; font-size: 20px; margin-bottom: 12px; }
.user-card { border: 1px solid var(--border); border-radius: 8px; padding: 12px; background: var(--panel-2); }
.user-name { font-weight: 600; }
.user-email { color: var(--muted); font-size: 12px; }
.user-roles { color: var(--accent-2); font-size: 12px; margin-top: 6px; }
.nav { display: flex; flex-direction: column; margin: 16px 0; gap: 8px; }
.nav-item { text-align: left; padding: 10px 12px; background: transparent; color: var(--text); border: 1px solid var(--border); border-radius: 8px; cursor: pointer; }
.nav-item:hover { background: #1f2633; }
.sidebar-footer { margin-top: auto; }

main { flex: 1; padding: 24px; max-width: 1200px; margin: 0 auto; }
.view.hidden { display: none; }
.panel { border: 1px solid var(--border); border-radius: 8px; padding: 12px; background: var(--panel); margin: 16px 0; }
.card { border: 1px solid var(--border); border-radius: 10px; padding: 16px; background: var(--panel); }
.grid { display: grid; gap: 16px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 900px) { .grid-2, .grid-3 { grid-template-columns: 1fr; } .sidebar { display: none; } }

.primary, .secondary, .nav-item, button { font: inherit; }
.primary { background: var(--accent); color: #0b1020; border: 0; padding: 10px 14px; border-radius: 8px; cursor: pointer; font-weight: 600; }
.secondary { background: transparent; color: var(--text); border: 1px solid var(--border); padding: 10px 14px; border-radius: 8px; cursor: pointer; }

label { display: grid; gap: 6px; font-size: 14px; color: var(--muted); margin: 8px 0; }
input, select { background: #0b1220; color: var(--text); border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px; }
input:focus, select:focus { outline: 2px solid var(--accent-2); border-color: var(--accent-2); }

table { width: 100%; border-collapse: collapse; font-size: 14px; }
th, td { padding: 10px 12px; border-bottom: 1px solid var(--border); text-align: left; }
th { color: var(--muted); font-weight: 500; }
tr.clickable { cursor: pointer; }
tr.clickable:hover { background: #1f2633; }

.metrics { margin: 16px 0; }
.metric { background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 16px; }
.metric .label { color: var(--muted); font-size: 13px; }
.metric .value { font-weight: 700; font-size: 28px; margin-top: 4px; }

.toolbar { display: flex; gap: 16px; align-items: center; margin: 12px 0; }

.progress { height: 10px; background: #0f1422; border: 1px solid var(--border); border-radius: 999px; overflow: hidden; }
.progress > div { height: 100%; background: var(--ok); }
.progress-label { font-size: 12px; color: var(--muted); margin-top: 6px; }

.expander { border: 1px solid var(--border); border-radius: 10px; margin: 12px 0; overflow: hidden; background: var(--panel); }
.expander-header { padding: 12px 14px; cursor: pointer; user-select: none; display: flex; justify-content: space-between; align-items: center; }
.expander-body { padding: 0 14px 14px; display: none; }
.expander.open .expander-body { display: block; }
.expander-header:hover { background: #1f2633; }

.muted { color: var(--muted); }
.error { color: var(--danger); margin-top: 6px; min-height: 20px; }
.notice { padding: 8px 12px; border-radius: 8px; background: #1b2330; border: 1px solid var(--border); color: var(--muted); margin: 8px 0 16px; }

.creds { display: grid; gap: 12px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cred-title { font-weight: 600; margin-bottom: 6px; }
code { display: block; background: #0b1220; border: 1px solid var(--border); padding: 6px 8px; border-radius: 6px; width: fit-content; }

.manager-only { display: none; }
.manager .manager-only { display: inline-block; }
