.login-main {
  display: grid;
  place-items: center;
  min-height: calc(100vh - 160px);
}

.login-card {
  width: min(420px, 100%);
  padding: 2.5rem;
}

.login-card h1 {
  margin: 0 0 0.5rem;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.login-card > p {
  margin: 0 0 1.5rem;
  color: var(--muted);
  font-size: 0.9rem;
}

.login-actions {
  display: grid;
  gap: 0.75rem;
}

.login-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-weight: 600;
  font-size: 0.95rem;
  padding: 0.65rem 1rem;
  border-radius: 0.5rem;
  transition:
    background 0.15s,
    opacity 0.15s;
}
.login-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.login-btn-discord {
  background: var(--discord-brand);
  color: var(--text-on-accent);
}
.login-btn-discord:hover:not(:disabled) {
  background: var(--discord-brand-hover);
}
.login-btn-google {
  background: var(--bg-panel);
  color: var(--text);
  border: 1px solid var(--border);
}
.login-btn-google:hover:not(:disabled) {
  background: var(--border);
}
.google-icon {
  flex-shrink: 0;
}
.login-actions .login-btn + .login-btn {
  margin-top: 0.25rem;
}
