/* =========================
   FLOATING LABEL - NINJA FORMS
   ========================= */

.nf-form-cont {
    --choices-highlighted-color: var(--light);
}

.nf-form-cont .field-wrap {
    position: relative;
}

.nf-form-cont .field-wrap .nf-field-label {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    z-index: 2;
    pointer-events: none;
    margin: 0;
    transition: all .2s ease;
}

.nf-form-cont .rgpdd .field-wrap .nf-field-label {
    position: relative;
    top: auto;
    padding-left: .75rem;
    transform: none;
    pointer-events: initial;
    transform: none !important;
    top: 0 !important;
}

.nf-form-cont .rgpdd .field-wrap.is-filled .nf-field-label {
    top: 0 !important;
}

.nf-form-cont .rgpdd .field-wrap .nf-field-label .ninja-forms-req-symbol {
    display: none;
}

.nf-form-cont .field-wrap .nf-field-label label {
    display: inline-block;
    margin: 0;
    font-size: 16px;
    line-height: 1;
    transition: all .2s ease;
}

.nf-form-cont .rgpdd .field-wrap .nf-field-label label,
.nf-form-cont .rgpdd .field-wrap.is-filled .nf-field-label label,
.nf-form-cont .rgpd-text {
    font-size: 13px;
    line-height: 1.25;
    margin-top: 0rem;
    top: 0 !important;
}

.nf-form-cont .rgpd-text {
    display: block;
    padding-left: 1.5rem;
    margin-top: -.75rem;
    margin-bottom: 2rem;
}

.nf-form-cont .rgpd-text a {
    color: inherit !important;
}


.nf-form-cont .field-wrap input:not([type="submit"]):not([type="file"]),
.nf-form-cont .field-wrap textarea,
.nf-form-cont .field-wrap select {
    padding-top: 22px !important;
}

.nf-form-cont .field-wrap select option {
    color: #000 !important;
}

/* textarea : label un peu plus haut au repos */
.nf-form-cont .textarea-wrap .nf-field-label {
    top: 22px;
    transform: none;
}

/* état actif / rempli */
.nf-form-cont .field-wrap.is-active .nf-field-label,
.nf-form-cont .field-wrap.is-filled .nf-field-label {
    top: -5px;
    transform: none;
}

.nf-form-cont .field-wrap.file_upload-wrap .nf-field-label,
.nf-form-cont .field-wrap.is-active .nf-field-label label,
.nf-form-cont .field-wrap.is-filled .nf-field-label label {
    font-size: 12px;
    line-height: 1;
}

.nf-form-cont .field-wrap.file_upload-wrap .nf-field-label,
.nf-form-cont .field-wrap.file_upload-wrap .nf-fu-button-cancel {
	display: none;
}

.nf-form-cont .field-wrap.file_upload-wrap .nf-field-element {
	margin-top: 1.25rem;
}

.nf-form-cont .field-wrap.file_upload-wrap .nf-fu-progress {
    margin: 10px 0 0;
    height: 4px;
}

.nf-form-cont .field-wrap.file_upload-wrap .files_uploaded p {
    margin: .5rem 0;
}

/* select : label toujours réduit en haut, pas de transition */
.nf-form-cont .list-wrap .nf-field-label {
    top: -8px;
    transform: none;
    transition: none;
}

.nf-form-cont .list-wrap .nf-field-label label {
    font-size: 12px;
    line-height: 1;
    transition: none;
}

/* "Delete" → "Supprimer" après upload fichier */
.nf-form-cont .files_uploaded a.delete {
	font-size: 0;
}
.nf-form-cont .files_uploaded a.delete::after {
	content: 'Supprimer';
	font-size: 14px;
}

/* exclure submit et upload */
.nf-form-cont .submit-wrap .nf-field-label,
.nf-form-cont .file_upload-wrap .nf-field-label {
    position: static;
    transform: none;
    pointer-events: auto;
}


.nf-form-cont input:-webkit-autofill,
.nf-form-cont input:-webkit-autofill:hover,
.nf-form-cont input:-webkit-autofill:focus,
.nf-form-cont input:-webkit-autofill:active {
    transition: background-color 9999s, color 9999s;
}


/* =========================
   NINJA FORMS - STYLES GLOBAUX
   ========================= */

.notitle .nf-field-label,
.nf-form-wrap .nf-form-fields-required {
	display: none !important;
}

.nf-form-wrap .nf-field-label .nf-label-span,
.nf-form-wrap .nf-field-label label {
	font-weight: 400;
	font-size: 12px;
}

.nf-form-wrap .ninja-forms-req-symbol {
	color: #fff;
}

.nf-form-wrap select.ninja-forms-field.nf-element,
.nf-form-wrap input[type="text"],
.nf-form-wrap input[type="email"],
.nf-form-wrap input[type="url"],
.nf-form-wrap input[type="password"],
.nf-form-wrap input[type="search"],
.nf-form-wrap input[type="number"],
.nf-form-wrap input[type="tel"],
.nf-form-wrap input[type="range"],
.nf-form-wrap input[type="date"],
.nf-form-wrap input[type="month"],
.nf-form-wrap input[type="week"],
.nf-form-wrap input[type="time"],
.nf-form-wrap input[type="datetime"],
.nf-form-wrap input[type="datetime-local"],
.nf-form-wrap input[type="color"],
.nf-form-wrap textarea {
	color: #fff;
	border: 0 !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.6) !important;
	border-radius: 0;
	padding: 10px 0px;
	background-color: transparent;
}

.nf-form-wrap .cp input {
	max-width: 280px;
}

.nf-form-wrap select:focus,
.nf-form-wrap input:focus,
.nf-form-wrap textarea:focus {
	color: #fff !important;
	border-color: #fff !important;
}

.nf-form-wrap .nf-fu-progress {
	padding: 0;
	background: transparent !important;
	box-shadow: none !important;
}

.nf-form-wrap .nf-fu-progress .nf-fu-progress-bar {
	box-shadow: none !important;
}

.nf-form-wrap .file_upload-wrap a.delete {
	color: var(--yellow) !important;
}

.nf-form-wrap .nf-error-msg,
.nf-form-wrap .nf-error select,
.nf-form-wrap .nf-error input,
.nf-form-wrap .nf-error textarea {
	color: var(--yellow) !important;
	border-color: var(--yellow) !important;
}

.nf-form-wrap .nf-error-msg {
	font-size: 14px;
}

.nf-form-wrap .nf-after-form-content .nf-error-msg {
	font-size: 12px;
}

.nf-form-wrap select {
    background-position-x: right;
	cursor: pointer;
}


.dark .nf-form-wrap .ninja-forms-req-symbol {
	color: var(--red) !important;
}

.dark .nf-form-wrap select.ninja-forms-field.nf-element,
.dark .nf-form-wrap input[type="text"],
.dark .nf-form-wrap input[type="email"],
.dark .nf-form-wrap input[type="url"],
.dark .nf-form-wrap input[type="password"],
.dark .nf-form-wrap input[type="search"],
.dark .nf-form-wrap input[type="number"],
.dark .nf-form-wrap input[type="tel"],
.dark .nf-form-wrap input[type="range"],
.dark .nf-form-wrap input[type="date"],
.dark .nf-form-wrap input[type="month"],
.dark .nf-form-wrap input[type="week"],
.dark .nf-form-wrap input[type="time"],
.dark .nf-form-wrap input[type="datetime"],
.dark .nf-form-wrap input[type="datetime-local"],
.dark .nf-form-wrap input[type="color"],
.dark .nf-form-wrap textarea {
	color: var(--graydk) !important;
	border-bottom-color: rgba(0, 0, 0, 0.3) !important;
}

.dark .field-wrap.file_upload-wrap.textbox-wrap .btn,
.dark .field-wrap.file_upload-wrap.textbox-wrap .btn:focus {
    color: var(--gray) !important;
    border-color: var(--gray);
}

.dark .field-wrap.file_upload-wrap.textbox-wrap .btn:hover {
    background-color: var(--gray);
    color: #fff !important;
}

.dark .nf-form-wrap .file_upload-wrap a.delete,
.dark .nf-form-wrap .nf-error-msg,
.dark .nf-form-wrap .nf-error select,
.dark .nf-form-wrap .nf-error input,
.dark .nf-form-wrap .nf-error textarea {
    color: var(--red) !important;
    border-color: var(--red) !important;
}

/* =========================
   CHOICES.JS (select custom)
   Charge dynamiquement seulement si un select NF existe
   ========================= */

.nf-form-wrap .choices {
    margin-bottom: 0;
}

.nf-form-wrap .choices__inner {
    min-height: auto;
    padding: 10px 0 0 0;
    border: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.6);
    border-radius: 0;
    background: transparent;
    color: #fff;
    font-size: 16px;
}

/* Forcer l'affichage de la valeur sélectionnée (évite le rendu "vide"). */
.nf-form-wrap .choices__list--single .choices__item {
    display: block;
    width: 100%;
    line-height: 1.35;
    font-size: 16px;
    color: inherit !important;
    opacity: 1 !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.nf-form-wrap .choices[data-type*='select-one']::after {
    border-color: rgba(255, 255, 255, 0.85) transparent transparent transparent;
    margin-top: -2px;
    right: 0;
}

.nf-form-wrap .choices[data-type*='select-one'].is-open::after {
    border-color: transparent transparent rgba(255, 255, 255, 0.85) transparent;
}

.nf-form-wrap .choices__list--single {
    padding: 0 16px 6px 0;
}

.nf-form-wrap .choices__list--dropdown,
.nf-form-wrap .choices__list[aria-expanded] {
    border: 0;
    border-radius: 0 0 12px 12px;
    overflow: hidden;
    background: #fff;
}

.nf-form-wrap .choices__list--dropdown .choices__item,
.nf-form-wrap .choices__list[aria-expanded] .choices__item {
    color: #1f1f1f;
    font-size: 15px;
    padding: 10px 14px;
}

.nf-form-wrap .choices__list--dropdown .choices__item--selectable.is-highlighted,
.nf-form-wrap .choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
    background: rgba(0, 0, 0, 0.06);
}

.dark .nf-form-wrap .choices__inner {
    color: var(--graydk);
    border-bottom-color: rgba(0, 0, 0, 0.3);
}

.dark .nf-form-wrap .choices__list--single .choices__item {
    color: var(--graydk) !important;
}

.dark .nf-form-wrap .choices[data-type*='select-one']::after {
    border-color: rgba(0, 0, 0, 0.55) transparent transparent transparent;
}

.dark .nf-form-wrap .choices[data-type*='select-one'].is-open::after {
    border-color: transparent transparent rgba(0, 0, 0, 0.55) transparent;
}

/* Conflit Ninja Forms:
 * certains styles natifs font `.list-select-wrap div div { display:none; }`
 * ce qui masque le markup interne de Choices.js.
 */
.nf-form-cont .list-select-wrap .choices,
.nf-form-cont .list-select-wrap .choices div,
.nf-form-cont .list-select-wrap .choices__inner,
.nf-form-cont .list-select-wrap .choices__list,
.nf-form-cont .list-select-wrap .choices__item {
    display: block !important;
}
.nf-form-cont .list-select-wrap .choices {
    margin-top: 20px;
    min-height: 46px;
}

.nf-form-cont .list-select-wrap .choices__inner select,
.nf-form-cont .list-select-wrap .choices__list--dropdown {
    display: none !important;
    z-index: 1000;
}
.nf-form-cont .list-select-wrap .choices__list--dropdown {
    top: calc(100% + 1px);
}

.nf-form-cont .list-select-wrap .choices.is-open .choices__list--dropdown {
    display: block !important;
}



.dark .nf-form-wrap .choices__list--single .choices__item {
    color: var(--graydk) !important;
}