.auth {
  min-height: 100vh; display: flex; flex-direction: column; align-items: center;
  padding: 36px 20px; background: var(--bg-soft);
}
.auth__brand { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 28px; font-weight: 700; }
.auth__card {
  width: 100%; max-width: 420px; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-md); padding: 28px;
  display: flex; flex-direction: column; gap: 14px;
}
.auth__card h1 { margin: 0; font-size: 1.6rem; letter-spacing: -.01em; }
.auth__lede { margin: -6px 0 6px; color: var(--text-muted); }
.auth__error {
  background: #fdecec; color: #9a2222; border: 1px solid #f3b9b9;
  padding: 10px 12px; border-radius: var(--radius-md); font-size: .92rem;
}
.auth__alt { color: var(--text-muted); margin: 4px 0 0; text-align: center; }
.auth__alt a { color: var(--primary); text-decoration: none; font-weight: 600; }
.auth__card label { display: flex; flex-direction: column; gap: 6px; font-size: .92rem; color: var(--text-muted); }
.auth__card label > span { font-weight: 600; color: var(--text); }
.auth__card input {
  border: 1px solid var(--border-strong); border-radius: var(--radius-md);
  padding: 11px 12px; background: white; color: var(--text);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.auth__card input:focus {
  outline: none; border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(11,92,255,.15);
}
.hint { color: var(--text-faint); font-size: .82rem; }

/* Info-card variant: used by /pending and /banned screens — same chrome as the
   login/register card but no inputs, just a heading + lede + a single action. */
.auth__card--info { gap: 18px; }
.auth__card--info .auth__lede { margin: 0; font-size: 1rem; line-height: 1.55; }
.auth__card--info .auth__alt { margin-top: 4px; }
.auth__card--banned { border-color: #f3b9b9; }
.auth__card--banned h1 { color: #9a2222; }
.auth__inline-form { margin: 0; }

@media (max-width: 640px) {
  .auth { padding: 22px 14px; }
  .auth__brand { margin-bottom: 18px; }
  .auth__card { padding: 22px 18px; border-radius: 14px; gap: 12px; }
  .auth__card h1 { font-size: 1.4rem; }
  .auth__card input { padding: 12px; font-size: 1rem; }
  .auth__card .btn { padding: 13px 16px; font-size: 1rem; }
}
