/* === Auth Page – scope dédié === */

/* Mise en page : prend toute la hauteur utile pour que le footer reste en bas */
.auth-page{
  min-height: calc(100vh - 500px); /* hauteur restante (header + footer ~) */
  display: flex;
  align-items: center;     /* centre verticalement */
  justify-content: center; /* centre horizontalement */
  padding: 24px 0 32px;
}

/* Carte contenant le formulaire */
.auth-card{
  width: 100%;
  max-width: 560px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 22px;
}

/* === Styles "modernes" du formulaire (adaptés du modal) === */
.auth-card .form{ margin: 0; padding: 4px 2px 0; color: var(--text); }
.auth-card .form h1{ margin: 0 0 10px; font-size: 1.6rem; line-height: 1.2; }

.auth-card .form .row{ margin: 10px 0; }
.auth-card .form label{
  display: block;
  margin-bottom: 6px;
  font-weight: 700;
  color: var(--text-2);
}

.auth-card .form input,
.auth-card .form select{
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface) 92%, white);
  color: var(--text);
  outline: none;
  transition: border-color var(--speed), box-shadow var(--speed), background-color var(--speed);
  box-shadow: var(--shadow);
}
.auth-card .form input::placeholder{
  color: color-mix(in srgb, var(--text-2) 70%, transparent);
}
.auth-card .form input:focus,
.auth-card .form select:focus{
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 22%, transparent);
  background: color-mix(in srgb, var(--surface) 98%, white);
}

/* Fieldset & legend */
.auth-card .form fieldset{
  margin: 12px 0 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface) 94%, white);
}
.auth-card .form legend{
  padding: 0 4px;
  font-weight: 700;
  color: var(--text-2);
  font-size: 0.95rem;
  margin-bottom: 6px;
}

/* Details (code de secours) */
.auth-card .form details{ margin-top: 6px; }
.auth-card .form details summary{
  list-style: none;
  cursor: pointer;
  color: var(--primary);
  text-decoration: underline;
}

/* Petites aides */
.auth-card .form .hint{ color: var(--text-2); font-size: .95rem; }
.auth-card .form .hint.block{ display: block; margin-top: 6px; }

/* Actions */
.auth-card .form .actions{
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 12px;
}
.auth-card .form .btn{ border-radius: 12px; }
.auth-card .form .link{
  border: 0;
  background: transparent;
  cursor: pointer;
  text-decoration: underline;
  color: var(--primary);
}

/* Panneau "mot de passe oublié" */
.auth-card #forgot-panel{
  display: none;
  margin-top: 12px;
  padding: 14px;
  border: 1px dashed color-mix(in srgb, var(--primary) 35%, var(--line));
  border-radius: 12px;
  background: color-mix(in srgb, var(--primary) 6%, var(--surface));
}

/* Flashes (cohérent avec whiteout-merged) */
.auth-card .wo-flashes{ margin: 10px 0 6px; display: grid; gap: 8px; }
.auth-card .wo-flash{
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 700;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow);
}
.auth-card .wo-flash--success{
  border-color: color-mix(in srgb, var(--success) 45%, var(--line));
  background: color-mix(in srgb, var(--success) 10%, var(--surface));
}
.auth-card .wo-flash--error{
  border-color: color-mix(in srgb, var(--danger) 45%, var(--line));
  background: color-mix(in srgb, var(--danger) 10%, var(--surface));
}
.auth-card .wo-flash--info{
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}

/* Petit ajustement responsive */
@media (max-width: 520px){
  .auth-card{ padding: 18px; }
}

.language-select-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.language-select {
    width: 100%;
    padding: 12px 15px;
    border-radius: 12px;
    border: 1px solid #d0d7de;
    background: #fff;
    font-size: 15px;
    appearance: none;
    cursor: pointer;
    transition: 0.2s ease;
}

.language-select:hover {
    border-color: #4ea9ff;
    box-shadow: 0 0 6px rgba(78, 169, 255, 0.5);
}

.language-select:focus {
    outline: none;
    border-color: #007bff;
    box-shadow: 0 0 10px rgba(0, 123, 255, 0.5);
}
