/* ══════════════════════════════════════════════════════
   ASSO AGENDA — Formulaire Vue d'Ensemble
   Charte : violet #5528FF · vert #27B782 · orange #EA4E1B · crème #F8F3E0
   Typo : Rubik Dirt (titres) · Barlow Semi Condensed · Barlow
   ══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Rubik+Dirt&family=Barlow+Semi+Condensed:wght@500;600&family=Barlow:wght@400;500&display=swap');

/* ── Variables ────────────────────────────────────────── */
.ve-form-wrap {
  --ve-violet:   #5528FF;
  --ve-violet-dk:#4418e0;
  --ve-violet-bg:rgba(85,40,255,0.06);
  --ve-vert:     #27B782;
  --ve-vert-bg:  rgba(39,183,130,0.06);
  --ve-orange:   #EA4E1B;
  --ve-creme:    #F8F3E0;
  --ve-border:   rgba(0,0,0,0.12);
  --ve-border-hover: rgba(0,0,0,0.25);
  --ve-bg-field: rgba(0,0,0,0.03);
  --ve-radius:   10px;
  --ve-radius-sm:8px;
  font-family: 'Barlow', sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  color: #1a1a1a;
  max-width: 680px;
  margin: 0 auto;
  padding: 0 0 3rem;
}

/* ── Sections ─────────────────────────────────────────── */
.ve-section {
  background: #fff;
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius);
  padding: 1.5rem 1.5rem 1.25rem;
  margin-bottom: 1rem;
}

.ve-section-label {
  font-family: 'Barlow Semi Condensed', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ve-violet);
  margin: 0 0 1rem;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ve-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--ve-violet);
  opacity: 0.2;
}

/* ── Champs ───────────────────────────────────────────── */
.ve-field { margin-bottom: 1rem; }
.ve-field:last-child { margin-bottom: 0; }

.ve-label {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 13px;
  font-weight: 500;
  color: #1a1a1a;
  margin-bottom: 6px;
}
.ve-opt {
  font-size: 11px;
  font-weight: 400;
  color: #888;
}
.ve-required { color: var(--ve-orange); margin-left: 2px; }
.ve-hint {
  font-size: 12px;
  color: #777;
  margin-top: 5px;
  font-style: italic;
}
.ve-occ-label {
  font-size: 11px;
  color: #777;
  margin-bottom: 4px;
}
.ve-char-count {
  font-size: 11px;
  color: #aaa;
  text-align: right;
  margin-top: 4px;
  transition: color 0.2s;
}
.ve-char-count.warn { color: var(--ve-orange); font-weight: 500; }

.ve-form-wrap input[type="text"],
.ve-form-wrap input[type="email"],
.ve-form-wrap input[type="url"],
.ve-form-wrap input[type="date"],
.ve-form-wrap input[type="time"],
.ve-form-wrap input[type="number"],
.ve-form-wrap select,
.ve-form-wrap textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 10px 13px;
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius-sm);
  font-family: 'Barlow', sans-serif;
  font-size: 14px;
  background: var(--ve-bg-field);
  color: #1a1a1a;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.ve-form-wrap input:focus,
.ve-form-wrap select:focus,
.ve-form-wrap textarea:focus {
  border-color: var(--ve-violet);
  box-shadow: 0 0 0 3px rgba(85,40,255,0.12);
  background: #fff;
}
.ve-form-wrap textarea { resize: vertical; min-height: 90px; }
.ve-form-wrap select { appearance: auto; cursor: pointer; }

.ve-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ── Onglets date ─────────────────────────────────────── */
.ve-date-tabs { display: flex; gap: 6px; margin-bottom: 12px; }
.ve-date-tab {
  flex: 1;
  padding: 9px 10px;
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius-sm);
  background: var(--ve-bg-field);
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  cursor: pointer;
  text-align: center;
  transition: all 0.15s;
  color: #666;
  user-select: none;
}
.ve-date-tab:hover { border-color: var(--ve-violet); color: var(--ve-violet); }
.ve-date-tab.active {
  border-color: var(--ve-violet);
  background: var(--ve-violet-bg);
  color: var(--ve-violet);
  font-weight: 500;
}
.ve-date-panel { display: none; }
.ve-date-panel.visible { display: block; }

/* ── Occurrences récurrentes ──────────────────────────── */
.ve-occurrences { display: flex; flex-direction: column; gap: 10px; margin-bottom: 8px; }
.ve-occ-card {
  background: var(--ve-bg-field);
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius-sm);
  padding: 12px 14px;
}
.ve-occ-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}
.ve-occ-num {
  font-family: 'Barlow Semi Condensed', sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: var(--ve-violet);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.ve-remove-occ {
  background: none;
  border: none;
  color: #aaa;
  cursor: pointer;
  font-size: 18px;
  padding: 0 2px;
  line-height: 1;
  transition: color 0.15s;
}
.ve-remove-occ:hover { color: var(--ve-orange); }
.ve-occ-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; margin-bottom: 8px; }

.ve-add-occ {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  padding: 9px;
  border: 1px dashed var(--ve-border);
  border-radius: var(--ve-radius-sm);
  background: none;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  color: var(--ve-violet);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  box-sizing: border-box;
}
.ve-add-occ:hover { border-color: var(--ve-violet); background: var(--ve-violet-bg); }

/* ── Radios ───────────────────────────────────────────── */
.ve-radio-group { display: flex; flex-direction: column; gap: 6px; }
.ve-radio-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 13px;
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius-sm);
  cursor: pointer;
  background: var(--ve-bg-field);
  transition: border-color 0.15s, background 0.15s;
  user-select: none;
}
.ve-radio-option:hover { border-color: var(--ve-violet); }
.ve-radio-option.selected { border-color: var(--ve-violet); background: var(--ve-violet-bg); }
.ve-radio-option input[type="radio"] { accent-color: var(--ve-violet); width: 15px; height: 15px; flex-shrink: 0; margin: 0; }
.ve-radio-option label { font-size: 14px; cursor: pointer; color: #1a1a1a; }

.ve-conditional {
  margin-top: 8px;
  padding: 12px 14px;
  background: var(--ve-violet-bg);
  border-left: 2px solid var(--ve-violet);
  border-radius: 0 var(--ve-radius-sm) var(--ve-radius-sm) 0;
}
.ve-cond-label {
  font-size: 13px;
  font-weight: 500;
  color: #1a1a1a;
  margin-bottom: 6px;
}

/* ── Cases à cocher ───────────────────────────────────── */
.ve-check-solo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 13px;
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius-sm);
  cursor: pointer;
  background: var(--ve-bg-field);
  transition: border-color 0.15s, background 0.15s;
  user-select: none;
}
.ve-check-solo:hover { border-color: var(--ve-vert); }
.ve-check-solo.selected { border-color: var(--ve-vert); background: var(--ve-vert-bg); }
.ve-check-solo input[type="checkbox"] { accent-color: var(--ve-vert); width: 15px; height: 15px; flex-shrink: 0; margin: 0; }
.ve-check-solo label { font-size: 14px; cursor: pointer; color: #1a1a1a; }

/* ── Tarifs ───────────────────────────────────────────── */
.ve-tarifs-wrap { display: flex; flex-direction: column; gap: 6px; }

.ve-tarif-gratuit {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 13px;
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius-sm);
  cursor: pointer;
  background: var(--ve-bg-field);
  transition: border-color 0.15s, background 0.15s;
  user-select: none;
}
.ve-tarif-gratuit:hover { border-color: var(--ve-vert); }
.ve-tarif-gratuit.selected { border-color: var(--ve-vert); background: var(--ve-vert-bg); }
.ve-tarif-gratuit input[type="radio"] { accent-color: var(--ve-vert); width: 15px; height: 15px; margin: 0; flex-shrink: 0; }
.ve-tarif-gratuit label { font-size: 14px; cursor: pointer; color: #1a1a1a; }

.ve-tarif-payant-group { display: flex; flex-direction: column; gap: 6px; }
.ve-tarif-card {
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius-sm);
  overflow: hidden;
  background: var(--ve-bg-field);
  cursor: pointer;
  transition: border-color 0.15s;
  user-select: none;
}
.ve-tarif-card.selected { border-color: var(--ve-violet); }
.ve-tarif-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 13px;
}
.ve-tarif-card.selected .ve-tarif-card-header { background: var(--ve-violet-bg); }
.ve-tarif-card-header input[type="checkbox"] { accent-color: var(--ve-violet); width: 15px; height: 15px; margin: 0; flex-shrink: 0; }
.ve-tarif-card-header label { font-size: 14px; cursor: pointer; color: #1a1a1a; }

.ve-tarif-fields {
  display: none;
  align-items: center;
  padding: 8px 13px 10px;
  border-top: 1px solid var(--ve-border);
  gap: 0;
}
.ve-tarif-fields.visible { display: flex; }
.ve-tarif-fields input[type="number"] {
  width: 100px !important;
  border-radius: var(--ve-radius-sm) 0 0 var(--ve-radius-sm) !important;
  border-right: none !important;
  text-align: right;
}
.ve-currency-group {
  display: flex;
  border: 1px solid var(--ve-border);
  border-radius: 0 var(--ve-radius-sm) var(--ve-radius-sm) 0;
  overflow: hidden;
  flex-shrink: 0;
}
.ve-currency-opt {
  padding: 10px 13px;
  font-size: 13px;
  font-family: 'Barlow', sans-serif;
  border: none;
  background: #fff;
  cursor: pointer;
  color: #888;
  border-right: 1px solid var(--ve-border);
  transition: background 0.12s, color 0.12s;
}
.ve-currency-opt:last-child { border-right: none; }
.ve-currency-opt.active { background: var(--ve-violet); color: #fff; font-weight: 600; }

/* ── Upload image ─────────────────────────────────────── */
.ve-upload-area {
  border: 2px dashed var(--ve-border);
  border-radius: var(--ve-radius-sm);
  padding: 24px;
  text-align: center;
  cursor: pointer;
  background: var(--ve-bg-field);
  transition: border-color 0.15s;
  position: relative;
}
.ve-upload-area:hover { border-color: var(--ve-violet); }
.ve-upload-area input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
}
.ve-upload-icon {
  width: 36px;
  height: 36px;
  background: var(--ve-violet);
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 10px;
}
.ve-upload-text { font-size: 13px; color: #777; }
.ve-upload-text strong { color: var(--ve-violet); font-weight: 500; }
.ve-upload-preview { text-align: center; }
.ve-upload-preview img { max-width: 220px; max-height: 140px; border-radius: var(--ve-radius-sm); object-fit: cover; display: block; margin: 0 auto 10px; }
.ve-upload-preview button {
  background: none;
  border: 1px solid var(--ve-orange);
  color: var(--ve-orange);
  border-radius: var(--ve-radius-sm);
  padding: 5px 12px;
  font-size: 12px;
  cursor: pointer;
  font-family: 'Barlow', sans-serif;
  transition: background 0.15s;
}
.ve-upload-preview button:hover { background: rgba(234,78,27,0.08); }

/* ── Bouton submit ────────────────────────────────────── */
.ve-submit {
  width: 100%;
  padding: 15px;
  background: var(--ve-violet);
  color: #fff;
  border: none;
  border-radius: var(--ve-radius);
  font-family: 'Barlow Semi Condensed', sans-serif;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.02em;
  cursor: pointer;
  margin-top: 0.5rem;
  transition: background 0.15s, transform 0.1s;
}
.ve-submit:hover { background: var(--ve-violet-dk); }
.ve-submit:active { transform: scale(0.99); }
.ve-submit:disabled { opacity: 0.6; cursor: not-allowed; }

.ve-notice {
  font-size: 12px;
  color: #aaa;
  text-align: center;
  margin-top: 0.75rem;
}

/* ── Erreurs ──────────────────────────────────────────── */
.ve-form-errors {
  background: rgba(234,78,27,0.08);
  border: 1px solid rgba(234,78,27,0.3);
  border-radius: var(--ve-radius-sm);
  padding: 14px 18px;
  margin-bottom: 16px;
  color: #c0390e;
  font-size: 14px;
}
.ve-form-errors ul { margin: 6px 0 0 16px; padding: 0; }
.ve-form-errors li { margin: 4px 0; }

/* ── Succès ───────────────────────────────────────────── */
.ve-success-screen {
  text-align: center;
  padding: 60px 20px;
  background: #fff;
  border: 1px solid var(--ve-border);
  border-radius: var(--ve-radius);
  margin-bottom: 1rem;
}
.ve-success-icon {
  width: 60px;
  height: 60px;
  background: var(--ve-vert);
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  margin: 0 auto 20px;
}
.ve-success-screen h2 {
  font-family: 'Rubik Dirt', cursive;
  font-size: 22px;
  font-weight: 400;
  color: var(--ve-violet);
  margin: 0 0 10px;
}
.ve-success-screen p { color: #666; font-size: 15px; }

/* ── Responsive ───────────────────────────────────────── */
@media (max-width: 600px) {
  .ve-section { padding: 1.1rem 1rem 0.9rem; }
  .ve-row { grid-template-columns: 1fr; }
  .ve-occ-grid { grid-template-columns: 1fr 1fr; }
  .ve-date-tabs { flex-direction: column; }
}
