.step-form, .adhesion-form {
    margin-top: 50px;
    row-gap: 20px;
}

.label-style {
    color: var(--color-navy) !important;
    font-weight: bold;
    font-family: 'Roboto';
}

.sublabel-style {
    color: var(--color-navy) !important;
    font-weight: normal;
    font-family: 'Roboto';
}

.revert-label-style {
    color: var(--color-navy);
    font-weight: normal;
    font-family: 'Roboto';
}

.input-style {
    border: solid 1px var(--color-navy) !important;
    border-radius: 10px !important;
    color: var(--color-navy);
    padding: 12px;
    height: 44px !important;
}

.input-style::placeholder {
    color: var(--color-gray-text-form);
    font-size: 17px !important;
    font-style: italic;
}

.age-container input {
    width: 6ch;
}

.post-age-text {
    margin-left: 6px;
}

.required-fields {
    font-size: 15px !important;
}

.error-container {
    margin: 10px 0;
    gap: 5px;
}

input[aria-invalid="true"] {
    border: 2px solid #b00020;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type=number] {
    -moz-appearance: textfield;
}

.form-error-message {
    color: var(--color-red-invalid-text);
}

.form-error-message:hover {
    color: var(--color-red-invalid-text);
}

.is-invalid {
    background-color: var(--color-red-invalid-bg) !important;
}

.form-check label {
    margin: 0 !important;
    font-size: 17px !important;
}

.radio-container .form-check label {
    color: var(--color-black) !important;
}

.navy-label-container .form-check label {
    color: var(--color-navy) !important;
}

.radio-container .form-check {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 0;
}

.radio-container .form-check-input {
    appearance: none;
    width: 20px;
    height: 20px;
    border: 1px solid rgba(66, 80, 102, 0.4);
    border-radius: 5000px;
    background-color: var(--color-white);
    position: relative;
    display: inline-block;
    cursor: pointer;
    margin: 0;
    flex-shrink: 0;
}

.radio-container .form-check-input::after {
    content: "";
    width: 8px;
    height: 8px;
    background-color: transparent;
    border-radius: 5000px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0);
    transition: transform 0.15s ease, background-color 0.15s ease;
}

.radio-container  .form-check-input:checked {
    background-color: var(--color-white);
}

.radio-container .form-check-input:checked::after {
    background-color: var(--color-navy);
    transform: translate(-50%, -50%) scale(1);
}

.checkbox-container .form-check {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 0;
}

.checkbox-container .form-check-input {
    appearance: none;
    width: 20px;
    height: 20px;
    border: 1px solid rgba(66, 80, 102, 0.4);
    border-radius: 5px;
    background-color: var(--color-white);
    position: relative;
    display: inline-block;
    cursor: pointer;
    margin: 0;
    flex-shrink: 0;
}

.checkbox-container .form-check-input::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("/refonte/icons/oav/icon-checked.svg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 14px;
    display: none;
}

.checkbox-container .form-check-input:checked::after {
    display: block;
}

.is-invalid.form-check-input, .is-invalid.form-check-input:checked {
    background-color: var(--color-red-invalid-bg);
}

@media (max-width: 991px) {
    .step-form {
        margin-bottom: 100px;
    }
}

.category-form {
    margin-top: 20px;
    row-gap: 30px;
}

.choice-container .form-check {
    align-items: start;
    margin-bottom: 30px;
}

.choice-container .form-check .form-check-input {
    margin-top: 1.5px;
}

.choice-container label {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.choice-title {
    color: var(--color-navy) !important;
    font-size: 17px !important;
    font-weight: bold;
}

.choice-desc {
    font-size: 16px !important;
    line-height: 19px;
}

.horizontal-choice-container {
    display: flex;
    gap: 20px;
}

.ppes-list {
    display: flex;
    gap: 10px;
    margin: 0;
}

.ppe-fields {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 20px;
    margin-right: 20px;
}

.ppe-container .form-check label, .step-form .parrainage-container .form-check label {
    color: var(--color-navy) !important;
    font-weight: bold;
}

.ppe-field {
    display: flex;
    flex-direction: column;
}

.ppe-field label {
    min-width: 180px;
    max-width: 180px;
}

.ppe-field select, .ppe-field input {
    width: 300px;
}

.ppe-field label {
    font-size: 18px !important;
    font-weight: normal;
}

.ppe-field .input-style {
    border: solid 1px var(--color-navy) !important;
    border-radius: 10px !important;
    color: var(--color-navy);
    padding: 0 8px;
    height: 32px !important;
}

.dropzone {
    border: 1px solid #3B7EA1;
    border-radius: 10px;
    padding: 20px 10px;
    background: #DDEDF2;
    cursor: pointer;
    transition: 0.2s;
    position: relative;
}

.dropzone:hover {
    border-color: #4f46e5;
    background: #f5f3ff;
}

.dropzone.dz-drag-hover {
    border-color: #22c55e;
    background: #f0fdf4;
}

.dz-message {
    text-align: center;
    color: #444;
}

.upload-icon {
    position: absolute;
    left: 20px;
    top: 0;
    bottom: 0;
    display: flex;
    align-items: center;
}

.upload-text {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.upload-title {
    font-size: 16px !important;
    font-weight: 600;
    color: var(--color-navy);
}

.upload-types {
    font-size: 14px !important;
    color: #45464F;
    font-style: italic;
}

.custom-preview {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 10px 20px;
    margin-top: 20px;
    border: 1px solid #3B7EA1;
    border-radius: 10px;
    background: var(--color-white);
}

.preview-image img {
    object-fit: cover;
}

.preview-content {
    flex: 1;
}

.preview-name {
    font-size: 16px !important;
    font-weight: 600;
    margin-bottom: 5px;
    color: var(--color-navy);
}

.preview-size {
    font-size: 14px !important;
    color: #45464F;
    font-style: italic;
}

.preview-remove {
    cursor: pointer;
    display: flex;
    gap: 5px;
}

.preview-remove > p {
    color: #DF0000;
    font-family: Roboto;
    font-size: 14px !important;
    text-decoration: underline;
}

.adhesion-pj-container {
    display: flex;
    align-items: center;
    gap: 10px;
}

.adhesion-pj-name {
    flex: 2;
}

.adhesion-pj-input {
    flex: 3;
}

.adhesion-pj-container .dropzone {
    padding: 10px 20px;
}