/* ============================================================
   forms.css — styles des formulaires de demande (concert / messe)
   Extraits de la page Concerts + ajouts pour le parcours en étapes.
   Utilise les variables globales de style.css (var(--primary), etc.).
   ============================================================ */

    /* ===================== Organisez un concert (panneau navy centré) ===================== */
    .organiser-concert {
      text-align: center;
      background: linear-gradient(150deg, var(--primary) 0%, var(--primary-mid) 100%);
      border-radius: var(--radius-lg);
      padding: 2.75rem 2rem;
      margin-bottom: 3rem;
      box-shadow: var(--shadow-md);
    }
    .organiser-concert h3 {
      color: #fff;
      font-family: 'Playfair Display', serif;
      font-size: 1.6rem; font-weight: 700; margin: 0 0 0.85rem;
    }
    .organiser-concert > p {
      color: rgba(255,255,255,0.82);
      max-width: 60ch; margin: 0 auto; line-height: 1.6;
    }
    .organiser-email { margin-top: 1.4rem !important; }
    .organiser-email a {
      display: inline-block;
      color: #fff; font-weight: 700; font-size: 1.2rem;
      text-decoration: none;
      border-bottom: 2px solid rgba(197,164,78,0.5);
      padding-bottom: 4px;
      transition: color var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
    }
    .organiser-email a:hover,
    .organiser-email a:focus-visible { color: var(--accent); border-color: var(--accent); }

    /* ===================== Formulaires de demande (concert / messe) ===================== */
    .demande-section { margin-bottom: 2.5rem; scroll-margin-top: 96px; }
    .demande-intro { text-align: center; max-width: 64ch; margin: 0 auto 1.75rem; }
    .demande-intro h3 { margin-bottom: 0.6rem; }
    .demande-intro p { color: var(--text-secondary); margin: 0 auto; }

    /* Onglets concert / messe */
    .demande-tabs {
      display: flex; gap: 0.5rem; justify-content: center;
      flex-wrap: wrap; margin-bottom: 1.75rem;
    }
    .demande-tab {
      font-family: 'Inter', sans-serif; font-size: 0.9rem; font-weight: 700;
      letter-spacing: 0.02em; cursor: pointer;
      padding: 0.7rem 1.5rem; border-radius: 50px;
      background: transparent; color: var(--primary);
      border: 1.5px solid rgba(15,29,54,0.18);
      transition: all var(--duration-fast) var(--ease);
    }
    .demande-tab:hover { border-color: var(--primary); background: rgba(15,29,54,0.04); }
    .demande-tab[aria-selected="true"] {
      background: var(--accent); color: var(--primary); border-color: var(--accent);
      box-shadow: var(--shadow-accent);
    }

    /* Carte formulaire */
    .aml-form {
      background: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      box-shadow: var(--shadow-md);
      padding: 2.25rem clamp(1.25rem, 3vw, 2.5rem);
      max-width: 760px; margin: 0 auto;
    }
    .aml-form[hidden] { display: none; }
    .aml-form .form-legend {
      font-family: 'Inter', sans-serif; font-size: 0.72rem; font-weight: 700;
      text-transform: uppercase; letter-spacing: 0.16em; color: var(--accent-ink);
      margin: 1.75rem 0 0.9rem; padding: 0; border: none;
    }
    .aml-form .form-legend:first-of-type { margin-top: 0; }
    .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.1rem; }
    .field { display: flex; flex-direction: column; gap: 0.35rem; }
    .field.col-2 { grid-column: 1 / -1; }
    .field > label, .radio-group > .group-label {
      font-family: 'Inter', sans-serif; font-size: 0.85rem; font-weight: 600;
      color: var(--primary);
    }
    .field .req { color: var(--accent-ink); }
    .field input, .field select, .field textarea {
      /* 16px minimum : empêche le zoom auto d'iOS au focus sur les champs (notamment les <select>) */
      font-family: 'Inter', sans-serif; font-size: 16px; color: var(--primary);
      background: #fff; border: 1.5px solid rgba(15,29,54,0.16);
      border-radius: var(--radius); padding: 0.7rem 0.85rem;
      transition: border-color var(--duration-fast) var(--ease), box-shadow var(--duration-fast) var(--ease);
      width: 100%;
    }
    .field textarea { resize: vertical; min-height: 90px; }
    .field input:focus, .field select:focus, .field textarea:focus {
      outline: none; border-color: var(--accent);
      box-shadow: 0 0 0 3px var(--accent-soft);
    }
    .field input[type="file"] { padding: 0.55rem; cursor: pointer; }
    .field .hint { font-size: 0.78rem; color: var(--text-muted); }
    .field.invalid input, .field.invalid select, .field.invalid textarea { border-color: #c0392b; }
    .field .err-msg { font-size: 0.78rem; color: #c0392b; display: none; }
    .field.invalid .err-msg { display: block; }

    /* Groupes radio (oui/non, forme de messe) */
    .radio-group { display: flex; flex-direction: column; gap: 0.5rem; }
    .radio-row { display: flex; flex-wrap: wrap; gap: 0.5rem 1.25rem; }
    .radio-row label {
      display: inline-flex; align-items: center; gap: 0.45rem;
      font-size: 0.92rem; color: var(--primary); cursor: pointer; font-weight: 500;
    }
    .radio-row input[type="radio"], .radio-row input[type="checkbox"] { width: auto; accent-color: var(--accent); }

    /* Honeypot anti-spam (invisible) */
    .hp-field { position: absolute; left: -9999px; top: -9999px; width: 1px; height: 1px; overflow: hidden; }

    .form-rgpd {
      font-size: 0.8rem; color: var(--text-muted); line-height: 1.5;
      margin: 1.5rem 0 1.25rem;
    }
    .form-rgpd a { color: var(--accent-ink); text-decoration: underline; text-underline-offset: 2px; }
    .form-actions { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
    .form-actions .btn[disabled] { opacity: 0.6; cursor: not-allowed; transform: none; }
    .form-status { font-size: 0.9rem; font-weight: 600; }
    .form-status.ok { color: #1e7a46; }
    .form-status.ko { color: #c0392b; }

    /* Bandeau de confirmation après envoi */
    .form-success {
      text-align: center; padding: 2.5rem 1.5rem;
      background: linear-gradient(150deg, var(--primary) 0%, var(--primary-mid) 100%);
      border-radius: var(--radius-lg); color: #fff;
      max-width: 760px; margin: 0 auto; box-shadow: var(--shadow-md);
    }
    .form-success[hidden] { display: none; }
    .form-success h3 { color: #fff; margin-bottom: 0.6rem; }
    .form-success p { color: rgba(255,255,255,0.85); max-width: 52ch; margin: 0 auto; }
    .form-success .check {
      width: 56px; height: 56px; margin: 0 auto 1rem;
      display: flex; align-items: center; justify-content: center;
      border-radius: 50%; background: rgba(197,164,78,0.18); color: var(--accent-hover);
    }
    .form-success .check svg { width: 30px; height: 30px; }

    .demande-fallback { text-align: center; margin-top: 1.5rem; font-size: 0.9rem; color: var(--text-secondary); }
    .demande-fallback a { color: var(--accent-ink); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }

    @media (max-width: 768px) {
      .form-grid { grid-template-columns: 1fr; }
    }

/* ===================== Parcours en étapes (wizard) ===================== */
.wizard-head { margin-bottom: 1.75rem; }
.wizard-progress { height: 6px; background: rgba(15,29,54,0.10); border-radius: 50px; overflow: hidden; }
.wizard-progress-bar { height: 100%; width: 0; background: var(--accent); border-radius: 50px; transition: width 0.3s var(--ease); }
.wizard-counter { margin: 0.6rem 0 0; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent-ink); }
.form-step[hidden] { display: none; }
.wizard-nav { display: flex; justify-content: space-between; gap: 1rem; margin-top: 1.75rem; flex-wrap: wrap; }
.wizard-nav .btn { min-width: 140px; }
.wizard-nav[hidden], .form-actions[hidden], .form-rgpd[hidden] { display: none; }
.wizard-saved { font-size: 0.8rem; color: var(--text-muted); margin: 0.75rem 0 0; }
.organiser-cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-top: 0.5rem; }

/* Encarts de texte (paragraphes de cadrage repris de la convention PDF) */
.form-note {
  grid-column: 1 / -1;
  background: rgba(15,29,54,0.035);
  border-left: 3px solid var(--accent);
  border-radius: 8px;
  padding: 0.85rem 1.05rem;
  font-size: 0.88rem; line-height: 1.6;
  color: var(--text-secondary);
}
.form-note strong { color: var(--primary); }
.form-note + .form-note { margin-top: -0.35rem; }

/* Ligne de secours « Un souci avec le formulaire ? » — centrée sous la carte du formulaire */
.demande-fallback { max-width: 760px; margin-left: auto; margin-right: auto; }
