    [x-cloak] {
        display: none !important;
    }

    /* --rp-primary / --cabinet-accent : définis dans filament/custom-styles.blade.php */

    /* Workflow feedback — progression des étapes (styles blade inline + mode sombre) */
    html.dark .fi-feedback-workflow-progress {
        background: #1f2937 !important;
        border-color: #374151 !important;
    }

    html.dark .fi-feedback-workflow-progress-track {
        background: #4b5563 !important;
    }

    .fi-sidebar-item.fi-active > a.fi-sidebar-item-button {
        box-shadow: inset 3px 0 0 0 var(--cabinet-accent);
    }

    .fi-topbar-item-button:hover {
        color: var(--cabinet-accent);
    }

    /* Cloche — pastille compteur visible malgré overflow-x-clip de la topbar */
    body.fi-panel-admin .fi-topbar .fi-app-notification-bell {
        position: relative;
        overflow: visible !important;
        z-index: 35;
    }

    body.fi-panel-admin .fi-app-notification-bell__icon,
    body.fi-panel-admin .fi-app-notification-bell__icon svg {
        color: #94a3b8 !important;
    }

    body.fi-panel-admin .fi-app-notification-bell__trigger:hover .fi-app-notification-bell__icon,
    body.fi-panel-admin .fi-app-notification-bell__trigger:hover .fi-app-notification-bell__icon svg {
        color: var(--cabinet-accent) !important;
    }

    html.dark body.fi-panel-admin .fi-app-notification-bell__icon,
    html.dark body.fi-panel-admin .fi-app-notification-bell__icon svg {
        color: #9ca3af !important;
    }

    body.fi-panel-admin .fi-app-notification-bell__trigger .fi-app-notification-bell__badge {
        position: absolute;
        top: 0.125rem;
        right: 0.125rem;
        z-index: 10;
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        box-sizing: border-box;
        width: 1.125rem;
        height: 1.125rem;
        min-width: 1.125rem;
        max-width: 1.125rem;
        aspect-ratio: 1;
        padding: 0;
        border-radius: 9999px;
        background-color: #dc2626 !important;
        color: #ffffff !important;
        font-size: 0.625rem;
        font-weight: 700;
        line-height: 1;
        letter-spacing: -0.02em;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
        border: 1.5px solid #991b1b;
        transform: translate(20%, -20%);
        pointer-events: none;
    }

    /* 2 chiffres : cercle agrandi (carré + border-radius), pas de pastille ovale */
    body.fi-panel-admin .fi-app-notification-bell__trigger .fi-app-notification-bell__badge--wide {
        width: 1.375rem;
        height: 1.375rem;
        min-width: 1.375rem;
        max-width: 1.375rem;
        padding: 0;
        font-size: 0.5625rem;
        transform: translate(18%, -22%);
    }

    /* 99+ : cercle un peu plus grand, toujours rond */
    body.fi-panel-admin .fi-app-notification-bell__trigger .fi-app-notification-bell__badge--wider {
        width: 1.5rem;
        height: 1.5rem;
        min-width: 1.5rem;
        max-width: 1.5rem;
        padding: 0;
        font-size: 0.5rem;
        letter-spacing: -0.04em;
        transform: translate(16%, -22%);
    }

    html.dark body.fi-panel-admin .fi-app-notification-bell__trigger .fi-app-notification-bell__badge {
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.55);
        border-color: #7f1d1d;
    }

    body.fi-panel-admin .fi-app-notification-bell__trigger {
        overflow: visible !important;
    }

    /* Cloche notifications — suppression des anneaux de focus bleus */
    body.fi-panel-admin .fi-app-notification-bell__trigger {
        -webkit-tap-highlight-color: transparent;
        outline: none !important;
        box-shadow: none !important;
        --tw-ring-color: transparent !important;
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-width: 0 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    body.fi-panel-admin .fi-app-notification-bell__trigger:focus,
    body.fi-panel-admin .fi-app-notification-bell__trigger:focus-visible,
    body.fi-panel-admin .fi-app-notification-bell__trigger:active {
        outline: none !important;
        box-shadow: none !important;
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    body.fi-panel-admin .fi-app-notification-bell__mobile-link {
        display: none;
    }

    @media (pointer: coarse) {
        body.fi-panel-admin .fi-app-notification-bell__desktop-trigger {
            display: none !important;
        }

        body.fi-panel-admin .fi-app-notification-bell__mobile-link {
            display: flex !important;
        }

        body.fi-panel-admin .fi-app-notification-bell__dropdown {
            display: none !important;
        }
    }

    /* Cloche — actions par notification (marquer lue / fermer) */
    body.fi-panel-admin .fi-app-notification-bell__mark-read:hover,
    body.fi-panel-admin .fi-app-notification-bell__mark-read:focus-visible {
        color: #16a34a !important;
        background-color: #dcfce7 !important;
    }

    html.dark body.fi-panel-admin .fi-app-notification-bell__mark-read:hover,
    html.dark body.fi-panel-admin .fi-app-notification-bell__mark-read:focus-visible {
        color: #4ade80 !important;
        background-color: rgba(22, 163, 74, 0.2) !important;
    }

    body.fi-panel-admin .fi-app-notification-bell__dismiss:hover,
    body.fi-panel-admin .fi-app-notification-bell__dismiss:focus-visible {
        color: #dc2626 !important;
        background-color: #fee2e2 !important;
    }

    html.dark body.fi-panel-admin .fi-app-notification-bell__dismiss:hover,
    html.dark body.fi-panel-admin .fi-app-notification-bell__dismiss:focus-visible {
        color: #f87171 !important;
        background-color: rgba(220, 38, 38, 0.2) !important;
    }

    body.fi-panel-admin .fi-app-notification-bell__item-link {
        display: block;
        text-decoration: none;
        color: inherit;
        cursor: pointer;
    }

    body.fi-panel-admin .fi-app-notification-bell__item-link:hover p:first-child {
        color: rgb(var(--primary-600, 22 163 74));
    }

    html.dark body.fi-panel-admin .fi-app-notification-bell__item-link:hover p:first-child {
        color: rgb(var(--primary-400, 74 222 128));
    }

    body.fi-panel-admin .fi-app-notification-bell__item--acknowledged {
        opacity: 0.58;
        background: #f8fafc;
    }

    body.fi-panel-admin .fi-app-notification-bell__item--acknowledged .fi-app-notification-bell__dot {
        opacity: 0.45;
    }

    body.fi-panel-admin .fi-app-notification-bell__item--acknowledged p,
    body.fi-panel-admin .fi-app-notification-bell__item--acknowledged a,
    body.fi-panel-admin .fi-app-notification-bell__item--acknowledged .fi-notification-mission-complete-btn {
        filter: grayscale(0.35);
    }

    html.dark body.fi-panel-admin .fi-app-notification-bell__item--acknowledged {
        background: rgba(255, 255, 255, 0.04);
    }

    /* Badges dans la sidebar (compteurs navigation) : neutres/gris */
    .fi-sidebar .fi-badge,
    .fi-sidebar .fi-badge.fi-color-primary,
    .fi-sidebar .fi-badge.fi-color-success {
        background: #f1f5f9 !important;
        color: #475569 !important;
        border: 1px solid #e2e8f0 !important;
        box-shadow: none !important;
    }

    .dark .fi-sidebar .fi-badge,
    .dark .fi-sidebar .fi-badge.fi-color-primary,
    .dark .fi-sidebar .fi-badge.fi-color-success {
        background: rgba(148, 163, 184, 0.12) !important;
        color: #cbd5e1 !important;
        border-color: rgba(148, 163, 184, 0.20) !important;
    }

    /* Une seule barre de chargement : #marabu-top-progress (NProgress désactivé). */
    #nprogress {
        display: none !important;
    }

    #marabu-top-progress {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        height: 3px;
        z-index: 99999;
        pointer-events: none;
        overflow: hidden;
        opacity: 0;
        transition: opacity 0.12s ease;
    }

    #marabu-top-progress.is-active {
        opacity: 1;
    }

    #marabu-top-progress .marabu-top-progress__bar {
        height: 100%;
        width: 100%;
        transform: scaleX(0);
        transform-origin: left center;
        background: #1c494f;
        box-shadow: 0 0 10px #1c494f, 0 0 5px #1c494f;
        will-change: transform;
    }

    #marabu-top-progress .marabu-top-progress__bar.is-animated {
        transition: transform 280ms ease;
    }

    html.fi-livewire-request {
        cursor: progress;
    }

    html.fi-livewire-request .fi-layout {
        cursor: progress;
    }

    /* Filtres / barres d’outils : léger feedback local en plus de la barre du haut */
    .fi-livewire-loading,
    .fi-client-filters-bar.fi-livewire-loading,
    .fi-kanban-search-bar.fi-livewire-loading,
    .fi-mission-taches-by-phase-page.fi-livewire-loading,
    .rp-date-range-toolbar.fi-livewire-loading,
    .rp-reporting-toolbar.fi-livewire-loading,
    .rp-db-bar.fi-livewire-loading,
    .rp-reporting-toolbar--taches.fi-livewire-loading,
    .fi-lead-section-heading-row.fi-livewire-loading {
        opacity: 0.72;
        pointer-events: none;
    }

    /* Logo fichier (<img>) — même taille max connexion + topbar + sidebar */
    body.fi-panel-admin .fi-simple-header .fi-logo img,
    body.fi-panel-admin .fi-topbar .fi-logo img,
    body.fi-panel-admin .fi-sidebar-header .fi-logo img {
        width: auto !important;
        max-width: 5.5rem !important;
        height: auto !important;
        max-height: 2rem !important;
        object-fit: contain;
    }

    /* Connexion / pages auth « simple » : logo et titre centrés */
    body.fi-body.fi-panel-admin:has(.fi-simple-page) .fi-simple-header,
    body.fi-body.fi-panel-admin.fi-login-page .fi-simple-header {
        align-items: center !important;
    }

    body.fi-body.fi-panel-admin:has(.fi-simple-page) .fi-simple-header-heading,
    body.fi-body.fi-panel-admin:has(.fi-simple-page) .fi-simple-header-subheading,
    body.fi-body.fi-panel-admin.fi-login-page .fi-simple-header-heading,
    body.fi-body.fi-panel-admin.fi-login-page .fi-simple-header-subheading {
        text-align: center !important;
        width: 100%;
    }

    /* Arrière-plan personnalisé pour la page de login Filament */
    /* Utiliser :has() pour cibler le body quand il contient la page de login */
    body.fi-body.fi-panel-admin:has(.fi-simple-page) {
        background-image: url('/images/bg_marabu.png') !important;
        background-size: cover !important;
        background-position: center center !important;
        background-repeat: no-repeat !important;
        background-attachment: fixed !important;
        min-height: 100vh !important;
    }

    /* Fallback avec classe JavaScript pour les navigateurs qui ne supportent pas :has() */
    body.fi-body.fi-panel-admin.fi-login-page {
        background-image: url('/images/bg_marabu.png') !important;
        background-size: cover !important;
        background-position: center center !important;
        background-repeat: no-repeat !important;
        background-attachment: fixed !important;
        min-height: 100vh !important;
    }

    /* S'assurer que le formulaire reste visible au-dessus de l'arrière-plan */
    .fi-simple-main-content,
    .fi-simple-page {
        position: relative;
        z-index: 1;
    }

    /* Améliorer la lisibilité du formulaire de login */
    .fi-simple-main-content .fi-card,
    .fi-simple-page .fi-card {
        background: rgba(255, 255, 255, 0.95) !important;
        backdrop-filter: blur(10px);
        box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04) !important;
    }

    /* Mode sombre : ajuster l'opacité du formulaire */
    .dark .fi-simple-main-content .fi-card,
    .dark .fi-simple-page .fi-card {
        background: rgba(15, 23, 42, 0.95) !important;
    }

    /* Pipeline : pas de défilement horizontal sur le bloc */
    .fi-lead-pipeline {
        overflow-x: hidden !important;
    }

    /* Base commune (pastille + libellé) */
    .fi-lead-pipeline-btn {
        box-shadow: none !important;
        outline: none !important;
    }

    /* Pastilles : clic / survol / focus */
    .fi-lead-pipeline-btn--dot {
        cursor: pointer !important;
        transition: transform 0.15s ease, opacity 0.15s ease !important;
    }

    .fi-lead-pipeline-btn--dot:hover {
        opacity: 1 !important;
        transform: translateY(-2px) !important;
    }

    .fi-lead-pipeline-btn--dot:active {
        transform: translateY(0px) scale(0.95) !important;
        box-shadow: none !important;
        outline: none !important;
    }

    .fi-lead-pipeline-btn--dot:focus-visible {
        outline: 2px solid rgb(156 163 175) !important;
        outline-offset: 3px !important;
        border-radius: 9999px !important;
        box-shadow: none !important;
    }

    .fi-lead-pipeline-btn--dot:hover > span:first-child {
        box-shadow: none !important;
    }

    /* Libellés : pas d’effet de survol / clic visuel (le clic reste actif) */
    .fi-lead-pipeline-btn--label {
        cursor: default !important;
        transition: none !important;
    }

    .fi-lead-pipeline-btn--label:hover,
    .fi-lead-pipeline-btn--label:active {
        transform: none !important;
        opacity: 1 !important;
        box-shadow: none !important;
    }

    /* Pas d’anneau visible au clavier sur les libellés (navigation par les pastilles) */
    .fi-lead-pipeline-btn--label:focus-visible {
        outline: none !important;
        box-shadow: none !important;
    }

    .fi-pipeline-dot--pending {
        border-width: 2px !important;
        border-style: solid !important;
        border-color: rgb(209 213 219) !important;
        background-color: rgb(249 250 251) !important;
        color: rgb(107 114 128) !important;
    }

    .dark .fi-pipeline-dot--pending {
        border-color: rgb(75 85 99) !important;
        background-color: rgb(15 23 42) !important;
        color: rgb(209 213 219) !important;
    }

    /* Même rendu au survol sur la pastille uniquement */
    .fi-lead-pipeline-btn--dot:hover .fi-pipeline-dot--pending {
        border-color: rgb(209 213 219) !important;
        background-color: rgb(249 250 251) !important;
        color: rgb(107 114 128) !important;
    }

    .dark .fi-lead-pipeline-btn--dot:hover .fi-pipeline-dot--pending {
        border-color: rgb(75 85 99) !important;
        background-color: rgb(15 23 42) !important;
        color: rgb(209 213 219) !important;
    }

    .fi-lead-pipeline-btn--dot:hover span:first-child {
        filter: none !important;
        opacity: 1 !important;
    }

    .fi-lead-pipeline-dot-col {
        cursor: pointer;
    }

    .fi-lead-pipeline-label-col {
        cursor: default;
    }

    /*
     * Connecteur (trait entre pastilles) : flex-1 pour s'étirer.
     * Les marges négatives (inline Blade) le font toucher le bord des pastilles.
     */
    .fi-lead-pipeline-connector {
        box-sizing: border-box !important;
        flex: 1 1 0% !important;
        width: auto !important;
        min-width: 12px !important;
        height: 3px !important;
        min-height: 3px !important;
        max-height: 3px !important;
        align-self: center !important;
    }

    /*
     * Espaceur dans la rangée des libellés : MEME comportement flex que le connecteur
     * => les colonnes libellés restent alignées sous les pastilles, SANS marges negatives
     * (evite le chevauchement des textes).
     */
    .fi-lead-pipeline-label-gap {
        flex: 1 1 0%;
        min-width: 12px;
        flex-shrink: 0;
    }

    /* Libellés : 2 lignes max, retour a la ligne sur mots longs ou "/" */
    .fi-lead-pipeline-step-label {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        overflow: hidden;
        overflow-wrap: anywhere;
        word-break: break-word;
        text-align: center;
        font-size: 13px;
        line-height: 1.35;
        hyphens: auto;
    }

    @media (min-width: 640px) {
        .fi-lead-pipeline-step-label {
            font-size: 14px;
        }
    }

    /* Portefeuille leads — en-tête : Vue liste (gauche), Nouveau lead (centre), Import (droite) */
    .fi-leads-portfolio-page .fi-header-actions {
        display: grid;
        grid-template-columns: 1fr auto 1fr;
        align-items: center;
        width: 100%;
        max-width: 100%;
        gap: 0.75rem;
    }

    .fi-leads-portfolio-page .fi-leads-portfolio-header-start {
        justify-self: start;
        grid-column: 1;
    }

    .fi-leads-portfolio-page .fi-leads-portfolio-header-create {
        justify-self: center;
        grid-column: 2;
    }

    .fi-leads-portfolio-page .fi-leads-portfolio-header-import {
        justify-self: end;
        grid-column: 3;
    }

    /* Bouton primaire icône seule (comme Nouveau lead, sans libellé visible) */
    .fi-leads-portfolio-page .fi-leads-portfolio-header-import .fi-btn {
        font-weight: 600;
        min-width: 2.5rem;
        padding-inline: 0.75rem;
    }

    /* ============================================================
       PORTEFEUILLE CLIENTS — cartes
       ============================================================ */

    /* Grille responsive : 1 → 2 → 3 → 4 colonnes */
    .fi-clients-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
        gap: 1rem;
        width: 100%;
    }

    .fi-client-card {
        position: relative;
        z-index: 0;
        background: #fff;
        border: 1px solid #e5e7eb;
        border-radius: 0.875rem;
        box-shadow: 0 1px 3px rgba(0,0,0,0.06);
        transition: box-shadow 0.15s, transform 0.15s;
    }

    /* Menu ⋮ ouvert : la carte entière passe au-dessus des cartes voisines (grille). */
    .fi-client-card--menu-open {
        z-index: 40;
    }

    .fi-client-card--menu-open .fi-client-card-created {
        visibility: hidden;
        pointer-events: none;
    }

    .fi-client-card:hover {
        box-shadow: 0 4px 14px rgba(0,0,0,0.10);
        transform: translateY(-1px);
    }

    .fi-client-card--menu-open:hover {
        transform: translateY(-1px);
    }

    .dark .fi-client-card {
        background: #1e293b;
        border-color: #334155;
    }

    .fi-client-card-inner {
        position: relative;
        display: flex;
        align-items: stretch;
        gap: 0;
        min-width: 0;
    }

    .fi-client-card-body {
        flex: 1 1 0;
        min-width: 0;
        display: flex;
        flex-direction: column;
        gap: 0.875rem;
        padding: 1rem 0.25rem 1rem 1.125rem;
        text-decoration: none;
        color: inherit;
    }

    .fi-client-card-body:hover .fi-client-card-name {
        color: var(--client-accent, #689D71);
    }

    .dark .fi-client-card-body:hover .fi-client-card-name {
        color: color-mix(in srgb, var(--client-accent, #689D71) 82%, #ffffff);
    }

    /* Informations : Enregistrer + Annuler alignés à droite, en haut du formulaire */
    .fi-resource-informations-edit-page .fi-informations-form-toolbar {
        display: flex;
        justify-content: flex-end;
        margin-bottom: 1.5rem;
    }

    .fi-resource-informations-edit-page .fi-informations-form-toolbar .fi-form-actions {
        margin: 0;
        padding: 0;
    }

    @media (max-width: 900px) {
        /* Pages Informations lead/client : lecture mobile en pile pour éviter les champs tronqués. */
        body.fi-panel-admin .fi-resource-informations-edit-page .fi-section-content .grid,
        body.fi-panel-admin .fi-resource-informations-edit-page .fi-fo-grid,
        body.fi-panel-admin .fi-resource-clients .fi-section-content .grid,
        body.fi-panel-admin .fi-resource-clients .fi-fo-grid {
            grid-template-columns: minmax(0, 1fr) !important;
        }

        body.fi-panel-admin .fi-resource-informations-edit-page .fi-section-content .grid > *,
        body.fi-panel-admin .fi-resource-informations-edit-page .fi-fo-grid > *,
        body.fi-panel-admin .fi-resource-clients .fi-section-content .grid > *,
        body.fi-panel-admin .fi-resource-clients .fi-fo-grid > * {
            grid-column: 1 / -1 !important;
            min-width: 0 !important;
            max-width: 100% !important;
        }

        body.fi-panel-admin .fi-resource-informations-edit-page .fi-input-wrp,
        body.fi-panel-admin .fi-resource-informations-edit-page .fi-input,
        body.fi-panel-admin .fi-resource-informations-edit-page .fi-select-input,
        body.fi-panel-admin .fi-resource-informations-edit-page .fi-textarea,
        body.fi-panel-admin .fi-resource-clients .fi-input-wrp,
        body.fi-panel-admin .fi-resource-clients .fi-input,
        body.fi-panel-admin .fi-resource-clients .fi-select-input,
        body.fi-panel-admin .fi-resource-clients .fi-textarea {
            width: 100% !important;
            max-width: 100% !important;
        }
    }

    /* Pages Informations lead/client : spinner visible sur Modifier, Annuler, contacts… */
    .fi-resource-edit-record-page .fi-ac-btn-action .fi-loading-indicator,
    .fi-client-contacts-repeater .fi-loading-indicator,
    .fi-client-contacts-repeater .fi-icon-btn .fi-loading-indicator {
        display: inline-flex;
    }

    .fi-client-card-menu {
        position: relative;
        z-index: 3;
        flex-shrink: 0;
        padding: 0.5rem 0.625rem 0.5rem 0;
        align-self: flex-start;
    }

    .fi-client-card-menu-trigger {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 2rem;
        height: 2rem;
        border: none;
        border-radius: 0.5rem;
        background: transparent;
        color: #9ca3af;
        cursor: pointer;
        transition: background 0.15s, color 0.15s;
    }

    .fi-client-card-menu-trigger:hover {
        background: #f3f4f6;
        color: #374151;
    }

    .dark .fi-client-card-menu-trigger:hover {
        background: #334155;
        color: #e2e8f0;
    }

    .fi-client-card-dropdown {
        position: absolute;
        top: 100%;
        right: 0;
        margin-top: 0.25rem;
        min-width: 12.5rem;
        padding: 0.375rem;
        background-color: #ffffff;
        background-clip: padding-box;
        border: 1px solid #e5e7eb;
        border-radius: 0.625rem;
        box-shadow: 0 12px 28px rgba(15, 23, 42, 0.16);
        z-index: 10;
        opacity: 1;
        isolation: isolate;
        overflow: hidden;
        pointer-events: auto;
    }

    /* Menus ⋮ autonomes (lignes tâches, toolbar colonnes) : z-index comme les cartes. */
    .fi-card-action-menu--open {
        position: relative;
        z-index: 40;
    }

    .fi-card-action-menu--open .fi-client-card-dropdown {
        z-index: 50;
    }

    /* Table repeater tâches par phase : le menu ne doit pas être rogné par overflow. */
    body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-container,
    body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component table tbody tr {
        overflow: visible;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component table tbody td {
        position: relative;
        overflow: visible;
    }

    @media (max-width: 1024px) {
        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg table {
            display: block;
            width: 100%;
        }

        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg thead {
            position: absolute !important;
            width: 1px !important;
            height: 1px !important;
            padding: 0 !important;
            margin: -1px !important;
            overflow: hidden !important;
            clip: rect(0, 0, 0, 0) !important;
            white-space: nowrap !important;
            border-width: 0 !important;
        }

        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg tbody,
        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg th,
        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg td {
            display: block;
            width: 100% !important;
        }

        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .table-repeater-row {
            display: flex;
            flex-direction: column;
            gap: 0.875rem;
            width: 100% !important;
            padding: 1rem;
            background: #ffffff;
            border-bottom: 1px solid #e5e7eb;
        }

        .dark body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .table-repeater-row {
            background: #111827;
            border-bottom-color: #374151;
        }

        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .table-repeater-column {
            padding: 0 !important;
            min-width: 0;
            max-width: 100%;
        }

        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .table-repeater-column.has-hidden-label .fi-fo-field-wrp > label {
            position: static !important;
            width: auto !important;
            height: auto !important;
            margin: 0 0 0.35rem !important;
            padding: 0 !important;
            overflow: visible !important;
            clip: auto !important;
            white-space: normal !important;
            font-size: 0.75rem;
            font-weight: 600;
            color: #64748b;
        }

        .dark body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .table-repeater-column.has-hidden-label .fi-fo-field-wrp > label {
            color: #94a3b8;
        }

        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .fi-fo-field-wrp,
        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .fi-input-wrp,
        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .fi-input,
        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .fi-select-input {
            width: 100% !important;
            max-width: 100% !important;
            min-width: 0 !important;
        }

        body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component.break-point-lg .table-repeater-row-actions {
            justify-content: flex-end;
            padding-left: 0;
            padding-right: 0;
            gap: 0.5rem;
        }
    }

    /* Ligne avec menu ouvert : au-dessus des ⋮ des autres lignes (comme fi-lead-mission-row--menu-open). */
    body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component tbody tr:has(.fi-card-action-menu--open) {
        position: relative;
        z-index: 40;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-component:has(.fi-card-action-menu--open) .fi-client-card-menu:not(.fi-card-action-menu--open) .fi-client-card-menu-trigger {
        visibility: hidden;
    }

    .fi-tache-row-options-menu.fi-client-card-menu {
        position: relative;
        z-index: 3;
        padding: 0;
        align-self: center;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-row-actions {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        gap: 0.5rem;
        margin: 0;
        padding: 0;
        list-style: none;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .table-repeater-row-actions > li {
        display: flex;
        align-items: center;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-tache-row-options-action {
        display: inline-flex;
        align-items: center;
        margin: 0;
        padding: 0;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-tache-row-options-action > * {
        margin: 0;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-card-action-menu--open .fi-client-card-dropdown {
        z-index: 50;
        background-color: #ffffff !important;
        opacity: 1 !important;
        box-shadow: 0 12px 28px rgba(15, 23, 42, 0.16);
    }

    .dark body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-card-action-menu--open .fi-client-card-dropdown {
        background-color: #1e293b !important;
    }

    /* Survol des entrées (même rendu que portefeuille leads / cartes). */
    body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-card-action-menu--open .fi-client-card-dropdown-item {
        background-color: transparent;
        transition: background-color 0.15s ease, color 0.15s ease;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-card-action-menu--open .fi-client-card-dropdown-item:hover {
        background-color: #f3f4f6;
    }

    .dark body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-card-action-menu--open .fi-client-card-dropdown-item:hover {
        background-color: #334155;
    }

    body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-card-action-menu--open .fi-client-card-dropdown-item--danger:hover {
        background-color: #fef2f2;
        color: #b91c1c;
    }

    .dark body.fi-panel-admin .fi-mission-taches-by-phase-page .fi-card-action-menu--open .fi-client-card-dropdown-item--danger:hover {
        background-color: rgba(127, 29, 29, 0.35);
        color: #f87171;
    }

    .fi-mission-phase-columns-toolbar {
        display: flex;
        justify-content: flex-end;
        margin-bottom: 0.75rem;
    }

    .fi-mission-phase-columns-menu.fi-client-card-menu {
        padding: 0;
        align-self: center;
    }

    .fi-mission-phase-columns-dropdown.fi-client-card-dropdown {
        min-width: 11rem;
        z-index: 50;
    }

    .fi-mission-phase-columns-option {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        padding: 0.5rem 0.625rem;
        font-size: 0.8125rem;
        color: #374151;
        border-radius: 0.375rem;
        cursor: pointer;
    }

    .fi-mission-phase-columns-option:hover {
        background: #f3f4f6;
    }

    .dark .fi-mission-phase-columns-option {
        color: #e2e8f0;
    }

    .dark .fi-mission-phase-columns-option:hover {
        background: #334155;
    }

    .fi-mission-phase-columns-checkbox {
        width: 1rem;
        height: 1rem;
        accent-color: #64748b;
    }

    .dark .fi-client-card-dropdown {
        background: #1e293b;
        border-color: #475569;
    }

    .fi-client-card-dropdown-item {
        display: block;
        width: 100%;
        padding: 0.5rem 0.625rem;
        font-size: 0.8125rem;
        color: #374151;
        text-decoration: none;
        border-radius: 0.375rem;
        border: none;
        background: transparent;
        text-align: left;
        cursor: pointer;
        font-family: inherit;
        transition: background-color 0.15s ease, color 0.15s ease;
    }

    .fi-client-card-dropdown-item:hover {
        background: #f3f4f6;
    }

    .dark .fi-client-card-dropdown-item {
        color: #e2e8f0;
    }

    .dark .fi-client-card-dropdown-item:hover {
        background: #334155;
    }

    .fi-client-card-dropdown-item--btn.fi-client-card-dropdown-item--warning {
        color: #b45309;
    }

    .dark .fi-client-card-dropdown-item--btn.fi-client-card-dropdown-item--warning {
        color: #fbbf24;
    }

    .fi-client-card-dropdown-item--btn.fi-client-card-dropdown-item--danger {
        color: #b91c1c;
    }

    .dark .fi-client-card-dropdown-item--btn.fi-client-card-dropdown-item--danger {
        color: #f87171;
    }

    .fi-client-card-header {
        display: flex;
        align-items: flex-start;
        gap: 0.75rem;
        width: 100%;
        min-width: 0;
        max-width: 100%;
    }

    .fi-client-avatar {
        flex-shrink: 0;
        width: 2.5rem;
        height: 2.5rem;
        border-radius: 0.5rem;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 0.8125rem;
        font-weight: 700;
        letter-spacing: 0.02em;
        color: #fff;
    }

    .fi-client-card-title {
        flex: 1 1 auto;
        min-width: 0;
        max-width: 100%;
        overflow: hidden;
    }

    .fi-client-card-name {
        font-size: 0.9375rem;
        font-weight: 600;
        color: #111827;
        line-height: 1.3;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        margin: 0;
        width: 100%;
        min-width: 0;
    }

    .dark .fi-client-card-name { color: #f1f5f9; }

    .fi-client-card-meta {
        font-size: 0.75rem;
        color: #6b7280;
        margin-top: 0.125rem;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .fi-client-card-footer {
        display: flex;
        align-items: flex-end;
        justify-content: flex-start;
        gap: 0.75rem;
        width: 100%;
        padding-top: 0.5rem;
        padding-right: 0;
        border-top: 1px solid #f3f4f6;
    }

    .dark .fi-client-card-footer { border-color: #334155; }

    /* Colonne droite fixe : bouton ⋮ calé à droite ; date en bas sans élargir la zone du titre */
    .fi-client-card-rail {
        flex: 0 0 2.75rem;
        width: 2.75rem;
        display: flex;
        flex-direction: column;
        align-items: flex-end;
        align-self: stretch;
        padding: 0.5rem 0.5rem 1rem 0;
        z-index: 2;
    }

    .fi-client-card-rail .fi-client-card-menu {
        padding: 0;
        flex-shrink: 0;
        margin-left: auto;
    }

    /* Même retrait horizontal que le corps de carte (padding-left 1.125rem) */
    .fi-client-card-inner > .fi-client-card-rail .fi-client-card-created {
        position: absolute;
        right: 1.125rem;
        bottom: 1rem;
        margin: 0;
        text-align: right;
        white-space: nowrap;
        z-index: 0;
        pointer-events: none;
    }

    .fi-client-card-stat {
        display: flex;
        flex-direction: column;
        gap: 0.05rem;
    }

    .fi-client-stat-value {
        font-size: 0.875rem;
        font-weight: 700;
        color: #111827;
        line-height: 1.2;
    }

    .dark .fi-client-stat-value { color: #f1f5f9; }

    .fi-client-stat-label {
        font-size: 0.6875rem;
        font-weight: 700;
        color: #111827;
        line-height: 1.2;
    }

    .dark .fi-client-stat-label {
        color: #f1f5f9;
    }

    .fi-client-card-created {
        display: inline-flex;
        align-items: baseline;
        gap: 0.35rem;
        flex-shrink: 0;
    }

    .fi-client-card-created-label,
    .fi-client-card-created-value {
        font-size: 0.6875rem;
        font-weight: 400;
        color: #9ca3af;
        line-height: 1.2;
    }

    /* Rail étroit : évite la coupure « Créé » / « le » sur deux lignes */
    .fi-client-card-created-label {
        white-space: nowrap;
    }

    .fi-client-card-created-value {
        font-style: italic;
    }

    .dark .fi-client-card-created-label,
    .dark .fi-client-card-created-value {
        color: #94a3b8;
    }

    /* Filtres portefeuille clients — barre unique alignée */
    .fi-client-filters-bar {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem;
        margin-bottom: 1.25rem;
    }

    .fi-client-filter-select {
        display: inline-block;
        height: 2.375rem;
        padding: 0 2.25rem 0 0.75rem;
        border-radius: 0.5rem;
        border: 1.5px solid #e2e8f0;
        background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 0.75rem center / 1rem;
        font-size: 0.8125rem;
        color: #374151;
        appearance: none;
        -webkit-appearance: none;
        cursor: pointer;
        box-shadow: 0 1px 3px rgba(0,0,0,0.05);
        white-space: nowrap;
        /* Comme le select statut sujet : pas d’étirement arbitraire dans les barres flex */
        width: max-content;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }

    @supports (field-sizing: content) {
        .fi-client-filter-select {
            field-sizing: content;
            width: auto;
            max-width: 100%;
        }
    }

    .fi-client-filter-select:focus {
        outline: none;
        border-color: #689D71;
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    .dark .fi-client-filter-select {
        background-color: #1e293b;
        border-color: #334155;
        color: #f1f5f9;
    }

    .dark .fi-client-filter-select:focus {
        border-color: #689D71;
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    .fi-client-filter-reset {
        height: 2.375rem;
        padding: 0 0.875rem;
        border-radius: 0.5rem;
        border: 1.5px solid #e2e8f0;
        background: #f8fafc;
        font-size: 0.8125rem;
        color: #64748b;
        cursor: pointer;
        box-shadow: 0 1px 2px rgba(0,0,0,0.04);
        transition: background 0.1s;
        white-space: nowrap;
    }

    .fi-client-filter-reset:hover {
        background: #f1f5f9;
        color: #475569;
    }

    .fi-client-filter-reset:focus,
    .fi-client-filter-reset:focus-visible {
        outline: none;
        border-color: #689D71;
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    .dark .fi-client-filter-reset {
        background: #0f172a;
        border-color: #334155;
        color: #94a3b8;
    }

    .dark .fi-client-filter-reset:focus,
    .dark .fi-client-filter-reset:focus-visible {
        outline: none;
        border-color: #689D71;
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    /* ============================================================
       KANBAN LEADS — styles
       ============================================================ */

    /* Barre de recherche Kanban */
    .fi-kanban-search-bar {
        margin-bottom: 1.25rem;
    }

    .fi-kanban-search-inner {
        position: relative;
        display: flex;
        align-items: center;
        max-width: 28rem;
        background: #fff;
        border: 1.5px solid #e2e8f0;
        border-radius: 9999px;
        padding: 0 1rem;
        box-shadow: 0 1px 4px rgba(0,0,0,0.06);
        transition: border-color 0.15s, box-shadow 0.15s;
    }

    .fi-kanban-search-inner:focus-within {
        border-color: #cbd5e1;
        box-shadow: 0 2px 10px rgba(0,0,0,0.08);
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    .dark .fi-kanban-search-inner {
        background: #1e293b;
        border-color: #334155;
    }

    .dark .fi-kanban-search-inner:focus-within {
        border-color: #475569;
        box-shadow: 0 2px 10px rgba(0,0,0,0.35);
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    .fi-kanban-search-icon {
        width: 1rem;
        height: 1rem;
        color: #94a3b8;
        flex-shrink: 0;
        margin-right: 0.5rem;
    }

    .fi-kanban-search-input {
        flex: 1;
        border: none;
        outline: none;
        background: transparent;
        font-size: 0.875rem;
        color: #1e293b;
        padding: 0.6rem 0;
    }

    /* Neutraliser les styles focus globaux (ring/outline Filament/Tailwind) */
    .fi-kanban-search-input:focus,
    .fi-kanban-search-input:focus-visible {
        outline: none !important;
        box-shadow: none !important;
        --tw-ring-shadow: 0 0 #0000 !important;
        --tw-ring-offset-shadow: 0 0 #0000 !important;
    }

    .fi-kanban-search-input::placeholder {
        color: #94a3b8;
    }

    .dark .fi-kanban-search-input {
        color: #f1f5f9;
    }

    .fi-kanban-search-clear {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 1.25rem;
        height: 1.25rem;
        border-radius: 9999px;
        background: #e2e8f0;
        color: #64748b;
        border: none;
        cursor: pointer;
        margin-left: 0.5rem;
        flex-shrink: 0;
        transition: background 0.1s;
    }

    .fi-kanban-search-clear:hover {
        background: #cbd5e1;
    }

    /* Board : grille 5 colonnes égales, pleine largeur */
    .fi-kanban-board {
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 1rem;
        width: 100%;
        align-items: start;
    }

    /* Sur petits écrans : scroll horizontal */
    @media (max-width: 1024px) {
        .fi-kanban-board {
            display: flex;
            overflow-x: auto;
            padding-bottom: 1rem;
        }
        .fi-kanban-column {
            min-width: 16rem;
            flex-shrink: 0;
        }
    }

    .fi-kanban-column {
        min-width: 0;
        display: flex;
        flex-direction: column;
        margin-bottom: 1.25rem;
    }

    .fi-kanban-header {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        padding: 0.625rem 0.875rem;
        border-radius: 0.75rem;
        border-width: 1px;
        border-style: solid;
        margin-bottom: 0.625rem;
        overflow: hidden;
    }

    /* Trait coloré à gauche comme indicateur visuel du statut */
    .fi-kanban-header-accent {
        width: 4px;
        height: 1.25rem;
        border-radius: 9999px;
        flex-shrink: 0;
    }

    .fi-kanban-header-label {
        flex: 1;
        font-size: 0.875rem;
        font-weight: 700;
        letter-spacing: 0.01em;
    }

    .fi-kanban-badge {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.5rem;
        height: 1.5rem;
        border-radius: 9999px;
        font-size: 0.75rem;
        font-weight: 700;
        color: #fff;
        flex-shrink: 0;
    }

    .fi-kanban-body {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        padding: 0.75rem;
        border-radius: 0.75rem;
        border-width: 1px;
        border-style: solid;
        min-height: 60vh;
    }

    /* Carte */
    .fi-kanban-card {
        display: block;
        background: #fff;
        border: 1px solid #e5e7eb;
        border-radius: 0.75rem;
        padding: 0.875rem 1rem;
        box-shadow: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
        transition: box-shadow 0.15s ease, transform 0.15s ease;
        text-decoration: none;
        cursor: pointer;
    }
    .fi-kanban-card:hover {
        box-shadow: 0 4px 12px rgba(0,0,0,0.10), 0 2px 6px rgba(0,0,0,0.06);
        transform: translateY(-1px);
    }
    .dark .fi-kanban-card {
        background: #1e293b;
        border-color: #334155;
    }

    .fi-kanban-card-name {
        font-size: 0.875rem;
        font-weight: 600;
        color: #111827;
        line-height: 1.35;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        overflow: hidden;
        margin: 0;
    }
    .dark .fi-kanban-card-name { color: #f1f5f9; }

    .fi-kanban-card-sector {
        font-size: 0.75rem;
        color: #9ca3af;
        margin-top: 0.125rem;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
    }

    .fi-kanban-card-tags {
        display: flex;
        flex-wrap: wrap;
        gap: 0.375rem;
        margin-top: 0.625rem;
    }

    .fi-kanban-tag {
        display: inline-flex;
        align-items: center;
        padding: 0.125rem 0.5rem;
        border-radius: 0.375rem;
        font-size: 0.6875rem;
        font-weight: 500;
        border-width: 1px;
        border-style: solid;
    }

    .fi-kanban-card-footer {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-top: 0.75rem;
    }

    .fi-kanban-card-date {
        font-size: 0.75rem;
        color: #9ca3af;
    }

    .fi-kanban-priority-dot {
        width: 0.625rem;
        height: 0.625rem;
        border-radius: 9999px;
        flex-shrink: 0;
    }

    /* ============================================================
       MISSIONS — vue portefeuille (liste de cartes)
       ============================================================ */

    .fi-missions-list {
        display: flex;
        flex-direction: column;
        gap: 0.75rem;
    }

    .fi-missions-empty {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 4rem 1rem;
        color: #94a3b8;
        font-size: 0.9rem;
    }

    .fi-mission-card {
        display: block;
        background: #fff;
        border: 1.5px solid #e8ecf1;
        border-radius: 0.875rem;
        padding: 1.1rem 1.25rem 1rem;
        text-decoration: none;
        color: inherit;
        box-shadow: 0 1px 3px rgba(0,0,0,0.05);
        transition: box-shadow 0.15s, border-color 0.15s;
    }

    .fi-mission-card:hover {
        box-shadow: 0 4px 12px rgba(0,0,0,0.09);
        border-color: #d1d9e0;
    }

    .dark .fi-mission-card {
        background: #1e293b;
        border-color: #334155;
    }

    .fi-mission-card-header {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 0.75rem;
        margin-bottom: 0.25rem;
    }

    .fi-mission-card-title {
        font-size: 0.9375rem;
        font-weight: 600;
        color: #111827;
        line-height: 1.35;
        flex: 1;
    }

    .dark .fi-mission-card-title { color: #f1f5f9; }

    .fi-mission-card-badge {
        font-size: 0.75rem;
        font-weight: 500;
        padding: 0.2rem 0.65rem;
        border-radius: 9999px;
        white-space: nowrap;
        flex-shrink: 0;
    }

    .fi-mission-card-subtitle {
        font-size: 0.8125rem;
        color: #6b7280;
        margin-bottom: 0.75rem;
    }

    .dark .fi-mission-card-subtitle { color: #94a3b8; }

    .fi-mission-card-progress-row {
        display: flex;
        align-items: center;
        gap: 0.6rem;
        margin-bottom: 0.75rem;
    }

    .fi-mission-card-progress-track {
        flex: 1;
        height: 6px;
        background: #e9ecef;
        border-radius: 9999px;
        overflow: hidden;
    }

    .dark .fi-mission-card-progress-track { background: #334155; }

    .fi-mission-card-progress-bar {
        height: 100%;
        border-radius: 9999px;
        transition: width 0.3s ease;
    }

    .fi-mission-card-pct {
        font-size: 0.8125rem;
        font-weight: 500;
        color: #374151;
        min-width: 2.5rem;
        text-align: right;
    }

    .dark .fi-mission-card-pct { color: #cbd5e1; }

    .fi-mission-card-footer {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.5rem;
    }

    .fi-mission-card-avatars {
        display: flex;
        gap: -0.25rem;
    }

    .fi-mission-avatar {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.625rem;
        height: 1.625rem;
        border-radius: 9999px;
        font-size: 0.625rem;
        font-weight: 700;
        color: #fff;
        border: 2px solid #fff;
        margin-right: -0.35rem;
        flex-shrink: 0;
        letter-spacing: 0.01em;
    }

.dark .fi-mission-avatar { border-color: #1e293b; }

.fi-mission-avatar--more {
        background: #e2e8f0;
        color: #64748b;
        font-size: 0.65rem;
    }

    .fi-mission-card-date {
        font-size: 0.78rem;
        color: #6b7280;
    }

    .dark .fi-mission-card-date { color: #94a3b8; }

    /* ============================================================
       TACHES — vue "Mes actions" (Aujourd'hui / Cette semaine / En retard…)
       ============================================================ */

    .fi-actions-filterbar {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        margin-bottom: 1.25rem;
    }

    .fi-actions-groups {
        display: flex;
        flex-direction: column;
        gap: 1.75rem;
    }

    .fi-actions-group-title {
        font-size: 0.6875rem;
        letter-spacing: 0.1em;
        font-weight: 700;
        color: #9ca3af;
        margin-bottom: 0.625rem;
        text-transform: uppercase;
    }

    .dark .fi-actions-group-title { color: #6b7280; }

    .fi-actions-group-list {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
    }

    .fi-actions-empty {
        padding: 0.75rem 0.25rem;
        color: #94a3b8;
        font-size: 0.875rem;
    }

    .fi-actions-all-empty {
        display: flex;
        flex-direction: column;
        align-items: center;
        padding: 4rem 1rem;
        color: #94a3b8;
        font-size: 0.9rem;
    }

    /* Ligne tâche */
    .fi-action-row {
        display: flex;
        align-items: flex-start;
        gap: 0.875rem;
        padding: 0.9rem 1.1rem;
        border-radius: 0.875rem;
        background: #fff;
        border: 1.5px solid #eef2f7;
        box-shadow: 0 1px 2px rgba(0,0,0,0.04);
        transition: box-shadow 0.15s;
    }

    .fi-action-row:hover {
        box-shadow: 0 3px 10px rgba(0,0,0,0.07);
    }

    .dark .fi-action-row {
        background: #1e293b;
        border-color: #334155;
    }

    /* Checkbox */
    .fi-action-checkbox {
        width: 1.25rem;
        height: 1.25rem;
        min-width: 1.25rem;
        border-radius: 0.35rem;
        border: 1.5px solid #cbd5e1;
        background: #fff;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        margin-top: 0.175rem;
        cursor: pointer;
        color: transparent;
        transition: background 0.15s, border-color 0.15s;
    }

    .fi-action-checkbox:hover {
        border-color: #689d71;
    }

    .fi-action-checkbox--checked {
        background: #689d71;
        border-color: #689d71;
        color: #fff;
    }

    .fi-action-checkbox--checked:disabled {
        cursor: default;
        opacity: 1;
    }

    .dark .fi-action-checkbox {
        background: #0f172a;
        border-color: #475569;
    }

    .dark .fi-action-checkbox--checked {
        background: #689d71;
        border-color: #689d71;
    }

    /* Body */
    .fi-action-body {
        flex: 1;
        min-width: 0;
    }

    .fi-action-title {
        font-size: 0.9375rem;
        font-weight: 600;
        color: #0f172a;
        line-height: 1.35;
        margin-bottom: 0.3rem;
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }

    .fi-action-title--done {
        text-decoration: line-through;
        color: #94a3b8;
    }

    .dark .fi-action-title { color: #f1f5f9; }
    .dark .fi-action-title--done { color: #64748b; }

    .fi-action-meta {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        flex-wrap: wrap;
    }

    .fi-action-project {
        font-size: 0.8125rem;
        color: #6b7280;
    }

    .dark .fi-action-project { color: #94a3b8; }

    .fi-action-chip {
        font-size: 0.75rem;
        font-weight: 600;
        padding: 0.15rem 0.55rem;
        border-radius: 9999px;
        white-space: nowrap;
    }

    /* ============================================================
       US-007 — FICHE DÉTAIL LEAD / CLIENT
       ============================================================ */

    .fi-lead-detail {
        display: flex;
        flex-direction: column;
        gap: 0;
        flex: 1;
        min-height: 0;
    }

    /* Carte unique gauche : identité + infos + contacts + scores (pas de bordure accent) */
    .fi-lead-profile-card {
        background: #fff;
        border: 1.5px solid #e8ecf1;
        border-radius: 1rem;
        box-shadow: 0 1px 4px rgba(0,0,0,0.05);
        overflow: hidden;
    }

    .dark .fi-lead-profile-card {
        background: #1e293b;
        border-color: #334155;
    }

    .fi-lead-profile-hero {
        display: flex;
        align-items: flex-start;
        gap: 1.25rem;
        padding: 1.25rem 1.5rem 1.125rem;
        border-bottom: 1px solid #f1f5f9;
    }

    .dark .fi-lead-profile-hero {
        border-bottom-color: #334155;
    }

    .fi-lead-profile-section {
        padding: 1rem 1.125rem 1.125rem;
        border-top: 1px solid #f1f5f9;
    }

    .dark .fi-lead-profile-section {
        border-top-color: #334155;
    }

    .fi-lead-profile-hero + .fi-lead-profile-section {
        border-top: none;
    }

    .fi-lead-avatar-lg {
        width: 3.5rem;
        height: 3.5rem;
        min-width: 3.5rem;
        border-radius: 0.875rem;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.125rem;
        font-weight: 800;
        color: #fff;
        letter-spacing: 0.02em;
    }

    .fi-lead-hero-identity { flex: 1; min-width: 0; }

    .fi-lead-hero-name {
        font-size: 1.375rem;
        font-weight: 800;
        color: #0f172a;
        margin: 0 0 0.25rem;
        line-height: 1.2;
    }

    .dark .fi-lead-hero-name { color: #f1f5f9; }

    .fi-lead-hero-meta {
        font-size: 0.875rem;
        color: #64748b;
        display: flex;
        gap: 0.375rem;
        flex-wrap: wrap;
        margin-bottom: 0;
    }

    .fi-lead-tag {
        display: inline-flex;
        align-items: center;
        padding: 0.2rem 0.625rem;
        border-radius: 9999px;
        font-size: 0.75rem;
        font-weight: 600;
        white-space: nowrap;
    }

    /* Layout 2 colonnes : droite occupe la hauteur (dashboard) */
    .fi-lead-detail-body {
        display: grid;
        grid-template-columns: minmax(19rem, 22rem) 1fr;
        gap: 1.25rem;
        align-items: stretch;
        flex: 1;
        min-height: calc(100vh - 11rem);
    }

    @media (max-width: 900px) {
        .fi-lead-detail-body {
            grid-template-columns: 1fr;
            min-height: 0;
        }
    }

    /* Sidebar : carte hauteur contenu, alignée en haut */
    .fi-lead-sidebar {
        display: flex;
        flex-direction: column;
        gap: 0;
        align-self: start;
        width: 100%;
    }

    .fi-lead-card-section {
        background: #fff;
        border: 1.5px solid #e8ecf1;
        border-radius: 0.875rem;
        padding: 1rem 1.125rem;
        box-shadow: 0 1px 3px rgba(0,0,0,0.04);
    }

    .dark .fi-lead-card-section {
        background: #1e293b;
        border-color: #334155;
    }

    .fi-lead-section-title {
        font-size: 0.6875rem;
        font-weight: 700;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: #94a3b8;
        margin: 0 0 0.75rem;
    }

    .fi-lead-section-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        margin-bottom: 0.75rem;
    }

    .fi-lead-section-head .fi-lead-section-title {
        margin: 0;
    }

    /* Panneau principal (fiche client / lead) : Missions, Sujets — hors style « petit label » gris */
    .fi-lead-detail .fi-lead-tab-panel .fi-lead-panel-heading {
        margin: 0;
        font-size: 1.25rem !important;
        font-weight: 800 !important;
        letter-spacing: -0.035em !important;
        text-transform: none !important;
        color: #0f172a !important;
        line-height: 1.2;
        font-family: inherit;
    }

    .dark .fi-lead-detail .fi-lead-tab-panel .fi-lead-panel-heading {
        color: #f8fafc !important;
    }

    .fi-lead-detail .fi-lead-tab-panel .fi-lead-panel-heading--sub {
        font-size: 1.0625rem !important;
        font-weight: 700 !important;
        letter-spacing: -0.025em !important;
        text-transform: none !important;
        color: #1e293b !important;
    }

    .dark .fi-lead-detail .fi-lead-tab-panel .fi-lead-panel-heading--sub {
        color: #e2e8f0 !important;
    }

    /* « Voir plus » à côté d’Informations : même police leads/clients (pile sans + corps lisible, pas l’héritage du titre en capitales) */
    .fi-lead-info-voir-plus {
        font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
        font-size: 0.8125rem;
        font-weight: 500;
        font-style: normal;
        letter-spacing: normal;
        text-transform: none;
        line-height: 1.25;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

    /* Info list */
    .fi-lead-info-list {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        margin: 0;
    }

    .fi-lead-info-row {
        display: flex;
        justify-content: space-between;
        gap: 0.5rem;
        font-size: 0.8125rem;
    }

    .fi-lead-info-row dt {
        color: #94a3b8;
        white-space: nowrap;
        flex-shrink: 0;
    }

    .fi-lead-info-row dd {
        color: #1e293b;
        text-align: right;
        font-weight: 500;
        margin: 0;
        word-break: break-word;
    }

    .dark .fi-lead-info-row dd { color: #cbd5e1; }

    .fi-lead-link {
        color: #1c494f;
        text-decoration: none;
    }

    .fi-lead-link:hover { text-decoration: underline; }

    /* Contacts */
    .fi-lead-contacts-list {
        display: flex;
        flex-direction: column;
        gap: 0.75rem;
        margin-bottom: 0.75rem;
    }

    .fi-lead-contact-row {
        display: grid;
        grid-template-columns: auto 1fr auto;
        align-items: center;
        gap: 0.625rem;
    }

    /* Carré centré sur la hauteur du bloc texte (email, téléphone, rôle) */
    .fi-lead-contact-avatar {
        box-sizing: border-box;
        align-self: center;
        justify-self: start;
        width: 2.875rem;
        height: 2.875rem;
        min-width: 2.875rem;
        flex-shrink: 0;
        border-radius: 0.5rem;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 0.75rem;
        font-weight: 700;
        line-height: 1;
        color: #fff;
    }

    .fi-lead-contact-info { flex: 1; min-width: 0; }

    .fi-lead-contact-name {
        font-size: 0.8125rem;
        font-weight: 600;
        color: #1e293b;
        display: flex;
        align-items: center;
        gap: 0.25rem;
    }

    .dark .fi-lead-contact-name { color: #f1f5f9; }

    .fi-lead-contact-title {
        font-size: 0.75rem;
        color: #64748b;
    }

    /* Bouton d'ajout (style vert comme la maquette) */
    .fi-lead-add-contact-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.5rem;
        width: auto;
        padding: 0.75rem 1.25rem;
        border-radius: 1rem;
        border: 0;
        background: #689D71;
        color: #fff;
        font-size: 1rem;
        font-weight: 700;
        cursor: pointer;
        text-decoration: none;
        transition: filter 0.12s, transform 0.12s;
        box-shadow: 0 1px 0 rgba(0,0,0,0.06);
    }

    .fi-lead-add-contact-btn::before {
        content: "+";
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.25rem;
        height: 1.25rem;
        font-size: 1.25rem;
        line-height: 1;
        font-weight: 900;
    }

    .fi-lead-add-contact-btn:hover {
        filter: brightness(0.95);
        transform: translateY(-1px);
    }

    .fi-lead-add-contact-btn:active {
        transform: translateY(0);
    }

    /* Score */
    .fi-lead-score-value {
        font-size: 2.5rem;
        font-weight: 800;
        color: #0f172a;
        line-height: 1;
        margin-bottom: 0.625rem;
    }

    .dark .fi-lead-score-value { color: #f1f5f9; }

    .fi-lead-score-bar-track {
        height: 6px;
        background: #e9ecef;
        border-radius: 9999px;
        overflow: hidden;
        margin-bottom: 0.5rem;
    }

    .dark .fi-lead-score-bar-track { background: #334155; }

    /* Barre d’avancement (sujets / missions) : même ligne que le %, sans marge parasite */
    .fi-lead-score-bar-track--inline {
        margin-bottom: 0;
        flex: 1;
        min-width: 0;
        align-self: center;
    }

    .fi-lead-info-progress-bar-line {
        display: flex;
        align-items: center;
        gap: 0.5rem;
    }

    .fi-lead-info-progress-percent {
        flex-shrink: 0;
        min-width: 2.5rem;
        font-size: 0.8125rem;
        font-weight: 700;
        text-align: right;
        line-height: 1;
        align-self: center;
    }

    .fi-lead-score-bar-fill {
        height: 100%;
        border-radius: 9999px;
        transition: width 0.4s ease;
    }

    .fi-lead-score-label {
        font-size: 0.8125rem;
        font-weight: 600;
        margin: 0;
    }

    /* Panel droit : cadre gris neutre (pas d’accent — comme prod) */
    .fi-lead-main {
        background: #fff;
        border: 1.5px solid #e8ecf1;
        border-radius: 0.875rem;
        overflow: hidden;
        box-shadow: 0 1px 3px rgba(0,0,0,0.04);
        min-height: 100%;
        display: flex;
        flex-direction: column;
        align-self: stretch;
    }

    .dark .fi-lead-main {
        background: #1e293b;
        border-color: #334155;
    }

    /* Onglets */
    .fi-lead-tabs {
        display: flex;
        border-bottom: 1.5px solid #f1f5f9;
        background: #f8fafc;
        padding: 0 0.25rem;
    }

    .dark .fi-lead-tabs {
        background: #0f172a;
        border-color: #334155;
    }

    .fi-lead-tab {
        display: inline-flex;
        align-items: center;
        gap: 0.375rem;
        padding: 0.75rem 1rem;
        font-size: 0.875rem;
        font-weight: 500;
        color: #64748b;
        border: none;
        background: transparent;
        cursor: pointer;
        border-bottom: 2px solid transparent;
        margin-bottom: -1.5px;
        transition: color 0.12s, border-color 0.12s;
        white-space: nowrap;
    }

    .fi-lead-tab:hover { color: #1e293b; }

    .fi-lead-tab--active {
        color: #1c494f;
        border-bottom-color: #1c494f;
        font-weight: 600;
    }

    .dark .fi-lead-tab--active {
        color: #689d71;
        border-bottom-color: #689d71;
    }

    .fi-lead-tab-badge {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 1.25rem;
        height: 1.25rem;
        padding: 0 0.3rem;
        border-radius: 9999px;
        background: #e2e8f0;
        color: #475569;
        font-size: 0.6875rem;
        font-weight: 700;
    }

    /* Contenu onglets : fond gris, remplit la hauteur sous la barre d’onglets */
    .fi-lead-tab-panel {
        flex: 1 1 auto;
        min-height: 0;
        display: flex;
        flex-direction: column;
        padding: 1.25rem 1.5rem;
        background: #f8fafc;
        overflow-y: auto;
    }

    .dark .fi-lead-tab-panel {
        background: #0f172a;
    }

    /* Timeline historique */
    .fi-lead-timeline {
        display: flex;
        flex-direction: column;
        gap: 0.75rem;
        position: relative;
    }

    .fi-lead-timeline::before {
        content: '';
        position: absolute;
        left: 0.875rem;
        top: 1rem;
        bottom: 0;
        width: 1.5px;
        background: #f1f5f9;
        z-index: 0;
    }

    .dark .fi-lead-timeline::before { background: #334155; }

    .fi-lead-timeline-item {
        display: flex;
        gap: 1rem;
        padding-bottom: 1.25rem;
        position: relative;
        z-index: 1;
    }

    .fi-lead-timeline-item--interactive {
        width: 100%;
        margin: 0 0 0 -0.25rem;
        padding: 0.625rem 0.75rem;
        border-radius: 0.625rem;
        border: 1.5px solid transparent;
        background: transparent;
        cursor: pointer;
        text-align: left;
        font: inherit;
        color: inherit;
        align-items: center;
        transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
    }

    .fi-lead-timeline-item--interactive .fi-lead-timeline-content {
        padding-top: 0;
        display: flex;
        align-items: center;
    }

    .fi-lead-timeline-item--interactive .fi-lead-timeline-header {
        align-items: center;
        margin-bottom: 0;
        width: 100%;
    }

    .fi-lead-timeline-item--interactive .fi-lead-timeline-title {
        line-height: 1.35;
    }

    .fi-lead-timeline-item--interactive:hover {
        background: #f8fafc;
        border-color: #e2e8f0;
        box-shadow: 0 1px 4px rgba(15, 23, 42, 0.06);
    }

    .dark .fi-lead-timeline-item--interactive:hover {
        background: #1e293b;
        border-color: #334155;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
    }

    .fi-lead-timeline-item--interactive:active {
        background: #f1f5f9;
        border-color: #cbd5e1;
    }

    .dark .fi-lead-timeline-item--interactive:active {
        background: #334155;
        border-color: #475569;
    }

    .fi-lead-timeline-item--interactive:focus-visible {
        outline: 2px solid #1c494f;
        outline-offset: 2px;
    }

    .fi-lead-timeline-item--interactive:hover .fi-lead-timeline-title {
        color: #1c494f;
    }

    .dark .fi-lead-timeline-item--interactive:hover .fi-lead-timeline-title {
        color: #86efac;
    }

    .fi-lead-timeline-header-aside {
        display: inline-flex;
        align-items: center;
        gap: 0.25rem;
        flex-shrink: 0;
    }

    .fi-lead-timeline-chevron {
        font-size: 1.25rem;
        font-weight: 300;
        color: #cbd5e1;
        line-height: 1;
        transition: color 0.15s ease, transform 0.15s ease;
    }

    .fi-lead-timeline-item--interactive:hover .fi-lead-timeline-chevron {
        color: #1c494f;
        transform: translateX(2px);
    }

    .dark .fi-lead-timeline-chevron {
        color: #475569;
    }

    .dark .fi-lead-timeline-item--interactive:hover .fi-lead-timeline-chevron {
        color: #86efac;
    }

    .fi-lead-activity-detail-value {
        font-size: 0.875rem;
        color: #1e293b;
        margin: 0;
        line-height: 1.5;
    }

    .fi-lead-activity-detail-value--multiline {
        white-space: pre-wrap;
    }

    .dark .fi-lead-activity-detail-value {
        color: #f1f5f9;
    }

    .fi-lead-timeline-dot {
        width: 1.75rem;
        height: 1.75rem;
        min-width: 1.75rem;
        border-radius: 9999px;
        border: 2px solid;
        background: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        position: relative;
        z-index: 1;
    }

    .dark .fi-lead-timeline-dot { background: #1e293b; }

    .fi-lead-timeline-content {
        flex: 1;
        min-width: 0;
        padding-top: 0.1rem;
    }

    .fi-lead-timeline-header {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        gap: 0.5rem;
        margin-bottom: 0.25rem;
    }

    .fi-lead-timeline-title {
        font-size: 0.9375rem;
        font-weight: 600;
        color: #1e293b;
        line-height: 1.3;
    }

    .dark .fi-lead-timeline-title { color: #f1f5f9; }

    .fi-lead-timeline-date {
        font-size: 0.75rem;
        color: #94a3b8;
        white-space: nowrap;
        flex-shrink: 0;
    }

    .fi-lead-timeline-desc {
        font-size: 0.8125rem;
        color: #475569;
        margin: 0.25rem 0;
        line-height: 1.5;
    }

    .dark .fi-lead-timeline-desc { color: #94a3b8; }

    .fi-lead-timeline-note {
        font-size: 0.8125rem;
        color: #64748b;
        background: #f8fafc;
        border-left: 3px solid #e2e8f0;
        padding: 0.4rem 0.75rem;
        border-radius: 0 0.375rem 0.375rem 0;
        margin: 0.375rem 0 0;
        line-height: 1.5;
    }

    .dark .fi-lead-timeline-note {
        background: #0f172a;
        border-left-color: #334155;
        color: #94a3b8;
    }

    .fi-lead-timeline-by {
        font-size: 0.6875rem;
        color: #94a3b8;
        margin-top: 0.25rem;
    }

    /* Missions list */
    .fi-lead-section-heading-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        margin-bottom: 1rem;
        flex-wrap: wrap;
    }

    .fi-lead-missions-list {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        overflow: visible;
    }

    .fi-lead-mission-row {
        --sujet-lead-accent: #1c494f;
        position: relative;
        z-index: 0;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.75rem 1rem;
        border-radius: 0.625rem;
        border: 1.5px solid #f1f5f9;
        border-left: 4px solid var(--sujet-lead-accent);
        background: #fff;
        text-decoration: none;
        transition: border-color 0.12s, box-shadow 0.12s;
    }

    /* Menu ⋮ ouvert : la ligne passe au-dessus des sujets voisins (comme les cartes portefeuille). */
    .fi-lead-mission-row--menu-open {
        z-index: 40;
    }

    .fi-lead-mission-row--menu-open:hover {
        z-index: 40;
    }

    .dark .fi-lead-mission-row {
        background: #0f172a;
        border-color: #334155;
        border-left-color: var(--sujet-lead-accent);
    }

    .fi-lead-mission-row--archived {
        /* Pas d’opacity sur la ligne : sinon le menu ⋮ devient translucide et laisse voir la ligne du dessous. */
        background: #f8fafc;
        border-style: dashed;
        border-left-style: solid;
        border-left-width: 4px;
        border-color: #e2e8f0;
        border-left-color: var(--sujet-lead-accent);
    }

    .dark .fi-lead-mission-row--archived {
        background: #1a2332;
        border-color: #475569;
        border-left-color: var(--sujet-lead-accent);
    }

    .fi-lead-mission-row--archived .fi-lead-mission-row-name,
    .fi-lead-mission-row--archived .fi-lead-tag {
        color: #64748b;
    }

    .dark .fi-lead-mission-row--archived .fi-lead-mission-row-name,
    .dark .fi-lead-mission-row--archived .fi-lead-tag {
        color: #94a3b8;
    }

    .fi-lead-mission-row:hover {
        border-color: #cbd5e1;
        border-left-color: var(--sujet-lead-accent);
        box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    }

    .fi-lead-mission-row-left { flex: 1; min-width: 0; }

    .fi-lead-mission-row-main {
        flex: 1;
        min-width: 0;
        margin: 0;
        padding: 0;
        text-align: left;
        cursor: pointer;
        background: transparent;
        border: none;
        font: inherit;
        color: inherit;
    }

    .fi-lead-mission-row-main:focus-visible {
        outline: 2px solid #4f46e5;
        outline-offset: 2px;
        border-radius: 0.25rem;
    }

    .fi-lead-mission-row-name {
        font-size: 0.875rem;
        font-weight: 700;
        color: #1e293b;
    }

    .dark .fi-lead-mission-row-name { color: #f1f5f9; }

    .fi-lead-mission-row-main:hover .fi-lead-mission-row-name,
    .fi-lead-mission-row-main:focus-visible .fi-lead-mission-row-name {
        color: var(--sujet-lead-accent, #1c494f);
    }

    .dark .fi-lead-mission-row-main:hover .fi-lead-mission-row-name,
    .dark .fi-lead-mission-row-main:focus-visible .fi-lead-mission-row-name {
        color: color-mix(in srgb, var(--sujet-lead-accent, #1c494f) 82%, #ffffff);
    }

    .fi-lead-info-progress-mission-name {
        font-size: 0.75rem;
        font-weight: 700;
        color: #64748b;
        margin-bottom: 0.2rem;
    }

    .dark .fi-lead-info-progress-mission-name {
        color: #9ca3af;
    }

    .fi-lead-mission-row-meta {
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        gap: 0.5rem;
        margin-top: 0.25rem;
    }

    .fi-lead-mission-status-badge {
        font-size: 0.6875rem;
        font-weight: 600;
    }

    .fi-lead-mission-row .fi-lead-mission-status-input {
        display: inline-block;
        height: 2rem;
        min-height: 2rem;
        padding: 0 2.25rem 0 0.5rem;
        font-size: 0.75rem;
        font-weight: 600;
        line-height: 1.25rem;
        border-radius: 0.5rem;
        box-sizing: border-box;
        /* Largeur selon les libellés (option la plus longue) ; pas d’étirement flex */
        width: max-content;
        max-width: 100%;
        min-width: 0;
        transition: box-shadow 0.15s, border-color 0.15s;
        /* Évite le bleu système de Chromium sur la liste et le focus du <select> */
        accent-color: #64748b;
        color-scheme: light;
    }

    /* Chromium : le champ suit la valeur affichée quand c’est supporté */
    @supports (field-sizing: content) {
        .fi-lead-mission-row .fi-lead-mission-status-input {
            field-sizing: content;
            width: auto;
            max-width: 100%;
        }
    }

    .dark .fi-lead-mission-row .fi-lead-mission-status-input {
        accent-color: #94a3b8;
        color-scheme: dark;
    }

    .fi-lead-mission-row .fi-lead-mission-status-input:focus,
    .fi-lead-mission-row .fi-lead-mission-status-input:focus-visible {
        outline: none;
        border-color: #d1d5db;
        box-shadow: 0 0 0 2px rgba(148, 163, 184, 0.35);
    }

    .dark .fi-lead-mission-row .fi-lead-mission-status-input:focus,
    .dark .fi-lead-mission-row .fi-lead-mission-status-input:focus-visible {
        border-color: #475569;
        box-shadow: 0 0 0 2px rgba(148, 163, 184, 0.25);
    }

    .fi-lead-mission-row .fi-lead-mission-status-input option {
        background-color: #ffffff;
        color: #0f172a;
    }

    .dark .fi-lead-mission-row .fi-lead-mission-status-input option {
        background-color: #0f172a;
        color: #f1f5f9;
    }

    .fi-lead-mission-row .fi-lead-mission-status-input:disabled {
        opacity: 0.75;
        cursor: not-allowed;
    }

    .fi-lead-mission-row-right {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        flex-shrink: 0;
        position: relative;
    }

    .fi-lead-mission-row-menu.fi-client-card-menu {
        padding: 0;
        align-self: center;
    }

    .fi-lead-mission-row .fi-client-card-dropdown {
        z-index: 50;
        background-color: #ffffff;
        opacity: 1;
        box-shadow: 0 12px 28px rgba(15, 23, 42, 0.16);
    }

    .dark .fi-lead-mission-row .fi-client-card-dropdown {
        background-color: #1e293b;
    }

    /* Colle au contenu du select, sans occuper le reste de la ligne flex */
    .fi-lead-mission-row-right .fi-lead-mission-status-select {
        flex: 0 1 auto;
        width: fit-content;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }

    .fi-lead-mission-row-right .fi-btn.fi-client-mission-documents-btn,
    .fi-lead-mission-row-right .fi-btn.fi-lead-mission-debuter-btn,
    .fi-client-mission-card-actions .fi-btn.fi-client-mission-documents-btn {
        min-height: 2rem;
        height: 2rem;
        padding-block: 0;
        align-items: center;
    }

    .fi-mission-documents-count,
    .fi-mission-taches-count {
        font-weight: 700;
    }

    .fi-lead-mission-row .fi-mission-documents-count,
    .fi-lead-mission-row .fi-mission-taches-count {
        color: var(--sujet-lead-accent, #1c494f);
    }

    .dark .fi-lead-mission-row .fi-mission-documents-count,
    .dark .fi-lead-mission-row .fi-mission-taches-count {
        color: color-mix(in srgb, var(--sujet-lead-accent, #1c494f) 82%, #ffffff);
    }

    @media (max-width: 640px) {
        body.fi-panel-admin .fi-lead-missions-list {
            gap: 0.75rem;
        }

        body.fi-panel-admin .fi-lead-mission-row {
            display: grid !important;
            grid-template-columns: minmax(0, 1fr);
            align-items: stretch;
            gap: 0.75rem;
            padding: 0.875rem 0.875rem 0.875rem 1rem;
        }

        body.fi-panel-admin .fi-lead-mission-row-main {
            display: block;
            width: 100%;
            min-width: 0;
        }

        body.fi-panel-admin .fi-lead-mission-row-name {
            display: block;
            max-width: 100%;
            overflow-wrap: anywhere;
            word-break: normal;
            hyphens: auto;
            font-size: 0.9375rem;
            line-height: 1.35;
        }

        body.fi-panel-admin .fi-lead-mission-row-meta {
            margin-top: 0.5rem;
        }

        body.fi-panel-admin .fi-lead-mission-row-right {
            display: grid !important;
            grid-template-columns: minmax(0, max-content) minmax(7.75rem, 1fr) auto;
            align-items: center !important;
            width: 100%;
            min-width: 0;
            gap: 0.5rem !important;
        }

        body.fi-panel-admin .fi-lead-mission-row-right .fi-btn.fi-client-mission-documents-btn {
            width: auto;
            max-width: 100%;
            min-width: 0;
            padding-inline: 0.625rem;
            white-space: nowrap;
        }

        body.fi-panel-admin .fi-lead-mission-row-right .fi-lead-mission-status-select,
        body.fi-panel-admin .fi-lead-mission-row-right .fi-lead-mission-status-select > div {
            width: 100%;
            min-width: 0;
        }

        body.fi-panel-admin .fi-lead-mission-row .fi-lead-mission-status-input {
            width: 100% !important;
            min-width: 0;
            max-width: 100%;
            height: 2rem;
            min-height: 2rem;
            font-size: 0.8125rem;
            padding-left: 0.625rem;
        }

        body.fi-panel-admin .fi-lead-mission-row-menu.fi-client-card-menu {
            justify-self: end;
        }
    }

    .fi-client-missions-grid--client-accent .fi-client-mission-card {
        --mission-lead-accent: var(--client-accent, #1c494f);
    }

    .fi-client-missions-grid--client-accent .fi-mission-documents-count,
    .fi-client-missions-grid--client-accent .fi-mission-taches-count {
        color: var(--client-accent, #689D71);
    }

    .dark .fi-client-missions-grid--client-accent .fi-mission-documents-count,
    .dark .fi-client-missions-grid--client-accent .fi-mission-taches-count {
        color: color-mix(in srgb, var(--client-accent, #689D71) 82%, #ffffff);
    }

    .fi-lead-subject-action-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 2rem;
        padding: 0.375rem 0.75rem;
        border-radius: 0.5rem;
        border: 1px solid #cbd5e1;
        background: #fff;
        color: #334155;
        text-decoration: none;
        font-size: 0.8125rem;
        font-weight: 600;
        transition: border-color 0.12s, background 0.12s, color 0.12s;
    }

    .fi-lead-subject-action-btn:hover {
        border-color: #94a3b8;
        background: #f8fafc;
        color: #0f172a;
    }

    .dark .fi-lead-subject-action-btn {
        background: #0f172a;
        border-color: #334155;
        color: #e2e8f0;
    }

    /* Missions en cartes (fiche client) */
    .fi-client-missions-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
        gap: 1rem;
    }

    .fi-client-missions-grid > .fi-client-mission-card {
        min-width: 0;
    }

    .fi-client-mission-card {
        --mission-lead-accent: #1c494f;
        position: relative;
        z-index: 0;
        border: 1.5px solid #f1f5f9;
        border-left: 4px solid var(--mission-lead-accent);
        border-radius: 0.625rem;
        padding: 1rem 1.125rem;
        background: #fff;
        transition: border-color 0.12s, box-shadow 0.12s;
        min-width: 0;
    }

    .fi-client-mission-card:hover {
        border-color: #cbd5e1;
        border-left-color: var(--mission-lead-accent);
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    }

    /* Fiche client : couleur du client au survol du nom de mission uniquement */
    .fi-client-missions-grid--client-accent .fi-client-mission-card-title:hover {
        color: var(--client-accent);
    }

    .dark .fi-client-missions-grid--client-accent .fi-client-mission-card-title:hover {
        color: color-mix(in srgb, var(--client-accent) 82%, #ffffff);
    }

    .dark .fi-client-mission-card {
        background: #0f172a;
        border-color: #334155;
        border-left-color: var(--mission-lead-accent);
    }

    .fi-client-mission-card-head {
        display: flex;
        flex-direction: row;
        align-items: flex-start;
        justify-content: space-between;
        gap: 0.5rem;
        min-width: 0;
        width: 100%;
    }

    .fi-client-mission-card-head-main {
        display: flex;
        flex-direction: column;
        gap: 0.35rem;
        align-items: flex-start;
        flex: 1;
        min-width: 0;
    }

    .fi-client-mission-card-cloture-icon {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: #16a34a;
        line-height: 0;
    }

    .dark .fi-client-mission-card-cloture-icon {
        color: #22c55e;
    }

    .fi-client-mission-card-title {
        font-size: 0.9375rem;
        font-weight: 700;
        color: #0f172a;
        text-decoration: none;
        line-height: 1.35;
        display: block;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .fi-client-mission-card-title:hover {
        color: #4f46e5;
    }

    .dark .fi-client-mission-card-title {
        color: #f1f5f9;
    }

    .dark .fi-client-mission-card-title:hover {
        color: #a5b4fc;
    }

    .fi-client-mission-card-code {
        font-size: 0.6875rem;
        font-family: ui-monospace, monospace;
        color: #64748b;
        display: block;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .fi-client-mission-card-badge {
        display: inline-flex;
        margin-top: 0.25rem;
        padding: 0.15rem 0.5rem;
        border-radius: 0.375rem;
        font-size: 0.6875rem;
        font-weight: 600;
    }

    .fi-client-mission-card-meta {
        margin: 0.5rem 0 0;
        font-size: 0.75rem;
        color: #64748b;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .fi-client-mission-card-actions {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem;
        margin-top: 0.875rem;
    }

    /* Documents / Tâches : même hauteur compacte que les sujets lead (2rem) */
    .fi-client-mission-card-actions .fi-btn,
    .fi-client-mission-card-actions .fi-lead-subject-action-btn {
        min-height: 2rem !important;
        height: 2rem !important;
        max-height: 2rem !important;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
        line-height: 1.25rem;
        box-sizing: border-box;
        align-items: center;
    }

    .fi-client-mission-card-actions .fi-lead-subject-action-btn {
        padding: 0 0.75rem;
    }

    .fi-client-mission-card-actions-menu {
        margin-inline-start: auto;
        display: inline-flex;
        align-items: center;
    }

    .fi-client-missions-heading-row {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem 1rem;
    }

    .fi-client-missions-filter {
        flex-shrink: 0;
    }

    .fi-client-missions-filter-select {
        min-width: 7.5rem;
        max-width: 100%;
        padding: 0.375rem 2rem 0.375rem 0.75rem;
        line-height: 1.35;
        appearance: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        background-color: #fff;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='2' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 0.5rem center;
        background-size: 1.125rem 1.125rem;
        text-overflow: ellipsis;
    }

    .dark .fi-client-missions-filter-select {
        background-color: rgb(17 24 39);
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='2' stroke='%239ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");
    }

    .fi-client-mission-card--menu-open {
        z-index: 40;
    }

    .fi-client-mission-card-actions-menu.fi-client-card-menu {
        position: relative;
        z-index: 3;
        margin-inline-start: auto;
    }

    .fi-client-mission-card .fi-client-card-dropdown {
        z-index: 50;
    }

    .fi-client-mission-card--archived {
        background: #f8fafc;
        border-style: dashed;
        border-left-style: solid;
        border-left-width: 4px;
        border-color: #e2e8f0;
        border-left-color: var(--mission-lead-accent, var(--client-accent, #1c494f));
    }

    .dark .fi-client-mission-card--archived {
        background: #1a2332;
        border-color: #475569;
        border-left-color: var(--mission-lead-accent, var(--client-accent, #1c494f));
    }

    /* Missions clôturées : icône check-badge ; bordure gauche = accent client (comme les autres cartes) */
    .fi-client-mission-card--cloturee,
    .fi-client-mission-card--cloturee:hover,
    .dark .fi-client-mission-card--cloturee,
    .dark .fi-client-mission-card--cloturee:hover {
        border-left-color: var(--mission-lead-accent, var(--client-accent, #1c494f));
    }

    .fi-client-mission-taches-link {
        gap: 0.25rem;
        white-space: nowrap;
    }

    /* Modal mission : texte des lignes tâche (taille légèrement supérieure au défaut) */
    .fi-mission-taches-modal .fi-mission-tache-titre {
        font-size: 0.9375rem; /* ~15px, entre text-sm et text-base */
        line-height: 1.35;
    }

    .fi-mission-taches-modal .fi-mission-tache-meta {
        font-size: 0.8125rem; /* ~13px, un peu au-dessus de text-xs */
        line-height: 1.4;
    }

    /* Libellé de statut (liste dans le modal mission) : couleur sur le texte seul */
    .fi-mission-taches-modal .fi-tache-statut-label {
        font-weight: 500;
    }

    .fi-mission-taches-modal .fi-tache-statut-label--non-commence {
        color: #4b5563;
    }

    .dark .fi-mission-taches-modal .fi-tache-statut-label--non-commence {
        color: #9ca3af;
    }

    .fi-mission-taches-modal .fi-tache-statut-label--en-cours {
        color: #0284c7;
    }

    .dark .fi-mission-taches-modal .fi-tache-statut-label--en-cours {
        color: #38bdf8;
    }

    .fi-mission-taches-modal .fi-tache-statut-label--termine {
        color: #16a34a;
    }

    .dark .fi-mission-taches-modal .fi-tache-statut-label--termine {
        color: #4ade80;
    }

    .fi-mission-taches-modal .fi-tache-statut-label--en-retard {
        color: #dc2626;
    }

    .dark .fi-mission-taches-modal .fi-tache-statut-label--en-retard {
        color: #f87171;
    }

    .fi-mission-taches-modal .fi-tache-statut-label--defaut {
        color: #6b7280;
    }

    .dark .fi-mission-taches-modal .fi-tache-statut-label--defaut {
        color: #9ca3af;
    }

    .fi-mission-taches-modal .fi-tache-echeance {
        font-weight: 500;
        color: #e57373;
    }

    .dark .fi-mission-taches-modal .fi-tache-echeance {
        color: #fca5a5;
    }

    .fi-tache-row-details-modal .fi-modal-content {
        padding-top: 0.25rem;
    }

    .fi-tache-row-details-modal .fi-activity-details {
        display: flex;
        flex-direction: column;
        gap: 1.25rem;
    }

    .fi-tache-row-details-modal .fi-activity-details__header {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        justify-content: space-between;
        gap: 0.75rem 1rem;
        padding-bottom: 1rem;
        padding-right: 2.75rem;
        position: relative;
        border-bottom: 1px solid #e5e7eb;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__header {
        border-bottom-color: #374151;
    }

    .fi-tache-row-details-modal .fi-activity-details__eyebrow {
        margin: 0;
        font-size: 0.6875rem;
        font-weight: 600;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: #689d71;
    }

    .fi-tache-row-details-modal .fi-activity-details__title {
        margin: 0.35rem 0 0;
        font-size: 1.25rem;
        font-weight: 600;
        line-height: 1.35;
        color: #111827;
        word-break: break-word;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__title {
        color: #f9fafb;
    }

    .fi-tache-row-details-modal .fi-activity-details__header-aside {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem;
    }

    .fi-tache-row-details-modal .fi-activity-details__close {
        position: absolute;
        top: 0;
        right: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 2rem;
        height: 2rem;
        border: 0;
        border-radius: 0.5rem;
        color: #6b7280;
        background: transparent;
        cursor: pointer;
        transition: color 0.15s ease, background-color 0.15s ease;
    }

    .fi-tache-row-details-modal .fi-activity-details__close:hover {
        color: #111827;
        background: #f3f4f6;
    }

    .fi-tache-row-details-modal .fi-activity-details__close:focus-visible {
        outline: 2px solid #689d71;
        outline-offset: 2px;
    }

    .fi-tache-row-details-modal .fi-activity-details__close svg {
        width: 1.25rem;
        height: 1.25rem;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__close {
        color: #9ca3af;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__close:hover {
        color: #f9fafb;
        background: #1f2937;
    }

    .fi-tache-row-details-modal .fi-activity-details__chip {
        display: inline-flex;
        align-items: center;
        border-radius: 9999px;
        padding: 0.25rem 0.625rem;
        font-size: 0.75rem;
        font-weight: 500;
        color: #374151;
        background: #f3f4f6;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__chip {
        color: #e5e7eb;
        background: #1f2937;
    }

    .fi-tache-row-details-modal .fi-activity-details__chip--phase {
        color: #1d4ed8;
        background: #dbeafe;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__chip--phase {
        color: #bfdbfe;
        background: rgba(30, 64, 175, 0.35);
    }

    .fi-tache-row-details-modal .fi-activity-details__status {
        border-radius: 9999px;
        padding: 0.25rem 0.625rem;
        font-size: 0.75rem;
        font-weight: 600;
        background: rgba(107, 114, 128, 0.12);
    }

    .fi-tache-row-details-modal .fi-activity-details__assignees {
        display: grid;
        grid-template-columns: auto 1fr auto;
        gap: 0.875rem;
        align-items: center;
        padding: 1rem;
        border-radius: 0.875rem;
        background: linear-gradient(135deg, rgba(104, 157, 113, 0.08), rgba(59, 130, 246, 0.06));
        border: 1px solid rgba(104, 157, 113, 0.18);
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__assignees {
        background: linear-gradient(135deg, rgba(104, 157, 113, 0.14), rgba(59, 130, 246, 0.08));
        border-color: rgba(104, 157, 113, 0.28);
    }

    .fi-tache-row-details-modal .fi-activity-details__assignees-icon {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 2.5rem;
        height: 2.5rem;
        border-radius: 9999px;
        color: #689d71;
        background: #fff;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__assignees-icon {
        color: #86c294;
        background: #111827;
    }

    .fi-tache-row-details-modal .fi-activity-details__assignees-icon svg {
        width: 1.25rem;
        height: 1.25rem;
    }

    .fi-tache-row-details-modal .fi-activity-details__label {
        margin: 0;
        font-size: 0.75rem;
        font-weight: 500;
        color: #6b7280;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__label {
        color: #9ca3af;
    }

    .fi-tache-row-details-modal .fi-activity-details__assignees-value {
        margin: 0.25rem 0 0;
        font-size: 0.9375rem;
        font-weight: 600;
        color: #111827;
        word-break: break-word;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__assignees-value {
        color: #f9fafb;
    }

    .fi-tache-row-details-modal .fi-activity-details__assignees-meta {
        align-self: start;
    }

    .fi-tache-row-details-modal .fi-activity-details__timeline {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.75rem;
    }

    @media (max-width: 640px) {
        .fi-tache-row-details-modal .fi-activity-details__timeline {
            grid-template-columns: 1fr;
        }
    }

    .fi-tache-row-details-modal .fi-activity-details__timeline-item {
        padding: 0.875rem;
        border-radius: 0.75rem;
        border: 1px solid #e5e7eb;
        background: #fff;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__timeline-item {
        border-color: #374151;
        background: #111827;
    }

    .fi-tache-row-details-modal .fi-activity-details__timeline-value {
        margin: 0.35rem 0 0;
        font-size: 0.9375rem;
        font-weight: 600;
        color: #111827;
    }

    .dark .fi-tache-row-details-modal .fi-activity-details__timeline-value {
        color: #f9fafb;
    }

    .fi-tache-row-details-modal .fi-activity-details__footnote {
        margin: 0;
        font-size: 0.75rem;
        color: #9ca3af;
        text-align: right;
    }

    .fi-tache-row-details-modal .fi-tache-statut-label--non-commence {
        color: #4b5563;
    }

    .dark .fi-tache-row-details-modal .fi-tache-statut-label--non-commence {
        color: #d1d5db;
    }

    .fi-tache-row-details-modal .fi-tache-statut-label--en-cours {
        color: #0284c7;
        background: rgba(2, 132, 199, 0.12);
    }

    .dark .fi-tache-row-details-modal .fi-tache-statut-label--en-cours {
        color: #38bdf8;
        background: rgba(56, 189, 248, 0.14);
    }

    .fi-tache-row-details-modal .fi-tache-statut-label--termine {
        color: #16a34a;
        background: rgba(22, 163, 74, 0.12);
    }

    .dark .fi-tache-row-details-modal .fi-tache-statut-label--termine {
        color: #4ade80;
        background: rgba(74, 222, 128, 0.14);
    }

    .fi-tache-row-details-modal .fi-tache-statut-label--en-retard {
        color: #dc2626;
        background: rgba(220, 38, 38, 0.12);
    }

    .dark .fi-tache-row-details-modal .fi-tache-statut-label--en-retard {
        color: #f87171;
        background: rgba(248, 113, 113, 0.14);
    }

    .fi-tache-row-details-modal .fi-tache-statut-label--defaut {
        color: #6b7280;
    }

    .dark .fi-tache-row-details-modal .fi-tache-statut-label--defaut {
        color: #d1d5db;
    }

    /* Modal tâches : seul le bouton fermer est visible dans l’en-tête Filament */
    .fi-mission-taches-action-modal .fi-modal-header {
        padding-bottom: 0;
    }

    .fi-mission-taches-action-modal .fi-modal-heading {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border-width: 0;
    }

    /* Modal documents sujet : même schéma (fermeture seule dans l’en-tête Filament) */
    .fi-sujet-documents-action-modal .fi-modal-header {
        padding-bottom: 0;
    }

    .fi-sujet-documents-action-modal .fi-modal-heading {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border-width: 0;
    }

    .fi-sujet-documents-search-bar {
        margin-bottom: 0.25rem;
    }

    .fi-sujet-documents-search-inner {
        max-width: none;
        width: 100%;
    }

    .fi-sujet-documents-modal-list {
        max-height: min(60vh, 32rem);
        overflow-y: auto;
        padding-right: 0.125rem;
        scrollbar-gutter: stable;
    }

    .fi-lead-add-activity-row {
        display: flex;
        justify-content: flex-end;
        margin-bottom: 1rem;
    }

    .fi-lead-add-activity-btn {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        padding: 0.4rem 0.875rem;
        border-radius: 0.5rem;
        border: 1.5px solid #e2e8f0;
        background: #fff;
        color: #475569;
        font-size: 0.8125rem;
        font-weight: 500;
        cursor: pointer;
    }

    .fi-lead-add-activity-btn:hover {
        border-color: #cbd5e1;
        color: #334155;
    }

    .fi-lead-add-activity-btn-icon {
        width: 0.875rem;
        height: 0.875rem;
    }

    .dark .fi-lead-add-activity-btn {
        background: #0f172a;
        border-color: #334155;
        color: #94a3b8;
    }

    /* Documents (fiche lead / client) */
    .fi-lead-documents-panel {
        display: flex;
        flex-direction: column;
        gap: 1.5rem;
    }

    .fi-lead-documents-upload {
        padding: 1rem 1.125rem;
        border-radius: 0.625rem;
        border: 1.5px dashed #cbd5e1;
        background: #fff;
    }

    .dark .fi-lead-documents-upload {
        background: #0f172a;
        border-color: #334155;
    }

    .fi-lead-documents-label {
        display: block;
        font-size: 0.8125rem;
        font-weight: 600;
        color: #334155;
        margin-bottom: 0.25rem;
    }

    .dark .fi-lead-documents-label { color: #e2e8f0; }

    .fi-lead-documents-hint {
        font-size: 0.75rem;
        color: #94a3b8;
        margin: 0 0 0.75rem;
    }

    .fi-lead-documents-upload-row {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.75rem;
        width: 100%;
    }

    /* Zone entre « Sélect. fichiers » et « Téléverser » : sélection + dernier envoi sur la même ligne */
    .fi-lead-documents-upload-middle {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem 1rem;
    }

    /* Input fichier masqué : le navigateur ne permet pas d’insérer une icône devant son libellé natif. */
    .fi-lead-documents-picker-wrap {
        position: relative;
        display: inline-flex;
        align-items: center;
    }

    .fi-lead-documents-file-input-native {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
        opacity: 0;
    }

    .fi-lead-documents-pick-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0.4rem 0.85rem;
        border-radius: 0.5rem;
        border: 1.5px solid #e2e8f0;
        background: #f8fafc;
        color: #475569;
        font-size: 0.8125rem;
        font-weight: 500;
        cursor: pointer;
    }

    .fi-lead-documents-pick-btn:hover {
        background: #f1f5f9;
        border-color: #cbd5e1;
    }

    .dark .fi-lead-documents-pick-btn {
        background: #1e293b;
        border-color: #334155;
        color: #e2e8f0;
    }

    .fi-lead-documents-selected-inline {
        min-width: 0;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem 1rem;
    }

    .fi-lead-documents-selected-chip {
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
        min-width: 0;
        max-width: 100%;
        font-size: 0.8125rem;
        color: #334155;
    }

    .dark .fi-lead-documents-selected-chip {
        color: #e2e8f0;
    }

    .fi-lead-documents-selected-name {
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-weight: 500;
    }

    /* Pastille identique avant (gris) / après (vert) envoi — pas de coche SVG */
    .fi-lead-documents-pill {
        flex-shrink: 0;
        width: 0.5rem;
        height: 0.5rem;
        border-radius: 9999px;
    }

    .fi-lead-documents-pill--pending {
        background: #cbd5e1;
    }

    .dark .fi-lead-documents-pill--pending {
        background: #64748b;
    }

    .fi-lead-documents-pill--done {
        background: #16a34a;
    }

    .dark .fi-lead-documents-pill--done {
        background: #22c55e;
    }

    .fi-lead-documents-submit {
        margin-left: auto;
        padding: 0.45rem 1rem;
        border-radius: 0.5rem;
        border: none;
        background: #1c494f;
        color: #fff;
        font-size: 0.8125rem;
        font-weight: 600;
        cursor: pointer;
    }

    .fi-lead-documents-submit:disabled {
        opacity: 0.65;
        cursor: not-allowed;
    }

    /* Select type document (même teinte que bouton Téléverser) */
    .fi-lead-documents-type-select {
        width: 100%;
        padding: 0.45rem 0.85rem;
        border-radius: 0.5rem;
        appearance: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        background-color: #fff;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%231c494f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 0.75rem center;
        background-size: 1rem 1rem;
        padding-right: 2.4rem;
        box-shadow: 0 0 0 1px rgba(28, 73, 79, 0.35);
        outline: none;
    }

    .fi-lead-documents-type-select:focus {
        box-shadow:
            0 0 0 1px rgba(28, 73, 79, 0.55),
            0 0 0 3px rgba(28, 73, 79, 0.18);
    }

    .dark .fi-lead-documents-type-select {
        background-color: rgba(255, 255, 255, 0.04);
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%2394a3b8' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 0.75rem center;
        background-size: 1rem 1rem;
        box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.35);
    }

    .dark .fi-lead-documents-type-select:focus {
        box-shadow:
            0 0 0 1px rgba(148, 163, 184, 0.55),
            0 0 0 3px rgba(148, 163, 184, 0.18);
    }

    .fi-lead-documents-error {
        margin: 0.5rem 0 0;
        font-size: 0.8125rem;
        color: #dc2626;
    }

    .fi-lead-documents-loading {
        margin-top: 0.5rem;
        font-size: 0.8125rem;
        color: #64748b;
    }

    .fi-lead-documents-just-uploaded {
        list-style: none;
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem 1rem;
    }

    .fi-lead-documents-just-uploaded-item {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        font-size: 0.8125rem;
        font-weight: 600;
        color: #166534;
    }

    .dark .fi-lead-documents-just-uploaded-item {
        color: #86efac;
    }

    .fi-lead-documents-just-uploaded-name {
        word-break: break-word;
    }

    .fi-lead-documents-list {
        list-style: none;
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
    }

    .fi-lead-document-row {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.75rem 1rem;
        border-radius: 0.625rem;
        border: 1.5px solid #f1f5f9;
        background: #fff;
    }

    .dark .fi-lead-document-row {
        background: #0f172a;
        border-color: #334155;
    }

    .fi-lead-document-row-main {
        flex: 1;
        min-width: 0;
    }

    .fi-lead-document-name {
        display: block;
        flex: 1;
        min-width: 0;
        font-size: 0.875rem;
        font-weight: 600;
        color: #1e293b;
        word-break: break-word;
    }

    .dark .fi-lead-document-name { color: #f1f5f9; }

    .fi-lead-document-meta {
        display: block;
        margin-top: 0.25rem;
        font-size: 0.75rem;
        color: #94a3b8;
    }

    .fi-lead-document-row-actions {
        display: flex;
        flex-shrink: 0;
        flex-wrap: wrap;
        gap: 0.375rem;
        justify-content: flex-end;
    }

    .fi-lead-document-btn {
        padding: 0.35rem 0.65rem;
        border-radius: 0.45rem;
        font-size: 0.75rem;
        font-weight: 600;
        cursor: pointer;
        border: 1.5px solid #e2e8f0;
        background: #fff;
        color: #475569;
    }

    .fi-lead-document-btn--download:hover {
        border-color: #1c494f;
        color: #1c494f;
    }

    .fi-lead-document-btn--delete {
        border-color: #fecaca;
        color: #b91c1c;
        background: #fff;
    }

    .fi-lead-document-btn--delete:hover {
        background: #fef2f2;
    }

    .fi-lead-empty-state--documents {
        padding: 2rem 1rem;
    }

    /* Notes */
    .fi-lead-notes-panel {
        display: flex;
        flex-direction: column;
    }

    .fi-lead-notes-textarea {
        height: auto;
        min-height: 10rem;
        resize: vertical;
        font-size: 0.9rem;
        line-height: 1.6;
    }

    /* État vide */
    .fi-lead-empty-state {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 3rem 1rem;
        color: #94a3b8;
        font-size: 0.9rem;
        text-align: center;
    }

    /* Bouton édition sur chaque ligne */
    .fi-action-edit-btn {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.75rem;
        height: 1.75rem;
        border-radius: 0.4rem;
        border: 1.5px solid #e2e8f0;
        background: #f8fafc;
        color: #94a3b8;
        cursor: pointer;
        opacity: 0;
        transition: opacity 0.15s, background 0.12s;
        margin-left: auto;
    }

    .fi-action-row:hover .fi-action-edit-btn {
        opacity: 1;
    }

    .fi-action-edit-btn:hover {
        background: #f1f5f9;
        color: #475569;
        border-color: #cbd5e1;
    }

    .dark .fi-action-edit-btn {
        background: #1e293b;
        border-color: #334155;
        color: #64748b;
    }

    /* Champs du drawer */
    .fi-edit-field {
        display: flex;
        flex-direction: column;
        gap: 0.375rem;
    }

    .fi-edit-label {
        font-size: 0.8125rem;
        font-weight: 600;
        color: #374151;
    }

    .dark .fi-edit-label { color: #cbd5e1; }

    .fi-edit-select,
    .fi-edit-input {
        width: 100%;
        height: 2.375rem;
        padding: 0 0.875rem;
        border-radius: 0.5rem;
        border: 1.5px solid #e2e8f0;
        background: #fff;
        font-size: 0.875rem;
        color: #1e293b;
        box-shadow: 0 1px 2px rgba(0,0,0,0.04);
        appearance: none;
        -webkit-appearance: none;
    }

    .fi-edit-select {
        padding-right: 2.25rem;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 0.75rem center;
        background-size: 1rem;
    }

    .fi-edit-select:focus,
    .fi-edit-input:focus {
        outline: none;
        border-color: #689D71;
        box-shadow: none;
    }

    textarea.fi-edit-input {
        height: auto;
        min-height: 6rem;
        padding-top: 0.5rem;
        padding-bottom: 0.5rem;
        line-height: 1.5;
    }

    textarea.fi-edit-input[readonly] {
        resize: none;
    }

    /* Détail activité : même rendu que le formulaire, non éditable */
    .fi-edit-select:disabled,
    .fi-edit-input[readonly] {
        opacity: 1;
        cursor: default;
        background-color: #f8fafc;
        color: #1e293b;
        border-color: #e2e8f0;
        box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
    }

    .dark .fi-edit-select:disabled,
    .dark .fi-edit-input[readonly] {
        background-color: #1e293b;
        color: #f1f5f9;
        border-color: #334155;
    }

    .fi-lead-activity-meta-line {
        font-size: 0.75rem;
        color: #94a3b8;
        margin: 0;
        line-height: 1.5;
    }

    .dark .fi-lead-activity-meta-line {
        color: #64748b;
    }

    .dark .fi-edit-select,
    .dark .fi-edit-input {
        background-color: #0f172a;
        border-color: #334155;
        color: #f1f5f9;
    }

    .fi-edit-error {
        font-size: 0.75rem;
        color: #dc2626;
        margin: 0;
    }

/* ── Layout ──────────────────────────────────────────────────────────── */
.rp-page { display:flex; flex-direction:column; gap:1.25rem; padding-bottom:3rem; }

.rp-header {
    display:flex; justify-content:space-between; align-items:flex-start;
    flex-wrap:wrap; gap:0.75rem; padding-bottom:0.5rem;
    border-bottom:1px solid #e5e7eb;
}
.rp-page-title  { font-size:1.375rem; font-weight:700; color:#0f172a; margin:0; }
.rp-page-subtitle { font-size:0.8125rem; color:#64748b; margin:0.15rem 0 0; }
.rp-header-actions { display:flex; gap:0.5rem; align-items:center; flex-wrap:wrap; }

.rp-reporting-toolbar {
    display:flex; justify-content:space-between; align-items:center;
    gap:1rem; flex-wrap:wrap; margin-bottom:0.75rem;
}
.rp-reporting-toolbar--taches {
    justify-content:space-between; align-items:center;
}
.rp-reporting-toolbar--with-budget {
    align-items:flex-end;
}
.rp-reporting-toolbar--with-budget .rp-budget-totals {
    align-items:flex-end;
}
.rp-reporting-toolbar .rp-date-range-toolbar {
    margin-bottom:0;
}
/* Filtre période (mois) — aligné sur le tableau reporting compact */
.rp-reporting-toolbar .rp-select {
    height:1.875rem;
    padding:0 1.625rem 0 0.5rem;
    font-size:0.75rem;
    line-height:1.25rem;
    border-width:1px;
    border-radius:0.375rem;
    background-size:0.875rem;
    background-position:right 0.5rem center;
}

/* Tous les tableaux Filament natifs (panel admin) — compact comme reporting */
body.fi-panel-admin .fi-ta {
    --fi-compact-table-font-size:0.75rem;
    --fi-compact-table-line-height:1.25rem;
}
body.fi-panel-admin .fi-ta .text-sm,
body.fi-panel-admin .fi-ta .text-base {
    font-size:var(--fi-compact-table-font-size) !important;
    line-height:var(--fi-compact-table-line-height) !important;
}
body.fi-panel-admin .fi-ta-header-cell-label {
    font-size:var(--fi-compact-table-font-size);
    line-height:1.125rem;
}
body.fi-panel-admin .fi-ta-header-cell {
    padding-top:0.5rem;
    padding-bottom:0.5rem;
}
body.fi-panel-admin .fi-ta-cell {
    padding-top:0.375rem;
    padding-bottom:0.375rem;
}
body.fi-panel-admin .fi-ta-cell .fi-ta-text {
    gap:0.125rem;
}
body.fi-panel-admin .fi-ta-filters-above-content-ctn,
body.fi-panel-admin .fi-ta-header-toolbar,
body.fi-panel-admin .fi-ta-filter-indicators,
body.fi-panel-admin .fi-ta-pagination {
    font-size:var(--fi-compact-table-font-size);
}
body.fi-panel-admin .fi-ta input.fi-input,
body.fi-panel-admin .fi-ta .choices__inner,
body.fi-panel-admin .fi-ta .fi-select-input-value-ctn {
    font-size:var(--fi-compact-table-font-size) !important;
}
body.fi-panel-admin .fi-ta-header-toolbar .fi-btn {
    font-size:var(--fi-compact-table-font-size);
    line-height:var(--fi-compact-table-line-height);
    padding:0.375rem 0.625rem;
    min-height:1.875rem;
}
body.fi-panel-admin .fi-ta-header-toolbar .fi-icon-btn {
    width:1.75rem;
    height:1.75rem;
    margin:0;
}
body.fi-panel-admin .fi-ta .fi-badge {
    font-size:0.6875rem;
    line-height:1rem;
    padding:0.125rem 0.375rem;
}
body.fi-panel-admin .fi-ta-actions .fi-icon-btn {
    width:1.75rem;
    height:1.75rem;
}
.rp-reporting-resource-table .rp-budget-total-label {
    font-size:0.6875rem;
}
.rp-reporting-resource-table .rp-budget-total-value {
    font-size:1.25rem;
    font-weight:700;
    letter-spacing:-0.01em;
}

/* Listes ressources Filament — en-tête aligné reporting */
body.fi-panel-admin .fi-resource-list-records-page .fi-header-heading,
body.fi-panel-admin .fi-resource-manage-related-records-page .fi-header-heading {
    font-size:1.375rem;
    line-height:1.75rem;
}
body.fi-panel-admin .fi-resource-list-records-page .fi-header-subheading,
body.fi-panel-admin .fi-resource-manage-related-records-page .fi-header-subheading {
    font-size:0.8125rem;
    line-height:1.25rem;
}
body.fi-panel-admin .fi-resource-list-records-page .fi-header .fi-btn,
body.fi-panel-admin .fi-resource-manage-related-records-page .fi-header .fi-btn {
    font-size:0.8125rem;
    line-height:1.25rem;
    padding:0.4375rem 0.75rem;
    min-height:2rem;
}
body.fi-panel-admin .fi-resource-list-records-page .fi-header .fi-btn .fi-btn-icon,
body.fi-panel-admin .fi-resource-manage-related-records-page .fi-header .fi-btn .fi-btn-icon {
    width:1rem;
    height:1rem;
}
body.fi-panel-admin .fi-resource-list-records-page > section,
body.fi-panel-admin .fi-resource-manage-related-records-page > section {
    gap:1.25rem;
}
.rp-taches-scope-select {
    display:inline-flex; width:auto; max-width:100%;
}
.rp-taches-scope-select .rp-select {
    width:auto; min-width:9.25rem; max-width:min(100%, 10.5rem);
}
.rp-date-range-toolbar {
    display:flex; gap:0.75rem; flex-wrap:wrap; align-items:flex-end;
    margin-bottom:0.75rem;
}
.rp-date-presets {
    display:flex; gap:0.35rem; flex-wrap:wrap; align-items:center;
}
.rp-date-preset {
    border:1px solid #d1d5db; border-radius:0.375rem; background:#fff;
    color:#334155; font-size:0.75rem; font-weight:600; padding:0.35rem 0.65rem;
    cursor:pointer; transition:background-color .15s ease,border-color .15s ease,color .15s ease;
}
.dark .rp-date-preset {
    background:#0f172a; border-color:#334155; color:#e2e8f0;
}
.rp-date-preset--active {
    background:#689D71; border-color:#689D71; color:#fff;
}
.dark .rp-date-preset--active {
    background:#689D71; border-color:#689D71; color:#fff;
}
.rp-date-range {
    display:flex; gap:0.75rem; flex-wrap:wrap; align-items:flex-end;
}
.rp-date-field {
    display:flex; flex-direction:column; gap:0.15rem;
}
.rp-date-label {
    font-size:0.6875rem; font-weight:500; color:#64748b;
    text-transform:uppercase; letter-spacing:0.02em;
}
.dark .rp-date-label { color:#94a3b8; }
.rp-date-input {
    width:8.75rem; max-width:100%; border:1px solid #d1d5db; border-radius:0.375rem;
    padding:0.3rem 0.45rem; font-size:0.75rem; color:#0f172a; background:#fff;
}
.dark .rp-date-input {
    background:#0f172a; border-color:#334155; color:#f1f5f9;
}
.rp-budget-totals {
    display:flex; justify-content:flex-end; align-items:center;
    gap:1.5rem; flex-wrap:wrap;
}
.rp-budget-total { text-align:right; }
.rp-budget-total-label {
    font-size:0.75rem; font-weight:500; color:#64748b;
    text-transform:uppercase; letter-spacing:0.02em;
}
.dark .rp-budget-total-label { color:#94a3b8; }
.rp-budget-total-value {
    font-size:1.5rem; font-weight:700; color:#0f172a; line-height:1.2;
    margin-top:0.15rem;
}
.dark .rp-budget-total-value { color:#f1f5f9; }

/* ── Carte de base ───────────────────────────────────────────────────── */
.rp-card {
    background:#fff; border-radius:0.875rem;
    border:1px solid #e5e7eb;
    box-shadow:0 1px 3px 0 rgba(0,0,0,.06),0 1px 2px -1px rgba(0,0,0,.04);
    padding:1.25rem 1.5rem;
}
.dark .rp-card { background:#1e293b; border-color:#334155; }
.rp-card-title {
    font-size:0.9375rem; font-weight:600; color:#1e293b;
    margin:0 0 1rem; padding:0;
}
.dark .rp-card-title { color:#f1f5f9; }
.rp-card-subtitle { font-size:0.7rem; font-weight:400; color:#9ca3af; }

/* ── KPI grid ────────────────────────────────────────────────────────── */
.rp-kpi-grid {
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(175px,1fr));
    gap:1rem;
}
.rp-kpi-card {
    background:#fff;
    border-radius:0.875rem;
    border:1px solid #e5e7eb;
    box-shadow:0 1px 4px rgba(0,0,0,.05);
    padding:1.1rem 1.25rem 1rem;
    display:flex;
    flex-direction:column;
    gap:0;
    transition:box-shadow .15s, transform .15s;
    position:relative;
    overflow:hidden;
}
.rp-kpi-card::after {
    content:'';
    position:absolute;
    inset:auto 0 0 0;
    height:3px;
    border-radius:0 0 0.875rem 0.875rem;
    background:var(--rp-kpi-accent, #e5e7eb);
}
.rp-kpi-card:hover { box-shadow:0 6px 18px rgba(0,0,0,.09); transform:translateY(-1px); }

.rp-kpi-card--link,
.rp-card--link,
a.rp-clickable {
    cursor:pointer;
    text-decoration:none;
    color:inherit;
    display:block;
}
.rp-kpi-card--link:focus-visible,
.rp-card--link:focus-visible,
a.rp-clickable:focus-visible {
    outline:2px solid var(--rp-primary);
    outline-offset:2px;
}
.rp-donut-legend-link {
    display:flex; align-items:center; gap:0.35rem;
    flex:1; min-width:0;
    text-decoration:none; color:inherit;
    border-radius:0.375rem;
    padding:0.15rem 0.25rem;
    margin:-0.15rem -0.25rem;
    transition:background .12s;
}
.rp-donut-legend-link--spaced {
    gap:1.25rem;
    width:100%;
}
.rp-donut-legend-link--spaced .rp-donut-legend-label {
    flex:1;
    min-width:0;
    padding-right:0.5rem;
}
.rp-donut-legend-link--spaced .rp-donut-legend-value {
    flex:0 0 auto;
    min-width:6.5rem;
    text-align:right;
    font-variant-numeric:tabular-nums;
}
.rp-donut-legend-link:hover { background:rgba(0,0,0,.04); }
.dark .rp-donut-legend-link:hover { background:rgba(255,255,255,.06); }
.rp-bar-row--link { cursor:pointer; text-decoration:none; color:inherit; }
.rp-bar-row--link:hover .rp-bar-label { color:var(--rp-primary); }
.rp-tl-row--link { cursor:pointer; text-decoration:none; color:inherit; }
.rp-tl-row--link:hover .rp-tl-name { color:var(--rp-primary); }
.rp-table-row--clickable:hover td { background:rgba(0,0,0,.03); }
.dark .rp-table-row--clickable:hover td { background:rgba(255,255,255,.04); }
.dark .rp-kpi-card { background:#1e293b; border-color:#334155; }

.rp-kpi-icon {
    width:2.25rem; height:2.25rem; border-radius:0.6rem;
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
    position:absolute; top:1rem; right:1rem;
    opacity:.85;
}
.rp-kpi-icon svg { width:1.2rem; height:1.2rem; }

/* Reporting / KPI couleurs */
.rp-kpi-indigo,
.rp-kpi-primary { --rp-kpi-accent:var(--rp-primary); }
.rp-kpi-indigo .rp-kpi-icon,
.rp-kpi-primary .rp-kpi-icon {
    background:color-mix(in srgb, var(--rp-primary) 14%, white);
    color:var(--rp-primary);
}
.dark .rp-kpi-indigo .rp-kpi-icon,
.dark .rp-kpi-primary .rp-kpi-icon {
    background:color-mix(in srgb, var(--rp-primary) 22%, #0f172a);
    color:color-mix(in srgb, var(--rp-primary) 92%, white);
}
.rp-kpi-green  { --rp-kpi-accent:#10b981; }
.rp-kpi-green  .rp-kpi-icon { background:#d1fae5; color:#10b981; }
.rp-kpi-blue   { --rp-kpi-accent:#3b82f6; }
.rp-kpi-blue   .rp-kpi-icon { background:#dbeafe; color:#3b82f6; }
.rp-kpi-amber  { --rp-kpi-accent:#f59e0b; }
.rp-kpi-amber  .rp-kpi-icon { background:#fef3c7; color:#d97706; }
.rp-kpi-orange { --rp-kpi-accent:#f97316; }
.rp-kpi-orange .rp-kpi-icon { background:#ffedd5; color:#f97316; }
.rp-kpi-red    { --rp-kpi-accent:#ef4444; }
.rp-kpi-red    .rp-kpi-icon { background:#fee2e2; color:#ef4444; }

.rp-kpi-body { display:flex; flex-direction:column; }
.rp-kpi-label { font-size:0.75rem; font-weight:500; color:#94a3b8; margin-bottom:0.35rem; text-transform:uppercase; letter-spacing:0.04em; }
.rp-kpi-value { font-size:2rem; font-weight:800; color:#0f172a; line-height:1; letter-spacing:-0.03em; }
.dark .rp-kpi-value { color:#f1f5f9; }
.rp-kpi-sub   { font-size:0.72rem; font-weight:500; color:#94a3b8; margin-top:0.45rem; display:flex; align-items:center; gap:0.25rem; }

/* ── 2-col layout ────────────────────────────────────────────────────── */
.rp-two-col { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1rem; }
.rp-two-col--charts { grid-template-columns:repeat(2, minmax(0, 1fr)); }
.rp-chart-card-head {
    display:flex; align-items:center; justify-content:space-between; gap:0.75rem;
    margin-bottom:0.5rem;
}
.rp-donut-legend-link--static {
    display:flex; align-items:center; gap:0.5rem;
    flex:1; min-width:0;
    cursor:default;
}

/* ── Barres horizontales ─────────────────────────────────────────────── */
.rp-bar-list { display:flex; flex-direction:column; gap:0.6rem; }
.rp-bar-row  { display:flex; align-items:center; gap:0.5rem; }
.rp-bar-label {
    display:flex; align-items:center; gap:0.35rem;
    min-width:130px; font-size:0.75rem; color:#374151; flex-shrink:0;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:160px;
}
.dark .rp-bar-label { color:#cbd5e1; }
.rp-bar-track {
    flex:1; height:6px; background:#f3f4f6; border-radius:9999px; overflow:hidden;
}
.dark .rp-bar-track { background:#334155; }
.rp-bar-fill { height:100%; border-radius:9999px; transition:width .4s ease; }
.rp-bar-count { font-size:0.7rem; font-weight:600; color:#6b7280; min-width:2.5rem; text-align:right; }

/* ── Graphique barres verticales ─────────────────────────────────────── */
/* Le parent des barres a une hauteur fixe : sinon height:% sur le fill ne s’applique pas
   (traits plats ~3px au lieu de vraies barres). */
.rp-chart-bars {
    display:flex; gap:0.5rem; align-items:flex-end;
    min-height:11rem; padding-top:0.5rem;
    overflow-x:auto; padding-bottom:0.25rem;
}
.rp-evolution-card__head {
    display:flex; align-items:center; justify-content:space-between; gap:0.75rem;
    margin-bottom:0.5rem;
}
.rp-evolution-card__head .rp-section-label { margin-bottom:0; }
.rp-evolution-card__link {
    flex-shrink:0;
    font-size:0.72rem; font-weight:600; color:var(--rp-primary);
    text-decoration:none; white-space:nowrap;
}
.rp-evolution-card__link:hover { text-decoration:underline; }
.rp-evolution-card__chart {
    overscroll-behavior-x:contain;
    -webkit-overflow-scrolling:touch;
    touch-action:pan-x;
}
.rp-chart-bar-col {
    display:flex; flex-direction:column; align-items:center;
    justify-content:flex-end;
    gap:0.35rem; flex:1; min-width:44px;
}
.rp-chart-bar-wrap {
    width:100%;
    height:9rem;
    min-height:9rem;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    align-items:stretch;
    background:#f1f5f9;
    border-radius:4px 4px 0 0;
    box-sizing:border-box;
    padding:0 4px;
}
.dark .rp-chart-bar-wrap { background:#1e293b; }
.rp-chart-bar-fill {
    width:100%; border-radius:4px 4px 0 0;
    transition:height .35s ease;
    flex-shrink:0;
    /* Au moins 6px si données non nulles : la hauteur réelle vient du style inline % */
    min-height:0;
}
.rp-bg-indigo,
.rp-bg-primary { background:var(--rp-primary, #689D71); }
.rp-bg-blue   { background:#3b82f6; }
.rp-bg-green  { background:#10b981; }
.rp-bg-amber  { background:#f59e0b; }
.rp-bg-red    { background:#ef4444; }
.rp-chart-bar-count {
    font-size:0.75rem; font-weight:700; color:#374151; line-height:1.2; min-height:1.1rem;
}
.dark .rp-chart-bar-count { color:#e2e8f0; }
.rp-chart-bar-label { font-size:0.6rem; color:#9ca3af; text-align:center; white-space:nowrap; line-height:1.2; }
.rp-chart-bar-due {
    font-size:0.75rem; font-weight:700; color:#374151; line-height:1.2; min-height:1.1rem;
}
.dark .rp-chart-bar-due { color:#e2e8f0; }
.rp-chart-bars--uniform .rp-chart-bar-fill { height:100% !important; min-height:6px; }
.rp-chart-bars--uniform .rp-chart-bar-col {
    display:grid;
    grid-template-rows:1.25rem 9rem 2.65rem;
    align-items:end;
    justify-content:stretch;
}
.rp-chart-bars--uniform .rp-chart-bar-due {
    align-self:end;
    justify-self:center;
}
.rp-chart-bars--uniform .rp-chart-bar-wrap {
    align-self:end;
}
.rp-chart-bar-meta {
    display:flex; flex-direction:column; align-items:center; gap:0.15rem;
    max-width:100%; min-width:0;
}
.rp-chart-bars--uniform .rp-chart-bar-label {
    max-width:100%; overflow:hidden; text-overflow:ellipsis;
}
.rp-chart-bars--uniform .rp-chart-bar-meta {
    height:2.65rem;
    justify-content:flex-start;
    overflow:hidden;
}
.rp-chart-bar-client {
    font-size:0.55rem; color:#6b7280; text-align:center; line-height:1.2;
    max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.dark .rp-chart-bar-client { color:#94a3b8; }
.rp-chart-bar-col--link {
    text-decoration:none; color:inherit; border-radius:0.25rem;
    transition:opacity .15s ease;
}
.rp-chart-bar-col--link:hover .rp-chart-bar-fill { opacity:.85; }
.rp-chart-bar-col--link:focus-visible {
    outline:2px solid var(--rp-primary); outline-offset:2px;
}

/* ── Grille secteur ──────────────────────────────────────────────────── */
.rp-sector-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:0.75rem; }
.rp-sector-item { background:#f9fafb; border-radius:0.5rem; padding:0.6rem 0.75rem; }
.dark .rp-sector-item { background:#0f172a; }
.rp-sector-name  { font-size:0.75rem; font-weight:500; color:#374151; margin-bottom:0.4rem; }
.dark .rp-sector-name { color:#cbd5e1; }
.rp-sector-count { font-size:0.7rem; color:#9ca3af; margin-top:0.3rem; text-align:right; }

/* ── Tableau ─────────────────────────────────────────────────────────── */
.rp-table-wrap { overflow-x:auto; border-radius:0.5rem; }
.rp-table { width:100%; border-collapse:collapse; font-size:0.8125rem; }
.rp-table thead tr { background:#f8fafc; }
.dark .rp-table thead tr { background:#0f172a; }
.rp-table th {
    padding:0.5rem 0.75rem; text-align:left;
    font-size:0.6875rem; font-weight:600; color:#6b7280;
    text-transform:uppercase; letter-spacing:.04em;
    border-bottom:1px solid #e5e7eb; white-space:nowrap;
}
.dark .rp-table th { border-color:#334155; color:#94a3b8; }
.rp-table td { padding:0.55rem 0.75rem; border-bottom:1px solid #f1f5f9; vertical-align:middle; }
.dark .rp-table td { border-color:#1e293b; }
.rp-table tbody tr:hover { background:#fafafa; }
.dark .rp-table tbody tr:hover { background:#1e293b; }
.rp-table tbody tr:last-child td { border-bottom:none; }
.rp-td-bold { font-weight:500; color:#0f172a; }
.dark .rp-td-bold { color:#f1f5f9; }
.rp-td-muted { color:#6b7280; font-size:0.75rem; }
.rp-td-danger { color:#ef4444 !important; font-weight:600; }
.rp-tr-highlight { background:#f0f9ff !important; }
.dark .rp-tr-highlight { background:#0c2340 !important; }
.rp-empty-row { text-align:center; color:#9ca3af; padding:2rem !important; font-size:0.8125rem; }

/* ── Éléments ─────────────────────────────────────────────────────────  */
.rp-badge {
    display:inline-block; padding:0.15rem 0.6rem;
    border-radius:9999px; font-size:0.6875rem; font-weight:500;
    white-space:nowrap;
}
.rp-badge-gray { background:#f3f4f6; color:#374151; }
.dark .rp-badge-gray { background:#334155; color:#cbd5e1; }

.rp-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; display:inline-block; }

.rp-avatar-xs {
    width:1.25rem; height:1.25rem; border-radius:50%; flex-shrink:0;
    background:#e0e7ff; color:#4f46e5; font-size:0.6rem; font-weight:700;
    display:inline-flex; align-items:center; justify-content:center;
}

.rp-score-pill {
    display:inline-block; padding:0.1rem 0.5rem; border-radius:9999px;
    font-size:0.7rem; font-weight:600;
}

.rp-link { color:var(--rp-primary); text-decoration:none; }
.rp-link:hover { text-decoration:underline; filter:brightness(0.92); }
.dark .rp-link { color:color-mix(in srgb, var(--rp-primary) 88%, #fff); }

.rp-empty { font-size:0.8125rem; color:#9ca3af; text-align:center; padding:1.5rem 0; }

/* ── Select / contrôles ───────────────────────────────────────────────── */
.rp-select {
    display:inline-block;
    height:2.375rem;
    padding:0 2.25rem 0 0.75rem;
    border-radius:0.5rem;
    border:1.5px solid #e2e8f0;
    background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 0.75rem center/1rem;
    font-size:0.8125rem;
    color:#374151;
    appearance:none;
    -webkit-appearance:none;
    cursor:pointer;
    box-shadow:0 1px 3px rgba(0,0,0,.05);
    white-space:nowrap;
    max-width:100%;
    min-width:0;
    box-sizing:border-box;
}
.rp-select:focus,
.rp-select:focus-visible {
    outline: none;
    border-color: var(--rp-primary);
    /* Une seule indication de focus : bordure verte (pas d’anneau Tailwind / bleu par-dessus) */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
    --tw-ring-shadow: 0 0 #0000 !important;
    --tw-ring-offset-shadow: 0 0 #0000 !important;
}
.dark .rp-select {
    background-color: #1e293b;
    border-color: #334155;
    color: #f1f5f9;
}
.dark .rp-select:focus,
.dark .rp-select:focus-visible {
    border-color: var(--rp-primary);
    --tw-ring-shadow: 0 0 #0000 !important;
    --tw-ring-offset-shadow: 0 0 #0000 !important;
}

.rp-btn-secondary {
    display:inline-flex; align-items:center; gap:0.35rem;
    height:2.1rem; padding:0 0.75rem; border-radius:0.5rem;
    border:1.5px solid #e2e8f0; background:#fff; color:#374151;
    font-size:0.8125rem; font-weight:500; cursor:pointer;
    box-shadow:0 1px 2px rgba(0,0,0,.05); transition:all .15s;
}
.rp-btn-secondary:hover { background:#f1f5f9; border-color:#cbd5e1; }
.dark .rp-btn-secondary { background:#1e293b; border-color:#475569; color:#e2e8f0; }

/* ── Bouton Mes tâches ────────────────────────────────────────────────── */
.rp-btn-mes-taches {
    display:inline-flex; align-items:center; gap:0.35rem;
    height:2.1rem; padding:0 0.85rem; border-radius:0.5rem;
    border:1.5px solid color-mix(in srgb, var(--rp-primary) 32%, #e2e8f0);
    background:color-mix(in srgb, var(--rp-primary) 9%, #f8fafc);
    color:var(--rp-primary);
    font-size:0.8125rem; font-weight:600; cursor:pointer;
    transition:all .15s;
}
.rp-btn-mes-taches:hover { background:color-mix(in srgb, var(--rp-primary) 16%, #f1f5f9); }
.rp-btn-mes-taches--active {
    background:var(--rp-primary); color:#fff; border-color:var(--rp-primary);
}
.rp-btn-mes-taches--active:hover { filter:brightness(0.92); }
.rp-badge-filter-mes-taches {
    font-size:0.75rem; font-weight:500; padding:0.2rem 0.6rem; border-radius:9999px;
    color:var(--rp-primary);
    background:color-mix(in srgb, var(--rp-primary) 10%, #f8fafc);
    border:1px solid color-mix(in srgb, var(--rp-primary) 22%, #e2e8f0);
}
.dark .rp-badge-filter-mes-taches {
    background:color-mix(in srgb, var(--rp-primary) 12%, #0f172a);
    border-color:color-mix(in srgb, var(--rp-primary) 35%, #334155);
}

/* ── Sélecteur de mission ─────────────────────────────────────────────── */
.rp-mission-grid {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:0.75rem;
}
.rp-mission-selector-card {
    display:flex; flex-direction:column; gap:0.3rem;
    padding:1rem 1.1rem; border-radius:0.75rem;
    border:1.5px solid #e2e8f0; background:#fafafa; cursor:pointer;
    text-align:left; transition:all .2s; position:relative;
}
.rp-mission-selector-card:hover {
    border-color:var(--rp-primary);
    background:color-mix(in srgb, var(--rp-primary) 5%, #fff);
    box-shadow:0 4px 12px color-mix(in srgb, var(--rp-primary) 22%, transparent);
    transform:translateY(-2px);
}
.dark .rp-mission-selector-card { background:#0f172a; border-color:#334155; }
.dark .rp-mission-selector-card:hover { border-color:var(--rp-primary); background:color-mix(in srgb, var(--rp-primary) 8%, #0f172a); }

.rp-mission-selector-header { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.25rem; }
.rp-mission-selector-icon {
    width:1.75rem; height:1.75rem; border-radius:0.4rem;
    background:color-mix(in srgb, var(--rp-primary) 14%, white);
    color:var(--rp-primary);
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.rp-mission-selector-icon svg { width:1rem; height:1rem; }
.rp-mission-selector-name { font-size:0.875rem; font-weight:600; color:#0f172a; line-height:1.3; }
.dark .rp-mission-selector-name { color:#f1f5f9; }
.rp-mission-selector-code { font-size:0.65rem; color:#9ca3af; font-family:monospace; }
.rp-mission-selector-client { font-size:0.75rem; color:var(--rp-primary); font-weight:500; }
.rp-mission-selector-arrow {
    position:absolute; bottom:0.75rem; right:0.75rem;
    width:1rem; height:1rem; color:#9ca3af; opacity:0; transition:opacity .2s;
}
.rp-mission-selector-card:hover .rp-mission-selector-arrow { opacity:1; color:var(--rp-primary); }

/* Badges statut mission dans sélecteur */
.rp-mission-selector-status {
    font-size:0.6rem; font-weight:600; padding:0.1rem 0.5rem;
    border-radius:9999px; white-space:nowrap;
}
.rp-mission-status-en_cours         { background:#d1fae5; color:#065f46; }
.rp-mission-status-termine           { background:#dbeafe; color:#1e40af; }
.rp-mission-status-planifie          { background:#e0e7ff; color:#3730a3; }
.rp-mission-status-en_pause          { background:#fef3c7; color:#92400e; }
.rp-mission-status-annule            { background:#fee2e2; color:#991b1b; }
.rp-mission-status-negociation       { background:#fef9c3; color:#713f12; }
.rp-mission-status-prospection       { background:#f3e8ff; color:#6b21a8; }
.rp-mission-status-en_attente_validation { background:#fef9c3; color:#713f12; }

/* ── Reporting tableau de bord (shell) ─────────────────────────────────── */
.rp-db { display:flex; flex-direction:column; }

/* Barre nav : onglets + contrôles côte à côte */
.rp-db-bar {
    display:flex; align-items:stretch; justify-content:space-between;
    gap:0.5rem; flex-wrap:wrap;
    border-bottom:2px solid #e5e7eb;
}
.dark .rp-db-bar { border-color:#334155; }

.rp-db-tabs { display:flex; flex-wrap:wrap; margin-bottom:-2px; }

.rp-db-tab {
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:0.4rem;
    padding:0.6rem 0.9rem;
    font-size:0.8125rem;
    font-weight:500;
    line-height:1;
    color:#64748b;
    border:none;
    border-bottom:2px solid transparent;
    background:transparent;
    cursor:pointer;
    white-space:nowrap;
    transition:color .12s, border-color .12s;
}
.rp-db-tab:hover { color:#1e293b; }
.dark .rp-db-tab { color:#94a3b8; }
.dark .rp-db-tab:hover { color:#f1f5f9; }
.rp-db-tab--on {
    color:var(--rp-primary, #689D71);
    border-bottom-color:var(--rp-primary, #689D71);
    font-weight:600;
}
.rp-db-tab-icon {
    display:block;
    width:1rem;
    height:1rem;
    flex-shrink:0;
    margin:0;
    opacity:.75;
}
.rp-db-tab--on .rp-db-tab-icon { opacity:1; }

/* Contrôles droite (select période / année + bouton rapport) */
.rp-db-actions {
    display:flex; align-items:center; gap:0.4rem;
    padding:0.4rem 0;
}
/* Même principe que .rp-select : flèche native masquée + chevron SVG, sinon double icônes / chevauchement texte */
.rp-db-select {
    display:inline-block;
    height:2rem;
    min-width:6.25rem;
    padding:0 1.875rem 0 0.55rem;
    border:1px solid #e2e8f0;
    border-radius:0.375rem;
    background-color:#fff;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 0.45rem center;
    background-size:0.875rem;
    font-size:0.75rem; line-height:1.2; color:#374151;
    cursor:pointer; outline:none;
    appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;
    box-sizing:border-box;
    transition:border-color .12s;
}
.dark .rp-db-select {
    background-color:#1e293b;
    border-color:#475569;
    color:#f1f5f9;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");
}
.rp-db-select:focus,
.rp-db-select:focus-visible {
    border-color: var(--rp-primary, #689D71);
    outline: none;
    --tw-ring-shadow: 0 0 #0000 !important;
    --tw-ring-offset-shadow: 0 0 #0000 !important;
}
.dark .rp-db-select:focus,
.dark .rp-db-select:focus-visible {
    border-color: var(--rp-primary, #689D71);
    --tw-ring-shadow: 0 0 #0000 !important;
    --tw-ring-offset-shadow: 0 0 #0000 !important;
}

.rp-db-detail-btn {
    display:inline-flex; align-items:center; gap:0.3rem;
    font-size:0.75rem; font-weight:500; color:#64748b;
    padding:0.275rem 0.625rem; border-radius:0.375rem;
    border:1px solid #e2e8f0; text-decoration:none;
    transition:color .12s, border-color .12s;
}
.rp-db-detail-btn:hover { color:var(--rp-primary, #689D71); border-color:var(--rp-primary, #689D71); }
.dark .rp-db-detail-btn { border-color:#475569; color:#94a3b8; }
.rp-db-detail-btn svg { width:0.75rem; height:0.75rem; }

/* Contenu onglet */
.rp-db-panel { padding-top:1.125rem; }
.rp-db-pane { display:flex; flex-direction:column; gap:0.875rem; }

/* Labels de section minimalistes (remplacent les h3 rp-card-title dans le dashboard) */
.rp-section-label {
    font-size:0.6rem; font-weight:700; letter-spacing:0.09em;
    text-transform:uppercase; color:#94a3b8; margin:0 0 0.5rem; line-height:1;
}
.rp-db-pane .rp-section-label { margin-bottom:1.125rem; }
.dark .rp-section-label { color:#475569; }

/* Spinner (conservé pour compat.) */
.rp-spinner { width:1.25rem; height:1.25rem; animation:rp-spin 0.8s linear infinite; }
@keyframes rp-spin { to { transform:rotate(360deg); } }

/* Aperçu clients (dashboard reporting) */
.rp-clients-apercu-card { display:flex; flex-direction:column; min-height:100%; }
.rp-clients-apercu-head {
    display:flex; align-items:center; justify-content:space-between; gap:0.75rem;
    margin-bottom:0.75rem;
}
.rp-clients-apercu-all { font-size:0.75rem; font-weight:500; white-space:nowrap; }
.rp-clients-apercu-list {
    list-style:none; margin:0; padding:0;
    display:flex; flex-direction:column; gap:0.65rem;
    max-height:18rem; overflow-y:auto;
}
.rp-clients-apercu-item {
    display:flex; flex-direction:column; gap:0.15rem;
    padding-bottom:0.65rem; border-bottom:1px solid rgba(0,0,0,.06);
}
.rp-clients-apercu-item:last-child { padding-bottom:0; border-bottom:none; }
.dark .rp-clients-apercu-item { border-bottom-color:rgba(255,255,255,.08); }
.rp-clients-apercu-name {
    font-size:0.875rem; font-weight:600; color:#0f172a;
    line-height:1.3;
}
.dark .rp-clients-apercu-name { color:#f1f5f9; }
.rp-clients-apercu-meta {
    font-size:0.75rem; color:#64748b; line-height:1.35;
}
.dark .rp-clients-apercu-meta { color:#94a3b8; }
.rp-clients-apercu-badge {
    display:inline-block; align-self:flex-start;
    font-size:0.625rem; font-weight:600; text-transform:uppercase; letter-spacing:0.04em;
    padding:0.1rem 0.35rem; border-radius:0.25rem;
    background:#f1f5f9; color:#64748b;
}
.dark .rp-clients-apercu-badge { background:#334155; color:#94a3b8; }

/* Donut reporting */
.rp-donut-block { padding:0.25rem 0; }
.rp-donut-row {
    display:flex; flex-wrap:wrap; align-items:center; justify-content:center;
    gap:1.5rem; margin-top:0.5rem;
}
.rp-donut-visual {
    position:relative; width:11rem; height:11rem; flex-shrink:0;
}
.rp-donut-ring {
    width:100%; height:100%; border-radius:50%;
    box-shadow:inset 0 0 0 1px rgba(0,0,0,.06);
}
.rp-donut-hole {
    position:absolute; inset:28%; border-radius:50%;
    background:#fff; display:flex; align-items:center; justify-content:center;
    box-shadow:0 1px 3px rgba(0,0,0,.08);
}
.dark .rp-donut-hole { background:#1e293b; box-shadow:none; }
.rp-donut-total { font-size:1.125rem; font-weight:700; color:#1e293b; }
.dark .rp-donut-total { color:#f1f5f9; }
.rp-donut-legend {
    list-style:none; margin:0; padding:0; min-width:12rem;
    font-size:0.8125rem;
}
.rp-donut-legend:has(.rp-donut-legend-link--spaced) {
    min-width:16rem;
    flex:1;
}
.rp-donut-legend li {
    display:flex; align-items:center; gap:0.5rem; margin-bottom:0.4rem;
}
.rp-donut-legend-label { flex:1; color:#64748b; }
.dark .rp-donut-legend-label { color:#94a3b8; }

/* Carte avancement moyen (missions) */
.rp-avancement-card { display:flex; flex-direction:column; gap:0.75rem; min-height:100%; }
.rp-avancement-head {
    display:flex; align-items:flex-end; justify-content:space-between; gap:0.75rem;
}
.rp-avancement-title { margin:0; }
.rp-avancement-moy {
    margin:0; font-size:1.75rem; font-weight:700; line-height:1;
    color:var(--rp-primary, #689D71); font-variant-numeric:tabular-nums;
}
.rp-avancement-moy span { font-size:1rem; font-weight:600; }
.rp-avancement-chart-label {
    margin:0; font-size:0.65rem; font-weight:600; text-transform:uppercase;
    letter-spacing:0.04em; color:#94a3b8;
}
.rp-avancement-stack {
    display:flex; width:100%; height:0.65rem; border-radius:9999px;
    overflow:hidden; background:#e2e8f0;
}
.dark .rp-avancement-stack { background:#334155; }
.rp-avancement-stack-seg {
    min-width:2px; height:100%; transition:width 0.35s ease;
}
.rp-avancement-legend {
    display:flex; flex-wrap:wrap; gap:0.35rem 0.75rem; margin:0; padding:0; list-style:none;
}
.rp-avancement-legend-item {
    display:inline-flex; align-items:center; gap:0.3rem; font-size:0.68rem; color:#64748b;
}
.dark .rp-avancement-legend-item { color:#94a3b8; }
.rp-avancement-legend-dot {
    width:0.5rem; height:0.5rem; border-radius:9999px; flex-shrink:0;
}
.rp-avancement-legend-count { font-weight:700; color:#1e293b; }
.dark .rp-avancement-legend-count { color:#f1f5f9; }
.rp-avancement-tasks {
    margin-top:auto; padding-top:0.5rem; border-top:1px solid #e5e7eb;
}
.dark .rp-avancement-tasks { border-top-color:#334155; }
.rp-avancement-tasks-head {
    display:flex; justify-content:space-between; align-items:center;
    margin-bottom:0.35rem; font-size:0.7rem;
}
.rp-avancement-tasks-label { font-weight:600; color:#475569; }
.dark .rp-avancement-tasks-label { color:#cbd5e1; }
.rp-avancement-tasks-pct { font-weight:700; color:var(--rp-primary, #689D71); }
.rp-avancement-tasks-track {
    height:0.5rem; border-radius:9999px; background:#e2e8f0; overflow:hidden;
}
.dark .rp-avancement-tasks-track { background:#334155; }
.rp-avancement-tasks-fill {
    height:100%; border-radius:9999px;
    background:linear-gradient(90deg, var(--rp-primary, #689D71), #3b82f6);
    transition:width 0.35s ease;
}
.rp-avancement-tasks-sub {
    margin:0.35rem 0 0; font-size:0.65rem; color:#94a3b8;
}

/* Jauge avancement (autres écrans) */
.rp-gauge-card { text-align:center; }
.rp-gauge-wrap { position:relative; display:inline-block; margin:0.25rem auto 0; }
.rp-gauge-svg { width:11rem; height:auto; display:block; }
.rp-gauge-value {
    position:absolute; left:50%; bottom:0.25rem; transform:translateX(-50%);
    font-size:1.35rem; font-weight:700; color:var(--rp-primary, #689D71);
}
.rp-gauge-hint {
    margin:0.5rem auto 0; max-width:16rem; font-size:0.65rem; line-height:1.35;
    color:#94a3b8;
}
.rp-gauge-details {
    margin:0.35rem auto 0; padding:0; list-style:none; max-width:16rem;
    font-size:0.7rem; color:#64748b; line-height:1.45;
}
.dark .rp-gauge-hint { color:#94a3b8; }
.dark .rp-gauge-details { color:#94a3b8; }

/* Timeline missions actives */
.rp-timeline-card { margin-top:0; }
.rp-tl-horizontal-wrap {
    width:100%;
    max-width:100%;
    overflow-x:auto;
    overflow-y:hidden;
    overscroll-behavior-x:contain;
    -webkit-overflow-scrolling:touch;
    padding-bottom:0.25rem;
}
.rp-tl-horizontal-inner {
    min-width:100%;
}
.rp-tl-horizontal-wrap::-webkit-scrollbar { height:6px; }
.rp-tl-horizontal-wrap::-webkit-scrollbar-thumb {
    background:#cbd5e1; border-radius:9999px;
}
.dark .rp-tl-horizontal-wrap::-webkit-scrollbar-thumb { background:#475569; }
.rp-tl-scroll {
    --rp-tl-visible-rows:10;
    --rp-tl-row-step:1.85rem;
    max-height:calc(var(--rp-tl-visible-rows) * var(--rp-tl-row-step));
    overflow-y:auto;
    overflow-x:hidden;
    padding-right:0.35rem;
    scrollbar-gutter:stable;
    -webkit-overflow-scrolling:touch;
}
.rp-tl-scroll .rp-tl-row,
.rp-tl-scroll .rp-tl-row--link {
    margin-bottom:0.4rem;
}
.rp-tl-scroll .rp-tl-row:last-child,
.rp-tl-scroll .rp-tl-row--link:last-child {
    margin-bottom:0;
}

/* Liste budget réel par mission (carte à côté de la jauge) */
.rp-budget-list-card { display:flex; flex-direction:column; min-height:0; }
.rp-budget-list-scroll {
    --rp-tl-visible-rows:10;
    --rp-tl-row-step:1.85rem;
    max-height:calc(var(--rp-tl-visible-rows) * var(--rp-tl-row-step));
    overflow-y:auto;
    overflow-x:hidden;
    padding-right:0.35rem;
    scrollbar-gutter:stable;
    -webkit-overflow-scrolling:touch;
}
.rp-budget-list-scroll::-webkit-scrollbar { width:6px; }
.rp-budget-list-scroll::-webkit-scrollbar-thumb {
    background:#cbd5e1; border-radius:9999px;
}
.dark .rp-budget-list-scroll::-webkit-scrollbar-thumb { background:#475569; }
.rp-budget-list-row {
    display:flex; align-items:center; justify-content:space-between; gap:0.75rem;
    margin-bottom:0.4rem; font-size:0.75rem;
}
.rp-budget-list-row:last-child { margin-bottom:0; }
.rp-budget-list-row--link {
    text-decoration:none; color:inherit; border-radius:0.375rem;
    padding:0.1rem 0.2rem; margin-left:-0.2rem; margin-right:-0.2rem;
    transition:background-color .15s;
}
.rp-budget-list-row--link:hover { background:#f1f5f9; }
.dark .rp-budget-list-row--link:hover { background:#334155; }
.rp-budget-list-row--link:hover .rp-budget-list-name { color:var(--rp-primary, #689D71); }
.rp-budget-list-name {
    font-weight:600; color:#1e293b; min-width:0;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.dark .rp-budget-list-name { color:#f1f5f9; }
.rp-budget-list-amount {
    flex-shrink:0; font-variant-numeric:tabular-nums; font-weight:700;
    color:#1e293b; font-size:0.7rem; white-space:nowrap;
}
.dark .rp-budget-list-amount { color:#e2e8f0; }
.rp-tl-scroll::-webkit-scrollbar { width:6px; }
.rp-tl-scroll::-webkit-scrollbar-thumb {
    background:#cbd5e1; border-radius:9999px;
}
.dark .rp-tl-scroll::-webkit-scrollbar-thumb { background:#475569; }
.rp-tl-axis {
    display:flex; justify-content:space-between; font-size:0.65rem;
    color:#94a3b8; margin-bottom:0.35rem; padding:0 0.15rem;
}
.rp-tl-header {
    display:grid; grid-template-columns:minmax(0,1fr) minmax(7rem,auto) minmax(0,2fr) 2.25rem;
    gap:0.5rem 1.5rem; align-items:center; margin-bottom:0.4rem; padding:0 0.15rem;
    font-size:0.6rem; font-weight:600; text-transform:uppercase; letter-spacing:0.04em;
    color:#94a3b8;
}
.rp-tl-header-budget { text-align:right; padding-right:0.25rem; }
.rp-tl-row,
.rp-tl-row--link {
    display:grid; grid-template-columns:minmax(0,1fr) minmax(7rem,auto) minmax(0,2fr) auto;
    gap:0.5rem 1.5rem; align-items:center; margin-bottom:0.55rem; font-size:0.75rem;
}
.rp-tl-budget {
    font-size:0.68rem; text-align:right; white-space:nowrap;
    font-variant-numeric:tabular-nums; font-weight:700; color:#1e293b;
    padding-right:0.25rem;
}
.dark .rp-tl-budget { color:#e2e8f0; }
.rp-tl-meta { min-width:0; }
.rp-tl-name { font-weight:600; color:#1e293b; display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dark .rp-tl-name { color:#f1f5f9; }
.rp-tl-sub { color:#94a3b8; font-size:0.65rem; }
.rp-tl-track {
    position:relative; height:0.55rem; border-radius:9999px;
    background:#e2e8f0; overflow:hidden;
}
.dark .rp-tl-track { background:#334155; }
.rp-tl-progress {
    height:100%; border-radius:9999px;
    background:linear-gradient(90deg, var(--rp-primary, #689D71), #3b82f6);
    min-width:0; transition:width 0.35s ease;
}
.rp-tl-progress--overdue {
    background:linear-gradient(90deg, #f97316, #ef4444);
}
.rp-tl-pct { font-variant-numeric:tabular-nums; font-weight:600; color:#64748b; font-size:0.7rem; width:2.25rem; text-align:right; }
.rp-tl-pct--overdue { color:#ef4444; }

/* ── Page Notifications ─────────────────────────────────────────────────── */
.notif-page {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    width: 100%;
    padding-bottom: 2rem;
}

.notif-page--loading .notif-groups,
.notif-page--loading .notif-stats,
.notif-page--loading .notif-toolbar {
    opacity: 0.65;
    pointer-events: none;
    transition: opacity 0.12s ease;
}

.notif-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 0.75rem 0 0.25rem;
}

.notif-pagination__btn {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--rp-primary, #689D71);
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 0.5rem;
    padding: 0.4rem 0.85rem;
    cursor: pointer;
    transition: background 0.12s ease, border-color 0.12s ease;
}

.notif-pagination__btn:hover:not(:disabled) {
    background: #f0fdf4;
    border-color: var(--rp-primary, #689D71);
}

.notif-pagination__btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.dark .notif-pagination__btn {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.1);
    color: #86efac;
}

.notif-pagination__info {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #64748b;
    font-variant-numeric: tabular-nums;
}

.notif-pagination__total {
    font-weight: 500;
    color: #94a3b8;
}

.notif-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.notif-stat {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 0.85rem 1rem;
    border-radius: 0.75rem;
    border: 1px solid #e2e8f0;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.dark .notif-stat {
    border-color: rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
}

.notif-stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: #0f172a;
    line-height: 1.1;
}

.dark .notif-stat-value { color: #f8fafc; }

.notif-stat-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: #64748b;
}

.notif-stat--unread .notif-stat-value { color: #dc2626; }
.notif-stat--read .notif-stat-value { color: #64748b; }
.notif-stat--total .notif-stat-value { color: var(--rp-primary, #689D71); }

.notif-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid #e2e8f0;
}

.dark .notif-toolbar { border-bottom-color: rgba(255, 255, 255, 0.08); }

.notif-tabs {
    display: inline-flex;
    padding: 0.2rem;
    border-radius: 0.625rem;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    gap: 0.15rem;
}

.dark .notif-tabs {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.08);
}

.notif-toolbar-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.notif-type-filter {
    position: relative;
}

.notif-type-filter__trigger {
    min-width: 0;
    max-width: 14rem;
}

.notif-type-filter__trigger--active {
    color: #0f172a;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.dark .notif-type-filter__trigger--active {
    color: #f8fafc;
    background: rgba(255, 255, 255, 0.1);
    box-shadow: none;
}

.notif-type-filter__label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.notif-type-filter__chevron {
    transition: transform 0.15s ease;
    opacity: 0.65;
}

.notif-type-filter__chevron--open {
    transform: rotate(180deg);
}

.notif-type-filter__menu {
    position: absolute;
    top: calc(100% + 0.35rem);
    left: 0;
    z-index: 50;
    min-width: 13.5rem;
    max-height: 16rem;
    overflow-y: auto;
    padding: 0.25rem;
    border-radius: 0.625rem;
    border: 1px solid #e2e8f0;
    background: #fff;
    box-shadow: 0 10px 25px rgba(15, 23, 42, 0.12);
}

.dark .notif-type-filter__menu {
    border-color: rgba(255, 255, 255, 0.1);
    background: #1e293b;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.35);
}

.notif-type-filter__option {
    display: flex;
    width: 100%;
    align-items: center;
    gap: 0.5rem;
    padding: 0.45rem 0.6rem;
    border: none;
    border-radius: 0.4rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #334155;
    background: transparent;
    cursor: pointer;
    text-align: left;
    transition: background-color 0.12s ease;
}

.notif-type-filter__option:hover {
    background: #f1f5f9;
}

.dark .notif-type-filter__option {
    color: #e2e8f0;
}

.dark .notif-type-filter__option:hover {
    background: rgba(255, 255, 255, 0.06);
}

.notif-type-filter__option--active {
    background: rgba(104, 157, 113, 0.12);
    color: var(--rp-primary, #689D71);
}

.dark .notif-type-filter__option--active {
    background: rgba(104, 157, 113, 0.2);
}

.notif-type-filter__option-dot {
    width: 0.5rem;
    height: 0.5rem;
    flex-shrink: 0;
    border-radius: 9999px;
}

.notif-type-filter__option-label {
    flex: 1;
    min-width: 0;
}

.notif-type-filter__option-count {
    flex-shrink: 0;
    min-width: 1.125rem;
    padding: 0 0.35rem;
    border-radius: 9999px;
    font-size: 0.625rem;
    font-weight: 700;
    line-height: 1.125rem;
    text-align: center;
    background: #e2e8f0;
    color: #475569;
}

.dark .notif-type-filter__option-count {
    background: rgba(255, 255, 255, 0.1);
    color: #94a3b8;
}

.notif-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.85rem;
    border-radius: 0.45rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #64748b;
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.notif-tab:hover {
    color: #334155;
    background: rgba(255, 255, 255, 0.7);
}

.dark .notif-tab:hover {
    color: #e2e8f0;
    background: rgba(255, 255, 255, 0.06);
}

.notif-tab--active {
    color: #0f172a;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.dark .notif-tab--active {
    color: #f8fafc;
    background: rgba(255, 255, 255, 0.1);
    box-shadow: none;
}

.notif-tab-badge {
    display: inline-flex;
    min-width: 1.125rem;
    height: 1.125rem;
    align-items: center;
    justify-content: center;
    padding: 0 0.3rem;
    border-radius: 9999px;
    font-size: 0.625rem;
    font-weight: 700;
    line-height: 1;
}

.notif-tab-badge--danger {
    background: #fee2e2;
    color: #b91c1c;
}

.notif-tab--active .notif-tab-badge--danger {
    background: #fecaca;
    color: #991b1b;
}

.notif-tab-badge--muted {
    background: #e2e8f0;
    color: #475569;
}

.notif-tab--active .notif-tab-badge--muted {
    background: #f1f5f9;
    color: #334155;
}

.notif-toolbar-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.notif-btn-ghost {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.75rem;
    border-radius: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--rp-primary, #689D71);
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.notif-btn-ghost:hover {
    background: rgba(104, 157, 113, 0.1);
}

.notif-btn-danger {
    color: #dc2626;
}

.notif-btn-danger:hover {
    background: #fef2f2;
}

.dark .notif-btn-danger:hover {
    background: rgba(220, 38, 38, 0.15);
}

.notif-bulk-select {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.35rem 0.15rem;
}

.notif-bulk-select-all {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #475569;
    cursor: pointer;
    user-select: none;
}

.dark .notif-bulk-select-all { color: #94a3b8; }

.notif-bulk-select-count {
    font-size: 0.75rem;
    color: #64748b;
}

.notif-bulk-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.65rem 0.85rem;
    border-radius: 0.625rem;
    border: 1px solid #dbeafe;
    background: #eff6ff;
}

.dark .notif-bulk-bar {
    border-color: rgba(59, 130, 246, 0.25);
    background: rgba(59, 130, 246, 0.1);
}

.notif-bulk-bar-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #1e40af;
}

.dark .notif-bulk-bar-label { color: #93c5fd; }

.notif-bulk-bar-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
}

body.fi-panel-admin .notif-page button.notif-checkbox {
    font: inherit;
    line-height: 1;
    appearance: none;
    -webkit-appearance: none;
    box-shadow: none;
    background-image: none;
    color: var(--rp-primary, #689d71);
}

.notif-checkbox {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    width: 1rem;
    height: 1rem;
    min-width: 1rem;
    min-height: 1rem;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
    border: 1.5px solid #94a3b8;
    border-radius: 0.25rem;
    background-color: #fff;
    cursor: pointer;
    transition: background-color 0.15s, border-color 0.15s;
}

.notif-checkbox__icon {
    width: 0.75rem;
    height: 0.75rem;
    opacity: 0;
    transform: scale(0.85);
    transition: opacity 0.12s ease, transform 0.12s ease;
    pointer-events: none;
}

body.fi-panel-admin .notif-page button.notif-checkbox.notif-checkbox--checked {
    border-color: var(--rp-primary, #689d71);
    background-color: #e8f4ea;
}

.notif-checkbox--checked .notif-checkbox__icon {
    opacity: 1;
    transform: scale(1);
    color: var(--rp-primary, #689d71);
}

.notif-checkbox:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

.dark .notif-checkbox {
    border-color: #64748b;
    background-color: #0f172a;
}

.dark body.fi-panel-admin .notif-page button.notif-checkbox.notif-checkbox--checked,
body.dark.fi-panel-admin .notif-page button.notif-checkbox.notif-checkbox--checked {
    border-color: var(--rp-primary, #689d71);
    background-color: rgba(104, 157, 113, 0.22);
}

.dark .notif-checkbox--checked .notif-checkbox__icon,
body.dark.fi-panel-admin .notif-checkbox--checked .notif-checkbox__icon {
    color: #a7d4b0;
}

.notif-item-checkbox {
    align-self: center;
}

.notif-item--selected {
    background: rgba(59, 130, 246, 0.06);
}

.dark .notif-item--selected {
    background: rgba(59, 130, 246, 0.12);
}

.notif-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3.5rem 1.5rem;
    text-align: center;
    border-radius: 0.75rem;
    border: 1px dashed #cbd5e1;
    background: #f8fafc;
}

.dark .notif-empty {
    border-color: rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.02);
}

.notif-empty-icon {
    width: 3rem;
    height: 3rem;
    color: #94a3b8;
    margin-bottom: 0.75rem;
}

.notif-empty-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: #475569;
    margin: 0;
}

.dark .notif-empty-title { color: #94a3b8; }

.notif-empty-link {
    margin-top: 0.65rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--rp-primary, #689D71);
    text-decoration: underline;
    text-underline-offset: 2px;
    background: none;
    border: none;
    cursor: pointer;
}

.notif-groups {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
}

.notif-group {
    border-radius: 0.75rem;
    border: 1px solid #e2e8f0;
    background: #fff;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}

.dark .notif-group {
    border-color: rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.02);
}

.notif-group-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid #f1f5f9;
    background: #f8fafc;
}

.dark .notif-group-header {
    border-bottom-color: rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
}

.notif-group-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 9999px;
    flex-shrink: 0;
}

.notif-group-title {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #475569;
}

.dark .notif-group-title { color: #94a3b8; }

.notif-group-badge {
    margin-left: auto;
    padding: 0.15rem 0.45rem;
    border-radius: 9999px;
    font-size: 0.625rem;
    font-weight: 700;
    background: #fee2e2;
    color: #b91c1c;
}

.notif-group-list { display: flex; flex-direction: column; }

.notif-subsection {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 1rem;
    background: #f1f5f9;
    border-top: 1px solid #e2e8f0;
    border-bottom: 1px solid #e2e8f0;
}

.dark .notif-subsection {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.06);
}

.notif-subsection-label {
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #94a3b8;
}

.notif-item {
    display: flex;
    align-items: stretch;
    gap: 0.85rem;
    padding: 0.9rem 1rem;
    border-bottom: 1px solid #f1f5f9;
    transition: background-color 0.12s ease;
}

.dark .notif-item {
    border-bottom-color: rgba(255, 255, 255, 0.05);
}

.notif-group-list .notif-item:last-child {
    border-bottom: none;
}

.notif-item:hover {
    background: #f8fafc;
}

.dark .notif-item:hover {
    background: rgba(255, 255, 255, 0.03);
}

.notif-item--unread {
    background: linear-gradient(90deg, rgba(104, 157, 113, 0.08) 0%, transparent 42%);
}

.dark .notif-item--unread {
    background: linear-gradient(90deg, rgba(104, 157, 113, 0.12) 0%, transparent 42%);
}

.notif-item--read {
    opacity: 0.88;
}

.notif-item--focused {
    box-shadow: inset 3px 0 0 0 #689d71;
    background: linear-gradient(90deg, rgba(104, 157, 113, 0.14) 0%, transparent 55%);
}

.dark .notif-item--focused {
    background: linear-gradient(90deg, rgba(104, 157, 113, 0.2) 0%, transparent 55%);
}

.notif-item-section-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    flex-shrink: 0;
    align-self: center;
    border-radius: 0.5rem;
    background: color-mix(in srgb, var(--section-color, #64748b) 14%, transparent);
    color: var(--section-color, #64748b);
}

.notif-item-section-icon svg {
    width: 1.125rem;
    height: 1.125rem;
}

.notif-item-main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    min-height: 2.75rem;
}

.notif-item--has-body.notif-item--has-footer .notif-item-main {
    min-height: 4.5rem;
}

.notif-item-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
}

.notif-item-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: #0f172a;
    line-height: 1.35;
    margin: 0;
}

.dark .notif-item-title { color: #f1f5f9; }

.notif-item-meta {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.2rem;
}

.notif-item-time {
    font-size: 0.6875rem;
    color: #94a3b8;
    white-space: nowrap;
    line-height: 1.75rem;
}

.notif-item-actions-row {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.15rem;
    flex-shrink: 0;
}

.notif-item-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 0.375rem;
    border: none;
    background: transparent;
    color: #94a3b8;
    cursor: pointer;
    transition: background-color 0.12s ease, color 0.12s ease;
}

.notif-item-action svg {
    width: 0.95rem;
    height: 0.95rem;
}

.notif-item-action--read:hover {
    color: #16a34a;
    background: #dcfce7;
}

.notif-item-action--unread:hover {
    color: #64748b;
    background: #f1f5f9;
}

.notif-item-action--delete:hover {
    color: #dc2626;
    background: #fee2e2;
}

.notif-item-middle {
    flex: 1;
    display: flex;
    align-items: center;
    min-height: 0;
    padding: 0.15rem 0;
}

.notif-item-text {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.45;
    color: #64748b;
}

.dark .notif-item-text { color: #94a3b8; }

.notif-item-footer {
    flex-shrink: 0;
    margin-top: 0;
    padding-top: 0.35rem;
}

@media (max-width: 640px) {
    .notif-stats {
        grid-template-columns: 1fr;
    }

    .notif-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .notif-toolbar-filters {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
    }

    .notif-tabs {
        width: 100%;
        justify-content: stretch;
    }

    .notif-type-filter {
        width: 100%;
    }

    .notif-type-filter__trigger {
        width: 100%;
        max-width: none;
        justify-content: center;
    }

    .notif-type-filter__menu {
        left: 0;
        right: 0;
        width: 100%;
        min-width: 0;
    }

    .notif-tab {
        flex: 1;
        justify-content: center;
    }

    .notif-item-head {
        flex-direction: column;
        gap: 0.35rem;
    }

    .notif-item-meta {
        display: flex;
        width: 100%;
        align-items: center;
        justify-content: space-between;
        text-align: left;
    }
}

/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 640px) {
    /* Formulaires Filament — base mobile confortable et sans débordement */
    body.fi-panel-admin .fi-form {
        gap: 1rem;
    }

    body.fi-panel-admin .fi-fo-grid,
    body.fi-panel-admin .fi-fo-component-ctn,
    body.fi-panel-admin .fi-section-content .grid,
    body.fi-panel-admin .fi-form [style*="--cols"] {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 0.875rem !important;
    }

    body.fi-panel-admin .fi-fo-grid > *,
    body.fi-panel-admin .fi-fo-component-ctn > *,
    body.fi-panel-admin .fi-section-content .grid > *,
    body.fi-panel-admin .fi-form [style*="--col-span"] {
        grid-column: 1 / -1 !important;
        min-width: 0 !important;
        max-width: 100% !important;
    }

    body.fi-panel-admin .fi-fo-field-wrp,
    body.fi-panel-admin .fi-fo-field-wrp > div,
    body.fi-panel-admin .fi-input-wrp,
    body.fi-panel-admin .fi-select-input,
    body.fi-panel-admin .fi-textarea {
        min-width: 0;
        max-width: 100%;
    }

    body.fi-panel-admin .fi-fo-field-wrp-label span,
    body.fi-panel-admin .fi-fo-field-wrp-helper-text,
    body.fi-panel-admin .fi-fo-field-wrp-error-message {
        line-height: 1.35;
    }

    body.fi-panel-admin .fi-input,
    body.fi-panel-admin .fi-select-input,
    body.fi-panel-admin .fi-textarea {
        width: 100%;
        font-size: 16px !important; /* évite le zoom automatique Chrome/iOS au focus */
        line-height: 1.45;
    }

    body.fi-panel-admin .fi-input-wrp {
        min-height: 2.75rem;
        border-radius: 0.75rem;
    }

    body.fi-panel-admin .fi-input,
    body.fi-panel-admin .fi-select-input {
        min-height: 2.75rem;
    }

    body.fi-panel-admin .fi-textarea {
        min-height: 6.5rem;
    }

    body.fi-panel-admin .fi-fo-checkbox-list,
    body.fi-panel-admin .fi-fo-radio {
        gap: 0.625rem;
    }

    body.fi-panel-admin .fi-fo-checkbox-list .fi-checkbox-input,
    body.fi-panel-admin .fi-fo-radio .fi-radio-input,
    body.fi-panel-admin .fi-checkbox-input {
        width: 1.125rem;
        height: 1.125rem;
        min-width: 1.125rem;
    }

    body.fi-panel-admin .fi-fo-repeater-item,
    body.fi-panel-admin .fi-fo-builder-item {
        border-radius: 0.875rem;
        overflow: hidden;
    }

    body.fi-panel-admin .fi-fo-repeater-item-header,
    body.fi-panel-admin .fi-fo-builder-item-header {
        gap: 0.5rem;
        align-items: center;
    }

    body.fi-panel-admin .fi-fo-actions,
    body.fi-panel-admin .fi-form-actions,
    body.fi-panel-admin .fi-modal-footer-actions {
        flex-wrap: wrap;
        gap: 0.625rem;
    }

    body.fi-panel-admin .fi-modal-window {
        box-sizing: border-box;
        justify-self: center !important;
        width: calc(100vw - 2rem) !important;
        width: calc(100dvw - 2rem) !important;
        max-width: min(calc(100vw - 2rem), 32rem) !important;
        max-width: min(calc(100dvw - 2rem), 32rem) !important;
        min-width: 0 !important;
        margin: 0 auto !important;
    }

    body.fi-panel-admin .fi-modal-header,
    body.fi-panel-admin .fi-modal-content,
    body.fi-panel-admin .fi-modal-footer {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    body.fi-panel-admin .fi-modal-window .fi-fo-grid,
    body.fi-panel-admin .fi-modal-window .fi-fo-component-ctn,
    body.fi-panel-admin .fi-modal-window .fi-section-content .grid,
    body.fi-panel-admin .fi-modal-window [style*="--cols"] {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 0.875rem !important;
    }

    body.fi-panel-admin .fi-modal-window .fi-fo-grid > *,
    body.fi-panel-admin .fi-modal-window .fi-fo-component-ctn > *,
    body.fi-panel-admin .fi-modal-window .fi-section-content .grid > *,
    body.fi-panel-admin .fi-modal-window [style*="--col-span"] {
        grid-column: 1 / -1 !important;
        min-width: 0 !important;
        max-width: 100% !important;
    }

    body.fi-panel-admin .fi-modal-window .fi-fo-field-wrp,
    body.fi-panel-admin .fi-modal-window .fi-fo-field-wrp > div,
    body.fi-panel-admin .fi-modal-window .fi-input-wrp,
    body.fi-panel-admin .fi-modal-window .fi-input,
    body.fi-panel-admin .fi-modal-window .fi-select-input,
    body.fi-panel-admin .fi-modal-window .fi-textarea {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
    }

    body.fi-panel-admin .fi-sujet-edit-modal .grid,
    body.fi-panel-admin .fi-sujet-infos-modal .grid,
    body.fi-panel-admin .fi-sujet-edit-modal .fi-fo-component-ctn,
    body.fi-panel-admin .fi-sujet-infos-modal .fi-fo-component-ctn,
    body.fi-panel-admin .fi-sujet-infos-modal [style*="--cols"],
    body.fi-panel-admin .fi-sujet-edit-modal [style*="--cols"] {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    body.fi-panel-admin .fi-sujet-edit-modal .grid > *,
    body.fi-panel-admin .fi-sujet-infos-modal .grid > *,
    body.fi-panel-admin .fi-sujet-edit-modal .fi-fo-component-ctn > *,
    body.fi-panel-admin .fi-sujet-infos-modal .fi-fo-component-ctn > *,
    body.fi-panel-admin .fi-sujet-infos-modal [style*="--col-span"],
    body.fi-panel-admin .fi-sujet-edit-modal [style*="--col-span"] {
        grid-column: 1 / -1 !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
    }

    body.fi-panel-admin .fi-modal-footer-actions,
    body.fi-panel-admin .fi-modal-footer .fi-ac {
        width: 100%;
    }

    body.fi-panel-admin .fi-modal-footer .fi-btn {
        min-height: 2.5rem;
        justify-content: center;
    }

    /* Auth mobile — flux mot de passe modifié / première connexion */
    body.fi-panel-admin .fi-password-choice-modal-window {
        justify-self: center !important;
        align-self: center !important;
        width: calc(100vw - 2rem) !important;
        width: calc(100dvw - 2rem) !important;
        max-width: min(calc(100vw - 2rem), 28rem) !important;
        max-width: min(calc(100dvw - 2rem), 28rem) !important;
        max-height: calc(100dvh - 1rem);
        margin: 0 auto !important;
        inset-inline-start: auto !important;
        inset-inline-end: auto !important;
        transform: none !important;
        overflow-y: auto;
    }

    body.fi-panel-admin .fi-password-choice-modal-window .fi-modal-header,
    body.fi-panel-admin .fi-password-choice-modal-window .fi-modal-heading,
    body.fi-panel-admin .fi-password-choice-modal-window .fi-modal-description {
        width: 100%;
        text-align: center !important;
    }

    body.fi-panel-admin .fi-password-choice-flow {
        width: 100%;
        max-width: 100%;
        text-align: center;
    }

    body.fi-panel-admin .fi-password-choice-flow .fi-section,
    body.fi-panel-admin .fi-password-choice-flow .fi-section-content {
        border-radius: 0.875rem;
    }

    body.fi-panel-admin .fi-password-choice-actions {
        display: grid !important;
        grid-template-columns: 1fr;
        width: 100%;
        gap: 0.75rem !important;
        justify-items: center;
    }

    body.fi-panel-admin .fi-password-choice-action,
    body.fi-panel-admin .fi-password-choice-action .fi-btn {
        width: 100%;
        min-height: 2.875rem;
        justify-content: center;
        white-space: normal;
        text-align: center;
    }

    body.fi-panel-admin .fi-password-choice-form {
        width: 100%;
        text-align: left;
    }

    body.fi-panel-admin .fi-password-choice-form .fi-fo-field-wrp {
        width: 100%;
    }

    body.fi-panel-admin .fi-password-choice-form .fi-input-wrp {
        min-height: 3rem;
    }

    body.fi-panel-admin .rp-db,
    body.fi-panel-admin .rp-db-panel,
    body.fi-panel-admin .rp-db-pane,
    body.fi-panel-admin .rp-card {
        min-width: 0;
        max-width: 100%;
    }

    body.fi-panel-admin .rp-card {
        box-sizing: border-box;
        padding: 1rem;
        overflow: hidden;
    }

    body.fi-panel-admin .rp-kpi-grid {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }

    body.fi-panel-admin .rp-kpi-card {
        min-width: 0;
        padding: 1rem 4.25rem 1rem 1rem;
    }

    body.fi-panel-admin .rp-kpi-icon {
        top: 1rem;
        right: 1rem;
        width: 2rem;
        height: 2rem;
    }

    body.fi-panel-admin .rp-kpi-icon svg {
        width: 1.05rem;
        height: 1.05rem;
    }

    body.fi-panel-admin .rp-kpi-label {
        max-width: 100%;
        overflow-wrap: anywhere;
        line-height: 1.3;
    }

    body.fi-panel-admin .rp-kpi-value {
        font-size: 1.5rem;
        line-height: 1.08;
        overflow-wrap: anywhere;
    }

    body.fi-panel-admin .rp-kpi-sub {
        max-width: 100%;
        overflow-wrap: anywhere;
        line-height: 1.35;
    }

    body.fi-panel-admin .rp-two-col,
    body.fi-panel-admin .rp-two-col--charts {
        grid-template-columns: minmax(0, 1fr);
    }

    body.fi-panel-admin .rp-evolution-card__head,
    body.fi-panel-admin .rp-chart-card-head {
        align-items: flex-start;
        gap: 0.5rem;
    }

    body.fi-panel-admin .rp-evolution-card__chart {
        width: 100%;
        min-width: 0;
        overflow-x: hidden;
    }

    body.fi-panel-admin .rp-chart-bars {
        width: 100%;
        min-width: 0;
        gap: 0.3rem;
        overflow-x: hidden;
    }

    body.fi-panel-admin .rp-chart-bar-col {
        min-width: 0;
        flex: 1 1 0;
        gap: 0.25rem;
    }

    body.fi-panel-admin .rp-chart-bar-wrap {
        height: 8rem;
        min-height: 8rem;
        padding: 0 2px;
    }

    body.fi-panel-admin .rp-chart-bars--uniform .rp-chart-bar-col {
        grid-template-rows: 1.15rem 8rem 2.75rem;
    }

    body.fi-panel-admin .rp-chart-bars--uniform .rp-chart-bar-meta {
        height: 2.75rem;
    }

    body.fi-panel-admin .rp-chart-bar-count {
        font-size: 0.68rem;
    }

    body.fi-panel-admin .rp-chart-bar-label {
        width: 100%;
        font-size: 0.5rem;
        white-space: normal;
        overflow-wrap: anywhere;
        line-height: 1.15;
    }

    body.fi-panel-admin .rp-donut-row {
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        gap: 1rem;
        width: 100%;
        min-width: 0;
        margin-top: 0;
    }

    body.fi-panel-admin .rp-donut-visual {
        align-self: center;
        width: min(10rem, 62vw);
        height: min(10rem, 62vw);
    }

    body.fi-panel-admin .rp-donut-legend,
    body.fi-panel-admin .rp-donut-legend:has(.rp-donut-legend-link--spaced) {
        width: 100%;
        min-width: 0;
        max-width: 100%;
        flex: 1 1 auto;
    }

    body.fi-panel-admin .rp-donut-legend li {
        width: 100%;
        min-width: 0;
    }

    body.fi-panel-admin .rp-donut-legend-link,
    body.fi-panel-admin .rp-donut-legend-link--static,
    body.fi-panel-admin .rp-donut-legend-link--spaced {
        width: 100%;
        min-width: 0;
        gap: 0.5rem;
    }

    body.fi-panel-admin .rp-donut-legend-label {
        min-width: 0;
        overflow-wrap: anywhere;
    }

    body.fi-panel-admin .rp-donut-legend-link--spaced .rp-donut-legend-value {
        min-width: 0;
        max-width: 45%;
        overflow-wrap: anywhere;
    }

    body.fi-panel-admin .rp-tl-horizontal-inner {
        min-width: 42rem;
    }

    body.fi-panel-admin .rp-tl-header,
    body.fi-panel-admin .rp-tl-row,
    body.fi-panel-admin .rp-tl-row--link {
        grid-template-columns: minmax(12rem, 1fr) minmax(7rem, auto) minmax(12rem, 2fr) 2.25rem;
    }

    body.fi-panel-admin .rp-timeline-card {
        overflow: hidden;
    }

    .rp-header { flex-direction: column; }
    .rp-mission-grid { grid-template-columns: 1fr; }
    .rp-tab { padding: 0.6rem 0.75rem; font-size: 0.8rem; }
}

    /* Fiche utilisateur — bouton « Retirer la photo » aligné au centre avec l’icône section */
    .fi-section-user-profile-photo .fi-section-header > .flex {
        align-items: center;
    }

    .fi-section-user-profile-photo .fi-section-header-icon {
        align-self: center !important;
        margin-top: 0 !important;
    }

    .fi-section-user-profile-photo .fi-section-header > .flex > .hidden.sm\:block {
        display: flex;
        align-items: center;
        align-self: center;
    }
