/* ============================================================
   FORMS.CSS — Styles réutilisables pour tous les formulaires
   Intègre les variables de base.css et étend les composants
   ============================================================ */

/* ------------------------------------------------------------
   Structure de base des formulaires
   ------------------------------------------------------------ */
.form-stack {
  max-width: var(--form-max-width, 800px);
  margin: 0 auto;
  padding: var(--space-6) 0;
}

.form-group {
  margin-bottom: var(--space-5);
}

.form-group__label {
  display: block;
  margin-bottom: var(--space-2);
  font-weight: var(--font-semi);
  color: var(--color-text);
}

.form-group__input,
.form-group__select,
.form-group__textarea {
  width: 100%;
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: var(--text-base);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-group__input:focus,
.form-group__select:focus,
.form-group__textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px var(--color-primary-bg);
}

.form-group__textarea {
  min-height: 100px;
  resize: vertical;
}

/* Champs spécifiques */
.form-group--checkbox,
.form-group--radio {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.form-group--checkbox label,
.form-group--radio label {
  margin-bottom: 0;
  cursor: pointer;
  font-weight: normal;
}

.form-group__help {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-2);
}

/* ------------------------------------------------------------
   États et validations
   ------------------------------------------------------------ */
.form-group--error .form-group__input,
.form-group--error .form-group__select,
.form-group--error .form-group__textarea {
  border-color: var(--color-danger);
}

.form-group__error-message {
  font-size: var(--text-sm);
  color: var(--color-danger);
  margin-top: var(--space-2);
}

/* ------------------------------------------------------------
   Sections et sous-titres
   ------------------------------------------------------------ */
.form-subtitle {
  font-size: var(--text-lg);
  margin: var(--space-6) 0 var(--space-4);
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
  padding-bottom: var(--space-2);
}

.form-separator {
  margin: var(--space-6) 0;
  border: none;
  border-top: 1px solid var(--color-border);
}

/* ------------------------------------------------------------
   Actions (boutons)
   ------------------------------------------------------------ */
.form-actions {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-6);
  flex-wrap: wrap;
}

.form-actions--right {
  justify-content: flex-end;
}

/* Boutons (réutilise vos classes existantes) */
.btn {
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-sm);
  font-weight: var(--font-semi);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.btn--primary {
  background: var(--color-primary);
  color: var(--color-text-on-primary);
  border: 1px solid var(--color-primary);
}

.btn--primary:hover {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
}

.btn--ghost {
  background: transparent;
  color: var(--color-primary);
  border: 1px solid transparent;
}

.btn--ghost:hover {
  background: var(--color-primary-bg);
  border-color: var(--color-border-strong);
}

/* ------------------------------------------------------------
   Champs dynamiques (ex: images/schémas)
   ------------------------------------------------------------ */
.form-section--dynamic {
  display: none;
  padding: var(--space-5);
  background: var(--color-surface-alt);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  margin-top: var(--space-4);
}

.form-section--dynamic.is-visible {
  display: block;
}

/* ------------------------------------------------------------
   Upload de fichiers
   ------------------------------------------------------------ */
.form-file-upload {
  position: relative;
  overflow: hidden;
}

.form-file-upload__input {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.form-file-upload__label {
  display: block;
  padding: var(--space-4);
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-sm);
  text-align: center;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.form-file-upload__label:hover {
  border-color: var(--color-primary);
  background: var(--color-primary-bg);
}

.form-file-upload__hint {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-2);
}

/* ------------------------------------------------------------
   Adaptations pour la Crosscall T5
   ------------------------------------------------------------ */
@media (max-width: 768px) {
  .form-group__input,
  .form-group__select,
  .form-group__textarea {
    padding: var(--space-4);
    font-size: var(--text-md);
  }

  .form-actions {
    flex-direction: column;
  }

  .btn {
    width: 100%;
    padding: var(--space-4);
  }
}

/* Cibles tactiles élargies */
@media (pointer: coarse) {
  .form-group__input,
  .form-group__select,
  .form-group__textarea,
  .btn {
    min-height: var(--touch-target);
  }
}
