/* ============================================================
   RQDT — auth.css
   Styles des pages d'authentification (connexion, inscription, etc.)
   ============================================================ */

/* ─── Layout ─────────────────────────────────────────────────── */
.auth-body {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-neutral-50);
  padding: var(--space-6);
}

.auth-wrap {
  width: 100%;
  max-width: 420px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}

.auth-brand {
  display: flex;
  justify-content: center;
}
.auth-brand a { display: flex; }
.auth-brand img { display: block; }

/* ─── Carte formulaire ──────────────────────────────────────── */
.auth-card {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
}

/* ─── En-tête formulaire ────────────────────────────────────── */
.auth-title {
  font-size: var(--fs-h3);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-1);
  text-align: center;
}

.auth-sub {
  font-size: var(--fs-body-sm);
  color: var(--fg-muted);
  text-align: center;
  margin-bottom: var(--space-6);
}
.auth-sub a {
  color: var(--color-primary-600);
  font-weight: 500;
  text-decoration: none;
}
.auth-sub a:hover { text-decoration: underline; }

/* ─── Formulaire ────────────────────────────────────────────── */
.auth-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

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

.form-field label {
  font-size: var(--fs-body-sm);
  font-weight: 500;
  color: var(--fg-default);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.form-label-link {
  font-size: var(--fs-caption);
  font-weight: 400;
  color: var(--color-primary-600);
  text-decoration: none;
}
.form-label-link:hover { text-decoration: underline; }

.form-field input {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  padding: 11px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
  color: var(--fg-default);
  outline: none;
  transition:
    border-color var(--dur-fast) var(--ease-out),
    box-shadow   var(--dur-fast) var(--ease-out);
  width: 100%;
}
.form-field input::placeholder { color: var(--fg-subtle); }
.form-field input:focus {
  border-color: var(--color-primary-400);
  box-shadow: var(--focus-ring);
}
.form-field.has-error input {
  border-color: var(--color-error-500);
}
.form-field.has-error input:focus {
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-error-500) 25%, transparent);
}

/* ─── Hints & erreurs champ ─────────────────────────────────── */
.form-hint {
  font-size: var(--fs-caption);
  color: var(--fg-muted);
}
.form-hint--error {
  color: var(--color-error-500);
  font-weight: 500;
}

/* Erreur globale (hors champ) */
.form-error--global {
  background: var(--color-error-50);
  border: 1px solid color-mix(in oklab, var(--color-error-500) 30%, transparent);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--fs-body-sm);
  color: var(--color-error-700);
  line-height: 1.5;
  margin-bottom: var(--space-2);
}
.form-error--global a {
  color: var(--color-error-700);
  font-weight: 600;
}

/* ─── Checkbox "Rester connecté" ────────────────────────────── */
.form-check label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-body-sm);
  color: var(--fg-muted);
  cursor: pointer;
  user-select: none;
}
.form-check input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--color-primary-500);
  flex-shrink: 0;
  cursor: pointer;
}

/* ─── Bouton pleine largeur ─────────────────────────────────── */
.btn-full {
  width: 100%;
  justify-content: center;
  border-radius: var(--radius-md);
  padding: 13px 20px;
  font-size: var(--fs-body);
  margin-top: var(--space-2);
}

/* ─── Mentions légales ──────────────────────────────────────── */
.auth-legal {
  font-size: var(--fs-caption);
  color: var(--fg-subtle);
  text-align: center;
  line-height: 1.5;
  margin-top: var(--space-1);
}
.auth-legal a {
  color: var(--fg-muted);
  text-decoration: underline;
}
.auth-legal a:hover { color: var(--fg-default); }

/* ─── Lien retour ───────────────────────────────────────────── */
.auth-back-link {
  font-size: var(--fs-body-sm);
  color: var(--fg-muted);
  text-decoration: none;
}
.auth-back-link:hover { color: var(--fg-strong); }

/* ─── Page de confirmation (verify-sent, forgot-sent) ────────── */
.auth-confirm {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.auth-confirm__icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--color-primary-50);
  color: var(--color-primary-500);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.auth-confirm .auth-title { margin-bottom: 0; }

.auth-confirm__text {
  font-size: var(--fs-body);
  color: var(--fg-default);
  line-height: 1.6;
  max-width: 340px;
}

.auth-confirm__note {
  font-size: var(--fs-body-sm);
  color: var(--fg-muted);
  line-height: 1.55;
}
.auth-confirm__note a {
  color: var(--color-primary-600);
  font-weight: 500;
  text-decoration: none;
}
.auth-confirm__note a:hover { text-decoration: underline; }

/* ─── Messages flash (dans auth-wrap) ──────────────────────── */
.flash {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--fs-body-sm);
  line-height: 1.5;
}
.flash a { font-weight: 600; }

.flash--success {
  background: var(--color-success-50);
  border: 1px solid color-mix(in oklab, var(--color-success-500) 30%, transparent);
  color: var(--color-success-700);
}
.flash--error {
  background: var(--color-error-50);
  border: 1px solid color-mix(in oklab, var(--color-error-500) 30%, transparent);
  color: var(--color-error-700);
}
.flash--warning {
  background: var(--color-warning-50);
  border: 1px solid color-mix(in oklab, var(--color-warning-500) 30%, transparent);
  color: var(--color-warning-700);
}
.flash--info {
  background: var(--color-info-50);
  border: 1px solid color-mix(in oklab, var(--color-info-500) 30%, transparent);
  color: var(--color-info-700);
}
