/**
 * Styles communs pour les pages publiques (contact, mentions légales, CGU, politique)
 * Thème clair, épuré, cohérent avec l'application.
 */

body.page-public {
  background: #fdfdfd;
  color: #1e293b;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  line-height: 1.6;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.page-public main {
  flex: 1;
  max-width: 800px;
  margin: 0 auto;
  padding: 2rem 1.5rem 3rem;
  width: 100%;
}

.page-public h1 {
  font-size: 1.75rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: #1e293b;
}

.page-public .page-public_intro {
  color: #64748b;
  font-size: 0.9375rem;
  margin-bottom: 1.5rem;
}

.page-public .content-block {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.page-public .content-block h2 {
  font-size: 1.125rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  color: #334155;
}

.page-public .content-block p,
.page-public .content-block ul {
  font-size: 0.9375rem;
  color: #475569;
  margin-bottom: 0.75rem;
}

.page-public .content-block ul {
  padding-left: 1.25rem;
}

.page-public .content-block li {
  margin-bottom: 0.35rem;
}

/* Formulaire contact */
.page-public .form-group {
  margin-bottom: 1.25rem;
}

.page-public .form-group label {
  display: block;
  font-weight: 500;
  font-size: 0.9375rem;
  color: #334155;
  margin-bottom: 0.35rem;
}

.page-public .form-group input,
.page-public .form-group textarea,
.page-public .form-group select {
  width: 100%;
  padding: 0.6rem 0.75rem;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  font-size: 0.9375rem;
  font-family: inherit;
  background: #f8fafc;
}

.page-public .form-group input:focus,
.page-public .form-group textarea:focus,
.page-public .form-group select:focus {
  outline: none;
  border-color: #335373;
  background: #fff;
}

.page-public .form-group textarea {
  min-height: 120px;
  resize: vertical;
}

.page-public .btn-submit {
  padding: 0.6rem 1.25rem;
  background: #335373;
  color: #fff;
  font-weight: 600;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.9375rem;
  transition: background 0.2s;
}

.page-public .btn-submit:hover {
  background: #2a4660;
}

.page-public .contact-email {
  margin-top: 1rem;
  font-size: 0.9375rem;
}

.page-public .contact-email a {
  color: #335373;
  text-decoration: none;
}

.page-public .contact-email a:hover {
  text-decoration: underline;
}

.page-public .alert {
  padding: 0.75rem 1rem;
  border-radius: 6px;
  margin-bottom: 1rem;
  font-size: 0.9375rem;
}

.page-public .alert-success {
  background: #dcfce7;
  color: #166534;
  border: 1px solid #bbf7d0;
}

.page-public .alert-error {
  background: #fee2e2;
  color: #991b1b;
  border: 1px solid #fecaca;
}

/* Alignement checkbox CGU (inscription) – grille 50px / auto */
.page-public .form-group--cgu .label-cgu {
  display: grid;
  grid-template-columns: 50px auto;
  gap: 0.5rem;
  font-weight: 500;
  cursor: pointer;
  margin-bottom: 40px;
}

.page-public .form-group--cgu .label-cgu input[type="checkbox"] {
  flex-shrink: 0;
  margin: 0;
}

/* Critères mot de passe (inscription) : neutre par défaut, vert / rouge selon validation */
.page-public .inscription-pwd-critere {
  color: #64748b;
}

.page-public .inscription-pwd-critere.inscription-pwd-ok {
  color: #16a34a;
}

.page-public .inscription-pwd-critere.inscription-pwd-ko {
  color: #dc2626;
}
