/* ==========================================================================
   Styles pour le Questionnaire Oksiigen Cyber (v2 - Bleu Principal + Pastels)
   ========================================================================== */

.oksiigen-questionnaire {
    box-sizing: border-box;
}

.oksiigen-questionnaire *,
.oksiigen-questionnaire *::before,
.oksiigen-questionnaire *::after {
    box-sizing: inherit;
}

/* --- Wrapper Général --- */
.oksiigen-questionnaire .questionnaire-wrapper {
    max-width: 1100px;
    /* Limite interne */
    width: 100%;
    /* Prend la largeur du conteneur parent */
    margin: 2.5em auto;
    box-sizing: border-box;
}

/* --- Boutons de Catégorie (Haut) - Style Maquette Originale --- */
.oksiigen-questionnaire .category-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 25px;
    justify-content: center;
}

.oksiigen-questionnaire .category-buttons button {
    padding: 8px 18px;
    border-width: 2px;
    /* Épaisseur normale */
    border-style: solid;
    border-radius: 20px;
    cursor: pointer;
    font-size: 0.9em;
    font-weight: 500;
    /* Normal */
    /* border-color, color, background-image sont définis par JS */
    background-color: #ffffff;
    background-image: none;
    transition: transform 0.01s ease, box-shadow 0.1s ease, border-width 0.1s ease, border-color 0.1s ease, background-image 0.2s ease-in-out, color 0.1s ease;
    position: relative;
}

.oksiigen-questionnaire .category-buttons button span {
    position: relative;
    z-index: 2;
    background: none;
    display: inline-block;
}

.oksiigen-questionnaire .category-buttons button:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
}

.oksiigen-questionnaire .category-buttons button:hover:not(.active) {
    transform: translateY(-1px);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
    filter: brightness(98%);
}


.oksiigen-questionnaire .category-buttons button.active {
    font-weight: bold;
    /* Texte en gras */
    border-width: 3px;
    /* Bordure plus épaisse */
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

/* --- Contenu Principal & Colonnes (inchangé) --- */
.oksiigen-questionnaire .main-content {
    display: flex;
    gap: 25px;
    background-color: #fff;
    padding: 25px 30px;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    border: 1px solid #f0f0f0;
}

.oksiigen-questionnaire .diagram-area {
    flex: 1 1 30%;
    order: 1;
    padding: 15px;
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
}

.oksiigen-questionnaire .dynamic-area {
    flex: 3 1 65%;
    order: 2;
    display: flex;
    flex-direction: column;
    background-color: #ffffff;
    /* Fond par défaut (sera écrasé par JS) */
    border-radius: 8px;
    /* Arrondi appliqué ici */
    padding: 25px;
    /* Padding appliqué ici */
    border: 1px solid #f0f0f0;
    /* Bordure globale légère */
    transition: background-color 0.5s ease-in-out;
    /* Transition pour le fond */
}

/* --- Diagramme (inchangé) --- */
.oksiigen-questionnaire .diagram-area h2#diagram-title {
    margin-top: 0;
    margin-bottom: 20px;
    font-size: 1.2em;
    color: #333;
    text-align: center;
    font-weight: 600;
}

.oksiigen-questionnaire .diagram-placeholder {
    width: 100%;
    /* Prend la largeur de .diagram-area */
    max-width: 300px;
    /* Limite la taille max sur Desktop */
    margin: 0 auto 20px auto;
    /* Centre */
    aspect-ratio: 1 / 1;
    /* Essaye de garder carré */
    position: relative;
    /* border: 1px dashed #dcdcdc; */
    /* Enlever la bordure placeholder */
}

.oksiigen-questionnaire .diagram-placeholder canvas {
    display: block;
    max-width: 100%;
    max-height: 100%;
    width: 100%;
    /* Important pour le responsive Chart.js */
    height: 100%;
    /* Important pour le responsive Chart.js */
}

/* --- Scores par Catégorie (inchangé) --- */
.oksiigen-questionnaire .category-scores {
    margin-top: 20px;
    padding-top: 15px;
    border-top: 1px solid #eee;
    text-align: left;
}

.oksiigen-questionnaire .category-scores h3 {
    font-size: 1.1em;
    color: #333;
    margin-bottom: 15px;
    font-weight: 600;
}

/* Pastille de couleur */
.oksiigen-questionnaire .score-category-color-dot {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%; /* Rond */
    flex-shrink: 0; /* Empêche de rétrécir */
    border: 1px solid rgba(0,0,0,0.1); /* Petite bordure discrète */
}

.oksiigen-questionnaire .score-item {
    margin-bottom: 18px;
}

.oksiigen-questionnaire .score-bar-item {
    display: flex;          /* Aligner les éléments horizontalement */
    align-items: center;    /* Centrer verticalement */
    margin-bottom: 12px;    /* Espace entre chaque ligne de catégorie */
    gap: 8px;               /* Espace entre pastille, label, et wrapper barre/pourcentage */
    font-size: 0.9em;
}

.oksiigen-questionnaire .score-bar-item label {
    /* flex-basis: 120px; */ /* Enlever si on veut que ça s'adapte */
    flex-grow: 1; /* Permet au label de prendre de la place */
    flex-shrink: 1;
    text-align: left; /* Plus de text-align: right */
    padding-right: 0;
    color: #444;
    font-weight: 500; /* Moins gras que le titre h3 */
    /* Pas de ::after avec ":" ici */
}

.oksiigen-questionnaire .score-percentage-text {
    display: inline-block; /* Pour qu'il s'affiche */
    min-width: 40px; /* Largeur minimale pour aligner (ex: "(100%)") */
    text-align: right;
    font-size: 0.9em;
    color: #555;
    font-weight: 500;
    margin-left: 5px; /* Espace après la barre */
}

.oksiigen-questionnaire .score-bar {
    flex-grow: 2;
    min-width: 100px;
    flex-basis: 150px;
    height: 14px;
    background-color: #e9ecef;
    border-radius: 6px;
    overflow: hidden;
    border: 1px solid #e0e0e0;
}

.oksiigen-questionnaire .score-bar-value {
    height: 100%;
    border-radius: 6px;
    transition: width 0.6s ease-in-out;
}

/* --- Zone de la Question --- */
.oksiigen-questionnaire .question-area {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.oksiigen-questionnaire .question-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    flex-wrap: wrap;
    gap: 10px;
}

/* Tag catégorie : Style Pastel géré par JS */
.oksiigen-questionnaire .current-category {
    padding: 6px 12px;
    border-radius: 15px;
    font-size: 0.8em;
    font-weight: bold;
    white-space: nowrap;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
    /* Optionnel : légère ombre */
}

.oksiigen-questionnaire .progress-indicator {
    font-size: 0.9em;
    color: #777;
    font-weight: 500;
    white-space: nowrap;
}

.oksiigen-questionnaire .progress-bar {
    display: none;
}

/* Caché */
.oksiigen-questionnaire .question-text {
    font-size: 1.15em;
    margin-top: 0;
    margin-bottom: 25px;
    color: #333;
    font-weight: 600;
    line-height: 1.5;
}

/* --- Options de Réponse (Highlight Bleu) --- */
.oksiigen-questionnaire .answer-options {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 30px;
}

.oksiigen-questionnaire .answer-option {
    border: 1px solid #dcdcdc;
    padding: 14px 18px;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    background-color: #fff;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
}

.oksiigen-questionnaire .answer-option:hover {
    background-color: #f9f9f9;
    border-color: #b0b0b0;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.oksiigen-questionnaire .answer-option input[type="radio"],
.oksiigen-questionnaire .answer-option input[type="checkbox"] {
    margin-right: 12px;
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    accent-color: #11b2e6;
    border: 1px solid #adb5bd;
    border-radius: 50%;
    background-color: #fff;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    position: relative;
    outline: none;
    box-shadow: none;
    transition: border-color 0.1s ease, background-color 0.1s ease;
    appearance: none;
}

/* Style quand SÉLECTIONNÉ VISUELLEMENT (classe .selected ou :checked) */
.oksiigen-questionnaire .answer-option.selected input[type="radio"],
.oksiigen-questionnaire .answer-option input[type="radio"]:checked {
    border-color: var(--current-accent-color);
    /* Utilise la variable pour la bordure */
    background-color: #fff;
    /* Garder fond blanc */
}

.oksiigen-questionnaire .answer-option.selected input[type="checkbox"],
.oksiigen-questionnaire .answer-option input[type="checkbox"]:checked {
    border-color: var(--current-accent-color);
    /* Utilise la variable pour la bordure */
    background-color: var(--current-accent-color);
    /* Utilise la variable pour le FOND de la coche */
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='M4 8l3 3 5-5'/%3e%3c/svg%3e");
    /* Coche blanche (trait un peu plus épais?) */
    background-repeat: no-repeat;
    background-position: center;
    background-size: 60%;
}

.oksiigen-questionnaire .answer-option input[type="checkbox"] {
    border-radius: 3px;
    /* Carré */
}


/* Style custom pour le POINT du RADIO */
.oksiigen-questionnaire .answer-option input[type="radio"]::before {
    content: '';
    display: block;
    width: 10px;
    height: 10px;
    /* Ajuster taille */
    border-radius: 50%;
    background-color: transparent;
    /* Transparent si non coché */
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) scale(0);
    transition: transform 0.1s ease-in-out;
}

.oksiigen-questionnaire .answer-option input[type="radio"]:checked::before {
    transform: translate(-50%, -50%) scale(1);
    /* Visible */
    background-color: var(--current-accent-color);
    /* Utilise la variable pour le point */
}

/* Style de l'option entière quand sélectionnée */
.oksiigen-questionnaire .answer-option.selected {
    border-color: var(--current-accent-color);
    /* Bordure couleur catégorie */
    background-color: var(--current-accent-color-pastel);
    /* Fond pastel catégorie */
    /* box-shadow: 0 0 0 1px var(--current-accent-color) inset; */
    /* Optionnel */
}

.oksiigen-questionnaire .answer-option.selected label {
    /* color: var(--current-accent-color); */
    /* Garder texte sombre ? */
    color: #333;
    /* Forcer texte sombre pour lisibilité sur pastel */
}

/* Enlever l'anneau de focus moche (optionnel, mais aide pour ce bug) */
.oksiigen-questionnaire .answer-option input[type="radio"]:focus,
.oksiigen-questionnaire .answer-option input[type="checkbox"]:focus {
    outline: none;
    box-shadow: 0 0 0 2px rgba(17, 178, 230, 0.2);
    /* Ou un box-shadow discret */
}

/* Assurer que les inputs NON sélectionnés n'ont PAS le style checked (même si focus?) */
.oksiigen-questionnaire .answer-option:not(.selected) input[type="radio"] {
    border-color: #adb5bd;
    background-color: #fff;
}

.oksiigen-questionnaire .answer-option:not(.selected) input[type="radio"]::before {
    background-color: #fff;
    /* Point blanc si pas sélectionné */
    transform: translate(-50%, -50%) scale(0);
    /* Assure qu'il est caché */
}

.oksiigen-questionnaire .answer-option:not(.selected) input[type="checkbox"] {
    border-color: #adb5bd;
    background-color: #fff;
    background-image: none;
    /* Pas de coche */
}

.oksiigen-questionnaire .answer-option label {
    cursor: pointer;
    flex-grow: 1;
    margin: 0;
    line-height: 1.4;
    color: #444;
}

/* --- Boutons de Navigation (Bleu + Position Fixe Droite) --- */
.oksiigen-questionnaire .navigation-buttons {
    margin-top: auto;
    /* Pousse en bas */
    display: flex;
    align-items: center;
    /* Garder l'alignement vertical */
    padding-top: 20px;
    border-top: 1px solid #f0f0f0;
    gap: 10px;
    /* Espace si les deux sont visibles */
}

.oksiigen-questionnaire .navigation-buttons button {
    padding: 10px 25px;
    border: 1px solid #dcdcdc;
    background-color: #fff;
    border-radius: 6px;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.95em;
    transition: all 0.2s ease;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
    color: #333;
}

.oksiigen-questionnaire .navigation-buttons button:hover {
    background-color: #f5f5f5;
    border-color: #b0b0b0;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
}

/* Bouton Précédent (style neutre) */
.oksiigen-questionnaire .navigation-buttons button#prev-question-btn {
    background-color: #f8f9fa;
    padding: 10px 15px;
    font-size: 1.1em;
    line-height: 1;
}

/* Boutons Suivant et Valider (Bleu) */
.oksiigen-questionnaire .navigation-buttons button#next-question-btn,
.oksiigen-questionnaire .navigation-buttons button#validate-answers-btn {
    margin-left: auto;
    color: white;
}

.oksiigen-questionnaire .navigation-buttons button#next-question-btn:hover,
.oksiigen-questionnaire .navigation-buttons button#validate-answers-btn:hover {
    filter: brightness(90%);
}

/* --- Zone Résultats / Formulaire (Focus Bleu) --- */
.oksiigen-questionnaire .results-area {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.oksiigen-questionnaire .results-header {
    text-align: center;
    margin-bottom: 30px;
}

.oksiigen-questionnaire .results-header h2 {
    margin-top: 0;
    font-size: 1.6em;
    color: #333;
    margin-bottom: 10px;
}

.oksiigen-questionnaire .results-header p {
    font-size: 1em;
    color: #555;
    max-width: 650px;
    margin: 0 auto 15px auto;
    line-height: 1.6;
}

.oksiigen-questionnaire #profile-type-display {
    font-weight: bold;
    font-size: 1.3em;
    margin-top: 20px;
}

.oksiigen-questionnaire #contact-info-form {
    max-width: 600px;
    margin: 0 2%;
    display: flex;
    align-content: center;
    flex-wrap: wrap;
}

.oksiigen-questionnaire .form-row {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 18px;
    width: 100%;
}

.oksiigen-questionnaire .form-group {
    flex: 1;
    min-width: calc(50% - 10px);
    display: flex;
    flex-direction: column;
}

.oksiigen-questionnaire .form-group label {
    margin-bottom: 6px;
    font-size: 0.85em;
    color: #555;
    font-weight: 600;
}

.oksiigen-questionnaire #profile-description-text {
    font-size: 0.8em;
    font-weight: normal;
}

.oksiigen-questionnaire .form-group input[type="text"],
.oksiigen-questionnaire .form-group input[type="email"],
.oksiigen-questionnaire .form-group input[type="tel"] {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid #ced4da;
    border-radius: 5px;
    font-size: 0.95em;
    transition: border-color 0.1s ease, box-shadow 0.1s ease;
}

/* Focus Bleu */
.oksiigen-questionnaire .form-group input:focus {
    border-color: #11b2e6;
    box-shadow: 0 0 0 2px rgba(17, 178, 230, 0.2);
    outline: none;
}

.oksiigen-questionnaire .cgu-group {
    flex-basis: 100%;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    margin-bottom: 25px;
}

.oksiigen-questionnaire .cgu-group input[type="checkbox"] {
    width: auto;
    height: auto;
    margin: 0;
    flex-shrink: 0;
}

.oksiigen-questionnaire .cgu-group label {
    margin-bottom: 0;
    font-weight: normal;
    font-size: 0.9em;
    color: #555;
    cursor: pointer;
    line-height: 1.3;
}

.oksiigen-questionnaire .g-recaptcha {
    text-align:center;
    margin-bottom: 20px;
}

.oksiigen-questionnaire .form-submit {
    min-width: 100%;
    justify-content: center;
    display: flex;
    flex-direction: column;
}

/* Bouton Submit Bleu */
.oksiigen-questionnaire .form-submit button {
    padding: 12px 35px;
    border: none;
    background-color: #11b2e6;
    color: white;
    border-radius: 6px;
    cursor: pointer;
    font-weight: bold;
    font-size: 1.05em;
    transition: background-color 0.1s ease, transform 0.1s ease;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.oksiigen-questionnaire .form-submit button:hover {
    background-color: #0d8fba;
}

.oksiigen-questionnaire .form-submit button:active {
    transform: translateY(1px);
}

/* Messages Formulaire (inchangé) */
.oksiigen-questionnaire #form-message {
    margin-top: 15px;
    padding: 10px;
    border-radius: 5px;
    font-size: 0.9em;
}

.oksiigen-questionnaire #form-message.success {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.oksiigen-questionnaire #form-message.error {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

.oksiigen-questionnaire #form-message.loading {
    background-color: #e2e3e5;
    color: #383d41;
    border: 1px solid #d6d8db;
}

.oksiigen-questionnaire .bonus-separator {
    border: none;
    border-top: 1px dashed #ccc;
    margin: 15px 0;
}

.oksiigen-questionnaire .bonus-checkbox {
    background-color: #f8f9fa;
    /* Léger fond différent */
    border-style: dashed;
    /* Bordure différente */
}

.oksiigen-questionnaire .bonus-checkbox.selected {
    border-color: #11b2e6;
    /* Bleu */
    background-color: #e7f7fe;
    /* Bleu très clair */
    box-shadow: 0 0 0 1px #11b2e6 inset;
    border-style: solid;
    /* Redevient solide si sélectionné */
}

.oksiigen-questionnaire .bonus-checkbox.selected label {
    color: #0d8fba;
    /* Bleu foncé */
}

.oksiigen-questionnaire .category-description-area {
    background-color: rgba(255, 255, 255, 0.5);
    /* Fond blanc semi-transparent */
    border: none;
    /* Pas de bordure */
    padding: 10px 15px;
    margin-top: 10px;
    margin-bottom: 15px;
    font-size: 1em;
    color: #444;
    /* Texte un peu plus foncé pour lisibilité */
    line-height: 1.5;
    border-radius: 4px;
    min-height: auto;
    font-style: normal;
}

main#content.site-main {
    /* Ou sélecteur plus précis si nécessaire */
    max-width: 1140px;
    /* Largeur max desktop */
    margin-left: auto;
    margin-right: auto;
    padding-left: 15px;
    /* Padding standard desktop */
    padding-right: 15px;
}

.oksiigen-questionnaire .score-bar-item label::after {
    content: ":";
    margin-left: 2px;
}

/* Style pour la Légende du Diagramme Radar */
.oksiigen-questionnaire .radar-legend-area {
    margin-top: 15px; /* Espace après le diagramme */
    margin-bottom: 20px; /* Espace avant les notes par catégorie */
    font-size: 0.9em; /* Plus petit que le reste */
}
.oksiigen-questionnaire .radar-legend-area ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-wrap: wrap; /* Permet plusieurs colonnes si nécessaire */
    gap: 5px 15px; /* Espace vertical et horizontal entre items */
    justify-content: center; /* Centrer les items si sur plusieurs lignes */
}
.oksiigen-questionnaire .radar-legend-area li {
    display: flex;
    align-items: center;
    /* flex-basis: 48%; */ /* Pour 2 colonnes, ajuster si besoin */
}
.oksiigen-questionnaire .legend-color-box {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 6px;
    border: 1px solid rgba(0,0,0,0.2);
    border-radius: 2px;
}
.oksiigen-questionnaire .legend-abbr {
    font-weight: bold;
    color: #333;
    margin-right: 4px;
}

.oksiigen-questionnaire .legend-name {
    color: #555;
}

.oksiigen-questionnaire .score-bar-wrapper {
    width: 100%;
}

.oksiigen-questionnaire .score-bar-item label {
    width: 80%;
}

.oksiigen-questionnaire .social-sharing-buttons {
    display: none !important;
}

.oksiigen-questionnaire .social-sharing-buttons > div {
    display: flex;
    justify-content: center;
    flex-direction: row;
}

.oksiigen-questionnaire .social-sharing-buttons > div > a {
    margin: 0 1em;
    width: 12%;
}

/* --- Point de rupture pour Tablettes (ex: < 992px) --- */
@media (max-width: 991.98px) {

    .oksiigen-questionnaire .score-bar-wrapper {
        width: 100%;
    }

    /* On garde .main-content en flex-row par défaut à cette taille */
    /* Mais on ajuste la zone des scores pour qu'elle passe en vertical */
    .oksiigen-questionnaire .score-bar-item {
        flex-wrap: wrap;
        /* Permettre le retour à la ligne */
        gap: 5px;
        /* Espace vertical réduit */
        margin-bottom: 12px;
        /* Espace entre items */
    }

    .oksiigen-questionnaire .score-bar-item label {
        flex-basis: auto; /* Le label prend sa largeur naturelle */
        flex-grow: 0; /* Ne grandit pas */
        margin-bottom: 0;
        margin-right: 5px; /* Espace avant la barre */
    }

    .oksiigen-questionnaire .score-bar-item label::after {
        display: none;
        /* Cacher les ':' */
    }

    .oksiigen-questionnaire .score-bar {
        flex-basis: 100px; /* Base réduite */
        flex-grow: 1;
    }

    /* Optionnel : Réduire un peu la taille max du diagramme ici aussi */
    .oksiigen-questionnaire .diagram-placeholder {
        max-width: 260px;
    }

    /* --- Diagramme sur Tablette --- */
    .oksiigen-questionnaire .diagram-placeholder {
        max-width: 280px;
        /* Un peu plus petit */
    }
}

/* --- Point de rupture Mobiles (ex: < 768px) --- */
/* C'est ici qu'on fait passer TOUT en colonne et qu'on gère les marges externes */
@media (max-width: 767.98px) {

    /* Forcer le conteneur du thème à prendre plus de largeur */
    body:not([class*="elementor-page"]) .site-main,
    main#content.site-main {
        max-width: none !important;
        padding-left: 10px !important;
        /* Garder un petit padding thème */
        padding-right: 10px !important;
    }

    .oksiigen-questionnaire .score-bar-item {
        flex-wrap: wrap; /* Maintenant on autorise le retour à la ligne */
        margin-bottom: 15px;
    }

    .oksiigen-questionnaire .score-category-color-dot {
        display: inline-block;
        width: 12px;
        height: 12px;
        border-radius: 50%;
        flex-shrink: 0; /* Empêche de rétrécir */
        margin-bottom: 2px;
    }

    .oksiigen-questionnaire .questionnaire-wrapper {
        width: 100%;
        padding: 0;
        margin: 1.5em auto;
        --current-accent-color: #11b2e6;
    }

    /* Passer .main-content en colonne */
    .oksiigen-questionnaire .main-content {
        flex-direction: column;
        padding: 15px;
        /* Padding interne réduit */
        gap: 15px;
        border-radius: 0;
        border-left: none;
        border-right: none;
        box-shadow: none;
    }

    .oksiigen-questionnaire .diagram-area {
        order: 1;
        padding: 10px;
        border: none;
    }

    .oksiigen-questionnaire .dynamic-area {
        order: 2;
        padding: 15px;
        border: none;
    }

    /* Zone des scores : Ajouter du padding et réduire marge item */
    .oksiigen-questionnaire .category-scores {
        padding-left: 5px;
        padding-right: 5px;
    }

    .oksiigen-questionnaire .score-item {
        margin-bottom: 15px;
    }

    .oksiigen-questionnaire .score-bar-item label {
        flex-basis: calc(100% - 20px); /* Pleine largeur moins la pastille et gap */
        margin-left: 0; /* Reset si on déplace la pastille à côté */
        text-align: left;
        font-size: 0.9em;
        margin-right: 0; /* Enlever la marge auto */
    }
    .oksiigen-questionnaire .score-bar-wrapper {
        flex-basis: 100%; /* Prend toute la largeur sous le label */
        min-width: unset;
        margin-top: 3px;
        justify-content: space-between; /* Assurer que le % est bien à droite */
    }

    .oksiigen-questionnaire .score-bar {
        flex-grow: 1;           /* La barre prend l'espace disponible dans le wrapper */
        height: 14px;
        background-color: #e9ecef;
        border: 1px solid #cccccc;
        border-radius: 7px;
        overflow: hidden;
        margin-right: 5px; /* Espace avant % */
    }

    .oksiigen-questionnaire .score-percentage-text {
        display: inline-block;
        font-size: 0.9em;
        color: #555;
        font-weight: 500;
        white-space: nowrap; /* Évite que le pourcentage passe à la ligne */
        flex-shrink: 0; /* Ne rétrécit pas */
    }

    /* Limiter taille Diagramme ENCORE PLUS sur mobile */
    .oksiigen-questionnaire .diagram-placeholder {
        max-width: 280px;
        width: 90%;
    }

    /* Formulaire : champs pleine largeur */
    .oksiigen-questionnaire .form-group {
        min-width: 100%;
    }

    .oksiigen-questionnaire .form-row {
        gap: 15px;
    }

    /* --- Diagramme sur Mobile --- */
    .oksiigen-questionnaire .diagram-placeholder {
        max-width: 260px;
        /* Encore plus petit */
        width: 90%;
        /* Limite la largeur par rapport à la colonne */
    }
}

/* --- Point de rupture Très Petits Mobiles (Optionnel < 480px) --- */
@media (max-width: 479.98px) {

    body:not([class*="elementor-page"]) .site-main,
    main#content.site-main {
        padding-left: 5px !important;
        /* Encore moins de padding thème */
        padding-right: 5px !important;
    }

    .oksiigen-questionnaire .main-content {
        padding: 5px;
    }

    .oksiigen-questionnaire .diagram-area {
        padding: 0;
    }

    .oksiigen-questionnaire .dynamic-area {
        padding: 10px;
    }

    .oksiigen-questionnaire .category-scores {
        padding-left: 0;
        padding-right: 0;
    }

    .oksiigen-questionnaire .diagram-placeholder {
        max-width: 220px;
        /* Encore plus petit */
        width: 95%;
    }

}