/* =====================================================
   Multipedia — Pages d'authentification
   Login, inscription, changement de mot de passe
   ===================================================== */

.auth-container {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  background: var(--bg-base);
  /* Légère ambiance cinematique en fond */
  background-image:
    radial-gradient(ellipse 60% 50% at 20% 60%, rgba(99, 102, 241, 0.07) 0%, transparent 100%),
    radial-gradient(ellipse 50% 40% at 80% 30%, rgba(245, 158, 11, 0.04) 0%, transparent 100%);
}

.auth-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-2xl);
  padding: var(--space-10) var(--space-8);
  width: 100%;
  max-width: 440px;
  box-shadow: var(--shadow-xl);
}

/* ─── Logo et titre ─── */

.auth-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.auth-logo-mark {
  width: 60px;
  height: 60px;
  border-radius: var(--radius-xl);
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: white;
  box-shadow: var(--shadow-glow);
  letter-spacing: -0.04em;
}

.auth-app-name {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--text-primary);
  letter-spacing: -0.03em;
}

.auth-title {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--text-primary);
  text-align: center;
  letter-spacing: -0.02em;
  margin-top: var(--space-2);
}

.auth-subtitle {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  text-align: center;
  margin-top: var(--space-2);
  margin-bottom: var(--space-6);
  line-height: var(--leading-relaxed);
}

/* ─── Formulaire ─── */

.auth-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* ─── Remember me ─── */

.auth-remember {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  cursor: pointer;
  user-select: none;
}

.auth-remember input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
}

/* ─── Message d'erreur global ─── */

.form-error {
  background: var(--error-dim);
  border: 1px solid rgba(248, 113, 113, 0.3);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: var(--error);
  text-align: center;
}

/* ─── Footer du formulaire ─── */

.auth-footer {
  margin-top: var(--space-6);
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.auth-footer a {
  color: var(--text-accent);
  font-weight: var(--font-medium);
}

.auth-footer a:hover { color: var(--accent); }

/* ─── Spinner (invitation en cours de validation) ─── */

.loading-spinner {
  width: 44px;
  height: 44px;
  margin: var(--space-6) auto;
  border: 3px solid var(--border-default);
  border-top-color: var(--accent);
  border-radius: var(--radius-full);
  animation: spin 0.9s linear infinite;
}

/* ─── Écrans de statut (invitation invalide, bienvenue) ─── */

.auth-status {
  text-align: center;
  padding: var(--space-4) 0;
}

.auth-status-icon {
  font-size: 3rem;
  margin-bottom: var(--space-4);
  display: block;
}

.error-title {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--error);
  text-align: center;
  margin-bottom: var(--space-3);
}

.success-title {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--success);
  text-align: center;
  margin-bottom: var(--space-3);
}

.error-description,
.welcome-text {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  text-align: center;
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-6);
}

.hint {
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-align: center;
  margin-top: var(--space-4);
  line-height: var(--leading-relaxed);
}

/* ─── Champ en lecture seule (URL d'invitation) ─── */

input[readonly] {
  background: var(--bg-elevated);
  color: var(--text-muted);
  cursor: default;
  border-color: var(--border-subtle);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
}
