/* =====================================================================
   HBI — Formulaire d'inscription. Dépend des tokens de site.css.
   ===================================================================== */

.inscription-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: start;
}

/* ---- Honeypot ---- */
/* Honeypot masqué sans décalage hors-écran (évite l'overflow horizontal mobile) */
.form-hp {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* ---- Bandeaux / confirmation ---- */
.form-banner {
  padding: 1rem 1.2rem;
  border-radius: 10px;
  font-size: var(--step-sm);
  margin-bottom: 2rem;
}
.form-banner--error { background: var(--surface-2); border: 1px solid var(--line); color: var(--ink); }

.form-confirm {
  max-width: 620px;
  padding: clamp(2rem, 5vw, 3.5rem);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-2);
}
.form-confirm h2 { font-size: var(--step-2); }
.form-confirm p { margin-top: 1rem; color: var(--ink-2); }
.form-confirm p:last-child { margin-top: 1.6rem; }

/* Les fieldsets ont un min-width:min-content par défaut -> peut déborder (ex: tableau langues).
   min-width:0 leur permet de rétrécir et de laisser les conteneurs scroller. */
.form fieldset { min-width: 0; }

/* ---- Blocs ---- */
.form-block {
  border: 0;
  padding: 0 0 clamp(1.6rem, 3vw, 2.4rem);
  margin: 0 0 clamp(1.6rem, 3vw, 2.4rem);
  border-bottom: 1px solid var(--line-soft);
}
.form-block > legend {
  font-family: var(--serif);
  font-size: var(--step-1);
  font-weight: 500;
  letter-spacing: -0.04em;
  margin-bottom: 1.2rem;
  padding: 0;
}
.form-block > legend span { color: var(--accent-2); }
.legend-note {
  font-family: var(--sans);
  font-size: var(--step-sm);
  font-weight: 400;
  letter-spacing: 0;
  color: var(--muted);
}

/* ---- Champs ---- */
.field { margin: 0 0 1rem; }
.field:last-child { margin-bottom: 0; }
.field label,
.radio-row > legend,
.check-row > legend {
  display: block;
  font-size: var(--step-sm);
  font-weight: 500;
  color: var(--ink-2);
  margin-bottom: .4rem;
}
.field label span { color: var(--accent-2); }

input[type="text"], input[type="email"], input:not([type]), textarea, select {
  width: 100%;
  min-width: 0;
  padding: .7rem .85rem;
  font: inherit;
  font-size: var(--step-sm);
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 9px;
  transition: border-color var(--t), box-shadow var(--t);
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--ink);
  box-shadow: 0 0 0 3px rgba(22,19,16,.06);
}
textarea { resize: vertical; line-height: 1.6; }

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-grid--3 { grid-template-columns: repeat(3, 1fr); }
.form-grid--2 { grid-template-columns: 1fr 1fr; }

.form-error { display: block; margin-top: .35rem; font-size: var(--step-xs); color: #9a2a1f; }

/* ---- Radios / cases ---- */
.radio-row, .check-row { border: 0; padding: 0; margin: 0 0 1rem; }
.radio-row label, .check-row label {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-right: 1.4rem;
  font-size: var(--step-sm);
  color: var(--ink);
  cursor: pointer;
}
.radio-row input, .check-row input { accent-color: var(--ink); width: auto; }

/* ---- Repeater ---- */
.repeater { display: grid; gap: .6rem; margin-bottom: .9rem; }
.repeater__row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr auto;
  gap: .5rem;
  align-items: center;
}
.repeater__row--5 { grid-template-columns: 1.3fr 1fr 1fr 1fr .8fr auto; }
.repeater__row--doc { grid-template-columns: 1fr 1.4fr auto; align-items: center; }
.repeater__row--doc input[type="file"] { font-size: var(--step-sm); min-width: 0; max-width: 100%; }
.repeater__del {
  width: 34px; height: 34px;
  border-radius: 8px;
  border: 1px solid var(--line);
  color: var(--muted);
  font-size: 1.2rem;
  line-height: 1;
  transition: background var(--t), color var(--t), border-color var(--t);
}
.repeater__del:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.btn--sm { padding: .55em 1.1em; font-size: var(--step-xs); }

/* ---- Tableau des langues ---- */
.lang-table { border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.lang-table__head, .lang-table__row {
  display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr);
  align-items: center;
}
.lang-table__head {
  background: var(--surface-2);
  font-size: var(--step-xs);
  letter-spacing: .04em;
  color: var(--muted);
  text-transform: uppercase;
}
.lang-table__head span { padding: .7rem .5rem; text-align: center; }
.lang-table__head span:first-child { text-align: left; }
.lang-table__row { border-top: 1px solid var(--line-soft); }
.lang-table__row:hover { background: var(--surface-2); }
.lang-table__name { padding: .7rem .85rem; font-size: var(--step-sm); font-weight: 500; }
.lang-table__row label { display: flex; justify-content: center; padding: .7rem .5rem; cursor: pointer; }
.lang-table__row label span { display: none; }   /* libellé de niveau (visible seulement en mobile) */
.lang-table__row input { accent-color: var(--ink); }

/* ---- Upload ---- */
input[type="file"] { font-size: var(--step-sm); min-width: 0; max-width: 100%; }
input[type="file"]::file-selector-button {
  font: inherit;
  font-size: var(--step-sm);
  padding: .5rem 1rem;
  margin-right: .8rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  cursor: pointer;
  transition: border-color var(--t);
}
input[type="file"]::file-selector-button:hover { border-color: var(--ink); }
.file-list { margin-top: .8rem; display: grid; gap: .35rem; }
.file-list li { font-size: var(--step-sm); color: var(--ink-2); display: flex; gap: .5rem; }
.file-list li::before { content: "—"; color: var(--muted); }

/* ---- Actions ---- */
.form-actions {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}
.form-note { font-size: var(--step-sm); color: var(--muted); }
.form-note span { color: var(--accent-2); }

/* ---- Carte téléchargement ---- */
.dl-card {
  position: sticky;
  top: 100px;
  padding: clamp(1.5rem, 3vw, 2rem);
  background: var(--surface-2);
  border-radius: var(--radius);
}
.dl-card h2 { font-size: var(--step-1); }
.dl-card p { margin: .9rem 0 1.3rem; font-size: var(--step-sm); color: var(--ink-2); }
.dl-card__links { display: grid; gap: .6rem; }
.dl-card .btn { width: 100%; justify-content: center; }
.dl-card__ext { opacity: .65; font-weight: 400; }
.dl-card__mail { margin-top: 1.3rem; font-size: var(--step-sm); color: var(--muted); }
.dl-card__mail a { color: var(--ink); border-bottom: 1px solid var(--line); }
.dl-card__mail a:hover { border-color: var(--accent); }

@media (max-width: 880px) {
  .inscription-layout { grid-template-columns: 1fr; }
  .dl-card { position: static; order: -1; }
}
@media (max-width: 620px) {
  .form-grid, .form-grid--3, .form-grid--2 { grid-template-columns: 1fr; }
  .repeater__row, .repeater__row--5 { grid-template-columns: 1fr 1fr; }
  .repeater__row--doc { grid-template-columns: 1fr; }
  .repeater__del { grid-column: 1 / -1; justify-self: end; }
  .lang-table { overflow: hidden; }
  .lang-table__head { display: none; }
  .lang-table__row {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem 1.4rem;
    padding: .9rem 1rem;
  }
  .lang-table__name { flex: 1 0 100%; padding: 0 0 .1rem; }
  .lang-table__row label { justify-content: flex-start; gap: .45rem; padding: 0; }
  .lang-table__row label span { display: inline; font-size: var(--step-sm); color: var(--ink-2); }
}
