/* =========================================================
   APRS – Forms
   Scope : nodes de type webform (ex : AMI TRANSCEND-ID)
   ========================================================= */

/* Layout global du formulaire */
article.node--type-webform .webform-submission-form {
  max-width: 960px;
  margin: 1.5rem auto 3rem;
}

/* Items de base */
article.node--type-webform .form-item,
article.node--type-webform .js-form-item {
  margin-block: 1rem;
}

.webform-options-display-two-columns > div {
	vertical-align: top;
	display: inline;
}

/* Labels */
article.node--type-webform .js-form-item > label,
article.node--type-webform .form-item > label {
  display: block;
  margin: 0 0 .35rem;
  font-size: 1rem;
  line-height: 1.2;
  font-weight: 400;
  color: var(--col-primary);
}

/* Indication "obligatoire" */
article.node--type-webform .form-required::after,
article.node--type-webform .js-form-required::after {
  color: var(--col-accent);
  font-weight: 600;
}
article.node--type-webform .form-required::before,
article.node--type-webform .js-form-required::before {
  content: none !important;
}

/* Champs texte / select / textarea / file */
article.node--type-webform input[type="text"],
article.node--type-webform input[type="email"],
article.node--type-webform input[type="number"],
article.node--type-webform input[type="search"],
article.node--type-webform input[type="file"],
article.node--type-webform select,
article.node--type-webform textarea {
  font-family: inherit;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: .6rem .8rem;
  border-radius: .5rem;
  border: 1px solid color-mix(in srgb, var(--col-primary), transparent 80%);
  background-color: #fff;
  font-size: .95rem;
  line-height: 1.4;
  box-shadow: none;
}

/* Focus accessible */
article.node--type-webform input:focus-visible,
article.node--type-webform select:focus-visible,
article.node--type-webform textarea:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--col-secondary), white 25%);
  outline-offset: 2px;
  border-color: var(--col-secondary);
}

/* Pas de .container-inline foireux */
article.node--type-webform .form-item .container-inline {
  display: block;
}

/* Textes d'aide / descriptions */
article.node--type-webform .webform-type-webform-markup,
article.node--type-webform .webform-element-description,
article.node--type-webform small.description {
  font-size: .85rem;
  color: var(--muted);
  margin-bottom: .35rem;
}


/* =========================================================
   Fieldsets & sections
   ========================================================= */

article.node--type-webform fieldset.webform-type-fieldset {
  border: 0;
  padding: 1.5rem 0;
  margin: 2rem 0 1.5rem;
  border-top: 2px solid var(--col-secondary);
}

/* Titre de section principal */
article.node--type-webform fieldset.webform-type-fieldset > legend > .fieldset-legend {
  display: block;
  margin: 0 2rem 0 0;
  font-size: 2rem;
  line-height: 1.2;
  color: var(--col-secondary);
  font-weight: 600;
}

/* Sous-fieldsets */
article.node--type-webform fieldset.webform-type-fieldset fieldset.webform-type-fieldset {
  padding-top: 1rem;
  margin-top: 3rem;
  border-top: 1px solid color-mix(in srgb, var(--col-primary), transparent 85%);
}

article.node--type-webform fieldset.webform-type-fieldset fieldset.webform-type-fieldset > legend > .fieldset-legend {
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--col-primary);
}

/* Wrapper interne */
article.node--type-webform .fieldset-wrapper {
  margin-block-start: 0;
  padding: 0;
}

article.node--type-webform .fieldset-legend,
article.node--type-webform .fieldset__legend {
  background-color: transparent;
}


/* =========================================================
   <details>/<summary> — style "tabs" Olivero-like
   ========================================================= */

article.node--type-webform details.form-wrapper {
  margin: 1.5rem 0;
  border: 1px solid #d8dde6;
  background-color: #f7f9fc;
  border-radius: .5rem;
  overflow: hidden;
}

article.node--type-webform details.form-wrapper > summary {
  display: block;
  position: relative;
  margin: 0;
  padding: .7rem 1rem .7rem 2.4rem;
  cursor: pointer;
  list-style: none;
  font-weight: 600;
  font-size: .95rem;
  color: var(--col-primary);
  outline: none;
}

article.node--type-webform details.form-wrapper > summary::-webkit-details-marker,
article.node--type-webform details.form-wrapper > summary::marker {
  display: none;
}

article.node--type-webform details.form-wrapper > summary::before {
  content: "+";
  position: absolute;
  left: .8rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  text-align: center;
  font-weight: 700;
  color: var(--col-secondary);
}

article.node--type-webform details.form-wrapper[open] > summary::before {
  content: "–";
}

article.node--type-webform details.form-wrapper .details-wrapper {
  padding: 2rem;
  background-color: #fff;
  border-top: 1px solid #d8dde6;
}

article.node--type-webform details.form-wrapper > summary:hover {
  background-color: #edf2fa;
}

article.node--type-webform details.form-wrapper > summary:focus-visible {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--col-secondary), white 20%);
  outline: none;
  background-color: #edf2fa;
}


/* =========================================================
   Webform multiple (Porteurs, entités, publications…)
   ========================================================= */

article.node--type-webform .form-type-webform-multiple > label {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--col-primary);
  margin-bottom: .35rem;
}

/* Masquer poids & toggle poids */
article.node--type-webform .tabledrag-toggle-weight-wrapper.webform-multiple-tabledrag-toggle-weight,
article.node--type-webform .webform-multiple-table--weight {
  display: none !important;
}

/* Table */
article.node--type-webform .webform-multiple-table table {
  width: 100%;
  margin: 0;
  border-collapse: collapse;
  background: #fafafa;
  font-size: .9rem;
}

article.node--type-webform .webform-multiple-table thead th {
  display: none;
}

article.node--type-webform .webform-multiple-table tbody tr {
  border-bottom: 1px solid rgba(0,0,0,.05);
}

article.node--type-webform .webform-multiple-table td {
  padding: .4rem;
  vertical-align: middle;
}

/* Champs inside tables : full width */
article.node--type-webform .webform-multiple-table table input[type="text"],
article.node--type-webform .webform-multiple-table table input[type="email"],
article.node--type-webform .webform-multiple-table table input[type="number"],
article.node--type-webform .webform-multiple-table table input[type="search"],
article.node--type-webform .webform-multiple-table table input[type="file"],
article.node--type-webform .webform-multiple-table table select,
article.node--type-webform .webform-multiple-table table textarea {
  width: 100% !important;
  max-width: 100% !important;
  display: block;
  box-sizing: border-box;
  border-radius: .5rem;
}

/* Fieldsets internes dans les tables */
article.node--type-webform .webform-multiple-table table fieldset.form-composite {
  padding-block: 0;
  border: 0;
}

/* Boutons +/- sobres */
article.node--type-webform .webform-multiple-table--operations .image-button {
  max-width: 26px;
  padding: 2px;
}

/* Handle drag & drop centré */
article.node--type-webform .webform-multiple-table--handle {
  width: 32px;
  padding: 0;
  text-align: center;
  vertical-align: middle;
}
article.node--type-webform .webform-multiple-table--handle .tabledrag-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
article.node--type-webform .webform-multiple-table--handle .tabledrag-handle .handle {
  margin-inline: 15px 0;
}

/* Masquer l'UI "Ajouter" globale si non souhaitée */
article.node--type-webform .webform-multiple-add {
  display: none;
}
article.node--type-webform #content .section p {
  max-width: 100%;
}


/* =========================================================
   Textareas
   ========================================================= */

article.node--type-webform .webform-type-textarea .form-textarea-wrapper,
article.node--type-webform .js-webform-type-textarea .form-textarea-wrapper {
  width: 100%;
  max-width: 100%;
}

article.node--type-webform .webform-type-textarea textarea,
article.node--type-webform .js-webform-type-textarea textarea,
article.node--type-webform textarea.form-textarea {
  width: 100% !important;
  max-width: 100% !important;
  display: block;
  box-sizing: border-box;
  border-radius: .5rem;
}

article.node--type-webform .text-count-wrapper {
  display: block;
  margin-top: .25rem;
  font-size: .8rem;
  color: var(--muted);
}


/* =========================================================
   Flexbox Webform (budgets & co)
   ========================================================= */

article.node--type-webform .webform-flexbox.js-webform-flexbox {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem 1.75rem;
}

article.node--type-webform .webform-flexbox .webform-flex {
  flex: 1 1 min(260px, 100%);
}

article.node--type-webform .webform-flexbox .webform-flex--container {
  width: 100%;
}

article.node--type-webform .webform-flexbox .js-form-item input,
article.node--type-webform .webform-flexbox .js-form-item select,
article.node--type-webform .webform-flexbox .js-form-item textarea {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box;
  border-radius: .5rem;
}

article.node--type-webform .webform-flexbox .js-form-item > label {
  display: block;
  margin: 0 0 .25rem;
  font-size: .95rem;
  font-weight: 400;
  color: var(--col-primary);
}


/* =========================================================
   Champ fichier (Version PDF LI)
   ========================================================= */

article.node--type-webform .webform-type-webform-document-file,
article.node--type-webform .js-webform-type-webform-document-file {
  margin-block: 1.5rem;
}

article.node--type-webform .webform-type-webform-document-file > label,
article.node--type-webform .js-webform-type-webform-document-file > label {
  display: block;
  margin: 0 0 .4rem;
  font-size: 1rem;
  font-weight: 500;
  color: var(--col-primary);
}

article.node--type-webform .webform-document-file.form-managed-file {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem .75rem;
  width: 100%;
  max-width: 100%;
}

/* Input file */
article.node--type-webform input[type="file"].form-file {
  flex: 1 1 260px;
  max-width: 100%;
  box-sizing: border-box;
  padding: .4rem .6rem;
  font-size: .9rem;
  border-radius: .5rem;
  border: 1px solid color-mix(in srgb, var(--col-primary), transparent 80%);
  background-color: #fff;
  color: var(--col-primary);
  cursor: pointer;
}

/* Bouton natif (file) */
article.node--type-webform input[type="file"].form-file::file-selector-button,
article.node--type-webform input[type="file"].form-file::-webkit-file-upload-button {
  padding: .45rem 1rem;
  margin-right: .6rem;
  border: 0;
  border-radius: .5rem;
  background: var(--col-primary);
  color: #fff;
  font-size: .85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .03em;
  cursor: pointer;
  transition: background .18s ease-out, transform .12s ease-out, box-shadow .18s ease-out;
}

article.node--type-webform input[type="file"].form-file:hover::file-selector-button,
article.node--type-webform input[type="file"].form-file:hover::-webkit-file-upload-button {
  background: var(--col-secondary);
  box-shadow: 0 2px 5px rgba(0,0,0,.15);
  transform: translateY(-1px);
}

article.node--type-webform .webform-type-webform-document-file .webform-element-description {
  margin-top: .25rem;
  font-size: .8rem;
  color: var(--muted);
}

article.node--type-webform input[type="file"].form-file:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--col-secondary), white 25%);
  outline-offset: 2px;
  border-color: var(--col-secondary);
}


/* =========================================================
   Select stylé (WP / PS5 & autres)
   ========================================================= */

article.node--type-webform select.form-select,
article.node--type-webform select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: .6rem 2.4rem .6rem .8rem;
  background-repeat: no-repeat;
  background-position: right .9rem center;
  background-image: url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23249DC5' d='M5 7l5 6 5-6z'/%3E%3C/svg%3E");
  cursor: pointer;
}

article.node--type-webform select option[value=""] {
  color: #9aa4b2;
}

#edit-projet-numero-wp-ou-ps5 {
  font-weight: 500;
}


/* =========================================================
   Bouton Soumettre
   ========================================================= */

article.node--type-webform .webform-actions,
article.node--type-webform .form-actions {
  margin-top: 2.5rem;
  text-align: right;
}

article.node--type-webform .webform-button--submit,
article.node--type-webform .form-actions .button--primary,
article.node--type-webform .form-actions .btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  padding: .7rem 2rem;
  border: 0;
  border-radius: .5rem;
  background: var(--col-primary);
  color: #fff;
  font-size: .95rem;
  font-weight: 600;
  letter-spacing: .02em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(0,0,0,.12);
  transition: background .18s ease-out, box-shadow .18s ease-out, transform .12s ease-out;
}

article.node--type-webform .webform-button--submit:hover,
article.node--type-webform .form-actions .button--primary:hover,
article.node--type-webform .form-actions .btn-primary:hover {
  background: var(--col-secondary);
  box-shadow: 0 3px 7px rgba(0,0,0,.18);
  transform: translateY(-1px);
  text-decoration: none;
}

article.node--type-webform .webform-button--submit:focus-visible,
article.node--type-webform .form-actions .button--primary:focus-visible,
article.node--type-webform .form-actions .btn-primary:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--col-secondary), white 25%);
  outline-offset: 3px;
  box-shadow: 0 0 0 1px #fff, 0 0 0 4px color-mix(in srgb, var(--col-secondary), white 25%);
}

article.node--type-webform .webform-button--submit:disabled,
article.node--type-webform .webform-button--submit[aria-disabled="true"] {
  background: #9aa4b2;
  box-shadow: none;
  cursor: not-allowed;
  transform: none;
}
div.webform-multiple-add.js-webform-multiple-add.container-inline
 {display: none;}
/* Éviter le double astérisque sur les champs obligatoires */

/* =========================================================
   Responsive
   ========================================================= */

@media (max-width: 768px) {
  article.node--type-webform .webform-submission-form {
    margin: 1rem 0 2rem;
  }

  article.node--type-webform .webform-flexbox.js-webform-flexbox {
    gap: .75rem;
  }

  article.node--type-webform .webform-flexbox .webform-flex {
    flex: 1 1 100%;
  }

  article.node--type-webform .webform-document-file.form-managed-file {
    flex-direction: column;
    align-items: flex-start;
  }

  article.node--type-webform .webform-multiple-table table {
    font-size: .85rem;
  }
  
    /* Wrapper : respirer un peu sur mobile */
    article.node--type-webform .webform-submission-form {
      padding-inline: 1rem;
      margin: 1rem auto 2rem;
    }
  
    /* Fieldsets : un peu plus compacts */
    article.node--type-webform fieldset.webform-type-fieldset {
      margin: 1.5rem 0 1rem;
      padding: 1rem 0;
      border-top-width: 1px;
    }
  
    article.node--type-webform fieldset.webform-type-fieldset > legend > .fieldset-legend {
      font-size: 1.5rem;
      margin-right: 0;
    }
  
    /* Summary des <details> : moins massif sur petit écran */
    article.node--type-webform details.form-wrapper > summary {
      padding: .6rem .75rem .6rem 2rem;
      font-size: .9rem;
    }
  
    article.node--type-webform details.form-wrapper .details-wrapper {
      padding: 1.25rem .75rem 1.5rem;
    }
  
    /* Flexbox budgets & co : full width, bien espacés */
    article.node--type-webform .webform-flexbox.js-webform-flexbox {
      gap: .75rem;
    }
  
    article.node--type-webform .webform-flexbox .webform-flex {
      flex: 1 1 100%;
    }
  
    /* Bloc fichier : pile verticale propre */
    article.node--type-webform .webform-document-file.form-managed-file {
      flex-direction: column;
      align-items: flex-start;
    }
  
    /* Boutons d'action : centrés sur mobile */
    article.node--type-webform .webform-actions,
    article.node--type-webform .form-actions {
      text-align: center;
    }
  
    article.node--type-webform .webform-button--submit,
    article.node--type-webform .form-actions .button--primary,
    article.node--type-webform .form-actions .btn-primary {
      width: 100%;
      max-width: 260px;
      justify-content: center;
    }
  
    /* Tables webform-multiple : scroll horizontal soft si besoin */
    article.node--type-webform .webform-multiple-table .table-responsive {
      overflow-x: auto;
    }
  
    /* On évite que ça soit trop tassé */
    article.node--type-webform .webform-multiple-table td {
      padding: .35rem;
    }
}
