/* ONYX page-specific layout — kept deliberately small. */

/* login */
.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.login-card { width: 380px; padding: 28px; }
.login-card .logo {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0.22em;
  font-size: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 22px;
}
.login-card .logo::before {
  content: "";
  width: 9px;
  height: 9px;
  background: var(--ai);
  transform: rotate(45deg);
}
.login-error {
  color: var(--bad);
  background: var(--bad-tint);
  border-radius: var(--radius-input);
  font-size: 13px;
  padding: 9px 12px;
  margin-bottom: 14px;
}

/* admin users */
.admin-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 18px; align-items: start; margin-top: 22px; }
