    .wf-step-intro h2 {
        font-family: "Karma" !important;
        font-size: 1.875rem;
        font-style: normal;
        font-weight: 400;
    }

    .wf-step {
        padding: 20px;
    }

    .input-icon {
        position: relative;
        width: 100%
    }

    .upload-container input[type="file"] {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        border: 0;
    }

    .upload-container label.upload-button {
        cursor: pointer;
        display: inline-flex;
        align-items: center;
        gap: 8px;
    }

    .wf-next.btn-disabled {
        background-color: #6c757d !important;
        border-color: #6c757d !important;
        opacity: 0.6;
        cursor: not-allowed !important;
    }

    .field-error {
        border-color: #dc3545 !important;
        background-color: #f8d7da !important;
    }

    .field-success {
        border-color: #28a745 !important;
        background-color: #d4edda !important;
    }

    .form-control {
        width: 100%;
        padding: 10px 14px;
        border: 1px solid #e5e7eb !important;
        border-radius: 6px;
        font-size: 15px;
        outline: none;
        transition: all .3s ease;
        margin-bottom: 16px;
        box-sizing: border-box
    }

    .form-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 20px;
        margin-bottom: 20px
    }

    .section-title {
        font-size: clamp(22px, 2.4vw, 28px);
        font-weight: 700;
        margin: 0 0 14px;
        color: #211B8F;
    }

    .help {
        color: #64748b;
        margin: 0 0 22px;
        font-size: 14px;
        line-height: 1.5;
    }

    fieldset {
        border: 0;
        padding: 0;
        margin: 0 0 20px;
    }

    .radios {
        display: flex;
        flex-wrap: wrap;
        gap: 18px 28px;
    }

    .radio {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        cursor: pointer;
        user-select: none;
    }

    .radio input {
        appearance: none;
        width: 18px;
        height: 18px;
        border: 2px solid #030191;
        border-radius: 50%;
        display: inline-block;
        position: relative;
    }

    .radio input:checked::before {
        content: "";
        position: absolute;
        inset: 3px;
        border-radius: 50%;
        background: #030191;
    }

    .grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 18px 24px;
    }

    .field {
        display: flex;
        flex-direction: column;
        gap: 8px;
    }

    .label {
        font-weight: 600;
        font-size: 14px;
        color: #333;
    }

    .required::after {
        content: "*";
        color: #dc3545;
        margin-left: 4px;
    }

    .input {
        display: flex;
        align-items: center;
        border: 2px solid #595959;
        border-radius: 8px;
        padding: 0;
        transition: border-color .2s, box-shadow .2s;
        height: 48px;
    }

    .input input,
    .input select {
        border: 0;
        outline: 0;
        width: 100%;
        background: transparent;
        font: inherit;
        color: inherit;
        padding: 12px;
        height: 100%;
        border-radius: 8px;
    }

    .btn {
        border: none;
        padding: 12px 16px;
        color: #fff;
        font-weight: 600;
        cursor: pointer;
        transition: opacity 0.3s;
    }

    .wf-wizard-nav {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 16px 24px;
        margin: 2rem 0;
    }

    .grid-item {
        border-radius: 4px;
        padding: 10px 16px;
        color: #fff;
        font-weight: 600;
        border: none;
        cursor: pointer;
        white-space: nowrap
    }

    .item-1 {
        grid-column: 1/2;
        grid-row: 1/2;
        background-color: #dc3545
    }

    .item-2 {
        grid-column: 2/3;
        grid-row: 1/2;
        background-color: #030191
    }

    .item-3 {
        grid-column: 4/5;
        grid-row: 1/2;
        background-color: #030191
    }

    .upload-container {
        border: 2px dashed #BFBFBF;
        border-radius: 8px;
        padding: 0.2rem;
        position: relative;
        display: flex;
        align-items: center;
        gap: 2rem;
        flex-wrap: wrap;
    }

    .upload-button {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 12px 20px;
        background-color: #030191;
        color: white;
        border-radius: 6px;
        cursor: pointer;
    }

    /* Afficher l'input natif de fichier (bouton Parcourir) au lieu du bouton personnalisé.
       On garde .file-details pour la compatibilité JS. */
    .upload-container input[type="file"].fr-upload__input,
    .upload-container input[type="file"] {
        position: static;
        width: auto;
        height: auto;
        padding: 8px 12px;
        margin: 0;
        overflow: visible;
        clip: auto;
        border: 2px solid #BFBFBF;
        border-radius: 6px;
        background: #ffffff;
    }

    /* Masquer le bouton bleu personnalisé pour n'afficher que le contrôle natif. */
    .upload-container .upload-button {
        display: none;
    }

    .upload-icon {
        width: 20px;
        height: 20px;
    }

    .upload-field {
        margin-bottom: 2rem;
    }

    .upload-info {
        display: flex;
        flex-direction: column;
        margin-top: 1rem;
        position: relative;
    }

    .toggle-info {
        display: flex;
        align-items: center;
        gap: 4px;
        background: none;
        border: none;
        color: #030191;
        cursor: pointer;
        padding: .25rem 0;
        font-size: .875rem;
        margin-top: .5rem;
    }

    .upload-requirements {
        font-size: .875rem;
        color: #64748b;
        line-height: 1.4;
        margin-top: .5rem;
        padding: .75rem;
        border-radius: 4px;
    }

    .upload-requirements[hidden] {
        display: none;
    }

    .conditional-form {
        margin-top: 24px;
        background: none !important;
        border-radius: 8px;
    }

    .conditional-upload {
        margin-left: 28px;
        margin-top: 12px;
        padding: 16px;
        border-radius: 6px;
    }

    .checkbox {
        display: flex;
        align-items: center;
        gap: 10px;
        cursor: pointer;
        user-select: none;
    }

    .checkbox input[type="checkbox"] {
        appearance: none;
        width: 18px;
        height: 18px;
        border: 2px solid #030191;
        border-radius: 4px;
        display: inline-block;
        position: relative;
        cursor: pointer;
    }

    .checkbox input[type="checkbox"]:checked::before {
        content: "✓";
        position: absolute;
        top: -2px;
        left: 2px;
        color: #030191;
        font-weight: bold;
    }

    .checkbox-field {
        margin-bottom: 20px;
    }

    .wf-step[hidden] {
        display: none !important
    }

    .wf-step.fin {
        padding: 2rem;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        border: 1px solid #BFBFBF;
        border-radius: 2px;
    }

    .wf-step.fin a.button {
        color: white;
        background-color: #211B8F;
        padding: .5rem 1rem;
        border-radius: 3px;
    }

    .accordions-section {
        border-top: 1px solid #ccc;
    }

    .accordions-content {
        display: none;
        padding: 15px;
        background: #f9f9f9;
    }

    .accordions-section.active .accordions-content {
        display: block;
    }

    .loader-overlay {
        display: none;
        position: fixed;
        inset: 0;
        z-index: 9999;
        align-items: center;
        justify-content: center;
    }

    .loader-overlay[aria-hidden="false"] {
        display: flex;
    }

    .loader-backdrop {
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, .35);
    }

    .loader-panel {
        position: relative;
        z-index: 1;
        background: #fff;
        border-radius: 10px;
        padding: 18px 22px;
        box-shadow: 0 10px 30px rgba(0, 0, 0, .2);
        display: flex;
        align-items: center;
        gap: 12px;
    }

    .spinner {
        width: 22px;
        height: 22px;
        border-radius: 50%;
        border: 3px solid #e5e7eb;
        border-top-color: #030191;
        animation: spin 0.9s linear infinite;
    }

    @keyframes spin {
        to {
            transform: rotate(360deg);
        }
    }

    .loader-text {
        margin: 0;
        font-weight: 600;
    }

    @media (max-width:720px) {

        .grid,
        .form-row {
            grid-template-columns: 1fr
        }

        .wf-wizard-nav {
            grid-template-columns: 1fr 1fr
        }

        .item-1 {
            grid-column: 1/-1
        }
    }

    .field div.note {
        margin-top: 8px;
        font-size: 12px;
        color: #595959 !important;
    }

    .legend {
        font-weight: 600;
        margin-bottom: 10px;
        color: #333;
    }

    .form-title {
        font-size: 1.4rem;
        font-weight: 600;
        margin: 32px 0 16px;
        color: var(--text-color, #222);
        letter-spacing: 1px;
        padding-bottom: 6px
    }

    .radio-group {
        display: flex;
        flex-direction: column;
        gap: 12px;
        margin-bottom: 20px;
    }

    .radio-group label {
        display: flex;
        align-items: flex-start;
        gap: 10px;
        font-weight: 500;
        cursor: pointer;
    }

    .radio-group.circle input[type="radio"] {
        appearance: none;
        width: 18px;
        height: 18px;
        border: 2px solid #030191;
        cursor: pointer;
        position: relative;
        margin-top: 3px;
        border-radius: 50%;
    }

    .radio-group.circle input[type="radio"]:checked::before {
        content: '';
        position: absolute;
        top: 3px;
        left: 3px;
        width: 9px;
        height: 9px;
        border-radius: 50%;
        background: #030191;
    }

    .field-error-message {
        color: red;
        font-size: 14px;
        margin-top: 5px;
    }

    #field-libelle-arme {
        display: none;
    }

    #section-allocation {
        display: none;
    }

    .webform-step-title {
        font-family: "Karma";
        font-size: 26px;
        font-weight: 500;
    }

    .webform-step-title::before {
        font-family: 'onacvg-icons';
        margin-right: 20px;
        font-size: 0.7em;
        line-height: 2.7rem;
    }

    .wf-step[data-step="2"] .webform-step-title::before {
        content: '\e9bb';
    }

    .wf-step[data-step="3"] .webform-step-title::before {
        content: '\e90a';
    }

    .wf-step[data-step="4"] .webform-step-title::before {
        content: '\e90e';
    }

    .wf-step[data-step="4"] .fr-upload {
        border: 1px solid #666;
        padding: 10px;
    }

    .wf-step[data-step="5"] .webform-step-title::before {
        content: '\1f5c7';
    }

    #fieldset-nature-demande {
        border-bottom: 1px solid #e0e0e0;
        margin-bottom: 40px;
        padding-bottom: 40px;
    }

    #fieldset-nature-demande legend {
        font-family: 'Montserrat', "Arial", sans-serif;
        color: #000;
        font-size: 0.6875rem;
        font-weight: 400;
        line-height: 2.2rem;
        text-transform: uppercase;
    }

    .conditional-form>legend {
        font-family: 'Karma';
        font-size: 1.375rem;
        font-weight: 500;
        line-height: 1.5625rem;
    }

    .conditional-form.fr-fieldset__content label {
        font-family: 'Montserrat', "Arial", sans-serif;
        color: #000;
        font-size: 0.6875rem;
        font-weight: 400;
        text-transform: uppercase;
    }

    .fieldset-civilite-rep {
        border: 0;
        padding: 0;
        position: relative;
        min-width: 0;
    }

    .fieldset-civilite-rep .fr-fieldset__legend {
        position: absolute !important;
        top: 50% !important;
        left: 0 !important;
        transform: translateY(-50%) !important;
        width: auto !important;
        padding: 0 !important;
        margin: 0 !important;
        font-size: 0.6875rem;
        text-transform: uppercase;
        font-weight: 400;
        white-space: nowrap;
        z-index: 1;
    }

    .fieldset-civilite-rep .fr-fieldset__content {
        font-family: "Montserrat", "Arial", sans-serif;
        font-weight: 400;
        display: flex !important;
        flex-wrap: wrap;
        align-items: center;
        gap: 0 24px;
        padding: 0 !important;
        margin: 0 !important;
        padding-left: 80px !important;
    }

    .fieldset-civilite-rep .fr-fieldset__content label {
        font-size: 0.875rem !important;
    }

    .fieldset-civilite-rep .fr-radio-group {
        margin: 0 !important;
    }

    .fieldset-civilite-rep {
        margin: 0.15rem !important;
    }

    #fieldset-distinctions {
        border-bottom: 1px solid #BABABA;
        border-top: 1px solid #BABABA;
        margin: 35px 0;
        padding: 30px 0;
    }

    .fr-upload-group .fr-upload {
        border: 1px solid #666;
        border-radius: 4px;
        padding: 1rem;
        width: 100%;
        background: #fff;
        cursor: pointer;
    }

    .fr-upload-group .fr-upload:hover,
    .fr-upload-group .fr-upload:focus {
        border-color: #000091;
        background: #f5f5fe;
    }