/* =============================================================================   app-ds.css â€” Design System rÃ©fÃ©rence   Consolidation de tous les CSS inline de l'Espace Projets   Les noms de classes et variables sont conservÃ©s Ã  l'identique des templates.   ============================================================================= *//* â”€â”€â”€ 1. Tokens / Variables â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */:root {    /* Teal */    --ctx-teal:        #0d9488;    --ctx-teal-light:  #e6f7f5;    --ctx-teal-hover:  #f0fafa;    --fin-teal:        #0d9488;    --fin-teal-light:  #e6f7f5;    --fin-teal-hover:  #f0fafa;    --res-teal:        #0d9488;    --res-teal-light:  #e6f7f5;    --res-teal-hover:  #f0fafa;    /* Border-radius (tous Ã  2px) */    --ctx-radius-lg:   2px;    --ctx-radius-md:   2px;    --ctx-radius-sm:   2px;    --fin-radius-lg:   2px;    --fin-radius-sm:   2px;    --res-radius:      2px;    /* Ombres */    --ctx-shadow:      0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);    --fin-shadow:      0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);    --res-shadow:      0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);    /* Bordures */    --ctx-border:      1px solid #e2e8f0;    --fin-border:      1px solid #e2e8f0;    --res-border:      1px solid #e2e8f0;    /* Texte */    --ctx-text-dark:   #2D3E50;    --ctx-text-mid:    #415873;    --ctx-text-muted:  #8fa1b3;    --fin-text-dark:   #2D3E50;    --fin-text-mid:    #415873;    --fin-text-muted:  #8fa1b3;    --res-text-dark:   #2D3E50;    --res-text-mid:    #415873;    --res-text-muted:  #8fa1b3;    /* Fonds */    --ctx-bg-section:  #fff;    --ctx-bg-card:     #fff;    --ctx-bg-header:   #fff;    --fin-bg:          #fff;    /* Largeur unifiÃ©e drawers + side-panel droit. RecalculÃ©e en JS dans app.js (mbwComputeDrawerWidth) : sidebar nav collapsed (60 px fixe) + 25% de la largeur restante. Plancher 380 px. */    --sp-w: 380px;}

/* â”€â”€â”€ 2. Drawer â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.drawer-task {    position: fixed;    top: 0; right: calc(-1 * var(--sp-w)); bottom: 0;    width: var(--sp-w);    background: #fff;    display: flex;    flex-direction: column;    box-shadow: -4px 0 24px rgba(0,0,0,0.18);    transition: right 0.3s ease;    z-index: 1060;}

.drawer-task.open { right: 0; }

.drawer-task .drawer-header {    display: flex;    justify-content: space-between;    align-items: center;    padding: 13px 24px 12px;    flex-shrink: 0;    background: #2D3E50;    border-bottom: 1px solid rgba(0,0,0,0.15);}

.drawer-task .drawer-header h1,.drawer-task .drawer-header h3 {    margin: 0;    font-size: 1.25rem;    font-weight: 700;    color: #fff;    white-space: nowrap;    overflow: hidden;    text-overflow: ellipsis;    max-width: calc(var(--sp-w) - 80px);}

.drawer-task .close-drawer {    background: none;    border: none;    font-size: 1.8rem;    line-height: 1;    cursor: pointer;    color: rgba(255,255,255,0.55);    opacity: 1;    padding: 0 0 0 12px;    flex-shrink: 0;}

.drawer-task .close-drawer:hover { color: #fff; }

.drawer-task > form {    display: flex;    flex-direction: column;    flex: 1;    min-height: 0;    overflow: hidden;}

.drawer-task .drawer-body {    flex: 1;    min-height: 0;    overflow-y: auto;    padding: 14px 22px;    background: #fff;}

.drawer-task .drawer-footer {    padding: 12px 24px;    border-top: 1px solid rgba(45,62,80,0.15);    background: #fff;    flex-shrink: 0;}

.drawer-task .field-label {    font-size: 0.72rem;    font-weight: 600;    color: #8fa1b3;    text-transform: uppercase;    letter-spacing: 0.04em;    margin-bottom: 5px;}

.drawer-section {    background: #f8fafb;    border: 1px solid #e2e8f0;    border-radius: 2px;    padding: 12px 14px;    margin-bottom: 10px;}

.drawer-section > .field-label:first-child { margin-bottom: 10px; }

.drawer-task .progress-pct {    font-size: 0.85rem;    font-weight: 600;    color: #8fa1b3;    min-width: 36px;    text-align: right;}

.drawer-task .drawer-template-band {    background: rgba(45,62,80,0.04);    border-bottom: 1px solid rgba(45,62,80,0.1);    padding: 8px 24px;    display: flex;    align-items: center;    flex-shrink: 0;    gap: 12px;}

.drawer-task .drawer-template-band .bootstrap-select { width: 100% !important; background: transparent !important; }

.drawer-task .drawer-template-band .bootstrap-select > .btn {    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;    background: rgba(13,148,136,0.07) !important;    border: 1px solid rgba(13,148,136,0.25) !important;    border-bottom: 1px solid rgba(13,148,136,0.25) !important;    color: #4b5563 !important;    box-shadow: none !important;    outline: none !important;    transition: background 0.2s, border-color 0.2s, color 0.2s;}

.drawer-task .drawer-template-band:hover .bootstrap-select > .btn,.drawer-task .drawer-template-band .bootstrap-select > .btn:focus,.drawer-task .drawer-template-band .bootstrap-select.show > .btn {    background: rgba(13,148,136,0.13) !important;    border-color: rgba(13,148,136,0.45) !important;    border-bottom-color: rgba(13,148,136,0.45) !important;    color: #0d9488 !important;}

/* â”€â”€ ContrÃ´les internes du drawer tÃ¢che â”€â”€ */

#taskDrawer .add_element_link.btn-primary {    background-color: #fff;    border: 1px solid #0d9488;    color: #0d9488;}

#taskDrawer .add_element_link.btn-primary:hover {    background-color: rgba(13,148,136,0.07);    border-color: #0d9488;    color: #0d9488;}

#taskDrawer input[type="range"] { accent-color: #0d9488; }

#taskDrawer input[type="radio"]:checked + .radio-label:before {    background-color: #0d9488 !important;    box-shadow: inset 0 0 0 4px #f4f4f4;}

#taskDrawer input[type="radio"]:focus + .radio-label:before { border-color: #0d9488 !important; }

#taskDrawer .form-check input[type="checkbox"]:checked + label::before {    background-color: #0d9488 !important;    border-color: #0d9488 !important;}

#taskDrawer .task-child-row .btnDelete {    background: none; border: none; padding: 2px 4px;    color: transparent; transition: color 0.15s; line-height: 1;}

#taskDrawer .task-child-row:hover .btnDelete { color: #9ca3af; }

#taskDrawer .task-child-row .btnDelete:hover { color: #ef4444 !important; }

#taskDrawer .form-group.row.pl-5 { margin-top: 14px !important; }

/* â”€â”€ Scrollbar drawer-body â”€â”€ */

.drawer-task .drawer-body::-webkit-scrollbar { width: 4px; background: transparent; }

.drawer-task .drawer-body::-webkit-scrollbar-track { background: transparent; border: none; }

.drawer-task .drawer-body::-webkit-scrollbar-thumb { background: transparent; border-radius: 4px; transition: background 0.25s; }

.drawer-task .drawer-body.ctx-scrolling::-webkit-scrollbar-thumb,.drawer-task .drawer-body.ctx-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0; }

.drawer-task .drawer-body::-webkit-scrollbar-thumb:hover { background: #9ca3af !important; }

.drawer-task .drawer-body { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.drawer-task .drawer-body.ctx-scrolling,.drawer-task .drawer-body.ctx-scrollbar-hover { scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€ Boutons drawer â”€â”€ */

.drawer-task .btn-navy {    background-color: #0d9488; border-color: #0d9488; color: #fff; padding: 0.5rem 1.25rem;}

.drawer-task .btn-navy:hover,.drawer-task .btn-navy:focus { background-color: #0f766e; border-color: #0f766e; color: #fff; }

.drawer-task .btn-cancel {    border: 1px solid rgba(45,62,80,0.28); color: #415873; padding: 0.5rem 1.25rem;}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Harmonisation drawer-task avec drawer-project (2026-05-23) :
   classes gÃ©nÃ©riques drw-* pour patterns partagÃ©s (labels, erreurs, propriÃ©taire
   pseudo-display, espacements, couleurs champs). Vocation : converger tous les
   drawers (Tasks/Jalons/Community/futurs) sur le mÃªme design. Voir
   docs/sessions/2026-05-23_drawer-actions-jalons-harmo.md.
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Body : padding harmonisÃ©, gap entre sections (alignÃ© avec drawer projet).
   Le gap s'applique aussi sur les conteneurs intermÃ©diaires #task-section et
   #milestone-section dont les enfants sont les VRAIES sections du formulaire. */
.drawer-task .drw-body { padding: 12px 16px 0; display: flex; flex-direction: column; gap: 14px; }
.drawer-task .drw-body > * { margin: 0 !important; }
.drawer-task .drw-body #task-section,
.drawer-task .drw-body #milestone-section { display: flex; flex-direction: column; gap: 14px; }
.drawer-task .drw-body #task-section > *,
.drawer-task .drw-body #milestone-section > * { margin: 0 !important; }

/* Labels champs */
.drawer-task .drw-field-label { display: block; font-size: 0.72rem; font-weight: 600; color: #8fa1b3; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 4px; padding-bottom: 0; }
.drawer-task .drw-label-required { color: #2D3E50 !important; }
.drawer-task .drw-field-label .text-danger { margin-left: 3px; }

/* Erreur inline sous le champ */
.drawer-task .drw-err-inline { color: #ef4444; font-size: 0.72rem; margin-top: 4px; display: block; }

/* Champs harmonisÃ©s (bordure fine, focus teal) */
.drawer-task .form-control { border: 1px solid #dde1e7; border-radius: 2px; font-size: 0.84rem; padding: 0.32rem 0.6rem; }
.drawer-task .form-control:focus { border-color: #0d9488; box-shadow: 0 0 0 2px rgba(13,148,136,0.12); }
.drawer-task .form-control.is-invalid { border-color: #ef4444; }
.drawer-task .bootstrap-select > .btn { border: 1px solid #dde1e7 !important; border-radius: 2px !important; font-size: 0.84rem !important; }
.drawer-task .bootstrap-select > .btn:focus,.drawer-task .bootstrap-select.show > .btn { border-color: #0d9488 !important; }
.drawer-task .bootstrap-select.form-control { border: none !important; padding: 0 !important; box-shadow: none !important; }
.drawer-task .bootstrap-select > select.form-control { border: none !important; box-shadow: none !important; }
.drawer-task .input-group .form-control { border-radius: 2px !important; }
.drawer-task .form-group { margin-bottom: 0; }
.drawer-task .bootstrap-select { width: 100% !important; }

/* Boutons footer */
.drawer-task .btn-navy { background-color: #0d9488; border-color: #0d9488; color: #fff; padding: 0.42rem 1.2rem; font-size: 0.84rem; border-radius: 2px; font-weight: 500; }
.drawer-task .btn-navy:hover,.drawer-task .btn-navy:focus { background-color: #0f766e; border-color: #0f766e; color: #fff; }

/* Bouton "Dupliquer/Appliquer modÃ¨le" : harmonisation teal (vs ambre/jaune actuel) */
.drawer-task .btn-amber { background: rgba(13,148,136,0.10) !important; border: 1px solid rgba(13,148,136,0.30) !important; color: #0d9488 !important; font-weight: 500; }
.drawer-task .btn-amber:hover,.drawer-task .btn-amber:focus { background: rgba(13,148,136,0.18) !important; border-color: rgba(13,148,136,0.50) !important; color: #0f766e !important; }
.drawer-task .btn-amber:disabled { opacity: 0.55; }

/* Drawer template band (zone de choix de modÃ¨le) â€” couleurs identiques au drawer projet
   (rgba(45,62,80,0.04) background; rgba(45,62,80,0.15) border au repos ; teal au focus/hover). */
.drawer-task .drawer-template-band { background: rgba(45,62,80,0.04) !important; border-bottom: 1px solid rgba(45,62,80,0.1) !important; padding: 8px 16px !important; gap: 8px !important; }
.drawer-task .drawer-template-band .bootstrap-select > .btn { background: rgba(45,62,80,0.04) !important; border: 1px solid rgba(45,62,80,0.15) !important; border-bottom: 1px solid rgba(45,62,80,0.15) !important; color: #4b5563 !important; box-shadow: none !important; outline: none !important; transition: background 0.2s, border-color 0.2s, color 0.2s; }
.drawer-task .drawer-template-band:hover .bootstrap-select > .btn,
.drawer-task .drawer-template-band .bootstrap-select > .btn:focus,
.drawer-task .drawer-template-band .bootstrap-select.show > .btn { border-color: rgba(13,148,136,0.45) !important; border-bottom-color: rgba(13,148,136,0.45) !important; color: #0d9488 !important; }

/* Zone ACCÃˆS â€” segmented control (3 boutons) + lock toggle, rendu manuellement
   dans le Twig (label > input + span). ContrÃ´le HTML total, plus de wrapper Symfony. */
.drawer-task .drw-access-segmented-radios { display: flex !important; align-items: stretch; padding: 2px; background: #f1f3f5; border-radius: 4px; gap: 2px; flex: 1; min-width: 0; }
.drawer-task .drw-access-seg { flex: 1 1 0; display: flex; align-items: center; justify-content: center; height: 22px; padding: 0 8px; margin: 0; font-size: 0.75rem; font-weight: 500; color: #8fa1b3; background: transparent; border-radius: 2px; cursor: pointer; transition: background 0.12s, color 0.12s, box-shadow 0.12s; white-space: nowrap; text-align: center; }
.drawer-task .drw-access-seg input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; margin: 0; }
.drawer-task .drw-access-seg:hover { color: var(--fin-text-mid); }
.drawer-task .drw-access-seg.active { background: #fff; color: var(--fin-teal); font-weight: 600; box-shadow: 0 1px 2px rgba(0,0,0,0.10), 0 0 0 1px rgba(0,0,0,0.04); }

/* VerrouillÃ© â€” toggle icÃ´ne lock */
.drawer-task .drw-access-lock-btn { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 26px; color: #cbd5e1; border: 1px solid #e2e8f0; border-radius: 4px; background: #fff; cursor: pointer; transition: color 0.12s, border-color 0.12s, background 0.12s; margin: 0; padding: 0; flex-shrink: 0; }
.drawer-task .drw-access-lock-btn input[type="checkbox"] { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; margin: 0; }
.drawer-task .drw-access-lock-btn i { font-size: 0.85rem; line-height: 1; }
.drawer-task .drw-access-lock-btn:hover { color: var(--fin-text-mid); border-color: #9ca3af; }
.drawer-task .drw-access-lock-btn.active { color: #fff; background: var(--fin-teal); border-color: var(--fin-teal); }

/* Rappels : checkbox + input nombre + "jours avant" alignÃ©s sur la mÃªme baseline.
   Le wrapper .form-check de Symfony a un padding-left Bootstrap (1.25rem) qui
   dÃ©cale tout â€” on le neutralise. La checkbox est laissÃ©e en position statique
   (PAS cachÃ©e). */
.drawer-task .drw-reminders-row { display: flex !important; align-items: center; flex-wrap: wrap; gap: 8px 18px; }
.drawer-task .drw-reminder { display: flex !important; align-items: center !important; gap: 6px !important; }
.drawer-task .drw-reminder .form-check { display: flex !important; align-items: center !important; margin: 0 !important; padding: 0 !important; min-height: 0 !important; }
.drawer-task .drw-reminder .form-check .form-check-input,
.drawer-task .drw-reminder input[type="checkbox"] { position: static !important; opacity: 1 !important; margin: 0 !important; flex-shrink: 0; width: 14px !important; height: 14px !important; }
.drawer-task .drw-reminder .form-check .form-check-label { display: none !important; }
.drawer-task .drw-reminder input[type="number"],
.drawer-task .drw-reminder input[type="text"] { width: 50px !important; padding: 3px 6px !important; font-size: 0.84rem !important; text-align: center; height: auto !important; min-height: 0 !important; }
.drawer-task .drw-reminder-suffix { font-size: 0.82rem; color: var(--fin-text-muted); white-space: nowrap; }
/* Checkbox rappel : couleur teal quand cochÃ©e (accent-color natif) */
.drawer-task .drw-reminder input[type="checkbox"] { accent-color: var(--fin-teal); cursor: pointer; }

/* Section repliable "ParamÃ¨tres avancÃ©s" â€” calquÃ©e sur drw-prj-ctx-section du drawer projet */
.drawer-task .drw-task-advanced { margin-top: 4px; background: #f8fafb; border: 1px solid #edf1f5; border-radius: 2px; }
.drawer-task .drw-task-advanced-toggle { display: flex; align-items: center; gap: 6px; padding: 10px 14px; cursor: pointer; text-decoration: none !important; color: var(--fin-teal); font-size: 0.82rem; font-weight: 600; background: transparent; border: none; width: 100%; text-align: left; transition: background-color 0.15s ease, color 0.15s ease; border-radius: 2px; }
.drawer-task .drw-task-advanced-toggle:hover { background-color: #eef4f5; color: #0f766e; text-decoration: none !important; }
.drawer-task .drw-task-advanced-toggle:hover .drw-task-advanced-icon { color: #0f766e; }
.drawer-task .drw-task-advanced-opt { font-size: 0.72rem; color: var(--fin-text-muted); font-weight: 400; margin-left: 2px; }
.drawer-task .drw-task-advanced-count { font-size: 0.7rem; font-weight: 500; color: #475569; background: #e6f4f1; border: 1px solid #c4e7e0; border-radius: 10px; padding: 1px 8px; margin-left: 6px; }
.drawer-task .drw-task-advanced-icon { margin-left: auto; transition: transform 0.18s ease, color 0.15s ease; font-size: 0.75rem; }
.drawer-task .drw-task-advanced-toggle[aria-expanded="true"] .drw-task-advanced-icon { transform: rotate(90deg); }
.drawer-task .drw-task-advanced-body { padding: 4px 14px 14px; flex-direction: column; gap: 14px; display: none; }
.drawer-task .drw-task-advanced-body.show { display: flex; }
.drawer-task .drw-task-advanced-body > * { margin: 0 !important; }

/* Bouton ClÃ´turer (drawer Ã©dition action) â€” outline navy pour diffÃ©rencier d'Enregistrer (teal plein) */
.drawer-task .drw-task-complete-btn { background: #fff; border: 1px solid #2D3E50; color: #2D3E50; font-weight: 600; border-radius: 2px; transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease; }
.drawer-task .drw-task-complete-btn:hover { background: #2D3E50; border-color: #2D3E50; color: #fff; }
.drawer-task .drw-task-complete-btn.is-disabled { background: #f1f5f9; border: 1px solid #e2e8f0; color: #94a3b8; cursor: not-allowed; font-weight: 500; }
.drawer-task .drw-task-complete-btn.is-disabled:hover { background: #f1f5f9; border-color: #e2e8f0; color: #94a3b8; }

/* Footer drawer Action â€” border-radius 2px uniforme sur tous les boutons (cohÃ©rence avec design ref) */
.drawer-task .drawer-footer .btn { border-radius: 2px; }

/* Bouton Ajouter (checklist) â€” alignement Ã  gauche, override de .pl-5 hÃ©ritÃ© du markup form */
.drawer-task .drw-task-advanced-body .form-group.row.pl-5 { padding-left: 0 !important; margin-left: 0; margin-right: 0; }

/* â”€â”€â”€ Mode DISPLAY (lecture seule) drawer Action â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Bandeau clÃ´ture en haut du body */
.drawer-task .drw-task-completed-banner {
    background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534;
    font-size: 0.82rem; padding: 7px 14px; border-radius: 2px;
}
/* Valeur read-only : texte simple, taille cohÃ©rente avec les inputs en edit */
.drawer-task .drw-readonly-value { font-size: 0.85rem; color: #2D3E50; line-height: 1.4; padding: 2px 0; }
.drawer-task .drw-readonly-html { padding-top: 4px; }
.drawer-task .drw-readonly-html p:last-child { margin-bottom: 0; }
/* Chip AccÃ¨s (Ã©quivalent visuel du segmented control en read-only) */
.drawer-task .drw-access-chip {
    display: inline-block; font-size: 0.72rem; font-weight: 500;
    border: 1px solid #ff855e; color: #ff855e;
    padding: 2px 10px; border-radius: 10px; background: #fff;
}
/* Nom d'action en read-only â€” encadrÃ© lÃ©ger comme en edit, centrÃ© */
.drawer-task .drw-name-readonly {
    border: 1px solid #dde1e7; border-radius: 2px;
    padding: 8px 10px; text-align: center;
    font-size: 1rem; color: #2D3E50; background: #fafbfc;
}
.drawer-task .drw-task-advanced-body .add_element_link { margin-left: 0; }

/* Slider Avancement : centrÃ© verticalement Ã  la mÃªme hauteur que le dropdown PrioritÃ© voisin
   (qui est plus haut). On contraint la cellule Ã  display:flex column avec l'input bar
   verticalement centrÃ©e dans l'espace restant sous le label. */
.drawer-task .drw-row-50 > * { display: flex !important; flex-direction: column !important; }
.drawer-task .drw-row-50 > * > .drw-field-label { flex-shrink: 0; }
.drawer-task .drw-row-50 > * > .d-flex.align-items-center { flex: 1; min-height: 30px; }

/* Champ "Nom de l'action" pleine largeur, style alignÃ© sur .item-edit-title du drawer projet
   ("Nom du dossier") : encadrÃ© complet 4 bords, placeholder centrÃ©, grisÃ© 300 weight. */
.drawer-task .drw-name-field input,
.drawer-task .drw-name-field textarea { width: 100% !important; font-size: 1.05rem !important; font-weight: 400 !important; padding: 8px 12px !important; height: auto !important; min-height: 0 !important; line-height: 1.4 !important; resize: none !important; color: #2D3E50; border: 1px solid #dde1e7 !important; border-radius: 2px !important; background: #fff !important; box-shadow: none !important; text-align: center !important; }
.drawer-task .drw-name-field input:focus,
.drawer-task .drw-name-field textarea:focus { border-color: var(--fin-teal) !important; outline: none !important; box-shadow: 0 0 0 2px rgba(13,148,136,0.12) !important; }
.drawer-task .drw-name-field input::placeholder,
.drawer-task .drw-name-field textarea::placeholder { font-weight: 300 !important; color: #94a3b8 !important; font-size: 0.95rem; text-align: center; }
.drawer-task .drw-name-field textarea { min-height: 38px !important; }

/* Date inputs dans le drawer : pleine largeur de leur cellule .drw-row-50 > * */
.drawer-task .drw-date-field input.form-control,
.drawer-task .drw-date-field input[type="text"] { width: 100% !important; max-width: none !important; }

/* Pseudo-display Porteur (responsable) â€” 1 user seulement (pas d'Ã©quipe comme projet) */
.drawer-task .drw-owner-inline { display: flex; flex-wrap: nowrap; align-items: baseline; gap: 4px; width: 100%; font-size: 0.82rem; padding: 5px 0 7px; border-bottom: 1px solid #f0f4f8; }
.drawer-task .drw-owner-label { color: #8fa1b3; font-size: 0.74rem; }
.drawer-task .drw-owner-value { color: #2D3E50; font-weight: 400; font-size: 0.78rem; }
.drawer-task .drw-owner-edit-icon { margin-left: auto; visibility: hidden; color: #8fa1b3; font-size: 0.78rem; text-decoration: none !important; }
.drawer-task .drw-owner-inline:hover .drw-owner-edit-icon { visibility: visible; }
.drawer-task .drw-owner-edit-icon:hover { color: #0d9488; }

/* Row dates / prioritÃ©-progress : flex 50/50 avec gap, sans Bootstrap row */
.drawer-task .drw-row-50 { display: flex !important; gap: 8px !important; margin: 0 !important; }
.drawer-task .drw-row-50 > * { flex: 1 1 0 !important; min-width: 0 !important; max-width: none !important; padding: 0 !important; }

.drawer-task .btn-cancel:hover { background-color: #f8fafb; border-color: rgba(45,62,80,0.5); color: #2D3E50; }

/* â”€â”€ Drawer crÃ©ation/Ã©dition projet (Ã©tape 4a redesign V1) â”€â”€ */

/* Drawer Ã©dition projet : mÃªme largeur que les autres drawers et le side-panel
   (var(--sp-w), pilotÃ©e par mbwComputeDrawerWidth() dans app.js). */
.drawer-project {    position: fixed;    top: 0; right: calc(-1 * var(--sp-w)); bottom: 0;    width: var(--sp-w);    background: #fff;    display: flex;    flex-direction: column;    box-shadow: -4px 0 24px rgba(0,0,0,0.18);    transition: right 0.3s ease;    z-index: 1060;}

/* Overlay sur toute la zone, quand drawer Nouveau projet ouvert */
/* La navbar primaire (gauche) et la colonne liste projets sont remontÃ©es au-dessus de l'overlay â†’ visibles + cliquables */
.drw-new-prj-overlay {
    position: fixed;
    top: 0; bottom: 0; left: 0; right: 0;
    background-color: rgba(45, 62, 80, 0);
    z-index: 1058;
    transition: background-color 0.25s ease;
}
/* L'overlay capte les clics pour les bloquer sur la zone projet (clic = no-op, ne ferme PAS le drawer).
   DÃ©sactivÃ© tant que la classe drawer-new-project-open n'est pas posÃ©e, pour ne pas perturber l'app au repos. */
body:not(.drawer-new-project-open) .drw-new-prj-overlay { pointer-events: none; }
body.drawer-new-project-open .drw-new-prj-overlay { background-color: rgba(0, 0, 0, 0.5); }
body.drawer-new-project-open .drw-new-prj-overlay.drw-overlay-flash { background-color: rgba(0, 0, 0, 0.25); }
/* Remonte navbar + colonne liste projets au-dessus de l'overlay (sans toucher au drawer qui reste au z-index 1060) */
/* IMPORTANT : ne PAS surcharger 'position' â€” la navbar-primary est position:absolute, la changer casse le layout (push de la page). */
/* HiÃ©rarchie : navbar (1062) > #list-toggle (1061) > drawer (1060) > col-left (1059) > overlay (1058) */
/* !important nÃ©cessaire car .navbar-primary.collapsed.expanded a 3 classes (spÃ©cificitÃ© 0,0,3,0) > notre 0,0,2,1 */
body.drawer-new-project-open .navbar-primary { z-index: 1062 !important; }
body.drawer-new-project-open #list-toggle { z-index: 1061 !important; }
body.drawer-new-project-open .col-left {
    z-index: 1059;
    background-color: #fff;
}
/* ::before Ã©tend visuellement la col-left de 15px Ã  gauche (gap .row Bootstrap entre navbar et col-left) et 200px en haut (padding section) â€” couvre les strips qui laissaient passer l'overlay */
/* Important : on ne PAS Ã©tendre Ã  droite, sinon on couvre la zone oÃ¹ l'ombre doit apparaÃ®tre */
body.drawer-new-project-open .col-left::before {
    content: '';
    position: absolute;
    top: -200px;
    bottom: 0;
    left: -15px;
    right: 0;
    background: #fff;
    z-index: -1;
    pointer-events: none;
}
/* RecrÃ©e l'ombre/dÃ©gradÃ© d'origine (qui Ã©tait sur .col-right::before z-index 50, dÃ©sormais masquÃ© par l'overlay) */
/* left: 100% = colle l'ombre au bord droit de la col-left ; width: 12px = Ã©tend vers la droite sur 12px (au-dessus de l'overlay) */
body.drawer-new-project-open .col-left::after {
    content: '';
    position: absolute;
    top: 0; bottom: 0;
    left: 100%;
    width: 12px;
    background: linear-gradient(to right, rgba(45,62,80,0.17), rgba(45,62,80,0));
    pointer-events: none;
    z-index: 1;
}
@media (max-width: 767px) { .drw-new-prj-overlay { display: none; } }

.drawer-project.open { right: 0; }

.drawer-project .drawer-header {    display: flex;    justify-content: space-between;    align-items: center;    padding: 13px 16px 12px;    flex-shrink: 0;    background: #2D3E50;    border-bottom: 1px solid rgba(0,0,0,0.15);}

.drawer-project .drawer-header h1,.drawer-project .drawer-header h3 {    margin: 0;    font-size: 1.25rem;    font-weight: 700;    color: #fff;    white-space: nowrap;    overflow: hidden;    text-overflow: ellipsis;    max-width: calc(var(--sp-w) - 80px);}

.drawer-project .close-drawer {    background: none;    border: none;    font-size: 1.8rem;    line-height: 1;    cursor: pointer;    color: rgba(255,255,255,0.55);    opacity: 1;    padding: 0 0 0 12px;    flex-shrink: 0;}

.drawer-project .close-drawer:hover { color: #fff; }

.drawer-project > form {    display: flex;    flex-direction: column;    flex: 1;    min-height: 0;    overflow: hidden;}

.drawer-project .drawer-body {    flex: 1;    min-height: 0;    overflow-y: auto;    padding: 14px 0 0 0;    background: #fff;}

.drawer-project .drawer-footer {    padding: 12px 16px;    border-top: 1px solid rgba(45,62,80,0.15);    background: #fff;    flex-shrink: 0;}

.drawer-project .drawer-body::-webkit-scrollbar { width: 4px; background: transparent; }

.drawer-project .drawer-body::-webkit-scrollbar-track { background: transparent; border: none; }

.drawer-project .drawer-body::-webkit-scrollbar-thumb { background: transparent; border-radius: 4px; transition: background 0.25s; }

.drawer-project .drawer-body.ctx-scrolling::-webkit-scrollbar-thumb,.drawer-project .drawer-body.ctx-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0; }

.drawer-project .drawer-body::-webkit-scrollbar-thumb:hover { background: #9ca3af !important; }

.drawer-project .drawer-body { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.drawer-project .drawer-body.ctx-scrolling,.drawer-project .drawer-body.ctx-scrollbar-hover { scrollbar-color: #c4c9d0 transparent; }

.drawer-project .btn-navy {    background-color: #0d9488; border-color: #0d9488; color: #fff; padding: 0.5rem 1.25rem;}

.drawer-project .btn-navy:hover,.drawer-project .btn-navy:focus { background-color: #0f766e; border-color: #0f766e; color: #fff; }

.drawer-project .btn-cancel {    border: 1px solid rgba(45,62,80,0.28); color: #415873; padding: 0.5rem 1.25rem;}

.drawer-project .btn-cancel:hover { background-color: #f8fafb; border-color: rgba(45,62,80,0.5); color: #2D3E50; }

.drawer-project .container-modal-scrollable { height: auto !important; overflow: visible !important; }

.drawer-project .drawer-template-band { background: rgba(45,62,80,0.04) !important; border-bottom: 1px solid rgba(45,62,80,0.1) !important; padding: 8px 16px !important; display: flex; align-items: center; flex-shrink: 0; gap: 8px !important; }
.drawer-project .drawer-template-band .bootstrap-select { width: 100% !important; background: transparent !important; }
.drawer-project .drawer-template-band .bootstrap-select > .btn { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; background: rgba(45,62,80,0.04) !important; border: 1px solid rgba(45,62,80,0.15) !important; border-bottom: 1px solid rgba(45,62,80,0.15) !important; color: #4b5563 !important; box-shadow: none !important; outline: none !important; transition: background 0.2s, border-color 0.2s, color 0.2s; }
.drawer-project .drawer-template-band:hover .bootstrap-select > .btn,
.drawer-project .drawer-template-band .bootstrap-select > .btn:focus,
.drawer-project .drawer-template-band .bootstrap-select.show > .btn { background: rgba(13,148,136,0.13) !important; border-color: rgba(13,148,136,0.45) !important; border-bottom-color: rgba(13,148,136,0.45) !important; color: #0d9488 !important; }

/* â”€â”€ Header fiche projet (Ã©tape 5 redesign V1) â”€â”€ */

.prj-header { padding: 12px 40px 0 40px; background: #fff; }

/* Alignement panneau droit : 40 px Ã  gauche et Ã  droite (harmonisation cible).
   Ã‰tape 1 â€” 2026-05-23. */
.prj-tabs-wrapper { padding: 0 40px; }
#item-toolbar-container { padding-left: 40px !important; padding-right: 40px; }

.prj-header-line1 { margin-bottom: 12px; flex-wrap: nowrap; column-gap: 10px; }

.prj-header-title { font-size: 1.05rem; font-weight: 700; color: #2D3E50; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; margin: 0; }

.prj-header-favorite { color: #cfd8dc; font-size: 0.95rem; text-decoration: none; cursor: pointer; transition: color 0.12s; display: inline-flex; align-items: center; }

.prj-header-favorite:hover { text-decoration: none; }

.prj-header-favorite .fa-star.fas { color: #0d9488; }

.prj-header-favorite .fa-star.far:hover { color: #0d9488; }

.prj-header-pill { display: inline-flex; align-items: center; gap: 5px; padding: 3px 9px; font-size: 0.7rem; font-weight: 600; border-radius: 2px; color: var(--pill-color, #2D3E50); background: color-mix(in srgb, var(--pill-color, #2D3E50) 10%, #fff); border: 1px solid color-mix(in srgb, var(--pill-color, #2D3E50) 30%, transparent); white-space: nowrap; line-height: 1.35; flex-shrink: 0; }

.prj-header-pill-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--pill-color, #2D3E50); display: inline-block; flex-shrink: 0; }

.prj-header-pill-alert .fas { font-size: 0.62rem; }

.prj-header-kebab { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 2px; color: #8fa1b3; background: transparent; border: 1px solid #e2e8f0; cursor: pointer; transition: background 0.12s, color 0.12s, border-color 0.12s; text-decoration: none; font-size: 0.9rem; }

.prj-header-kebab:hover,.prj-header-kebab[aria-expanded="true"] { background: #e6f7f5; color: #0d9488; border-color: #0d9488; text-decoration: none; }

.prj-header-line2 { gap: 0; padding: 0 0 10px; justify-content: flex-start; }

.prj-header-info { display: flex; flex-direction: column; min-width: 0; flex: 0 0 calc(100% / 6); padding: 0 14px; }

.prj-header-info:first-child { padding-left: 0; }

.prj-header-info:last-child { padding-right: 0; }

.prj-header-info + .prj-header-info { border-left: 1px solid #eef2f5; }

.prj-header-info-owner { flex-direction: row !important; align-items: center; gap: 10px; }

.prj-header-owner-avatar .circled,.prj-header-owner-avatar .md-circled,.prj-header-owner-avatar .lg-circled { width: 28px !important; height: 28px !important; font-size: 0.65rem !important; line-height: 28px !important; flex-shrink: 0; }

.prj-header-owner-avatar .circled img,.prj-header-owner-avatar .md-circled img,.prj-header-owner-avatar .lg-circled img { width: 28px !important; height: 28px !important; }

.prj-header-owner-text { display: flex; flex-direction: column; min-width: 0; }

.prj-header-info-label { font-size: 0.6rem; font-weight: 600; color: #b0bcc8; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 3px; }

.prj-header-info-value { font-size: 0.76rem; font-weight: 500; color: #2D3E50; line-height: 1.3; }

.prj-header-info-empty { font-size: 0.78rem; font-weight: 400; color: #8fa1b3; font-style: italic; text-decoration: none; border-bottom: 1px dotted #8fa1b3; }

.prj-header-info-empty:hover { color: #0d9488; border-bottom-color: #0d9488; text-decoration: none; }

.prj-header-info-link { color: inherit; text-decoration: none; cursor: pointer; transition: color 0.12s; }

.prj-header-info-link:hover { color: #0d9488; text-decoration: none; }

.prj-header-line3 { padding: 10px 14px; background: #f4f6f9; border-radius: 3px; margin: 2px 0 0; font-size: 0.78rem; }

.prj-header-phase-dot { width: 8px; height: 8px; border-radius: 50%; background: #0d9488; display: inline-block; margin-right: 8px; flex-shrink: 0; box-shadow: 0 0 0 3px rgba(13,148,136,0.20); }

.prj-header-phase-label { color: #8fa1b3; font-weight: 500; }

.prj-header-phase-value { color: #2D3E50; font-weight: 600; }

/* Onglets fiche projet (style underline DS, indÃ©pendant de main-generic-tabs partagÃ© avec Suppliers) */

.prj-tabs-wrapper { background: #fff; padding-bottom: 4px; }

.prj-tabs.nav-tabs { border-bottom: 1px solid #e2e8f0; background: #fff; padding-left: 0; flex-wrap: nowrap; }

.prj-tabs.nav-tabs .nav-item { flex: 0 0 auto; }

.prj-tabs.nav-tabs .nav-link, .prj-tabs.nav-tabs .nav-link.active, .prj-tabs.nav-tabs .nav-link:hover { position: relative; border: none; background: transparent; font-family: inherit !important; font-size: 0.85rem !important; font-weight: 400 !important; padding: 10px 14px; margin: 0 28px 0 0; transition: color 0.12s; }

.prj-tabs.nav-tabs .nav-link { color: #6b7a8d; }

.prj-tabs.nav-tabs .nav-link::after { content: ''; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: #0d9488; transform: scaleX(0); transform-origin: center; transition: transform 0.15s ease; }

.prj-tabs.nav-tabs .nav-link:hover { color: #0d9488; font-weight: 400 !important; }

.prj-tabs.nav-tabs .nav-link:hover::after { transform: scaleX(1); }

.prj-tabs.nav-tabs .nav-link.active, .prj-tabs.nav-tabs .nav-link.active:hover { color: #0d9488 !important; font-weight: 600 !important; border-bottom: none !important; }

.prj-tabs.nav-tabs .nav-link.active::after, .prj-tabs.nav-tabs .nav-link:hover::after { transform: scaleX(1); }

.prj-tabs.nav-tabs .nav-link:focus { outline: none; box-shadow: none; }


/* â”€â”€ Lien description (partagÃ© tÃ¢che + jalon) â”€â”€ */

.drawer-desc-trigger {    color: rgba(13,148,136,0.65); font-size: 0.85rem;    cursor: pointer; display: inline-flex; align-items: center; gap: 4px;}

.drawer-desc-trigger:hover { color: #0d9488; text-decoration: none; }

/* â”€â”€â”€ 3. Side Panel â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

#side-panel {    position: fixed;    right: calc(-1 * var(--sp-w)); top: 0; bottom: 0;    width: var(--sp-w);    background: #f4f6f8;    border-left: 1px solid #e2e8f0;    box-shadow: -6px 0 12px rgba(45,62,80,0.17);    z-index: 500;    display: flex;    flex-direction: column;    transition: right 0.28s ease;    overflow: hidden;}body.sp-open #side-panel { right: 0; }

#project-container, #item-toolbar-container { transition: margin-right 0.28s ease; }body.sp-open #project-container { margin-right: var(--sp-w); }body.sp-open #item-toolbar-container { margin-right: var(--sp-w); }body.sp-open .margined { max-width: none !important; }

/* â”€â”€ Bouton toggle â”€â”€ */

/* sp-toggle (dÃ©plier panel droit) â€” compact, chevron seul, Ã©tape 6.6 */
#sp-toggle { position: fixed; right: 0; top: 50%; transform: translateY(-50%); z-index: 501; background: #2D3E50; color: #fff; border: none; border-radius: 4px 0 0 4px; width: 18px; height: 48px; padding: 0; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: right 0.28s ease, background 0.15s; }
#sp-toggle:hover { background: #0d9488; }
body.modal-open #sp-toggle { visibility: hidden; pointer-events: none; }
#sp-toggle:focus, #sp-toggle:focus-visible { outline: none; box-shadow: none; }
#sp-toggle #sp-toggle-icon { font-size: 0.7rem; transition: transform 0.28s; }
body.sp-open #sp-toggle { right: var(--sp-w); }
body.sp-open #sp-toggle #sp-toggle-icon { transform: rotate(180deg); }

/* â”€â”€ Sections accordion (refonte Ã©tape 6.6 â€” fond clair cohÃ©rent thÃ¨me blanc) â”€â”€ */

.sp-section { display: flex; flex-direction: column; flex-shrink: 0; }

.sp-section.sp-active { flex: 1; min-height: 0; }

.sp-section-header { background: #f1f5f9; color: #2D3E50; padding: 9px 14px; cursor: pointer; display: flex; align-items: center; justify-content: space-between; font-size: 0.78rem; font-weight: 600; user-select: none; border-bottom: 1px solid #e2e8f0; transition: background 0.15s; flex-shrink: 0; }

.sp-section-header:hover { background: #e6f7f5; }

.sp-icon { color: #0d9488; margin-right: 7px; }

.sp-chevron { font-size: 0.6rem; opacity: 0.55; transition: transform 0.2s; flex-shrink: 0; color: #6b7a8d; }

.sp-section.sp-active .sp-chevron { transform: rotate(180deg); }

.sp-add-inline { color: #8fa1b3; font-size: 0.65rem; line-height: 1; text-decoration: none; padding: 2px 4px; border-radius: 2px; transition: color 0.15s, background 0.15s; }

.sp-add-inline:hover { color: #0d9488; background: rgba(13,148,136,0.10); text-decoration: none; }

.sp-section-body {    display: none; overflow-y: auto; overflow-x: hidden;    background: #fff; flex: 1; min-height: 0;}

.sp-section.sp-active .sp-section-body { display: flex; flex-direction: column; }

.sp-section-body::-webkit-scrollbar { width: 3px; }

.sp-section-body::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 3px; }

.sp-loader {    display: flex; align-items: center; justify-content: center;    padding: 24px; color: #9ca3af; font-size: 1.1rem; flex: 1;}

/* â”€â”€ Empty state panel â”€â”€ */

.sp-empty-state {    display: flex; flex-direction: column; align-items: center; justify-content: center;    padding: 28px 16px; text-align: center; gap: 6px;}

.sp-empty-state-icon { font-size: 1.4rem; color: #d1d5db; margin-bottom: 4px; }

.sp-empty-state-title { font-size: 0.78rem; font-weight: 600; color: #6b7280; line-height: 1.3; }

.sp-empty-state-hint { font-size: 0.71rem; color: #9ca3af; line-height: 1.4; max-width: 200px; }

/* â”€â”€ Item rows (notes / docs) â”€â”€ */

.sp-item-row {    display: flex; align-items: center;    padding: 7px 12px; border-bottom: 1px solid #f3f4f6;    gap: 8px; position: relative;}

.sp-item-row:last-child { border-bottom: none; }

.sp-item-row:hover { background: #fafafa; }

.sp-item-row-body { flex: 1; min-width: 0; }

.sp-item-row-name {    font-size: 0.78rem; font-weight: 500; color: #374151;    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}

.sp-item-row-meta { font-size: 0.68rem; color: #9ca3af; margin-top: 2px; display: flex; align-items: center; gap: 6px; }

.sp-item-row-badge {    display: inline-block; font-size: 0.62rem;    border: 1px solid #ff855e; color: #ff855e;    border-radius: 20px; padding: 0 5px; line-height: 1.5;}

.sp-item-row-actions {    display: flex; align-items: center; gap: 6px;    opacity: 0; transition: opacity 0.15s; flex-shrink: 0;}

.sp-item-row:hover .sp-item-row-actions { opacity: 1; }

.sp-item-row-actions a { color: #9ca3af; font-size: 0.75rem; line-height: 1; text-decoration: none; }

.sp-item-row-actions a:hover { color: #ef4444; }

#sp-body-documents .sp-item-row-actions a.sp-doc-view:hover,#sp-body-documents .sp-item-row-actions a.sp-doc-download:hover { color: #00897b; }

.sp-item-row-avatar { flex-shrink: 0; margin-right: 6px; }

/* Avatar 18px */

#sp-body-notes .sp-item-row-avatar .md-circled,#sp-body-documents .sp-item-row-avatar .md-circled {    width: 18px !important; height: 18px !important;    min-width: 18px !important; line-height: 18px !important;}

#sp-body-notes .sp-item-row-avatar .md-circled img,#sp-body-documents .sp-item-row-avatar .md-circled img { width: 18px !important; height: 18px !important; }

#sp-body-notes .sp-item-row-avatar .md-circled div,#sp-body-documents .sp-item-row-avatar .md-circled div {    font-size: 7px !important; line-height: 18px !important; padding-top: 0 !important;}

#sp-body-notes .sp-note-row { cursor: pointer; }

/* â”€â”€ Barre d'action Notes/Fichiers â”€â”€ */

.sp-panel-add-bar {    margin-top: auto; padding: 8px 12px 10px;    position: sticky; bottom: 0;    background: #f4f6f8; z-index: 1;    display: flex; flex-direction: column; gap: 6px;}

.sp-panel-add-btn {    display: flex; align-items: center; justify-content: center; gap: 6px;    width: 100%; padding: 7px 12px;    background: #0d9488; color: #fff !important;    border-radius: 2px; font-size: 0.75rem; font-weight: 500;    text-decoration: none; transition: background 0.15s;}

.sp-panel-add-btn:hover { background: #0f766e; color: #fff !important; text-decoration: none; }

#sp-open-doc-history {    font-size: 10.5px; color: rgba(13,148,136,0.4);    text-decoration: none;    display: inline-flex; align-items: center; justify-content: center; gap: 4px;    transition: color 0.2s;}

#sp-open-doc-history:hover,#sp-open-doc-history.sp-doc-hist-near { color: #0d9488; text-decoration: none; }

/* â”€â”€â”€ 4. Onglet Contexte â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ *//* â”€â”€ Layout colonnes â”€â”€ */

.ctx-left-col  { background: var(--ctx-bg-section); display: flex; flex-direction: column; overflow: hidden; flex: 0 0 60% !important; max-width: 60% !important; }

.ctx-right-col { background: var(--ctx-bg-section); display: flex; flex-direction: column; overflow: hidden; flex: 0 0 40% !important; max-width: 40% !important; }

.ctx-col-top-strip { flex: 0 0 10px; background: var(--ctx-bg-section); transition: opacity 0.18s ease; }

.ctx-col-top-strip.ctx-strip-hidden { opacity: 0; }

/* Ã‰tape 4c.2-bis â€” Barre de titre de section (FICHE PROJET / ASSOCIATIONS).
   Remplace le ctx-col-top-strip vide pour donner un chapeau sÃ©mantique aux 2 colonnes du Contexte.
   Inclut titre uppercase discret + % complÃ©tude + boutons d'action + barre de progression dessous. */
.ctx-section-title-bar {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    column-gap: 10px;
    padding: 8px 16px 8px 40px;
    background: var(--ctx-bg-section);
    flex: 0 0 auto;
}
.ctx-section-title-bar-right { padding: 8px 40px 8px 16px; grid-template-columns: 1fr; }
/* line-height fixe sur les Ã©lÃ©ments pour garantir l'alignement vertical des 2 titres (gauche/droite) */
.ctx-section-title-label {
    font-size: 0.72rem;
    font-weight: 600;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    line-height: 24px;
}
/* Mini-cercle + % discret alignÃ© sur le bas du cercle (alignement baseline-end) */
.ctx-section-title-completion {
    display: inline-flex;
    align-items: flex-end;
    gap: 4px;
    cursor: help;
    line-height: 1;
}
.ctx-section-title-completion svg {
    width: 18px; height: 18px;
    display: block;
}
.ctx-section-title-percent {
    font-size: 0.62rem;
    font-weight: 300;
    color: #94a3b8;
    line-height: 1;
    padding-bottom: 1px;
}
.ctx-section-title-actions {
    display: inline-flex;
    gap: 6px;
    align-items: center;
    line-height: 24px;
}
.ctx-section-title-actions .ctx-action-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 24px; height: 24px;
    color: #cbd5e1;
    font-size: 0.78rem;
    text-decoration: none;
    border-radius: 4px;
    transition: background 0.12s ease, color 0.12s ease;
}
.ctx-section-title-actions .ctx-action-btn:hover { background: #e6f7f5; color: #0d9488; }

.ctx-left-col .container-scrollable,.ctx-right-scrollable { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; width: 100%; }

.ctx-left-col .container-scrollable > div { padding-left: 40px !important; padding-right: 8px !important; }
.ctx-right-scrollable { scrollbar-gutter: stable; }
.ctx-right-scrollable > div { padding-left: 21px !important; padding-right: 34px !important; }

/* Ã‰tape 2 â€” Alignement 40/40 onglets Finance / Tasks / RÃ©sultats (2026-05-23).
   scrollbar-gutter: stable + compensation padding-right par la largeur de la
   scrollbar pour aligner le bord droit des cartes sur celui du header
   quelle que soit la prÃ©sence d'une scrollbar. */
#project-costs-content { padding-left: 40px; padding-right: 34px; }
#project-costs-content .container-scrollable { scrollbar-gutter: stable; }
.res-col-scrollable { scrollbar-gutter: stable; }
.res-left-col .res-col-scrollable > div { padding-left: 40px; padding-right: 8px; }
.res-right-col .res-col-scrollable > div { padding-left: 16px; padding-right: 37px; }

/* Neutralise scroll parasite */

#project-preview-col, #item-content { background: var(--ctx-bg-section) !important; overflow: hidden !important; }

/* â”€â”€ Scrollbars colonnes principales â”€â”€ */

.ctx-left-col .container-scrollable::-webkit-scrollbar,.ctx-right-scrollable::-webkit-scrollbar { width: 3px; background: transparent !important; }

.ctx-left-col .container-scrollable::-webkit-scrollbar-track,.ctx-right-scrollable::-webkit-scrollbar-track { background: transparent !important; border: none !important; }

.ctx-left-col .container-scrollable::-webkit-scrollbar-thumb,.ctx-right-scrollable::-webkit-scrollbar-thumb { background: transparent !important; border-radius: 4px; transition: background 0.25s; }

.ctx-left-col .container-scrollable.ctx-scrolling::-webkit-scrollbar-thumb,.ctx-right-scrollable.ctx-scrolling::-webkit-scrollbar-thumb,.ctx-left-col .container-scrollable.ctx-scrollbar-hover::-webkit-scrollbar-thumb,.ctx-right-scrollable.ctx-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0 !important; }

.ctx-left-col .container-scrollable,.ctx-right-scrollable { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.ctx-left-col .container-scrollable.ctx-scrolling,.ctx-right-scrollable.ctx-scrolling,.ctx-left-col .container-scrollable.ctx-scrollbar-hover,.ctx-right-scrollable.ctx-scrollbar-hover { scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€ Cards infos gauche â”€â”€ */

.ctx-info-card { background: var(--ctx-bg-card); border: var(--ctx-border); border-radius: var(--ctx-radius-lg); box-shadow: var(--ctx-shadow); margin-bottom: 16px; }


.ctx-info-card-header { display: flex; align-items: center; gap: 12px; padding: 12px 20px; border-bottom: 1px solid rgba(45,62,80,0.35); background: #fff; }

.ctx-info-card-body { padding: 12px 20px 16px 20px; }

.ctx-info-card-body .row.ml-2 { margin-left: 0 !important; margin-right: 0 !important; margin-bottom: 8px !important; align-items: baseline; }

.ctx-info-card-body .row.ml-2 .col-6.col-md-4,.ctx-info-card-body .row.ml-2 .px-0.px-sm-3.col-6.col-md-4 { font-size: 0.72rem; color: var(--ctx-text-muted); font-weight: 400; padding-left: 0 !important; padding-right: 8px !important; }

.ctx-info-card-body .row.ml-2 .col-6.col-md-8,.ctx-info-card-body .row.ml-2 .col-md-8 { font-size: 0.79rem; color: var(--ctx-text-dark); font-weight: 500; padding-left: 0 !important; padding-right: 0 !important; }

.ctx-info-card-body .row.ml-2 .col-md-12 { font-size: 0.79rem; color: var(--ctx-text-mid); line-height: 1.5; padding-left: 0 !important; padding-right: 0 !important; }

.ctx-info-card-body .auto-truncated { white-space: normal !important; overflow: visible !important; text-overflow: unset !important; }

.ctx-info-card-body .starrating { display: flex; gap: 3px; flex-wrap: wrap; }

.ctx-info-card-body .starrating .fas { color: var(--ctx-teal) !important; }

.ctx-info-card-body .starrating .far { color: #cfd8dc !important; }

.ctx-info-card-body .sm-squared { display: none !important; }

.ctx-calculated-field .ctx-calculated-icon { font-size: 0.62rem; color: var(--ctx-text-muted); margin-right: 4px; opacity: 0.7; cursor: help; }

/* â”€â”€ IcÃ´ne box + titre â”€â”€ */

.ctx-icon-box { display: flex; align-items: center; justify-content: center; color: var(--ctx-teal); font-size: 0.88rem; flex-shrink: 0; width: 18px; }

.ctx-icon-box-sm { display: flex; align-items: center; justify-content: center; color: var(--ctx-teal); font-size: 0.88rem; flex-shrink: 0; width: 18px; }

.ctx-card-title { font-size: 0.80rem; font-weight: 500; color: var(--ctx-text-dark); letter-spacing: normal; }

/* â”€â”€ Sections droite â”€â”€ */

.ctx-section { background: var(--ctx-bg-card); border: var(--ctx-border); border-radius: var(--ctx-radius-lg); box-shadow: var(--ctx-shadow); margin-bottom: 16px; }

.ctx-section-header {    display: flex; align-items: center;    padding: 12px 16px; background: #fff;    border-bottom: 1px solid rgba(45,62,80,0.35);    border-radius: var(--ctx-radius-lg) var(--ctx-radius-lg) 0 0;    gap: 8px; flex-wrap: wrap;}

.ctx-sh-left { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

.ctx-section-label { font-size: 0.80rem; font-weight: 500; color: var(--ctx-text-dark); letter-spacing: normal; }

.ctx-sh-right { display: flex; align-items: center; gap: 6px; margin-left: auto; flex-wrap: nowrap; }

.ctx-sh-right .select2-container { min-width: 148px; }

.ctx-sh-right .select2-container--default .select2-selection--single { height: 27px; border: 1px solid #d1d5db; border-radius: var(--ctx-radius-sm); background: #fff; }

.ctx-sh-right .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 25px; color: #9ca3af; font-size: 0.73rem; padding-left: 9px; padding-right: 22px; }

.ctx-sh-right .select2-container--default .select2-selection--single .select2-selection__arrow { height: 25px; width: 20px; }

/* â”€â”€ Listes scrollables â”€â”€ */

.ctx-section-list { max-height: 152px; overflow-y: auto; padding-top: 2px; padding-bottom: 2px; }

.ctx-section-list-lg { max-height: 190px; }

.ctx-section-list::-webkit-scrollbar { width: 3px; }

.ctx-section-list::-webkit-scrollbar-track { background: transparent; }

.ctx-section-list::-webkit-scrollbar-thumb { background: transparent; border-radius: 3px; transition: background 0.2s; }

.ctx-section:hover .ctx-section-list::-webkit-scrollbar-thumb { background: #c4c9d0; }

.ctx-section-list::-webkit-scrollbar-thumb:hover { background: #9ca3af; }

.ctx-section-list { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.ctx-section:hover .ctx-section-list { scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€ Planning strip â”€â”€ */

.ctx-planning-strip { display: flex; flex-wrap: wrap; gap: 4px 24px; align-items: center; padding: 8px 20px; border-top: 1px solid #e2e8f0; background: transparent; border-radius: 0; }

.ctx-planning-strip .row.ml-2 { display: flex !important; flex-direction: row !important; align-items: center; gap: 6px; margin: 0 !important; width: auto !important; flex: 0 0 auto; }

.ctx-planning-strip .row.ml-2 [class*="col-"] { width: auto !important; flex: 0 0 auto !important; padding: 0 !important; max-width: none !important; }

.ctx-planning-strip .row.ml-2 .col-6.col-md-4,.ctx-planning-strip .row.ml-2 .px-0.px-sm-3.col-6.col-md-4 { font-size: 0.70rem; color: var(--ctx-text-muted); white-space: nowrap; font-weight: 400; }

.ctx-planning-strip .row.ml-2 .col-6.col-md-8,.ctx-planning-strip .row.ml-2 .col-md-8 { font-size: 0.79rem; font-weight: 500; color: var(--ctx-text-dark); white-space: nowrap; padding-left: 0 !important; }

/* â”€â”€ Badge compteur â”€â”€ */

.ctx-count-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 16px; height: 16px; padding: 0 4px; background: var(--ctx-teal-light); color: var(--ctx-teal); border-radius: 2px; font-size: 0.65rem; font-weight: 600; line-height: 1; }

/* â”€â”€ Boutons d'action header card â”€â”€ */

.ctx-action-btn { flex-shrink: 0; width: 26px; height: 26px; padding: 0; border: 1px solid #e5e7eb; border-radius: var(--ctx-radius-sm); background: #fff; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; color: var(--ctx-text-muted); font-size: 0.72rem; transition: background 0.15s, color 0.15s, border-color 0.15s; text-decoration: none; }

.ctx-action-btn:hover { text-decoration: none; }

.ctx-action-edit:hover   { background: var(--ctx-teal-light); color: var(--ctx-teal); border-color: var(--ctx-teal); }

.ctx-action-source:hover { background: #eff6ff; color: #3b82f6; border-color: #93c5fd; }

.ctx-action-delete:hover { background: #fef2f2; color: #ef4444; border-color: #fca5a5; }

.ctx-action-kebab:hover,.ctx-action-kebab[aria-expanded="true"] { background: var(--ctx-teal-light); color: var(--ctx-teal); border-color: var(--ctx-teal); }

.ctx-action-menu { font-size: 0.78rem; min-width: 200px; border: 1px solid #e5e7eb; border-radius: var(--ctx-radius-sm); box-shadow: 0 4px 12px rgba(0,0,0,0.08); padding: 4px 0; }

.ctx-action-menu .dropdown-item { padding: 8px 14px; color: var(--ctx-text-dark); display: flex; align-items: center; transition: background 0.12s, color 0.12s; }

.ctx-action-menu .dropdown-item:hover,.ctx-action-menu .dropdown-item:focus { background: var(--ctx-teal-light); color: var(--ctx-teal); }

.ctx-action-menu .dropdown-item .fas { width: 16px; font-size: 0.78rem; color: var(--ctx-text-muted); }

.ctx-action-menu .dropdown-item:hover .fas { color: var(--ctx-teal); }

.ctx-action-menu .ctx-action-item-delete { color: #ef4444; }

.ctx-action-menu .ctx-action-item-delete:hover,.ctx-action-menu .ctx-action-item-delete:focus { background: #fef2f2; color: #ef4444; }

.ctx-action-menu .ctx-action-item-delete .fas { color: #ef4444; }

.ctx-action-menu .ctx-action-item-delete:hover .fas,.ctx-action-menu .ctx-action-item-delete:focus .fas { color: #ef4444; }

.ctx-action-menu .dropdown-divider { margin: 4px 0; border-top-color: #f1f5f9; }

/* â”€â”€ Bouton expand â”€â”€ */

.ctx-expand-btn { flex-shrink: 0; width: 24px; height: 24px; padding: 0; border: 1px solid #e5e7eb; border-radius: var(--ctx-radius-sm); background: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--ctx-text-muted); font-size: 0.65rem; transition: background 0.15s, color 0.15s, border-color 0.15s; margin-left: 4px; }

.ctx-expand-btn:hover { background: var(--ctx-teal-light); color: var(--ctx-teal); border-color: var(--ctx-teal); }

.ctx-expand-btn i { transition: transform 0.22s ease; }

.ctx-section.ctx-expanded .ctx-expand-btn { background: var(--ctx-teal-light); color: var(--ctx-teal); border-color: var(--ctx-teal); }

.ctx-section.ctx-expanded .ctx-expand-btn i { transform: rotate(180deg); }

/* â”€â”€ Bouton + (ajouter inline) â”€â”€ */

.ctx-add-btn { background: none; border: 1px solid #d1d5db; color: var(--ctx-teal); min-width: 24px; height: 24px; padding: 0 5px; border-radius: var(--ctx-radius-sm); font-size: 0.68rem; flex-shrink: 0; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: background 0.15s, color 0.15s, border-color 0.15s; white-space: nowrap; overflow: hidden; }

.ctx-add-btn .ctx-add-label { max-width: 0; overflow: hidden; padding-left: 0; transition: max-width 0.2s ease, opacity 0.2s ease, padding-left 0.2s ease; opacity: 0; font-size: 0.72rem; font-weight: 500; }

.ctx-add-btn:hover .ctx-add-label,.ctx-add-btn.active .ctx-add-label { max-width: 60px; opacity: 1; padding-left: 4px; }

.ctx-add-btn:hover,.ctx-add-btn.active { background: var(--ctx-teal); color: #fff; border-color: var(--ctx-teal); }

.ctx-add-btn:disabled { opacity: 0.45; cursor: not-allowed; pointer-events: none; }

/* â”€â”€ Panneau inline associer â”€â”€ */

.ctx-add-panel { padding: 8px 12px; background: var(--ctx-teal-light); border-bottom: 1px solid #b2f0e8; display: flex; align-items: center; gap: 8px; flex-wrap: nowrap; }

.ctx-add-panel .flex-fill { min-width: 0; flex: 1; }

.ctx-add-panel .select2-container { width: 100% !important; }

.ctx-add-panel .select2-container--default .select2-selection--single { height: 27px; border: 1px solid #d1d5db; border-radius: var(--ctx-radius-sm); background: #fff; }

.ctx-add-panel .select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 25px; font-size: 0.73rem; padding-left: 9px; padding-right: 22px; color: #374151; }

.ctx-add-panel .select2-container--default .select2-selection--single .select2-selection__arrow { height: 25px; }

/* â”€â”€ Bouton assoc â”€â”€ */

.ctx-btn-assoc { background: #fff !important; border: 1px solid var(--ctx-teal) !important; color: var(--ctx-teal) !important; border-radius: var(--ctx-radius-sm); font-size: 0.75rem; padding: 3px 12px; white-space: nowrap; line-height: 1.5; font-weight: 500; }

.ctx-btn-assoc:hover { background: var(--ctx-teal-hover) !important; }

.ctx-btn-delete { background: #fff; border: 1px solid #d1d5db; color: #4b5563; border-radius: var(--ctx-radius-sm); }

.ctx-btn-delete:hover { background: #f9fafb; }

/* â”€â”€ RangÃ©es membres / fournisseurs / projets â”€â”€ */

.ctx-member-row { display: flex; align-items: center; padding: 0 14px 0 12px; gap: 8px; height: 38px; border-bottom: 1px solid #f3f4f6; transition: background 0.1s; }

.ctx-member-row:last-child { border-bottom: none; }

.ctx-member-row:hover { background: #f9fafb; }

.ctx-member-avatar { flex-shrink: 0; display: flex; align-items: center; }

.ctx-member-row .circled,.ctx-member-row .md-circled { width: 20px !important; height: 20px !important; min-width: 20px; font-size: 0.55rem !important; line-height: 20px !important; }

.ctx-member-row .circled img,.ctx-member-row .md-circled img { width: 20px !important; height: 20px !important; }

.ctx-avatar-placeholder, .ctx-avatar-group { width: 20px; height: 20px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.55rem; flex-shrink: 0; }

.ctx-avatar-placeholder { border: 1px solid #FF5722; color: #FF5722; }

.ctx-avatar-group { background: var(--ctx-teal-light); color: var(--ctx-teal); }

.ctx-member-name { font-size: 0.79rem; font-weight: 400; color: var(--ctx-text-mid); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-decoration: none; }a.ctx-member-name:hover { color: var(--ctx-teal); text-decoration: none; }

.ctx-member-cat { font-size: 0.72rem; color: var(--ctx-text-muted); white-space: nowrap; flex-shrink: 0; }

.ctx-member-actions { width: 20px; flex-shrink: 0; display: flex; justify-content: flex-end; }

.ctx-member-delete { visibility: hidden; color: #d1d5db; font-size: 0.78rem; flex-shrink: 0; text-decoration: none; padding: 2px 4px; }

.ctx-member-row:hover .ctx-member-delete { visibility: visible; }

.ctx-member-delete:hover { color: #ef4444; }

/* â”€â”€ Contacts fournisseur â”€â”€ */[id^="ctxCS"] { border-left: 2px solid #e9ecef; margin-left: 26px; }

.ctx-contact-row { display: flex; align-items: center; gap: 8px; padding: 0 12px 0 10px; height: 34px; border-bottom: 1px solid #f3f4f6; transition: background 0.1s; }

.ctx-contact-row:hover { background: #f9fafb; }

.ctx-contact-row:last-of-type { border-bottom: none; }

.ctx-contact-name { font-size: 0.8rem; font-weight: 500; color: var(--ctx-text-dark); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.ctx-contact-cat { font-size: 0.75rem; color: var(--ctx-text-muted); flex-shrink: 0; }

.ctx-contact-actions { width: 20px; flex-shrink: 0; display: flex; justify-content: flex-end; }

.ctx-contact-actions .ctx-member-delete { visibility: hidden; }

.ctx-contact-row:hover .ctx-contact-actions .ctx-member-delete { visibility: visible; }

.ctx-contact-add-trigger { display: flex; align-items: center; gap: 6px; padding: 6px 12px; font-size: 0.78rem; color: var(--ctx-teal); cursor: pointer; border-top: 1px solid #f3f4f6; transition: background 0.1s; user-select: none; }

.ctx-contact-add-trigger:hover { background: var(--ctx-teal-light); }

.ctx-contact-add-trigger i { font-size: 0.68rem; }

.ctx-contact-add-panel { overflow: hidden; max-height: 0; padding-top: 0 !important; padding-bottom: 0 !important; transition: max-height 0.18s ease, padding 0.18s ease; }

.ctx-contact-add-panel.open { max-height: 120px; padding-top: 8px !important; padding-bottom: 8px !important; overflow: visible; }

/* â”€â”€ Fournisseurs â”€â”€ */

.ctx-supplier-row { display: flex; align-items: center; padding: 0 14px 0 12px; gap: 8px; height: 38px; border-bottom: 1px solid #f3f4f6; transition: background 0.1s; }

.ctx-supplier-row:last-child { border-bottom: none; }

.ctx-supplier-row:hover { background: #f9fafb; }

.ctx-supplier-row:hover .btn-hover { display: inline-block !important; }

.ctx-supplier-row:hover .ctx-member-delete { visibility: visible; }

.ctx-supplier-toggle { cursor: pointer; color: #9ca3af; flex-shrink: 0; width: 16px; font-size: 0.8rem; }

.ctx-supplier-name { font-size: 0.79rem; font-weight: 400; color: var(--ctx-text-mid); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.ctx-supplier-badge { display: inline-flex; align-items: center; border: none; border-radius: 2px; font-size: 0.68rem; font-weight: 400; padding: 2px 7px; line-height: 1.4; white-space: nowrap; flex-shrink: 0; background: #f1f3f5; color: #8fa1b3; transition: color 0.15s ease, background 0.15s ease; }

.ctx-supplier-row:hover .ctx-supplier-badge { background: #e8edf2; color: var(--badge-color); }

.ctx-open-action { color: #d1d5db; opacity: 0; pointer-events: none; font-size: 0.78rem; flex-shrink: 0; text-decoration: none; padding: 4px 6px; position: relative; z-index: 2; transition: opacity 0.1s; }

.ctx-supplier-row:hover .ctx-open-action,.ctx-contact-row:hover .ctx-open-action { opacity: 1; pointer-events: auto; }

.ctx-open-action:hover { color: var(--ctx-teal) !important; }

.ctx-supplier-actions { min-width: 44px; display: flex; align-items: center; justify-content: flex-end; gap: 4px; }

/* â”€â”€ RangÃ©es projets liÃ©s â”€â”€ */

.ctx-project-row { display: flex; align-items: center; padding: 0 14px 0 12px; gap: 8px; height: 38px; border-bottom: 1px solid #f3f4f6; transition: background 0.1s; }

.ctx-project-row:last-child { border-bottom: none; }

.ctx-project-row:hover { background: #f9fafb; }

.ctx-project-row .circled,.ctx-project-row .md-circled { width: 20px !important; height: 20px !important; min-width: 20px; font-size: 0.55rem !important; line-height: 20px !important; }

.ctx-project-row .circled img,.ctx-project-row .md-circled img { width: 20px !important; height: 20px !important; }

.ctx-project-name { font-size: 0.79rem; font-weight: 400; color: var(--ctx-text-mid); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-decoration: none; }a.ctx-project-name:hover { color: var(--ctx-teal); text-decoration: none; }

.ctx-project-date { font-size: 0.72rem; color: var(--ctx-text-muted); flex-shrink: 0; white-space: nowrap; }

/* â”€â”€ Label sous-section â”€â”€ */

.ctx-subsection-label { padding: 6px 16px 2px 16px; margin-bottom: 0; font-size: 0.67rem; font-weight: 700; color: #9ca3af; text-transform: uppercase; letter-spacing: 0.08em; }

/* â”€â”€ Empty state â”€â”€ */

.ctx-empty-state { display: flex; flex-direction: column; align-items: center; padding: 22px 16px 18px; text-align: center; gap: 5px; }

.ctx-empty-state-icon { font-size: 1.5rem; color: #d1dce8; margin-bottom: 4px; line-height: 1; }

.ctx-empty-state-title { font-size: 0.79rem; font-weight: 500; color: var(--ctx-text-muted); line-height: 1.4; }

.ctx-empty-state-hint { font-size: 0.72rem; color: #adbdcc; line-height: 1.5; max-width: 215px; }

/* â”€â”€â”€ 5. Onglet Finance (tab) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

#project-costs-content { background: var(--fin-bg); }

.fin-inner { max-width: 100%; margin: 0; padding: 16px 0 32px; }

#project-costs-content .margined { margin-right: 0 !important; margin-left: 0 !important; max-width: 100% !important; }

/* â”€â”€ Cards â”€â”€ */

.fin-card { background: #fff; border: var(--fin-border); border-radius: var(--fin-radius-lg); box-shadow: var(--fin-shadow); margin-bottom: 16px; }

.fin-card-header { display: flex; align-items: center; gap: 12px; padding: 12px 20px; background: #fff; border-bottom: 1px solid rgba(45,62,80,0.35); border-radius: var(--fin-radius-lg) var(--fin-radius-lg) 0 0; flex-wrap: wrap; }

.fin-card-body { padding: 12px 20px 16px; }

.fin-card-footer { border-top: 1px solid #e2e8f0; padding: 8px 20px; display: flex; justify-content: space-between; align-items: center; }

.fin-icon-box { display: flex; align-items: center; justify-content: center; color: var(--fin-teal); font-size: 0.88rem; flex-shrink: 0; width: 18px; }

.fin-card-title { font-size: 0.80rem; font-weight: 500; color: var(--fin-text-dark); letter-spacing: normal; }

.fin-card-actions { display: flex; align-items: center; gap: 6px; margin-left: auto; flex-wrap: wrap; }

/* â”€â”€ Empty state â”€â”€ */

.fin-empty-state { display: flex; flex-direction: column; align-items: center; padding: 22px 16px 20px; text-align: center; gap: 5px; }

.fin-empty-state-icon { font-size: 1.5rem; color: #d1dce8; margin-bottom: 4px; line-height: 1; }

.fin-empty-state-title { font-size: 0.79rem; font-weight: 500; color: #8fa1b3; line-height: 1.4; }

.fin-empty-state-hint { font-size: 0.72rem; color: #adbdcc; line-height: 1.5; max-width: 240px; }

/* â”€â”€ Boutons â”€â”€ */

.fin-btn { display: inline-flex; align-items: center; gap: 5px; font-size: 0.75rem; font-weight: 500; line-height: 1.5; padding: 3px 12px; border-radius: var(--fin-radius-sm); border: 1px solid; cursor: pointer; white-space: nowrap; text-decoration: none; transition: background 0.15s, color 0.15s; position: relative; }

.fin-btn:hover { text-decoration: none; }

.fin-btn-teal   { background: #fff; border-color: var(--fin-teal); color: var(--fin-teal); }

.fin-btn-teal:hover { background: var(--fin-teal-hover); color: var(--fin-teal); }

.fin-btn-solid  { background: var(--fin-teal); border-color: var(--fin-teal); color: #fff !important; }

.fin-btn-solid:hover { background: #0f766e; border-color: #0f766e; color: #fff !important; }

.fin-btn-grey   { background: #fff; border-color: #d1d5db; color: var(--fin-text-mid); }

.fin-btn-grey:hover { background: #f9fafb; color: var(--fin-text-mid); }

.fin-btn-danger { background: #fff; border-color: #ef4444; color: #ef4444; }

.fin-btn-danger:hover { background: #fef2f2; color: #ef4444; }

.fin-btn-footer { font-size: 0.75rem; padding: 3px 10px; }

.fin-btn-footer.fin-btn-grey:hover { border-color: var(--fin-teal) !important; color: var(--fin-teal) !important; background: var(--fin-teal-hover) !important; }

/* Tooltip sur .fin-btn */

.fin-btn[data-tooltip]::after {    content: attr(data-tooltip); position: absolute;    top: calc(100% + 10px); left: 50%; transform: translateX(-50%);    background: #1f2937; color: #fff; font-size: 0.74rem; font-weight: 400; line-height: 1.5;    padding: 5px 10px; border-radius: 6px; white-space: nowrap;    box-shadow: 0 4px 14px rgba(0,0,0,0.18);    opacity: 0; pointer-events: none; transition: opacity 0.18s; z-index: 1000;}

.fin-btn[data-tooltip]::before {    content: ''; position: absolute;    top: calc(100% + 4px); left: 50%; transform: translateX(-50%);    border: 5px solid transparent; border-bottom-color: #1f2937;    opacity: 0; pointer-events: none; transition: opacity 0.18s; z-index: 1000;}

.fin-btn[data-tooltip]:hover::after,.fin-btn[data-tooltip]:hover::before { opacity: 1; }

/* â”€â”€ Badge statut â”€â”€ */

.fin-status-pill { display: inline-flex; align-items: center; gap: 5px; border-radius: 100px; border: 1px solid transparent; padding: 3px 10px; font-size: 0.74rem; font-weight: 600; white-space: nowrap; margin-left: 6px; }

.fin-status-pill i { font-size: 0.65rem; }

.fin-badge-orange    { color: #c2410c; background: #fff7ed; border-color: #fed7aa; }

.fin-badge-amber     { color: #92400e; background: #fffbeb; border-color: #fde68a; }

.fin-badge-yellow    { color: #b45309; background: #fef3c7; border-color: #fde68a; }

.fin-badge-green     { color: #166534; background: #f0fdf4; border-color: #bbf7d0; }

.fin-badge-darkgreen { color: #14532d; background: #dcfce7; border-color: #86efac; }

/* â”€â”€ Alerte â”€â”€ */

.fin-alert { display: flex; align-items: flex-start; gap: 10px; border-radius: var(--fin-radius-sm); padding: 10px 14px; font-size: 0.82rem; margin-bottom: 14px; }

.fin-alert i { flex-shrink: 0; margin-top: 2px; }

.fin-alert-danger  { background: #fef2f2; border: 1px solid #fca5a5; color: #991b1b; }

.fin-alert-info    { background: #eff6ff; border: 1px solid #bfdbfe; color: #1e40af; }

.fin-alert-success { background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534; }

/* â”€â”€ KPI mÃ©triques â”€â”€ */

.fin-kpi-grid { display: flex; gap: 10px; flex-wrap: wrap; padding: 12px 20px 14px; }

.fin-kpi-item { flex: 1; min-width: 130px; background: #f8fafb; border: var(--fin-border); border-radius: var(--fin-radius-sm); padding: 10px 14px; text-align: center; }

.fin-kpi-item.fin-kpi-final { background: var(--fin-teal-light); border-color: rgba(13,148,136,0.25); }

.fin-kpi-item.fin-kpi-dash { opacity: 0.55; }

.fin-kpi-label { font-size: 0.68rem; color: var(--fin-text-muted); font-weight: 400; margin-bottom: 6px; }

.fin-kpi-value { font-size: 1.05rem; font-weight: 600; color: var(--fin-text-dark); line-height: 1.2; }

.fin-kpi-item.fin-kpi-final .fin-kpi-value { color: var(--fin-teal); }

/* â”€â”€ Performance (tab) â”€â”€ */

.fin-card--perf-tab { border-left: 2px solid var(--fin-teal) !important; }

.fin-card--perf-tab > .fin-card-header { background: var(--fin-teal-light); }

.fin-perf-grid { display: flex; gap: 10px; flex-wrap: wrap; padding: 12px 20px 14px; }

.fin-perf-item { flex: 1; min-width: 180px; background: #f8fafb; border: var(--fin-border); border-radius: var(--fin-radius-sm); padding: 10px 16px; text-align: center; }

.fin-perf-label { font-size: 0.68rem; color: var(--fin-text-muted); font-weight: 400; margin-bottom: 8px; }

.fin-perf-value { font-size: 1.1rem; font-weight: 700; line-height: 1.2; }

.fin-perf-value.fin-gain  { color: #16a34a; }

.fin-perf-value.fin-loss  { color: #ef4444; }

.fin-perf-value.fin-avoid { color: #16a34a; }

.fin-perf-pct { font-size: 0.8rem; color: var(--fin-text-muted); margin-left: 8px; font-weight: 500; }

/* â”€â”€ DurÃ©e contrat â”€â”€ */

.fin-contract-row { display: flex; align-items: center; gap: 8px; padding: 10px 20px; border-top: 1px solid #e2e8f0; font-size: 0.82rem; color: var(--fin-text-mid); }

.fin-contract-row strong { color: var(--fin-text-dark); }

.fin-contract-row i { color: var(--fin-teal); }

/* â”€â”€ Bouton nÃ©go terminÃ©e + tooltip â”€â”€ */

.fin-nego-btn { position: relative; font-size: 0.75rem; color: #6b7280; text-decoration: none; transition: color 0.15s; }

.fin-nego-btn:hover { color: #ef4444; font-weight: 600; text-decoration: none; }

.fin-nego-btn::after { content: attr(data-tooltip); position: absolute; bottom: calc(100% + 10px); right: 0; background: #1f2937; color: #fff; font-size: 0.76rem; font-weight: 400; line-height: 1.5; padding: 7px 12px; border-radius: 7px; width: 230px; white-space: normal; box-shadow: 0 4px 14px rgba(0,0,0,0.18); opacity: 0; pointer-events: none; transition: opacity 0.18s; z-index: 1000; }

.fin-nego-btn::before { content: ''; position: absolute; bottom: calc(100% + 4px); right: 18px; border: 6px solid transparent; border-top-color: #1f2937; opacity: 0; pointer-events: none; transition: opacity 0.18s; z-index: 1000; }

.fin-nego-btn:hover::after,.fin-nego-btn:hover::before { opacity: 1; }

/* â”€â”€ Validators â”€â”€ */

.fin-validators-title { font-size: 0.67rem; font-weight: 700; color: #8fa1b3; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 4px; }

.fin-validator-row { display: flex; align-items: stretch; gap: 16px; padding: 10px 0; border-bottom: 1px solid #e2e8f0; }

.fin-validator-row:last-of-type { border-bottom: none; }

.fin-validator-type { width: 200px; flex-shrink: 0; font-size: 0.80rem; font-weight: 600; color: var(--fin-text-mid); line-height: 1.4; }

.fin-validator-content { flex: 1; min-width: 0; display: flex; align-items: center; gap: 8px; }

.fin-validator-cat { font-size: 0.72rem; color: #9ca3af; font-style: italic; font-weight: 400; }

.fin-validator-name { font-size: 0.82rem; font-weight: 400; color: #4b5563; }

.fin-validator-delete-wrap { width: 20px; flex-shrink: 0; display: flex; justify-content: flex-end; }

.fin-validator-row .btnDelete { visibility: hidden; color: #d1d5db !important; font-size: 0.82rem; text-decoration: none !important; }

.fin-validator-row:hover .btnDelete { visibility: visible; }

.fin-validator-row .btnDelete:hover { color: #ef4444 !important; }

.fin-add-panel { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }

.fin-add-panel .bootstrap-select { width: 220px !important; flex-shrink: 0; }

.fin-add-panel .bootstrap-select > .btn.dropdown-toggle { font-size: 0.80rem; border: 1px solid #d1d5db !important; border-radius: var(--fin-radius-sm) !important; background: #fff !important; color: var(--fin-text-mid) !important; box-shadow: none !important; }

.fin-add-panel .bootstrap-select.show > .btn.dropdown-toggle { border-color: var(--fin-teal) !important; }

/* â”€â”€ Historique demandes â”€â”€ */

.fin-req-list { padding: 0 20px 10px; }

.fin-req-title { font-size: 0.67rem; font-weight: 700; color: #8fa1b3; text-transform: uppercase; letter-spacing: 0.08em; margin: 14px 0 8px; }

.fin-req-row { display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; border-bottom: 1px solid #e2e8f0; font-size: 0.80rem; }

.fin-req-row:last-child { border-bottom: none; }

.fin-req-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; background: #d1d5db; }

.fin-req-dot.ok { background: #16a34a; }

.fin-req-dot.ko { background: #ef4444; }

.fin-req-body { flex: 1; min-width: 0; color: var(--fin-text-mid); }

.fin-req-meta { font-size: 0.73rem; color: var(--fin-text-muted); margin-top: 2px; }

.fin-req-comment { font-size: 0.75rem; color: var(--fin-text-muted); font-style: italic; margin-top: 3px; }

.fin-req-actions { flex-shrink: 0; }

/* â”€â”€ Hint box ambre â”€â”€ */

.fin-hint { position: relative; background: #fffbeb; border: 1px solid #fde68a; border-radius: var(--fin-radius-sm); padding: 12px 16px; font-size: 0.82rem; color: #92400e; margin-bottom: 16px; }

.fin-hint p { margin-bottom: 6px; }

.fin-hint p:last-of-type { margin-bottom: 0; }

.fin-hint .hint-actions { background: rgba(255,251,235,0.85); }

.fin-hint .hint-dismiss-forever { color: #b45309; }

.fin-hint .hint-actions .close { color: #b45309; border-color: rgba(180,83,9,0.35); }

/* â”€â”€ Notice mobile â”€â”€ */

.fin-mobile-notice { display: flex; align-items: center; gap: 10px; background: #fff; border: var(--fin-border); border-radius: var(--fin-radius-sm); padding: 12px 16px; font-size: 0.82rem; color: var(--fin-text-mid); margin-top: 4px; }

/* â”€â”€ Scrollbar Finance tab â”€â”€ */

#project-costs-content .container-scrollable::-webkit-scrollbar { width: 6px; background: transparent !important; }

#project-costs-content .container-scrollable::-webkit-scrollbar-track { background: transparent !important; border: none !important; }

#project-costs-content .container-scrollable::-webkit-scrollbar-thumb { background: transparent !important; border-radius: 4px; transition: background 0.25s; }

#project-costs-content .container-scrollable.ctx-scrolling::-webkit-scrollbar-thumb,#project-costs-content .container-scrollable.ctx-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0 !important; }

#project-costs-content .container-scrollable { scrollbar-width: thin; scrollbar-color: transparent transparent; }

#project-costs-content .container-scrollable.ctx-scrolling,#project-costs-content .container-scrollable.ctx-scrollbar-hover { scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€ Switcher vue Liste/Gantt â”€â”€ */

.view-sw-btn { transition: background 0.15s, color 0.15s; }

.view-sw-btn:hover { background: #c4cdd8 !important; color: #1e293b !important; text-decoration: none; }

/* â”€â”€â”€ 6. Onglet Actions â€” Liste â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.tasks-fin-card { background: #fff; border: 1px solid #e5e7eb; border-radius: var(--fin-radius-lg); box-shadow: var(--fin-shadow); }

.tasks-outer-wrapper { padding: 8px 40px 20px 40px !important; overflow-x: hidden; background: #fff; }
.tasks-fin-card { scrollbar-gutter: stable; }

/* EmpÃªche la scrollbar globale du body quand on est dans le module Projets :
   le layout est multi-panneaux, fait pour tenir en 1 Ã©cran. Le card .tasks-fin-card
   gÃ¨re son propre scroll vertical. Classe activÃ©e par index.html.twig (cf. JS). */
body.mbw-prj-module { overflow-y: hidden !important; }

/* â”€â”€ Empty state â”€â”€ */

.tasks-empty-state { display: flex; flex-direction: column; align-items: center; padding: 32px 16px 28px; text-align: center; gap: 6px; }

.tasks-empty-state-icon { font-size: 1.5rem; color: #d1dce8; margin-bottom: 4px; line-height: 1; }

.tasks-empty-state-title { font-size: 0.79rem; font-weight: 500; color: #8fa1b3; line-height: 1.4; }

.tasks-empty-state-hint { font-size: 0.72rem; color: #adbdcc; line-height: 1.5; max-width: 260px; }

/* â”€â”€ Hint â”€â”€ */

.tasks-fin-hint { position: relative; background: #fffbeb; border: 1px solid #fde68a; border-radius: var(--fin-radius-sm); padding: 12px 16px; font-size: 0.82rem; color: #92400e; margin-top: 12px; margin-bottom: 8px; }

.item-infos .tasks-fin-hint { margin-top: 12px; }

.tasks-fin-hint p { margin-bottom: 6px; }

.tasks-fin-hint p:last-of-type { margin-bottom: 0; }

.tasks-fin-hint .hint-actions { background: rgba(255,251,235,0.85); }

.tasks-fin-hint .hint-dismiss-forever { color: #b45309; }

.tasks-fin-hint .hint-actions .close { color: #b45309; border-color: rgba(180,83,9,0.35); }

/* â”€â”€ Filtres â”€â”€ */

/* Segmented control gÃ©nÃ©rique (switcher de vue) â€” pattern rÃ©utilisable.
   Track gris clair, segment actif = carte blanche soulevÃ©e (ombre + teal). */
.view-switch { display: inline-flex; align-items: center; align-self: center; padding: 0 2px; background: #f1f3f5; border: 1px solid #d1d5db; border-radius: 4px; gap: 2px; height: 24px; }
.view-switch-item { display: inline-flex; align-items: center; gap: 5px; height: 22px; padding: 0 10px; font-size: 0.75rem; font-weight: 500; color: #8fa1b3; background: transparent; border-radius: 2px; text-decoration: none !important; cursor: pointer; transition: background 0.12s, color 0.12s, box-shadow 0.12s; white-space: nowrap; }
.view-switch-item i { font-size: 0.7rem; }
.view-switch-item:hover { color: var(--fin-text-mid); }
.view-switch-item.active { background: #fff; color: var(--fin-teal) !important; font-weight: 600; box-shadow: 0 1px 2px rgba(0,0,0,0.10), 0 0 0 1px rgba(0,0,0,0.04); cursor: default; }
.view-switch-item.active:hover { color: var(--fin-teal) !important; }
.view-switch-item.locked { color: #8fa1b3; cursor: not-allowed; opacity: 0.65; }

.fin-filter-btn { display: inline-flex; align-items: center; gap: 5px; font-size: 0.75rem; font-weight: 500; line-height: 1.5; padding: 3px 12px; border-radius: var(--fin-radius-sm); border: 1px solid #d1d5db; cursor: pointer; white-space: nowrap; text-decoration: none; transition: background 0.15s, color 0.15s; color: var(--fin-text-muted) !important; background: #fff; user-select: none; align-self: center; }

.fin-filter-btn:hover { background: #e8edf2; color: var(--fin-text-mid) !important; text-decoration: none; }

.fin-filter-btn.filter-on { background: var(--fin-teal-light); border-color: var(--fin-teal); color: var(--fin-teal) !important; }

.fin-filter-btn.filter-on:hover { background: var(--fin-teal-hover); border-color: var(--fin-teal); color: var(--fin-teal) !important; }

/* â”€â”€ En-tÃªtes triables â”€â”€ */

.sortable-col { cursor: pointer; user-select: none; }

.sortable-col:hover { color: #343a40; }

.sort-icon { font-size: 0.72rem; opacity: 0.28; margin-left: 4px; vertical-align: middle; transition: opacity 0.15s, color 0.15s; }

.sortable-col:hover .sort-icon { opacity: 0.65; color: #343a40; }

.sortable-col.sort-active .sort-icon { opacity: 1; color: var(--fin-teal); }

/* â”€â”€ Layout tableau â”€â”€ */

.tasks-list-header,.tasks-list-row { display: flex; align-items: center; width: 100%; }

.tasks-list-header { min-height: 32px; border-bottom: 1px solid rgba(45,62,80,0.35); font-size: 0.72rem; color: var(--fin-text-muted); font-weight: 500; padding: 0; position: sticky; top: 0; z-index: 5; background-color: #fff; border-radius: var(--fin-radius-lg) var(--fin-radius-lg) 0 0; }

.tasks-list-row { min-height: 48px; border-bottom: 1px solid #f3f4f6; border-left: 3px solid transparent; background: #fff; transition: background 0.12s ease; cursor: pointer; font-size: 0.78rem; color: var(--fin-text-mid); }

.tasks-list-row:hover { background: var(--fin-teal-hover); }

.tasks-list-header,.tasks-list-row { padding-left: 12px; padding-right: 12px; }

/* Colonnes */

.task-col-statut    { width: 34px;  flex-shrink: 0; display: flex; justify-content: center; align-items: center; }

.task-col-type      { width: 36px;  flex-shrink: 0; display: flex; justify-content: center; align-items: center; }

.task-col-titre     { flex: 1; min-width: 0; padding: 0 12px; display: flex; align-items: center; gap: 6px; }

.task-col-titre .task-name-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
/* Input Ã©ditable du libellÃ© d'action et de jalon (Ã©dition inline) : mÃªme look que
   les colonnes Date d'Ã©chÃ©ance et PrioritÃ© (encadrÃ© gris au hover, halo teal au focus). */
.task-col-titre input.task-name-input,.task-col-titre input.milestone-name-input { flex: 1; min-width: 0; height: 28px; border: 1px solid transparent; border-radius: 4px; background: transparent; padding: 4px 6px; font-size: 0.78rem; color: var(--fin-text-dark); line-height: 1.2; transition: border-color 0.15s, background-color 0.15s; }
.task-col-titre input.task-name-input:hover,.task-col-titre input.milestone-name-input:hover { border-color: #9ca3af; background-color: #f3f4f6; cursor: text; }
.task-col-titre input.task-name-input:focus,.task-col-titre input.milestone-name-input:focus { outline: none; border-color: var(--fin-teal) !important; background-color: #fff !important; box-shadow: 0 0 0 2px rgba(20,184,166,0.10); }

/* IcÃ´ne Å“il "Ouvrir la fiche" Ã  la fin de l'intitulÃ©, visible uniquement au survol de la ligne. */
.task-col-titre .task-row-open-eye { flex-shrink: 0; margin-left: 4px; color: var(--fin-text-muted); font-size: 0.85rem; opacity: 0; cursor: pointer; transition: opacity 0.15s, color 0.15s; }
.tasks-list-row:hover .task-row-open-eye { opacity: 1; }
.task-col-titre .task-row-open-eye:hover { color: var(--fin-teal); }

.task-col-porteur   { width: 108px; flex-shrink: 0; display: flex; align-items: center; gap: 6px; overflow: hidden; }

.task-col-porteur .porteur-name { font-size: 0.75rem; color: var(--fin-text-mid); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Bootstrap-Select porteur (Ã©dition inline) â€” mÃªme apparence "encadrÃ© gris au hover" que Date et PrioritÃ©. */
.task-col-porteur .bootstrap-select { width: 100% !important; margin: 0 !important; height: auto !important; background-color: transparent !important; align-self: center !important; display: block !important; }
.task-col-porteur .bootstrap-select > select { display: none !important; }
.task-col-porteur .bootstrap-select > .btn { border: 1px solid transparent !important; border-radius: 4px !important; background: transparent !important; box-shadow: none !important; padding: 4px 22px 4px 8px !important; margin: 0 !important; font-size: 0.75rem !important; width: 100% !important; line-height: 1.2; height: 28px !important; max-height: 28px !important; cursor: pointer !important; display: flex !important; align-items: center !important; transition: border-color 0.15s, background-color 0.15s; overflow: visible !important; position: relative !important; }
.task-col-porteur .bootstrap-select > .btn:hover { border-color: #9ca3af !important; background-color: #f3f4f6 !important; box-shadow: none !important; }
.task-col-porteur .bootstrap-select > .btn::after { position: absolute !important; right: 7px !important; top: 50% !important; transform: translateY(-50%) !important; margin: 0 !important; border-top-color: #9ca3af !important; opacity: 0 !important; transition: opacity 0.15s; }
.task-col-porteur .bootstrap-select > .btn:hover::after { opacity: 1 !important; }
.task-col-porteur .bootstrap-select > .btn .bs-caret { display: none !important; }
.task-col-porteur .bootstrap-select .filter-option { overflow: visible; display: flex !important; align-items: center !important; margin: 0 !important; padding: 0 !important; height: 100% !important; flex: 1 !important; }
.task-col-porteur .bootstrap-select .filter-option-inner { margin: 0 !important; padding: 0 !important; width: 100%; height: 100% !important; display: flex !important; align-items: center !important; }
.task-col-porteur .bootstrap-select .filter-option-inner-inner { overflow: visible !important; white-space: nowrap; display: flex !important; align-items: center !important; gap: 5px; font-size: 0.75rem; color: var(--fin-text-mid); }

.task-col-progress  { width: 90px;  flex-shrink: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 0 6px; margin-right: 8px; gap: 3px; }

.task-col-echeance  { width: 118px; flex-shrink: 0; display: flex; align-items: center; }

.task-col-checklist { width: 70px;  flex-shrink: 0; text-align: center; }

.task-col-priorite  { width: 102px; flex-shrink: 0; display: flex; align-items: center; }

.task-col-actions   { width: 24px;  flex-shrink: 0; display: flex; justify-content: center; align-items: center; }

/* â”€â”€ Jalons â”€â”€ */

.task-col-type .milestone-flag-badge { font-size: 13px; color: var(--fin-teal); line-height: 1; display: flex; align-items: center; justify-content: center; position: static; }

.milestone-task-row { border-left: 3px solid var(--fin-teal); }

/* â”€â”€ Checkboxes â”€â”€ */

.task-col-statut input[type="hidden"] { display: none; }

.task-col-statut .task-cb { appearance: none; -webkit-appearance: none; width: 20px; height: 20px; border: 2px solid #adb5bd; border-radius: 50%; cursor: pointer; display: inline-block; position: relative; transition: background 0.15s, border-color 0.15s; margin: 0 !important; flex-shrink: 0; vertical-align: middle; outline: none !important; }

.task-col-statut .task-cb:focus,.task-col-statut .task-cb:focus-visible,.task-col-statut .task-cb:active { outline: none !important; box-shadow: none !important; border-style: solid !important; }

.task-col-statut .task-cb::-moz-focus-inner { border: 0 !important; outline: 0 !important; }

.task-col-statut .task-cb:checked { background-color: var(--fin-teal); border-color: var(--fin-teal); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z' fill='%23fff'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; background-size: 12px 12px; }

.task-col-statut .fake-checkbox { width: 20px; height: 20px; border: 2px solid #ced4da; border-radius: 50%; display: inline-block; cursor: default; flex-shrink: 0; }

.task-done-circle { width: 20px; height: 20px; background: var(--fin-teal); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 9px; flex-shrink: 0; }

/* â”€â”€ PrioritÃ© â”€â”€ */

.priority-square { display: inline-block; width: 12px; height: 12px; border-radius: 3px; flex-shrink: 0; }

.task-col-priorite .bootstrap-select { width: 100% !important; margin: 0 !important; height: auto !important; background-color: transparent !important; align-self: center !important; display: block !important; }

.task-col-priorite .bootstrap-select > select { display: none !important; }

.task-col-priorite .bootstrap-select > .btn { border: 1px solid transparent !important; border-radius: 4px !important; background: transparent !important; box-shadow: none !important; padding: 4px 22px 4px 14px !important; margin: 0 !important; font-size: inherit; width: 100% !important; line-height: 1.2; height: 28px !important; max-height: 28px !important; cursor: pointer !important; display: flex !important; align-items: center !important; transition: border-color 0.15s, background-color 0.15s; overflow: visible !important; position: relative !important; }

.task-col-priorite .bootstrap-select > .btn:hover { border-color: #9ca3af !important; background-color: #edf0f2 !important; box-shadow: none !important; }

.task-col-priorite .bootstrap-select > .btn::after { position: absolute !important; right: 7px !important; top: 50% !important; transform: translateY(-50%) !important; margin: 0 !important; border-top-color: #9ca3af !important; opacity: 0 !important; transition: opacity 0.15s; }

.task-col-priorite .bootstrap-select > .btn:hover::after { opacity: 1 !important; }

.task-col-priorite .bootstrap-select > .btn .bs-caret { display: none !important; }

.task-col-priorite .bootstrap-select .filter-option { overflow: visible; display: flex !important; align-items: center !important; margin: 0 !important; padding: 0 0 0 8px !important; height: 100% !important; flex: 1 !important; }

.task-col-priorite .bootstrap-select .filter-option-inner { margin: 0 !important; padding: 0 !important; width: 100%; height: 100% !important; display: flex !important; align-items: center !important; }

.task-col-priorite .bootstrap-select .filter-option-inner-inner { overflow: visible !important; white-space: nowrap; display: flex !important; align-items: center !important; gap: 5px; }

.task-col-priorite .bootstrap-select .dropdown-menu li a span.text { overflow: visible !important; white-space: nowrap; }

.task-col-priorite > .priority-square { margin-left: 8px; }

/* â”€â”€ Ã‰chÃ©ance â”€â”€ */

/* Padding + bordure transparente toujours appliquÃ©s pour que TOUS les Ã©tats de la
   cellule Ã‰chÃ©ance (action open/closed/display, jalon open/closed) aient le MÃŠME
   espacement entre l'icÃ´ne calendrier et la date. Le hover/focus visible n'est
   activÃ© que pour la variante Ã©ditable (datetime-picker non readonly). */
.task-col-echeance span { gap: 6px; padding: 4px 6px; border: 1px solid transparent; border-radius: 4px; transition: border-color 0.15s, background-color 0.15s; }

.task-col-echeance span:has(.datetime-picker:not([readonly])):hover { border-color: #9ca3af; background-color: #f3f4f6; cursor: text; }

.task-col-echeance span:has(.datetime-picker:not([readonly])):focus-within { border-color: var(--fin-teal) !important; background-color: #fff !important; box-shadow: 0 0 0 2px rgba(20,184,166,0.10); }

.task-col-echeance .datetime-picker:not([readonly]):hover { cursor: text; }

.task-date-late { border: 1.5px solid #ef4444; color: #ef4444 !important; border-radius: 4px; padding: 1px 6px; }

.task-col-echeance .datetime-picker,.task-col-echeance .milestone-date-input { background: transparent !important; border: none !important; box-shadow: none !important; outline: none !important; width: 90px; height: auto !important; font-size: inherit; line-height: inherit !important; color: inherit !important; padding: 0 !important; margin: 0 !important; }

.task-col-echeance .form-control.datetime-picker,.task-col-echeance .form-control.milestone-date-input { height: auto; padding: 0 !important; border: none !important; box-shadow: none !important; background: transparent !important; color: inherit !important; }

/* RÃ¨gle ci-dessus rendue inutile par le padding uniforme sur .task-col-echeance span. LaissÃ©e en commentaire pour traÃ§abilitÃ©. */

/* â”€â”€ Barre de progression â”€â”€ */

.task-progress-slider { -webkit-appearance: none; appearance: none; width: 100%; height: 3px; border-radius: 2px; outline: none; cursor: pointer; background: linear-gradient(to right, #0d9488 var(--pct, 0%), #e2e8f0 var(--pct, 0%)); }

.task-progress-slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 11px; height: 11px; border-radius: 50%; background: #0d9488; cursor: pointer; transition: transform 0.1s; }

.task-progress-slider::-webkit-slider-thumb:hover { transform: scale(1.25); }

.task-progress-slider::-moz-range-thumb { width: 11px; height: 11px; border-radius: 50%; background: #0d9488; border: none; cursor: pointer; }

.task-progress-pct { font-size: 0.63rem; color: var(--fin-text-muted); line-height: 1; }

.task-progress-bar-wrap { width: 100%; height: 3px; background: #e2e8f0; border-radius: 2px; overflow: hidden; }

.task-progress-bar-fill { height: 100%; background: #0d9488; border-radius: 2px; }

/* â”€â”€ Bouton supprimer / access badge / checklist â”€â”€ */

.task-del-btn { display: none; color: var(--fin-text-muted); font-size: 0.85rem; line-height: 1; }

.tasks-list-row:hover .task-del-btn { display: flex; }

.task-del-btn:hover { color: #ef4444; }

.task-access-badge { font-size: 0.68rem; font-weight: 600; border: 1px solid #fde68a; color: #92400e; background: #fffbeb; padding: 1px 7px; border-radius: 100px; white-space: nowrap; flex-shrink: 0; }

.task-checklist-done { color: var(--fin-teal); }

/* â”€â”€ Scrollbar Actions card â”€â”€ */

.tasks-fin-card::-webkit-scrollbar { width: 3px; background: transparent !important; }

.tasks-fin-card::-webkit-scrollbar-track { background: transparent !important; border: none !important; }

.tasks-fin-card::-webkit-scrollbar-thumb { background: transparent !important; border-radius: 4px; transition: background 0.25s; }

.tasks-fin-card.tasks-scrolling::-webkit-scrollbar-thumb,.tasks-fin-card.tasks-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0 !important; }

.tasks-fin-card { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.tasks-fin-card.tasks-scrolling,.tasks-fin-card.tasks-scrollbar-hover { scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€â”€ 6b. Onglet Actions â€” Gantt â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.gantt-elastic__chart-scroll-container--horizontal::-webkit-scrollbar,.gantt-elastic__chart-scroll-container--vertical::-webkit-scrollbar { width: 4px; height: 4px; background: transparent; }

.gantt-elastic__chart-scroll-container--horizontal::-webkit-scrollbar-track,.gantt-elastic__chart-scroll-container--vertical::-webkit-scrollbar-track { background: transparent; border: none; }

.gantt-elastic__chart-scroll-container--horizontal::-webkit-scrollbar-thumb,.gantt-elastic__chart-scroll-container--vertical::-webkit-scrollbar-thumb { background: transparent; border-radius: 4px; transition: background 0.25s; }

.gantt-elastic__chart-scroll-container--horizontal.ctx-scrolling::-webkit-scrollbar-thumb,.gantt-elastic__chart-scroll-container--vertical.ctx-scrolling::-webkit-scrollbar-thumb,.gantt-elastic__chart-scroll-container--horizontal.ctx-scrollbar-hover::-webkit-scrollbar-thumb,.gantt-elastic__chart-scroll-container--vertical.ctx-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0; }

.gantt-elastic__chart-scroll-container--horizontal::-webkit-scrollbar-thumb:hover,.gantt-elastic__chart-scroll-container--vertical::-webkit-scrollbar-thumb:hover { background: #9ca3af !important; }

.gantt-elastic__chart-scroll-container--horizontal,.gantt-elastic__chart-scroll-container--vertical { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.gantt-elastic__chart-scroll-container--horizontal.ctx-scrolling,.gantt-elastic__chart-scroll-container--vertical.ctx-scrolling,.gantt-elastic__chart-scroll-container--horizontal.ctx-scrollbar-hover,.gantt-elastic__chart-scroll-container--vertical.ctx-scrollbar-hover { scrollbar-color: #c4c9d0 transparent; }

#app g[task^="P_"] svg.gantt-elastic__chart-row-bar { clip-path: inset(25% 0); }

#gantt-user-filter option { font-size: 0.72rem; }

#gantt-help-button {    position: absolute; bottom: 20px; right: 56px; z-index: 100;    width: 32px; height: 32px; border-radius: 50%;    background: #fff; border: 1px solid #e2e8f0;    box-shadow: 0 2px 6px rgba(0,0,0,0.12);    display: flex; align-items: center; justify-content: center;    color: #8fa1b3; font-size: 0.85rem;    cursor: pointer; transition: box-shadow 0.15s, color 0.15s;    text-decoration: none;}

#gantt-help-button:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.18); color: #2D3E50; }

/* â”€â”€â”€ 7. Onglet RÃ©sultats â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.res-left-col  { background: #fff; display: flex; flex-direction: column; overflow: hidden; flex: 0 0 60% !important; max-width: 60% !important; }

.res-right-col { background: #fff; display: flex; flex-direction: column; overflow: hidden; flex: 0 0 40% !important; max-width: 40% !important; }

.res-col-top-strip { flex: 0 0 16px; background: #fff; }

.res-left-col  .res-col-scrollable,.res-right-col .res-col-scrollable { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; width: 100%; }

/* Scrollbars */

.res-col-scrollable::-webkit-scrollbar { width: 3px; background: transparent !important; }

.res-col-scrollable::-webkit-scrollbar-track { background: transparent !important; border: none !important; }

.res-col-scrollable::-webkit-scrollbar-thumb { background: transparent !important; border-radius: 4px; transition: background 0.25s; }

.res-col-scrollable.res-scrolling::-webkit-scrollbar-thumb,.res-col-scrollable.res-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0 !important; }

.res-col-scrollable { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.res-col-scrollable.res-scrolling,.res-col-scrollable.res-scrollbar-hover { scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€ Carte commune â”€â”€ */

.res-card { background: #fff; border: var(--res-border); border-radius: var(--res-radius); box-shadow: var(--res-shadow); margin-bottom: 16px; }

.res-card-header { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-bottom: 1px solid rgba(45,62,80,0.35); background: #fff; border-radius: var(--res-radius) var(--res-radius) 0 0; }

.res-card-icon { display: flex; align-items: center; justify-content: center; color: var(--res-teal); font-size: 0.88rem; width: 18px; flex-shrink: 0; }

.res-card-title { font-size: 0.80rem; font-weight: 500; color: var(--res-text-dark); }

.res-count-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 16px; height: 16px; padding: 0 4px; background: var(--res-teal-light); color: var(--res-teal); border-radius: 2px; font-size: 0.65rem; font-weight: 600; line-height: 1; }

.res-header-right { margin-left: auto; display: flex; align-items: center; gap: 6px; }

.res-action-btn { flex-shrink: 0; width: 26px; height: 26px; padding: 0; border: 1px solid #e5e7eb; border-radius: var(--res-radius); background: #fff; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; color: var(--res-text-muted); font-size: 0.72rem; transition: background 0.15s, color 0.15s, border-color 0.15s; text-decoration: none; }

.res-action-btn:hover { text-decoration: none; }

.res-action-edit:hover { background: var(--res-teal-light); color: var(--res-teal); border-color: var(--res-teal); }

.res-add-btn { background: none; border: 1px solid #d1d5db; color: var(--res-teal); min-width: 24px; height: 24px; padding: 0 7px; border-radius: var(--res-radius); font-size: 0.72rem; font-weight: 500; flex-shrink: 0; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 4px; transition: background 0.15s, color 0.15s, border-color 0.15s; white-space: nowrap; }

.res-add-btn:hover { background: var(--res-teal); color: #fff; border-color: var(--res-teal); }

.res-add-btn:disabled { opacity: 0.45; cursor: not-allowed; pointer-events: none; }

/* â”€â”€ Empty state â”€â”€ */

.res-empty-state { display: flex; flex-direction: column; align-items: center; padding: 28px 16px 24px; text-align: center; gap: 6px; }

.res-empty-state-icon { font-size: 1.5rem; color: #d1dce8; margin-bottom: 4px; line-height: 1; }

.res-empty-state-title { font-size: 0.79rem; font-weight: 500; color: var(--res-text-muted); line-height: 1.4; }

.res-empty-state-hint { font-size: 0.72rem; color: #adbdcc; line-height: 1.5; max-width: 215px; }

/* â”€â”€ Groupes et items contrats â”€â”€ */

.res-contract-group { padding-bottom: 12px; border-bottom: 1px solid #e4eaf2; }

.res-contract-group:last-child { border-bottom: none; padding-bottom: 4px; }

.res-children-zone { border-left: 3px solid var(--res-teal-light); margin-left: 16px; }

.res-contract-item { padding: 12px 16px; transition: background 0.12s; }

.res-contract-item:hover { background: #f4faf9; }

.res-contract-item + .res-contract-item { border-top: 1px solid #eaeff6; }

.res-children-zone .res-contract-item + .res-contract-item { border-top: 1px solid #eaeff6; }

.res-ci-row1 { display: flex; align-items: flex-start; gap: 8px; margin-bottom: 5px; }

.res-ci-name { font-size: 0.82rem; font-weight: 600; color: var(--res-text-dark); flex: 1; min-width: 0; line-height: 1.3; text-transform: uppercase; letter-spacing: 0.03em; }

.res-ci-open { visibility: hidden; color: #b0bec5; text-decoration: none; font-size: 0.82rem; flex-shrink: 0; padding: 2px 4px; transition: color 0.12s; }

.res-contract-item:hover .res-ci-open { visibility: visible; }

.res-ci-open:hover { color: var(--res-teal) !important; text-decoration: none; }

.res-ci-supplier { font-size: 0.72rem; font-weight: 600; color: var(--res-teal); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 7px; display: flex; align-items: center; gap: 5px; }

.res-ci-supplier i { font-size: 0.66rem; }

.res-ci-badges { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }

.res-badge, .res-validation-badge { display: inline-block; border-radius: var(--res-radius); padding: 1px 7px; font-size: 0.68rem; font-weight: 400; line-height: 1.5; border: 1px solid #cfd8e3 !important; color: #8a97a7 !important; white-space: nowrap; transition: color 0.15s, border-color 0.15s; }

.res-contract-item:hover .res-badge,.res-contract-item:hover .res-validation-badge { color: var(--badge-color, #0d9488) !important; border-color: var(--badge-color, #0d9488) !important; }

.res-ci-footer { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; padding-top: 7px; border-top: 1px solid #eaeff6; font-size: 0.72rem; color: var(--res-text-muted); }

.res-ci-footer-item { display: flex; align-items: center; gap: 4px; }

.res-ci-footer-item i { font-size: 0.65rem; }

.res-ci-footer-item.res-amount { color: var(--res-teal); font-weight: 500; }

.res-ci-footer-item.res-date-warn { color: #e67e22; }

/* â”€â”€ Rattachement parent â”€â”€ */

.res-ci-parent-row { display: flex; align-items: center; gap: 4px; margin-top: -11px; margin-bottom: 10px; font-size: 0.72rem; font-style: italic; }

.res-ci-parent-label { color: var(--res-text-muted); flex-shrink: 0; white-space: nowrap; }

.res-ci-parent-arrow { font-size: 0.90rem; font-style: normal; }

.res-ci-parent-name { color: var(--res-text-mid); font-weight: 500; flex: 0 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.res-ci-parent-open { visibility: hidden; color: #b0bec5; text-decoration: none; font-size: 0.80rem; font-style: normal; flex-shrink: 0; padding: 0 3px; transition: color 0.12s; }

.res-contract-item:hover .res-ci-parent-open { visibility: visible; }

.res-ci-parent-open:hover,.res-ci-parent-open:hover i { color: #0d9488 !important; text-decoration: none; }

.res-ci-parent-spacer { flex: 1; }

/* â”€â”€ BÃ©nÃ©fices qualitatifs (display) â”€â”€ */

.res-benefits-body { padding: 12px 16px 16px; }

.res-note-separator { border: none; border-top: 1px solid #e2e8f0; margin: 14px 0 12px; }

.res-note-label { font-size: 0.67rem; font-weight: 700; color: #9ca3af; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 6px; }

.res-note-text { font-size: 0.79rem; color: var(--res-text-mid); line-height: 1.6; white-space: pre-line; }

.res-qb-group { margin-bottom: 10px; }

.res-qb-group:last-child { margin-bottom: 0; }

.res-qb-cat { font-size: 0.65rem; font-weight: 700; color: var(--res-teal); text-transform: uppercase; letter-spacing: 0.09em; padding-bottom: 4px; border-bottom: 1px solid #e6f7f5; margin-bottom: 5px; }

.res-qb-item { padding: 4px 0 4px 2px; }

.res-qb-item + .res-qb-item { border-top: 1px solid #f1f5f9; }

.res-qb-main { display: flex; align-items: center; gap: 7px; }

.res-qb-check { color: var(--res-teal); font-size: 0.70rem; flex-shrink: 0; }

.res-qb-label { font-size: 0.79rem; color: var(--res-text-mid); flex: 1; line-height: 1.35; }

.res-qb-stars { font-size: 0.72rem; color: #f59e0b; letter-spacing: 1px; flex-shrink: 0; }

.res-qb-stars-empty { color: #dde3ea; }

.res-qb-comment { font-size: 0.73rem; color: #8fa1b3; font-style: italic; padding-left: 20px; margin-top: 2px; line-height: 1.4; }

/* â”€â”€ Bloc no-access â”€â”€ */

.res-no-access-block { margin: 12px 16px; background: #fffbeb; border: 1px solid #fde68a; border-radius: 2px; padding: 10px 14px; font-size: 0.80rem; color: #92400e; line-height: 1.5; }

/* â”€â”€â”€ 8. Pages Enjeux et performance â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

#project-costs-page { background: var(--fin-bg); }

.pc-inner { margin: 0 auto; padding: 20px 4px 40px; }

.pc-project-name { font-size: 1.1rem; font-weight: 700; color: var(--fin-text-dark); margin-bottom: 12px; padding-bottom: 10px; border-bottom: 1px solid #e5e7eb; }

/* Cards (versions enjeux â€” Ã©tendent .fin-card dÃ©fini en passe 5) */

.pc-left > .fin-card, .pc-left > .fin-alert + .fin-card { margin-bottom: 28px; }

.fin-card-header.pc-collapsible { cursor: pointer; user-select: none; }

.fin-card-header.pc-collapsible:hover { background: #f0f4f7; }

.fin-card-header.pc-collapsible[aria-expanded="true"] .pc-chevron { transform: rotate(180deg); }

.pc-chevron { margin-left: auto; color: var(--fin-text-muted); font-size: 0.82rem; transition: transform 0.2s; }

/* â”€â”€ En-tÃªte module â”€â”€ */

.fin-module-header { display: flex; align-items: center; justify-content: space-between; padding: 0 24px; min-height: 64px; background: #1a3347; color: #fff; gap: 16px; flex-shrink: 0; }

.fin-module-header-left { display: flex; flex-direction: column; gap: 3px; min-width: 0; overflow: hidden; }

.fin-module-title-row { display: flex; align-items: baseline; gap: 8px; overflow: hidden; }

.fin-module-back { display: inline-flex; align-items: center; gap: 5px; font-size: 0.70rem; color: rgba(255,255,255,0.45); text-decoration: none; transition: color 0.15s; }

.fin-module-back:hover { color: rgba(255,255,255,0.85); text-decoration: none; }

.fin-module-project-name { font-size: 0.90rem; font-weight: 400; color: rgba(255,255,255,0.60); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 280px; }

.fin-module-project-name--link { text-decoration: none; transition: color 0.15s ease; }

.fin-module-project-name--link:hover { color: rgba(255,255,255,0.95); text-decoration: underline; cursor: pointer; }

.fin-module-title-sep { color: rgba(255,255,255,0.40); font-size: 1.1rem; flex-shrink: 0; line-height: 1; }

.fin-module-section { font-weight: 700; color: #fff; font-size: 0.90rem; white-space: nowrap; }

.fin-module-header-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.fin-module-status-pill { display: inline-flex; align-items: center; gap: 5px; border-radius: 100px; padding: 4px 12px; font-size: 0.70rem; font-weight: 700; background: rgba(255,255,255,0.10); color: rgba(255,255,255,0.90); border: 1px solid rgba(255,255,255,0.20); white-space: nowrap; }

.fin-module-status-pill.fin-badge-orange    { color: #c2410c; background: #fff7ed; border-color: #fed7aa; }

.fin-module-status-pill.fin-badge-amber     { color: #92400e; background: #fffbeb; border-color: #fde68a; }

.fin-module-status-pill.fin-badge-yellow    { color: #b45309; background: #fef3c7; border-color: #fde68a; }

.fin-module-status-pill.fin-badge-green     { color: #166534; background: #f0fdf4; border-color: #bbf7d0; }

.fin-module-status-pill.fin-badge-darkgreen { color: #14532d; background: #dcfce7; border-color: #86efac; }

.fin-module-cta { display: inline-flex; align-items: center; gap: 6px; padding: 7px 18px; border-radius: 6px; font-size: 0.80rem; font-weight: 600; line-height: 1.4; background: var(--fin-teal); color: #fff; border: none; cursor: pointer; text-decoration: none; white-space: nowrap; transition: background 0.15s; }

.fin-module-cta:hover { background: #0f766e; color: #fff; text-decoration: none; }

.fin-module-actions { display: flex; align-items: center; gap: 8px; padding: 8px 24px; background: #f1f3f5; border-bottom: 2px solid #e0e4e8; flex-wrap: wrap; min-height: 46px; }

.fin-module-actions-sep { flex: 1; min-width: 16px; }

.pc-header-btn { background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.22); color: rgba(255,255,255,0.85); font-size: 0.72rem; border-radius: var(--fin-radius-sm); padding: 3px 10px; cursor: pointer; display: inline-flex; align-items: center; gap: 5px; transition: background 0.15s; white-space: nowrap; }

.pc-header-btn:hover { background: rgba(255,255,255,0.20); color: #fff; }

/* â”€â”€ Layout 2 colonnes â”€â”€ */

.pc-layout { display: flex; gap: 16px; align-items: flex-start; }

.pc-left { flex: 1; min-width: 0; }

.pc-right { flex: 0 0 340px; width: 340px; flex-shrink: 0; }

.pc-right .fin-card { margin-bottom: 12px; }

.pc-right .pc-validation-cols { flex-direction: column; }

.pc-right .pc-validation-left { border-right: none; border-bottom: 1px solid #f3f4f6; }

.pc-right .fin-validator-row { flex-direction: column; gap: 6px; }

.pc-right .fin-validator-type { width: auto; }

.pc-right .fin-add-panel { flex-wrap: wrap; }

.pc-right .fin-add-panel .bootstrap-select { max-width: 100% !important; min-width: 0 !important; }@media (max-width: 900px) { .pc-layout { flex-direction: column; } .pc-right { width: 100%; flex: none; } }

/* â”€â”€ Dates row â”€â”€ */

.pc-dates-row { display: flex; align-items: center; gap: 10px; padding: 12px 20px; border-bottom: 1px solid rgba(13,148,136,0.2); flex-wrap: wrap; font-size: 0.82rem; color: var(--fin-text-mid); background: #e6f7f5 !important; }

.pc-dates-row label { margin: 0; font-weight: 600; font-size: 0.75rem; color: var(--fin-text-muted); }

.pc-dates-row .form-control { width: 130px; font-size: 0.82rem; padding: 3px 8px; height: auto; }

.pc-dates-sep { color: #d1d5db; font-weight: 300; font-size: 1.1rem; }

.pc-dates-hint { font-size: 0.76rem; color: var(--fin-text-muted); margin: 10px 16px 4px; padding: 6px 10px; background: #f8fafc; border-left: 3px solid var(--fin-teal); border-radius: 0 4px 4px 0; }

.pc-dates-hint i { color: var(--fin-teal); margin-right: 4px; }

/* â”€â”€ Tableau coÃ»ts â”€â”€ */

.pc-costs-table { width: 100%; border-collapse: collapse; font-size: 0.82rem; table-layout: fixed; }

.pc-kpi-cell { padding: 14px 8px !important; text-align: center; vertical-align: middle; background: #f8fafb; border-bottom: 2px solid #e2e8f0 !important; }

.pc-kpi-cell.fin-kpi-dash { opacity: 0.55; }

.pc-kpi-cell.fin-kpi-final { background: var(--fin-teal-light) !important; }

.pc-kpi-cell.fin-kpi-warn { background: #fff7ed !important; }

.pc-kpi-cell.fin-kpi-warn .fin-kpi-value { color: #c2410c; }

.pc-kpi-cell.fin-kpi-warn .fin-kpi-label { color: #c2410c; }

.pc-kpi-cell .fin-kpi-label { font-size: 0.65rem; color: var(--fin-text-muted); font-weight: 400; margin-bottom: 5px; }

.pc-kpi-cell .fin-kpi-value { font-size: 0.96rem; font-weight: 600; color: var(--fin-text-dark); line-height: 1.2; }

.pc-kpi-cell.fin-kpi-final .fin-kpi-value { color: var(--fin-teal); }

.pc-costs-table th { padding: 14px 8px; font-size: 0.65rem; font-weight: 600; color: var(--fin-text-muted); text-transform: uppercase; letter-spacing: 0.05em; border-bottom: 2px solid #e2e8f0; text-align: center; background: #f8fafb; vertical-align: middle; }

.pc-costs-table th:first-child { text-align: left; width: 140px; }

.pc-costs-table td { padding: 6px 8px; border-bottom: 1px solid #e2e8f0; vertical-align: middle; text-align: center; }

.pc-costs-table td:first-child { text-align: left; color: var(--fin-text-muted); font-size: 0.78rem; }

.pc-costs-table tr.pc-tr-total td { font-weight: 700; font-size: 0.82rem; background: #f0f4f7; border-top: 2px solid #d1d5db !important; border-bottom: 2px solid #d1d5db !important; }

.pc-costs-table tr.pc-tr-total .form-control { font-weight: 700 !important; font-size: 0.82rem !important; color: var(--fin-text-dark) !important; }

.pc-costs-table tr.pc-tr-subtotal td { font-size: 0.78rem; color: var(--fin-text-muted); }

.pc-costs-table tr.pc-tr-year td { font-size: 0.80rem; }

.pc-costs-table .form-control { font-size: 0.80rem; padding: 3px 6px; height: auto; text-align: center; }

.pc-costs-table .input-group { flex-wrap: nowrap; }

.pc-col-locked { background: #f9fafb !important; color: #9ca3af !important; }

.pc-col-final  { background: var(--fin-teal-light) !important; }

.pc-th-locked  { color: #d1d5db !important; }

.pc-th-final   { color: var(--fin-teal) !important; }

.fin-th-warn   { background: #fffbeb !important; color: #92400e !important; }

.pc-td-warn    { background: #fffbeb !important; }

.pc-locked-dash { color: #d1d5db; font-size: 1rem; }

.pc-declare-link { font-size: 0.70rem; font-weight: 500; color: var(--fin-teal); text-decoration: underline; display: block; margin-top: 2px; }

.pc-declare-link:hover { color: #0f766e; }

.pc-cancel-result-btn { color: #d1d5db; margin-left: 4px; }

.pc-cancel-result-btn:hover { color: #ef4444; }

.pc-trash-btn { color: #d1d5db; font-size: 0.80rem; text-decoration: none; padding: 2px 4px; }

.pc-trash-btn:hover { color: #ef4444; text-decoration: none; }

.pc-tfoot-toggle { cursor: pointer; }

.pc-tfoot-toggle td { padding: 6px 10px; text-align: left !important; color: var(--fin-text-muted); font-size: 0.75rem; border-top: 1px solid #e5e7eb; }

.pc-tfoot-toggle:hover td { background: #f8fafb; color: var(--fin-teal); }

.pc-yearly-icon { transition: transform 0.2s; }

.pc-yearly-icon.open { transform: rotate(180deg); }

.pc-td-rowlabel { font-size: 0.72rem; color: var(--fin-text-muted); font-style: italic; }

.pc-variation-toggle { display: inline-flex; align-items: center; gap: 3px; font-size: 0.70rem; font-style: normal; color: var(--fin-teal); text-decoration: none; margin-top: 3px; opacity: 0.75; transition: opacity 0.15s; }

.pc-variation-toggle:hover { opacity: 1; text-decoration: none; color: var(--fin-teal); }

.pc-variation-toggle .pc-vt-icon { transition: transform 0.2s; }

.pc-variation-toggle.open .pc-vt-icon { transform: rotate(45deg); }

.pc-td-computed { font-weight: 600; font-size: 0.82rem; }

#pc-total-yearly .pc-td-computed { font-weight: 400; text-align: center !important; }

#pc-total-yearly td { vertical-align: middle !important; }

#pc-total-yearly.show { display: table-row-group !important; }

#pc-rc-yearly.show { display: table-row-group !important; }

#pc-rc-yearly .pc-td-computed { font-weight: 400 !important; }

#pc-rc-variation td:not(:first-child) { text-align: center !important; }

#pc-rc-variation .form-control { text-align: center !important; }

#pc-rc-variation .input-group { width: 100%; justify-content: center; }

.pc-resimulate-row td { background: #fafbfc; border-top: 1px dashed #e5e7eb !important; }

.fin-btn-disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

.fin-btn-grey--publish:hover { background: var(--fin-teal-hover); border-color: var(--fin-teal); color: var(--fin-teal); }

.pc-incoherence-alert { display: flex; align-items: flex-start; gap: 8px; margin: 0; padding: 8px 18px 10px; font-size: 0.78rem; color: #92400e; background: #fffbeb; border-top: 1px solid #fde68a; }

.pc-incoherence-alert i { color: #f59e0b; flex-shrink: 0; margin-top: 2px; }

.pc-simulation-notice { display: none; align-items: center; gap: 10px; padding: 8px 16px 8px 18px; font-size: 0.78rem; color: #0f766e; background: #f0fdfa; border-top: 1px solid #99f6e4; }

.pc-simulation-notice i.fa-info-circle { flex-shrink: 0; color: var(--fin-teal); }

.pc-simulation-notice-close { margin-left: auto; background: none; border: none; color: #99f6e4; font-size: 0.9rem; cursor: pointer; padding: 0 2px; line-height: 1; }

.pc-simulation-notice-close:hover { color: #0f766e; }

#pc-toast-container { position: fixed; bottom: 24px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; pointer-events: none; }

.pc-toast { display: flex; align-items: flex-start; gap: 10px; padding: 10px 14px; border-radius: 6px; font-size: 0.80rem; font-weight: 500; color: #fff; background: #ef4444; box-shadow: 0 4px 12px rgba(0,0,0,0.15); opacity: 0; transform: translateY(8px); transition: opacity 0.2s ease, transform 0.2s ease; pointer-events: auto; max-width: 320px; }

.pc-toast.visible { opacity: 1; transform: translateY(0); }

.pc-toast i { flex-shrink: 0; margin-top: 1px; }

/* â”€â”€ KPI + Performance (pages enjeux) â”€â”€ */

.fin-kpi-grid { display: flex; gap: 12px; flex-wrap: wrap; padding: 16px 20px 18px; }

.fin-kpi-item { flex: 1; min-width: 120px; background: #f8fafb; border: var(--fin-border); border-radius: var(--fin-radius-sm); padding: 12px 14px; text-align: center; }

.fin-kpi-item.fin-kpi-final { background: var(--fin-teal-light); border-color: var(--fin-teal); }

.fin-kpi-item.fin-kpi-dash { opacity: 0.55; }

.fin-perf-grid { display: flex; gap: 0; }

.fin-perf-item { flex: 1; background: #f8fafb; padding: 14px 8px; text-align: center; border-bottom: 2px solid #e5e7eb; }

.fin-perf-item:not(:last-child) { border-right: 1px solid #e5e7eb; }

.fin-perf-item.fin-kpi-final { background: var(--fin-teal-light); }

/* Hero performance */

.pc-perf-global { padding: 20px 24px 0; }

.pc-perf-section-label { font-size: 0.62rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #1a3556; margin-bottom: 10px; }

.pc-perf-hero-kpis { display: flex; border-radius: 2px; overflow: hidden; border: 1.5px solid rgba(26,53,86,0.22) !important; }

.pc-perf-kpi { flex: 1; background: linear-gradient(135deg, #d0ddef 0%, #f0fdf9 100%) !important; padding: 18px 24px; text-align: center; }

.pc-perf-kpi + .pc-perf-kpi { border-left: 1px solid rgba(26,53,86,0.18) !important; }

.pc-perf-kpi-label { font-size: 0.62rem; font-weight: 400; color: var(--fin-text-muted); margin-bottom: 9px; }

.pc-perf-kpi-value { font-size: 1.35rem; font-weight: 600; line-height: 1.2; }

.pc-perf-global-toggle { display: flex; align-items: center; gap: 6px; font-size: 0.72rem; color: var(--fin-text-muted); cursor: pointer; user-select: none; padding: 8px 0 16px; }

.pc-perf-yearly-table { width: 100%; border-collapse: collapse; margin-top: 6px; table-layout: fixed; }

.pc-perf-yearly-table th { font-size: 0.62rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--fin-text-muted); padding: 6px 8px; border-bottom: 1px solid #e5e7eb; text-align: center; background: #f0fdf9; }

.pc-perf-yearly-table th:first-child { text-align: left; }

.pc-perf-yearly-table td { padding: 5px 8px; border-bottom: 1px solid #f3f4f6; vertical-align: middle; text-align: center; font-size: 0.80rem; }

.pc-perf-yearly-table td:first-child { text-align: left; color: var(--fin-text-muted); font-style: italic; font-size: 0.72rem; }

.pc-perf-yearly-inner th { background: #f8fafb; font-size: 0.58rem; }

.pc-perf-yearly-inner td { font-size: 0.72rem; padding: 4px 14px; }

.pc-perf-yearly-inner td:first-child { font-size: 0.68rem; padding: 4px 14px; }

.pc-perf-breakdown { margin-top: 16px; padding: 14px 24px 20px; border-top: 1px solid rgba(13,148,136,0.18); background: rgba(255,255,255,0.55); }

.pc-perf-breakdown-header { margin-bottom: 12px; }

.pc-perf-breakdown-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

.pc-perf-breakdown-col { background: #fff; border: 1px solid #e2e8f0; border-radius: 2px; overflow: hidden; }

.pc-perf-breakdown-col-header { padding: 8px 14px; background: #f8fafb; border-bottom: 1px solid #e2e8f0; font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--fin-text-muted); }

.pc-perf-breakdown-col-body { padding: 14px 14px 10px; display: flex; gap: 16px; }

.pc-perf-breakdown-metric { flex: 1; }

.pc-perf-breakdown-metric-label { font-size: 0.60rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--fin-text-muted); margin-bottom: 4px; }

.pc-perf-breakdown-metric-value { font-size: 0.90rem; font-weight: 700; }

.pc-perf-inner-toggle { display: flex; align-items: center; gap: 5px; font-size: 0.68rem; color: var(--fin-text-muted); cursor: pointer; user-select: none; padding: 6px 14px 10px; border-top: 1px solid #f3f4f6; }

.fin-gain  { color: #16a34a; }

.fin-loss  { color: #ef4444; }

.fin-avoid { color: #16a34a; }

.fin-perf-badge { margin-left: auto; display: inline-flex; align-items: center; padding: 2px 10px; border-radius: 100px; background: rgba(255,255,255,0.20); color: #fff; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; border: 1px solid rgba(255,255,255,0.35); white-space: nowrap; }

/* â”€â”€ Variantes cards enjeux â”€â”€ */

.fin-card--ooc,.fin-card--rc { border-left: 2px solid var(--fin-teal) !important; }

.fin-card--ooc > .fin-card-header,.fin-card--rc > .fin-card-header { background: #e6f7f5 !important; }

.fin-card--aggregate > .fin-card-header { border-top: 2px solid #2D3E50; }

.fin-card--aggregate > .fin-card-header .fin-icon-box { color: #2D3E50; }

.fin-card--performance { border: 1px solid #2D3E50 !important; background: #fff; overflow: hidden; }

.fin-card--performance > .fin-card-header { background: #2D3E50; border-bottom: none; border-radius: 0 !important; }

.fin-card--performance > .fin-card-header .fin-icon-box { color: var(--fin-teal); }

.fin-card--performance > .fin-card-header .fin-card-title { color: #fff; font-size: 0.80rem; }

/* â”€â”€ Inline edit â”€â”€ */

.pc-inline-edit { border-color: transparent !important; background-color: transparent !important; box-shadow: none !important; transition: border-color 0.15s ease, background-color 0.15s ease; }

.pc-inline-edit:hover { border-color: #9ca3af !important; background-color: #f3f4f6 !important; cursor: text; }

.pc-inline-edit:focus { border-color: var(--fin-teal) !important; background-color: #fff !important; box-shadow: 0 0 0 2px rgba(20,184,166,0.10) !important; }

.pc-inline-edit:disabled { border-color: transparent !important; background-color: transparent !important; opacity: 0.45; cursor: not-allowed; }

#project_costs_costsNotes.pc-inline-edit { resize: none; }

#project_costs_costsNotes.pc-inline-edit:focus { resize: vertical; }

.pc-save-status { color: #9ca3af; font-size: 0.48rem; line-height: 1; cursor: default; opacity: 0; transition: opacity 0.2s ease, color 0.2s ease; }

.pc-save-status.is-saving { opacity: 1; }

.pc-save-status.is-saved  { opacity: 1; color: var(--fin-teal); }

.pc-calc-running { color: var(--fin-teal); background: #f0fdf9; font-style: italic; }

/* â”€â”€ Contrats footer â”€â”€ */

.pc-contract-body { padding: 12px 20px; display: flex; flex-direction: column; gap: 8px; font-size: 0.82rem; }

.pc-contract-row { display: flex; align-items: center; gap: 10px; }

.pc-contract-label { font-size: 0.74rem; color: var(--fin-text-muted); font-weight: 500; width: 90px; flex-shrink: 0; }

.pc-contract-body .form-control { width: 120px; font-size: 0.82rem; padding: 3px 8px; height: auto; }

.pc-contract-duration { font-size: 0.78rem; color: var(--fin-text-muted); }

/* â”€â”€ Validation â”€â”€ */

.pc-validation-cols { display: flex; min-height: 0; }

.pc-validation-left { flex: 0 0 38%; padding: 16px 20px; border-right: 1px solid #f3f4f6; min-width: 0; }

.pc-validation-right { flex: 1; padding: 16px 20px; min-width: 0; }

.pc-validation-history { max-height: 280px; overflow-y: auto; padding-right: 6px; }

.pc-validation-history::-webkit-scrollbar { width: 4px; }

.pc-validation-history::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 4px; }

.fin-req-scrollable { max-height: 260px; overflow-y: auto; padding-right: 6px; }

.fin-req-scrollable::-webkit-scrollbar { width: 4px; }

.fin-req-scrollable::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 4px; }@media (max-width: 767px) { .pc-validation-cols { flex-direction: column; } .pc-validation-left { border-right: none; border-bottom: 1px solid #f3f4f6; } }

/* â”€â”€ Params (vue display) â”€â”€ */

.pc-params-row { display: flex; align-items: center; gap: 16px; padding: 12px 0; border-bottom: 1px solid #f3f4f6; font-size: 0.82rem; flex-wrap: wrap; }

.pc-params-row:last-child { border-bottom: none; }

.pc-params-label { width: 160px; flex-shrink: 0; font-weight: 600; color: var(--fin-text-mid); font-size: 0.78rem; }

.pc-params-value { flex: 1; min-width: 0; color: var(--fin-text-mid); }

.pc-perf-type-label { padding: 10px 20px 0; font-size: 0.72rem; font-weight: 700; color: var(--fin-text-muted); text-transform: uppercase; letter-spacing: 0.06em; }

.pc-perf-total-row td { background: var(--fin-teal-light) !important; font-weight: 700; border-top: 2px solid rgba(13,148,136,0.2) !important; border-bottom: 2px solid rgba(13,148,136,0.2) !important; }

.pc-perf-total-row td:first-child { font-size: 0.72rem; color: var(--fin-teal); font-style: normal; text-transform: uppercase; letter-spacing: 0.04em; }

/* â”€â”€ Scrollbar page enjeux â”€â”€ */

#project-costs-scroll::-webkit-scrollbar { width: 6px; background: transparent; }

#project-costs-scroll::-webkit-scrollbar-thumb { background: transparent; border-radius: 4px; }

#project-costs-scroll.ctx-scrolling::-webkit-scrollbar-thumb { background: #c4c9d0; }

/* â”€â”€â”€ 9. Fil d'activitÃ© â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#sp-body-activity .sp-act-filters { display: flex; flex-wrap: wrap; gap: 4px; padding: 8px 10px 6px; background: #fff; border-bottom: 1px solid #e9ecef; flex-shrink: 0; position: relative; z-index: 10; }

#sp-body-activity .sp-act-filter-btn { font-size: 11px; padding: 2px 9px; border-radius: 12px; border: 1px solid #b2dfdb; color: #00695c; background: #fff; text-decoration: none; line-height: 1.6; white-space: nowrap; transition: background .15s, color .15s; }

#sp-body-activity .sp-act-filter-btn.active,#sp-body-activity .sp-act-filter-btn:hover { background: #00695c; border-color: #00695c; color: #fff; text-decoration: none; }

/* Scroll structure */

#sp-body-activity { overflow: hidden !important; }

#sp-body-activity .sp-act-filters { flex-shrink: 0; }

#sp-body-activity .row.no-gutters.bg-white { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; }

#sp-body-activity .row.no-gutters.bg-white::-webkit-scrollbar { width: 3px; }

#sp-body-activity .row.no-gutters.bg-white::-webkit-scrollbar-thumb { background: #b2dfdb; border-radius: 3px; }

#sp-body-activity .comment-tab { flex-shrink: 0; }

#sp-body-activity .row.no-gutters.bg-white > .col-md-12 { padding: 0; }

#sp-body-activity .container-scrollable { height: auto !important; max-height: none !important; overflow: visible !important; }

/* Avatar */

#sp-body-activity .media > .md-circled { margin-top: 2px; }

#sp-body-activity .md-circled { width: 18px !important; height: 18px !important; min-width: 18px !important; line-height: 18px !important; }

#sp-body-activity .md-circled img { width: 18px !important; height: 18px !important; }

#sp-body-activity .md-circled div { font-size: 7px !important; line-height: 18px !important; padding-top: 0 !important; }

/* Items */

#sp-body-activity .media { align-items: flex-start; border-bottom: 1px solid #f1f3f5; }

#sp-body-activity .media-parent { padding: 6px 8px 0 !important; margin-bottom: 0 !important; }

#sp-body-activity .media-child  { padding: 4px 6px 0 !important; margin-bottom: 2px !important; background: rgba(0,0,0,.02); }

/* Header flex */

#sp-body-activity .project-activity-header { flex-wrap: wrap; margin-top: 2px !important; align-items: center; gap: 0; }

#sp-body-activity .spa-name-wrap { flex: 1 1 auto; min-width: 0; order: 1; }

#sp-body-activity .spa-name { font-size: 12px; font-weight: 600; color: #1a3a4a; margin-bottom: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block; }

#sp-body-activity .spa-time-wrap { flex: 0 0 auto; order: 2; }

#sp-body-activity .spa-time { font-size: 10px !important; color: #90a4ae !important; font-weight: 400; margin-left: 4px; white-space: nowrap; }

#sp-body-activity .spa-badges-wrap { flex: 0 0 auto; order: 3; display: flex; gap: 2px; margin-left: 3px; }

#sp-body-activity .spa-badge { font-size: 9px; padding: 1px 5px; border-radius: 8px; font-weight: 600; white-space: nowrap; border: 1px solid; }

#sp-body-activity .spa-badge-new       { background: #fdecea; color: #c62828; border-color: #ef9a9a; }

#sp-body-activity .spa-badge-important { background: #fdecea; color: #c62828; border-color: #ef9a9a; }

#sp-body-activity .spa-badge-obsolete  { background: #f5f5f5; color: #757575; border-color: #bdbdbd; font-style: italic; }

#sp-body-activity .spa-badge-deleted   { background: #fdecea; color: #c62828; border-color: #ef9a9a; }

#sp-body-activity .fresh-item-container { flex: 0 0 auto; order: 4; }

#sp-body-activity .spa-action-text { flex: 0 0 100%; order: 10; font-size: 11px; color: #546e7a; line-height: 1.4; margin-left: 0 !important; margin-top: 1px; }

/* RÃ©actions */

#sp-body-activity .project-activity-reaction-container { position: relative; display: flex; align-items: center; flex: 0 0 auto; order: 5; }

#sp-body-activity .project-activity-reaction { display: flex; align-items: center; gap: 2px; }

#sp-body-activity .project-activity-reaction .reactions-container { display: inline-flex; align-items: center; }

#sp-body-activity .project-activity-reaction img { width: 14px !important; height: 14px !important; }

#sp-body-activity .reactions-count { font-size: 9px; color: #78909c; margin-right: 1px; }

#sp-body-activity .spa-star-icon { font-size: 12px; color: #b0bec5; margin-left: 3px; cursor: pointer; transition: color .15s; }

#sp-body-activity .spa-star-icon.fas { color: #f9a825 !important; }

#sp-body-activity .spa-star-icon.far:hover { color: #f9a825; }

#sp-body-activity .spa-reaction-picker { display: none; position: fixed; background: #fff; border: 1px solid #e0e0e0; border-radius: 6px; padding: 6px 10px; box-shadow: 0 2px 10px rgba(0,0,0,.12); z-index: 1050; white-space: nowrap; }

#sp-body-activity .spa-reaction-picker img { width: 22px !important; height: 22px !important; margin: 0 3px; cursor: pointer; }

#sp-body-activity .spa-react-trigger { font-size: 13px; color: #cfd8dc; cursor: pointer; transition: color .15s; line-height: 1; }

#sp-body-activity .spa-react-trigger:hover { color: #00695c; }

#sp-body-activity .spa-toolbar-star { font-size: 13px; color: #b0bec5; cursor: pointer; transition: color .15s; }

#sp-body-activity .spa-toolbar-star.fas { color: #f9a825; }

#sp-body-activity .spa-toolbar-star:hover { color: #f9a825; }

/* Contenu */

#sp-body-activity .project-activity-content { padding: 2px 0 0; }

#sp-body-activity .spa-panel { display: flex; align-items: center; gap: 5px; background: #f8fafb; border-left: 2px solid #b2dfdb; border-radius: 3px; padding: 3px 7px; font-size: 11px; min-width: 0; margin-top: 3px; }

#sp-body-activity .spa-main  { flex: 1; min-width: 0; font-size: 11px; color: #1a3a4a; }

#sp-body-activity .spa-meta  { flex-shrink: 0; color: #78909c; font-size: 10px; white-space: nowrap; }

#sp-body-activity .spa-icon  { color: #78909c; font-size: 12px; flex-shrink: 0; }

#sp-body-activity .spa-link  { color: #78909c; flex-shrink: 0; }

#sp-body-activity .spa-link:hover { color: #00695c; }

#sp-body-activity .spa-panel-row2 { display: flex; align-items: center; gap: 5px; font-size: 11px; color: #546e7a; margin-top: 2px; padding-left: 9px; min-width: 0; }

#sp-body-activity .spa-sub { flex: 1; min-width: 0; }

#sp-body-activity .spa-pill { font-size: 9px; padding: 1px 6px; border-radius: 8px; border: 1px solid; white-space: nowrap; flex-shrink: 0; }

#sp-body-activity .spa-priority { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; display: inline-block; }

#sp-body-activity .spa-panel-perf { flex-wrap: wrap; gap: 3px; }

#sp-body-activity .spa-label { color: #78909c; font-size: 10px; }

#sp-body-activity .spa-val   { font-size: 11px; font-weight: 600; }

#sp-body-activity .spa-sep-dot { color: #cfd8dc; }

#sp-body-activity .spa-comment { font-size: 11px; color: #37474f; line-height: 1.5; padding: 2px 0; margin-top: 2px; }

#sp-body-activity .spa-comment-important { color: #c62828; font-weight: 600; }

/* SÃ©parateur date */

#sp-body-activity .current-date { top: 3px !important; padding-top: 10px !important; margin-bottom: 12px !important; background: #fff; z-index: 5; position: sticky; }

#sp-body-activity .current-date .border-top { margin-top: 6px !important; padding-bottom: 4px !important; }

/* Enfants */

#sp-body-activity .media-childs-container-container { margin-left: 0; margin-top: 2px; }

#sp-body-activity .media-childs-container-container.spa-has-children { border-left: 2px solid #eceff1; padding-left: 6px; }

#sp-body-activity .media-childs-toolbar { padding: 0; }

#sp-body-activity .spa-replies-bar { display: flex; align-items: center; gap: 4px; padding: 2px 4px; font-size: 11px; }

#sp-body-activity .media-childs-user-container { gap: 2px; }

#sp-body-activity .media-childs-user-container .user-picture { width: 18px !important; height: 18px !important; font-size: 8px !important; line-height: 18px !important; min-width: 18px; }

#sp-body-activity .spa-replies-link { color: #78909c; font-size: 11px; text-decoration: none; }

#sp-body-activity .spa-replies-link:hover { color: #00695c; text-decoration: none; }

#sp-body-activity .fresh-item-childs-container { font-size: 10px; }

/* Toolbar */

#sp-body-activity .project-activity-toolbar { padding: 2px 4px 3px; }

#sp-body-activity .spa-toolbar-row { display: flex; align-items: center; width: 100%; min-height: 20px; }

#sp-body-activity .spa-toolbar-items { display: inline-flex; align-items: center; opacity: 0; pointer-events: none; transition: opacity .15s; }

#sp-body-activity .media-parent:hover .spa-toolbar-items { opacity: 1; pointer-events: auto; }

#sp-body-activity .spa-tool-sep { width: 1px; height: 11px; background: #cfd8dc; margin: 0 6px; flex-shrink: 0; }

#sp-body-activity .spa-reply-btn { cursor: pointer; font-size: 11px; color: #78909c; padding: 0 2px; user-select: none; flex-shrink: 0; }

#sp-body-activity .spa-reply-btn:hover { color: #00695c; }

#sp-body-activity .comment-panel.d-inline-block ~ .spa-toolbar-row { display: none !important; }

/* Formulaire commentaire */

#sp-body-activity .comment-panel { width: 100% !important; }

#sp-body-activity .comment-panel .row.no-gutters > div[class*="col-"] { flex: 0 0 100% !important; max-width: 100% !important; }

#sp-body-activity .comment-panel .col-11,#sp-body-activity .comment-tab .col-11 { position: relative; }

#sp-body-activity .comment-panel .emoji-picker-icon,#sp-body-activity .comment-tab .emoji-picker-icon { right: 35px !important; transition: color 0.15s; }

#sp-body-activity .comment-panel .emoji-picker-icon:hover,#sp-body-activity .comment-tab .emoji-picker-icon:hover { color: #0d9488 !important; }

#sp-body-activity .comment-panel .form-check,#sp-body-activity .comment-tab .form-check { position: absolute !important; right: 8px !important; top: 5px !important; z-index: 4; padding: 0 !important; margin: 0 !important; }

#sp-body-activity .comment-panel .form-check-input,#sp-body-activity .comment-tab .form-check-input { display: none !important; }

#sp-body-activity .comment-panel label.form-check-important,#sp-body-activity .comment-tab label.form-check-important { position: static !important; top: auto !important; right: auto !important; }

#sp-body-activity .comment-panel label.form-check-important::before,#sp-body-activity .comment-panel label.form-check-important:hover::before,#sp-body-activity .comment-panel input[type="checkbox"]:checked + label.form-check-important::before,#sp-body-activity .comment-tab label.form-check-important::before,#sp-body-activity .comment-tab label.form-check-important:hover::before,#sp-body-activity .comment-tab input[type="checkbox"]:checked + label.form-check-important::before { position: static !important; margin-left: 0 !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; width: 20px !important; height: 20px !important; line-height: 20px !important; padding: 0 !important; box-sizing: border-box !important; }

#sp-body-activity .emoji-wysiwyg-editor { padding-right: 70px !important; }

#sp-body-activity .emoji-wysiwyg-editor.medium-editor-placeholder:after { top: 50% !important; transform: translateY(-50%) !important; white-space: nowrap !important; }

#sp-body-activity .comment-tab { padding: 4px 8px !important; }

#sp-body-activity .comment-tab .col-10 { flex: 0 0 100%; max-width: 100%; margin: 0 !important; }

/* â”€â”€â”€ 10. BÃ©nÃ©fices qualitatifs (drawer) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

#benefits-search { border: 1px solid #e2e8f0; border-radius: 2px; font-size: 0.79rem; color: #415873; padding: 6px 10px 6px 32px; background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%238fa1b3' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.099zm-5.242 1.156a5.5 5.5 0 1 1 0-11 5.5 5.5 0 0 1 0 11z'/%3E%3C/svg%3E") no-repeat 10px center; transition: border-color 0.15s; }

#benefits-search:focus { border-color: #0d9488; box-shadow: 0 0 0 2px rgba(13,148,136,0.12); outline: none; }

#benefitsDrawer textarea.form-control { border: 1px solid #e2e8f0; border-radius: 2px; font-size: 0.79rem; color: #415873; resize: vertical; transition: border-color 0.15s; }

#benefitsDrawer textarea.form-control:focus { border-color: #0d9488; box-shadow: 0 0 0 2px rgba(13,148,136,0.12); outline: none; }

.qb-category-group { margin-bottom: 10px; }

.qb-category-header { font-size: 0.67rem; font-weight: 700; color: #0d9488; text-transform: uppercase; letter-spacing: 0.08em; padding: 0 2px 5px; border-bottom: 1px solid #e6f7f5; margin-bottom: 5px; }

.qb-item { border: 1px solid #e2e8f0; border-radius: 2px; margin-bottom: 5px; background: #fff; transition: border-color 0.12s, background 0.12s; overflow: hidden; }

.qb-item:hover { background: #f0fafa; border-color: #b2e0db; }

.qb-item.qb-checked { background: #e6f7f5; border-color: #0d9488; }

.qb-item-main { display: flex; align-items: center; gap: 10px; padding: 9px 14px; cursor: pointer; }

.qb-checkbox { appearance: none; -webkit-appearance: none; width: 16px; height: 16px; border: 2px solid #d1d5db; border-radius: 3px; flex-shrink: 0; cursor: pointer; transition: background 0.12s, border-color 0.12s; }

.qb-checkbox:checked { background: #0d9488; border-color: #0d9488; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z' fill='%23fff'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; background-size: 11px; }

.qb-label { font-size: 0.79rem; color: #415873; cursor: pointer; margin: 0; font-weight: 400; flex: 1; }

.qb-label a { color: inherit; text-decoration: none; }

.qb-enrich-toggle { background: none; border: none; padding: 2px 4px; color: #94a3b8; cursor: pointer; flex-shrink: 0; line-height: 1; transition: color 0.1s; }

.qb-enrich-toggle:hover { color: #0d9488; }

.qb-enrich-toggle .qb-chevron { font-size: 0.70rem; transition: transform 0.2s; display: inline-block; }

.qb-item.qb-enrich-collapsed .qb-chevron { transform: rotate(-90deg); }

.qb-enrichment { border-top: 1px solid rgba(13,148,136,0.15); padding: 8px 14px 10px; background: rgba(13,148,136,0.04); }

.qb-opt-hint { font-size: 0.67rem; color: #8fa1b3; font-style: italic; margin-left: 3px; }

.qb-stars-row { display: flex; align-items: center; gap: 10px; margin-bottom: 7px; }

.qb-enrich-label { font-size: 0.70rem; color: #6b7a8d; white-space: nowrap; }

.qb-stars { display: flex; gap: 3px; }

.qb-star { font-size: 1.15rem; color: #d1d9e4; cursor: pointer; transition: color 0.1s; line-height: 1; user-select: none; }

.qb-star.qb-star-on { color: #f59e0b; }

.qb-star:hover { color: #f59e0b; }

.qb-comment { font-size: 0.76rem; color: #415873; border: 1px solid #dde4ec !important; border-radius: 2px !important; resize: vertical; min-height: 44px; padding: 5px 8px !important; transition: border-color 0.15s !important; }

.qb-comment:focus { border-color: #0d9488 !important; box-shadow: 0 0 0 2px rgba(13,148,136,0.10) !important; outline: none !important; }

#qb-toggle-all { font-size: 0.72rem; color: #6b7a8d; background: none; border: none; padding: 0; cursor: pointer; text-decoration: underline; text-decoration-style: dotted; text-underline-offset: 2px; }

#qb-toggle-all:hover { color: #0d9488; }

/* â”€â”€ BÃ©nÃ©fices qualitatifs â€” vue lecture (tabs/qualitative_benefits.html.twig) â”€â”€ */

.qbr-list { padding-bottom: 8px; }

.qbr-category-header {    font-size: 0.67rem; font-weight: 700; color: #0d9488;    text-transform: uppercase; letter-spacing: 0.08em;    padding: 10px 2px 5px; border-bottom: 1px solid #e6f7f5;    margin-bottom: 5px;}

.qbr-category-header:first-child { padding-top: 0; }

.qbr-item {    border-left: 2px solid #e2e8f0;    padding: 6px 10px; margin-bottom: 4px;    transition: border-color 0.12s;}

.qbr-item-enriched { border-left-color: #0d9488; }

.qbr-item-main { display: flex; align-items: center; gap: 8px; }

.qbr-check-icon { color: #0d9488; font-size: 0.80rem; flex-shrink: 0; }

.qbr-label { font-size: 0.82rem; color: #415873; flex: 1; }

.qbr-stars { font-size: 0.78rem; color: #f59e0b; letter-spacing: 1px; }

.qbr-comment { font-size: 0.75rem; color: #6b7a8d; margin-top: 3px; padding-left: 22px; font-style: italic; }

/* â”€â”€ Navigation onglets projet : voir rÃ¨gles .prj-tabs plus haut â”€â”€ */

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•   MODULE COMMUNAUTÃ‰ â€” classes com-*   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• *//* â”€â”€ Page layout â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ *//* â”€â”€ Variables communautÃ© â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */:root {    --com-teal:       #0d9488;    --com-teal-light: #e6f7f5;    --com-teal-hover: #f0fafa;    --com-navy:       #2D3E50;    --com-mid:        #415873;    --com-muted:      #8fa1b3;    --com-border:     1px solid #e2e8f0;    --com-shadow:     0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);    --com-bg:         #fff;    --com-bg-page:    #f4f6f9;}

/* â”€â”€ Page wrapper â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ *//* â”€â”€ Variables communautÃ© â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */:root {    --com-teal:       #0d9488;    --com-teal-light: #e6f7f5;    --com-teal-hover: #f0fafa;    --com-navy:       #2D3E50;    --com-navy-dark:  #1a3347;    --com-mid:        #415873;    --com-muted:      #8fa1b3;    --com-border:     1px solid #e2e8f0;    --com-shadow:     0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);    --com-bg:         #fff;    --com-bg-page:    #f4f6f9;}

/* â”€â”€ Page wrapper â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-page { padding-top: 0; background: var(--com-bg-page); min-height: 100vh; }

/* â”€â”€ Variables communautÃ© (alignÃ©es sur ctx-*) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */:root {    --com-teal:       #0d9488;    --com-teal-light: #e6f7f5;    --com-teal-hover: #f0fafa;    --com-navy:       #2D3E50;    --com-navy-dark:  #1a3347;    --com-mid:        #415873;    --com-muted:      #8fa1b3;    --com-border:     1px solid #e2e8f0;    --com-shadow:     0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);    --com-bg:         #fff;    --com-bg-page:    #f4f6f9;    --com-radius:     2px;}

/* â”€â”€ Header navy (identique fin-module-header) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-page-header {    display: flex; align-items: center; justify-content: space-between;    padding: 0 24px; min-height: 64px;    background: var(--com-navy-dark); color: #fff;    gap: 16px; flex-shrink: 0;}

.com-page-header-left { display: flex; align-items: center; gap: 14px; }

.com-page-header-icon {    width: 36px; height: 36px; border-radius: var(--com-radius);    background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.90);    display: flex; align-items: center; justify-content: center;    font-size: 0.95rem; flex-shrink: 0;}

.com-page-header-title {    font-size: 0.90rem; font-weight: 700; color: #fff;    display: flex; align-items: center; gap: 8px; margin-bottom: 2px;}

.com-page-header-meta { font-size: 0.72rem; color: rgba(255,255,255,0.50); display: flex; align-items: center; gap: 4px; }

.com-meta-sep { color: rgba(255,255,255,0.25); }

.com-scope-chip {    display: inline-flex; align-items: center;    font-size: 0.68rem; font-weight: 600; padding: 2px 9px;    border-radius: 100px; white-space: nowrap;}

.com-scope-team { background: rgba(13,148,136,0.30); color: #5eead4; border: 1px solid rgba(94,234,212,0.25); }

.com-scope-enterprise { background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.75); border: 1px solid rgba(255,255,255,0.18); }

.com-btn-new {    background: rgba(255,255,255,0.15); color: #fff;    border: 1px solid rgba(255,255,255,0.25); border-radius: var(--com-radius);    font-size: 0.80rem; font-weight: 500; padding: 5px 14px; transition: background 0.15s;}

.com-btn-new:hover { background: rgba(255,255,255,0.25); color: #fff; }

/* â”€â”€ Switcher â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-switcher-bar {    display: flex; align-items: center; padding: 0 20px;    background: var(--com-bg); border-bottom: var(--com-border);    box-shadow: 0 1px 3px rgba(0,0,0,0.05);}

.com-switcher { display: flex; }

.com-switcher-tab {    display: inline-flex; align-items: center; padding: 10px 18px;    font-size: 0.80rem; font-weight: 500; color: var(--com-muted);    text-decoration: none; border-bottom: 2px solid transparent;    transition: color 0.15s, border-color 0.15s; white-space: nowrap;}

.com-switcher-tab:hover { color: var(--com-navy); text-decoration: none; }

.com-switcher-tab.active { color: var(--com-navy); font-weight: 600; border-bottom-color: var(--com-teal); }

.com-badge {    display: inline-flex; align-items: center; justify-content: center;    min-width: 16px; height: 16px; padding: 0 4px; margin-left: 6px;    border-radius: 2px; background: var(--com-teal); color: #fff; font-size: 0.63rem; font-weight: 700;}

/* â”€â”€ Colonnes â€” !important car Bootstrap no-gutters Ã©crase le padding â”€â”€ */

.com-columns { min-height: calc(100vh - 170px); }

.com-col-feed  { background: var(--com-bg) !important; padding: 16px !important; border-right: var(--com-border); }

.com-col-right { background: var(--com-bg) !important; padding: 16px !important; overflow-y: auto; }

.com-col-right::-webkit-scrollbar { width: 3px; }

.com-col-right::-webkit-scrollbar-track { background: transparent; }

.com-col-right::-webkit-scrollbar-thumb { background: transparent; }

.com-col-right:hover::-webkit-scrollbar-thumb { background: #c4c9d0; }

/* â”€â”€ Filtres (style ctx-section compact) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-filters {    background: var(--com-bg); border: var(--com-border);    border-radius: var(--com-radius); box-shadow: var(--com-shadow);    padding: 8px 14px; margin-bottom: 14px;    display: flex; gap: 6px; flex-wrap: wrap; align-items: center;}

.com-filter {    font-size: 0.73rem; font-weight: 500; color: #a0aec0;    padding: 3px 10px; border-radius: var(--com-radius); background: #f1f3f5;    text-decoration: none; border: 1px solid transparent;    transition: color 0.12s, background 0.12s;}

/* Hover : texte teal (au lieu du navy var(--com-navy) qui rendait trop "noir") + bg teal tres clair. */
.com-filter:hover { color: #0d9488; background: #f0fbf9; text-decoration: none; }

.com-filter.active { background: var(--com-teal-light); color: var(--com-teal); border-color: var(--com-teal); font-weight: 600; }

/* â”€â”€ Post items â€” style ctx-info-card â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-post-item {    background: var(--com-bg); border-radius: var(--com-radius);    border: var(--com-border); box-shadow: var(--com-shadow);    margin-bottom: 14px; cursor: pointer;    transition: box-shadow 0.15s, border-color 0.15s;    position: relative; overflow: hidden;}

.com-post-item:last-child { margin-bottom: 0; }

.com-post-item:hover { box-shadow: 0 3px 12px rgba(0,0,0,0.10); border-color: #c8d3dd; }

.com-post-item.com-post-selected { border-color: var(--com-teal); box-shadow: 0 2px 8px rgba(13,148,136,0.14); }

.com-post-item.com-post-unread { border-left: 3px solid var(--com-teal); }

.com-post-item.com-post-pinned .com-post-item-header { background: #f0f4ff; }

/* Header de carte â€” identique ctx-info-card-header */

.com-post-item-header {    display: flex; align-items: center; gap: 12px;    padding: 10px 16px;    border-bottom: 1px solid rgba(45,62,80,0.12);    background: var(--com-bg);}

.com-post-item-author { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; overflow: hidden; }

.com-post-author { font-size: 0.78rem; font-weight: 600; color: var(--com-navy); white-space: nowrap; }

.com-post-date { font-size: 0.70rem; color: var(--com-muted); white-space: nowrap; }

.com-post-pin { color: var(--com-teal); font-size: 0.70rem; }

.com-post-item-badges { display: flex; align-items: center; gap: 5px; flex-shrink: 0; }

.com-post-type-tag {    display: inline-flex; align-items: center;    font-size: 0.67rem; font-weight: 600; padding: 2px 7px;    border-radius: var(--com-radius); white-space: nowrap;}

.com-post-type-conversation { background: #eef1f5; color: var(--com-mid); }

.com-post-type-event { background: var(--com-teal-light); color: var(--com-teal); }

.com-post-new-badge { font-size: 0.62rem; font-weight: 700; background: var(--com-teal); color: #fff; border-radius: 2px; padding: 2px 5px; }

.com-post-replies { font-size: 0.70rem; color: var(--com-muted); white-space: nowrap; }

/* Boutons action inline â€” style ctx-action-btn (hover de proximitÃ©) */

.com-post-actions { display: flex; align-items: center; gap: 4px; flex-shrink: 0; margin-left: 4px; }

.com-post-action-btn {    width: 24px; height: 24px;    display: inline-flex; align-items: center; justify-content: center;    border: 1px solid transparent; border-radius: var(--com-radius);    background: transparent; font-size: 0.72rem; cursor: pointer; padding: 0;    color: transparent;    transition: color 0.12s, background 0.12s, border-color 0.12s;}

.com-post-item:hover .com-post-action-btn { color: #b0bec5; background: #fff; border-color: #e5e7eb; }

.com-post-action-btn.com-post-action-active { color: var(--com-teal) !important; }

.com-post-action-pin:hover { background: var(--com-teal-light) !important; border-color: var(--com-teal) !important; color: var(--com-teal) !important; }

.com-post-action-delete:hover { background: #fef2f2 !important; border-color: #fca5a5 !important; color: #ef4444 !important; }

/* Corps de carte â€” identique ctx-info-card-body */

.com-post-item-body { padding: 12px 16px 14px; }

.com-post-title { font-weight: 600; font-size: 0.87rem; color: var(--com-navy); margin-bottom: 5px; line-height: 1.4; }

.com-post-preview {    font-size: 0.78rem; color: var(--com-muted); line-height: 1.45;    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;}

.com-post-event-info { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.com-post-event-date { font-size: 0.73rem; color: #415873; font-weight: 500; }

.com-post-attached { font-size: 0.72rem; color: var(--com-muted); margin-top: 4px; }

/* â”€â”€ Empty state â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-empty-state {    text-align: center; padding: 50px 20px; color: var(--com-muted);    background: var(--com-bg); border: var(--com-border);    border-radius: var(--com-radius); box-shadow: var(--com-shadow);}

.com-empty-state i { font-size: 2rem; margin-bottom: 12px; display: block; color: #c8d3dd; }

.com-empty-state p { font-size: 0.83rem; line-height: 1.6; }

/* â”€â”€ Panneaux droite â€” style ctx-section â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-panel {    background: var(--com-bg); border: var(--com-border);    border-radius: var(--com-radius); box-shadow: var(--com-shadow);    margin-bottom: 14px; overflow: hidden;}

.com-panel:last-child { margin-bottom: 0; }

.com-panel-title {    display: flex; align-items: center; gap: 8px;    padding: 10px 16px;    border-bottom: 1px solid rgba(45,62,80,0.35);    font-size: 0.70rem; font-weight: 700; letter-spacing: 0.07em;    text-transform: uppercase; color: var(--com-mid);    background: var(--com-bg);}

.com-panel-title i { color: var(--com-teal); font-size: 0.80rem; width: 16px; }

.com-panel-count { background: var(--com-teal-light); color: var(--com-teal); border-radius: var(--com-radius); font-size: 0.63rem; font-weight: 600; padding: 1px 6px; min-width: 18px; text-align: center; }

/* â”€â”€ Sondages â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-poll-card { padding: 10px 16px; cursor: pointer; transition: background 0.12s; border-bottom: 1px solid #f3f4f6; }

.com-poll-card:last-child { border-bottom: none; }

.com-poll-card:hover { background: var(--com-teal-hover); }

.com-poll-question { font-size: 0.80rem; font-weight: 500; color: var(--com-navy); margin-bottom: 8px; }

.com-poll-option { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }

.com-poll-option-label { font-size: 0.72rem; color: var(--com-mid); width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex-shrink: 0; }

.com-poll-bar-wrap { flex: 1; height: 4px; background: #e2e8f0; border-radius: 2px; overflow: hidden; }

.com-poll-bar { height: 100%; background: var(--com-teal); border-radius: 2px; transition: width 0.3s; }

.com-poll-pct { font-size: 0.68rem; color: var(--com-muted); width: 30px; text-align: right; flex-shrink: 0; }

.com-poll-meta { font-size: 0.68rem; color: var(--com-muted); margin-top: 5px; }

/* â”€â”€ Documents â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-doc-card { display: flex; align-items: center; gap: 10px; padding: 8px 16px; border-bottom: 1px solid #f3f4f6; transition: background 0.12s; }

.com-doc-card:last-child { border-bottom: none; }

.com-doc-card:hover { background: #f9fafb; }

.com-doc-icon { color: var(--com-muted); font-size: 0.92rem; flex-shrink: 0; }

.com-doc-info { flex: 1; min-width: 0; }

.com-doc-name { font-size: 0.78rem; font-weight: 500; color: var(--com-navy); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.com-doc-meta { font-size: 0.68rem; color: var(--com-muted); }

.com-doc-fav { color: #c8d3dd; background: none; border: none; padding: 2px 4px; font-size: 0.85rem; flex-shrink: 0; cursor: pointer; }

.com-doc-fav.active, .com-doc-fav:hover { color: var(--com-teal); }

/* â”€â”€ Membres â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-members-list { display: flex; flex-wrap: wrap; gap: 6px; padding: 10px 16px; }

.com-member { display: inline-block; transition: transform 0.12s; }

.com-member:hover { transform: scale(1.1); }

/* â”€â”€ Drawer â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-drawer-loading { color: var(--com-muted); }

.com-drawer-title { font-size: 0.88rem; font-weight: 600; color: #fff; }

#communityDrawer.com-drawer-fullscreen { left: 65px; width: calc(100% - 65px); }

/* Scrollbar du drawer CommunautÃ© â€” fine et masquÃ©e au repos, visible au hover */
#communityDrawer #drawerBody::-webkit-scrollbar { width: 3px; background: transparent; }
#communityDrawer #drawerBody::-webkit-scrollbar-track { background: transparent; border: none; }
#communityDrawer #drawerBody::-webkit-scrollbar-thumb { background: transparent; border-radius: 3px; transition: background 0.25s; }
#communityDrawer #drawerBody:hover::-webkit-scrollbar-thumb { background: #c4c9d0; }
#communityDrawer #drawerBody::-webkit-scrollbar-thumb:hover { background: #9ca3af; }
#communityDrawer #drawerBody { scrollbar-width: thin; scrollbar-color: transparent transparent; }
#communityDrawer #drawerBody:hover { scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€ Thread â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-thread { display: flex; flex-direction: column; height: 100%; }

.com-thread-header { padding: 20px 20px 16px; border-bottom: var(--com-border); }

.com-thread-author-row { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }

.com-thread-author-info { flex: 1; min-width: 0; }

.com-thread-author-name { font-size: 0.85rem; font-weight: 600; color: var(--com-navy); }

.com-thread-date { font-size: 0.74rem; color: var(--com-muted); }

.com-thread-pin-badge { font-size: 0.68rem; font-weight: 600; color: var(--com-teal); background: var(--com-teal-light); border-radius: 2px; padding: 2px 6px; }
.com-thread-hidden-badge { font-size: 0.68rem; font-weight: 600; color: #92400e; background: #fef3c7; border-radius: 2px; padding: 2px 6px; }

.com-thread-title { font-size: 0.95rem; font-weight: 600; color: var(--com-navy); margin: 0 0 8px; line-height: 1.4; }

.com-thread-event-date {    display: inline-flex; align-items: center; gap: 6px;    background: var(--com-teal-light); color: var(--com-teal);    border-radius: var(--com-radius); padding: 4px 10px; font-size: 0.80rem; margin-bottom: 10px;}

.com-thread-body { font-size: 0.85rem; color: var(--com-mid); line-height: 1.6; white-space: pre-wrap; }

.com-thread-section { padding: 12px 20px; border-bottom: var(--com-border); }

.com-thread-section-title {    font-size: 0.67rem; font-weight: 700; text-transform: uppercase;    letter-spacing: 0.07em; color: var(--com-muted); margin-bottom: 10px;}

.com-poll-inline { margin-bottom: 12px; }

.com-poll-inline:last-child { margin-bottom: 0; }

.com-poll-vote-form { display: flex; flex-direction: column; gap: 6px; }

.com-poll-vote-option {    display: flex; align-items: center; gap: 8px; font-size: 0.83rem; color: var(--com-mid);    padding: 6px 10px; border: var(--com-border); border-radius: var(--com-radius);    cursor: pointer; margin: 0; font-weight: normal;    transition: background 0.12s, border-color 0.12s;}

.com-poll-vote-option:hover { background: var(--com-teal-light); border-color: var(--com-teal); color: var(--com-navy); }

.com-poll-voters { margin-top: 2px; padding-left: 4px; }

.com-poll-results { padding: 0; }

.com-add-doc-btn { font-size: 0.78rem; color: var(--com-muted); }

.com-add-doc-btn:hover { color: var(--com-teal); border-color: var(--com-teal); }

.com-doc-upload-form { background: var(--com-bg); border: var(--com-border); border-radius: var(--com-radius); padding: 12px; margin-top: 8px; }

.com-add-poll-btn { font-size: 0.78rem; color: var(--com-muted); margin-top: 10px; }

.com-add-poll-btn:hover { color: var(--com-teal); border-color: var(--com-teal); }

.com-poll-create-form { background: var(--com-bg); border: var(--com-border); border-radius: var(--com-radius); padding: 12px; margin-top: 8px; }

.com-poll-create-form .form-control-sm { font-size: 0.82rem; }

.com-thread-reactions { display: flex; gap: 6px; padding: 10px 20px; border-bottom: var(--com-border); }

.com-reaction-btn {    display: inline-flex; align-items: center; gap: 4px;    background: #f1f3f5; border: var(--com-border); border-radius: var(--com-radius);    padding: 3px 10px; font-size: 0.85rem; cursor: pointer;    transition: background 0.12s, border-color 0.12s;}

.com-reaction-btn:hover { background: var(--com-teal-light); border-color: var(--com-teal); }

.com-reaction-btn.active { background: var(--com-teal-light); border-color: var(--com-teal); color: var(--com-teal); font-weight: 600; }

.com-reaction-count { font-size: 0.75rem; color: var(--com-muted); }

.com-thread-replies { flex: 1; overflow-y: auto; padding: 8px 0; }

.com-thread-replies-title {    font-size: 0.67rem; font-weight: 700; text-transform: uppercase;    letter-spacing: 0.07em; color: var(--com-muted); padding: 4px 20px 10px;}

.com-reply-item { display: flex; padding: 10px 20px; gap: 10px; border-bottom: 1px solid #f3f4f6; }

.com-reply-item:last-child { border-bottom: none; }

.com-reply-left { flex-shrink: 0; }

.com-reply-body { flex: 1; min-width: 0; }

.com-reply-meta { margin-bottom: 3px; }

.com-reply-author { font-size: 0.80rem; font-weight: 600; color: var(--com-navy); }

.com-reply-date { font-size: 0.70rem; color: var(--com-muted); }

.com-reply-text { font-size: 0.83rem; color: var(--com-mid); line-height: 1.5; }

.com-thread-reply-form { padding: 8px 12px; border-top: var(--com-border); background: var(--com-bg); flex-shrink: 0; }

.com-reply-input-wrap { min-width: 0; }

.com-reply-textarea { font-size: 0.83rem; border: var(--com-border); border-radius: var(--com-radius); resize: none; }

.com-reply-textarea:focus { border-color: var(--com-teal); outline: none; box-shadow: 0 0 0 2px rgba(13,148,136,0.12); }

.com-feed-hidden { display: none !important; }

/* == CommunautÃ© : boutons d'action header ========================== */

.com-header-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.com-btn-action {    font-size: 0.78rem; font-weight: 600; padding: 6px 14px; border-radius: var(--com-radius);    display: inline-flex; align-items: center; gap: 5px; border: none;    transition: opacity 0.14s, transform 0.1s; cursor: pointer; color: #fff;}

.com-btn-action:hover { opacity: 0.88; transform: translateY(-1px); color: #fff; text-decoration: none; }

.com-btn-conversation { background: #3b82f6; }

.com-btn-event        { background: #10b981; }

.com-btn-poll         { background: #8b5cf6; }

.com-btn-document     { background: #f59e0b; }

/* == CommunautÃ© : types post (stripe + tags + item border) ========= */

.com-post-type-stripe {    width: 4px; border-radius: 4px 0 0 4px;    position: absolute; top: 0; left: 0; bottom: 0;}

.com-post-item { position: relative; padding-left: 4px; }

.com-post-type-conversation .com-post-type-stripe { background: #3b82f6; }

.com-post-type-event        .com-post-type-stripe { background: #10b981; }

.com-post-type-poll         .com-post-type-stripe { background: #8b5cf6; }

.com-post-type-document     .com-post-type-stripe { background: #f59e0b; }

.com-post-type-poll    { background: #f5f0ff; color: #7c3aed; }

.com-post-type-document{ background: #fffbeb; color: #b45309; }

.com-post-type-conversation-tag { background: #eff6ff; color: #2563eb; border: 1px solid #bfdbfe; }

.com-post-type-event-tag        { background: #ecfdf5; color: #059669; border: 1px solid #a7f3d0; }

.com-post-type-poll-tag         { background: #f5f3ff; color: #7c3aed; border: 1px solid #ddd6fe; }

.com-post-type-document-tag     { background: #fffbeb; color: #b45309; border: 1px solid #fde68a; }

/* == CommunautÃ© : post item content par type ======================= */

.com-post-ics-link { font-size: 0.70rem; color: var(--com-teal); text-decoration: none; border: 1px solid var(--com-teal); border-radius: 4px; padding: 2px 8px; white-space: nowrap; }
.com-post-ics-link:hover { background: var(--com-teal-light); }

.com-post-poll-preview { font-size: 0.78rem; color: var(--com-mid); margin-top: 5px; display: flex; align-items: center; gap: 6px; }

.com-post-poll-votes { font-size: 0.70rem; color: var(--com-muted); background: #f3f4f6; border-radius: 10px; padding: 2px 7px; }

.com-post-doc-preview { display: flex; align-items: center; gap: 6px; font-size: 0.78rem; color: var(--com-mid); margin-top: 5px; }

.com-post-doc-size { color: var(--com-muted); }

.com-doc-cat-tag { font-size: 0.65rem; font-weight: 600; background: #fef3c7; color: #92400e; border-radius: 3px; padding: 1px 6px; }

/* == CommunautÃ© : drawer header type colors ======================== */

.com-thread-type-badge {    display: inline-flex; align-items: center; font-size: 0.68rem; font-weight: 700;    text-transform: uppercase; letter-spacing: 0.06em;    border-radius: 3px; padding: 2px 8px; margin-bottom: 8px;}

.com-post-type-conversation-header { border-top: 3px solid #3b82f6; }

.com-post-type-event-header         { border-top: 3px solid #10b981; }

.com-post-type-poll-header          { border-top: 3px solid #8b5cf6; }

.com-post-type-document-header      { border-top: 3px solid #f59e0b; }

/* == CommunautÃ© : fil d'activitÃ© (drawer) ========================== */

.com-activity-feed { flex: 1; overflow-y: auto; padding: 8px 0; scrollbar-width: thin; scrollbar-color: transparent transparent; transition: scrollbar-color 0.2s; }
.com-activity-feed:hover { scrollbar-color: #c4c9d0 transparent; }

.com-activity-feed::-webkit-scrollbar { width: 3px; background: transparent; }
.com-activity-feed::-webkit-scrollbar-track { background: transparent; }
.com-activity-feed::-webkit-scrollbar-thumb { background: transparent; border-radius: 2px; transition: background 0.2s; }
.com-activity-feed:hover::-webkit-scrollbar-thumb { background: #c4c9d0; }
.com-activity-feed::-webkit-scrollbar-thumb:hover { background: #9ca3af; }

.com-activity-item {    display: flex; gap: 10px; padding: 12px 20px;    border-bottom: 1px solid #f3f4f6;}

.com-activity-item:last-child { border-bottom: none; }

.com-activity-main { background: #fafbfc; }

.com-activity-avatar { flex-shrink: 0; }

.com-activity-body { flex: 1; min-width: 0; }

.com-activity-header { display: flex; align-items: baseline; flex-wrap: wrap; gap: 4px; margin-bottom: 6px; }

.com-activity-author { font-size: 0.80rem; font-weight: 600; color: var(--com-navy); }

.com-activity-action { font-size: 0.78rem; color: var(--com-muted); }

.com-activity-time   { font-size: 0.70rem; color: var(--com-muted); margin-left: auto; }

.com-activity-content { margin-top: 0; }

.com-activity-event-card { padding: 10px 14px; }

.com-activity-event-date { display: flex; align-items: center; gap: 6px; font-size: 0.82rem; font-weight: 500; color: #059669; }

.com-activity-doc-card { display: flex; align-items: center; gap: 12px; padding: 10px 14px; }

.com-activity-doc-icon { font-size: 1.4rem; flex-shrink: 0; }

.com-activity-doc-info { flex: 1; min-width: 0; }

.com-activity-doc-name { font-size: 0.82rem; font-weight: 600; color: var(--com-navy); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.com-activity-doc-meta { font-size: 0.70rem; color: var(--com-muted); display: flex; align-items: center; gap: 5px; flex-wrap: wrap; margin-top: 2px; }

.com-activity-compose-poll, .com-activity-compose-doc { padding: 8px 20px; }

.com-activity-docs-section { }

.com-activity-add-btn {    display: inline-flex; align-items: center; gap: 5px;    font-size: 0.75rem; color: var(--com-muted);    background: none; border: 1px dashed #c8d3dd; border-radius: var(--com-radius);    padding: 5px 12px; cursor: pointer; transition: color 0.12s, border-color 0.12s;}

.com-activity-add-btn:hover { color: var(--com-teal); border-color: var(--com-teal); }

/* == CommunautÃ© : base documentaire ================================ */

.com-panel-docs { }

.com-doc-search-wrap { padding: 8px 16px 4px; }

.com-doc-filters { padding: 4px 16px 8px; }

.com-doc-cats { display: flex; flex-wrap: wrap; gap: 4px; }

.com-doc-cat, .com-doc-scope {    font-size: 0.68rem; font-weight: 600; cursor: pointer;    border-radius: 2px; padding: 3px 9px;    border: 1px solid #e2e8f0; color: var(--com-mid); background: #f9fafb;    transition: background 0.12s, border-color 0.12s, color 0.12s;    display: inline-flex; align-items: center; gap: 3px;}

.com-doc-cat:hover, .com-doc-scope:hover { border-color: var(--com-teal); color: var(--com-teal); background: var(--com-teal-light); }

.com-doc-cat.active, .com-doc-scope.active { background: var(--com-teal); color: #fff; border-color: var(--com-teal); }

.com-doc-library { overflow-y: auto; max-height: 380px; }

.com-doc-library::-webkit-scrollbar { width: 3px; }

.com-doc-library::-webkit-scrollbar-thumb { background: #c4c9d0; border-radius: 2px; }

.com-doc-lib-item {    display: flex; align-items: center; gap: 10px;    padding: 8px 16px; border-bottom: 1px solid #f3f4f6;    transition: background 0.12s;}

.com-doc-lib-item:last-child { border-bottom: none; }

.com-doc-lib-item:hover { background: #f9fafb; }

.com-doc-lib-icon { font-size: 1.05rem; flex-shrink: 0; color: var(--com-muted); }

.com-doc-lib-info { flex: 1; min-width: 0; }

.com-doc-lib-name {    display: block; font-size: 0.78rem; font-weight: 600; color: var(--com-navy);    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;    text-decoration: none;}

.com-doc-lib-name:hover { color: var(--com-teal); text-decoration: underline; }

.com-doc-lib-meta { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; font-size: 0.66rem; color: var(--com-muted); margin-top: 2px; }

.com-doc-lib-dl {    flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%;    display: flex; align-items: center; justify-content: center;    color: var(--com-muted); background: #f1f3f5;    font-size: 0.78rem; text-decoration: none; transition: background 0.12s, color 0.12s;}

.com-doc-lib-dl:hover { background: var(--com-teal-light); color: var(--com-teal); }

.com-doc-scope-badge {    display: inline-flex; align-items: center; gap: 3px;    font-size: 0.62rem; font-weight: 700; border-radius: 3px; padding: 1px 5px;}

.com-doc-scope-badge-enterprise { background: #eff6ff; color: #2563eb; }

.com-doc-scope-badge-team       { background: #ecfdf5; color: #059669; }

.com-empty-state-sm {    text-align: center; padding: 20px 16px; color: var(--com-muted);}

.com-empty-state-sm i { font-size: 1.4rem; margin-bottom: 6px; display: block; }

.com-empty-state-sm p { font-size: 0.78rem; margin: 0; }

/* == CommunautÃ© : option "non visible manager" ===================== */

.com-manager-hidden-wrap {    background: #fff8f0; border: 1px solid #fde68a; border-radius: var(--com-radius);    padding: 8px 12px;}

.com-manager-hidden-wrap label { font-size: 0.82rem; font-weight: 500; color: #92400e; cursor: pointer; }

.com-manager-hidden-wrap .fa-eye-slash { color: #b45309; }

.com-manager-hidden-hint { font-size: 0.72rem; color: #a16207; margin-top: 3px; }

/* == CommunautÃ© : modal headers colorÃ©s ============================ */

.com-modal-header { color: #fff; }

.com-modal-header .close { color: #fff; opacity: 0.8; }

.com-modal-header-conversation { background: #3b82f6; }

.com-modal-header-event        { background: #10b981; }

.com-modal-header-poll         { background: #8b5cf6; }

.com-modal-header-document     { background: #f59e0b; }

.com-btn-submit-conversation { background: #3b82f6; color: #fff; }

.com-btn-submit-conversation:hover { background: #2563eb; color: #fff; }

.com-btn-submit-event { background: #10b981; color: #fff; }

.com-btn-submit-event:hover { background: #059669; color: #fff; }

.com-btn-submit-poll { background: #8b5cf6; color: #fff; }

.com-btn-submit-poll:hover { background: #7c3aed; color: #fff; }

.com-btn-submit-document { background: #f59e0b; color: #fff; }

.com-btn-submit-document:hover { background: #d97706; color: #fff; }

/* == CommunautÃ© : barre de rÃ©daction bas du drawer ================= */

.com-compose-bar { display: flex; gap: 8px; align-items: flex-start; padding: 0; }
.com-compose-bar .com-activity-avatar { flex-shrink: 0; margin-top: 2px; }
.com-compose-inner { flex: 1; min-width: 0; }
.com-compose-inner .com-reply-textarea { width: 100%; padding: 6px 10px; line-height: 1.4; }
.com-compose-actions { display: flex; align-items: center; gap: 6px; margin-top: 4px; }

.com-compose-tool-btn {    background: none; border: 1px solid #e2e8f0; border-radius: var(--com-radius);    color: var(--com-muted); font-size: 0.85rem; padding: 4px 9px; cursor: pointer;    transition: background 0.12s, border-color 0.12s, color 0.12s;}

.com-compose-tool-btn:hover { background: var(--com-teal-light); border-color: var(--com-teal); color: var(--com-teal); }

.com-poll-create-form, .com-doc-upload-form {    margin: 0 16px 8px; padding: 12px; border-radius: var(--com-radius);}

/* == CommunautÃ© : encadrÃ© source (contenu original du post) ======== */

.com-source-card { margin: 0; padding: 18px 20px 16px; border-bottom: 2px solid transparent; max-height: 42vh; display: flex; flex-direction: column; overflow: hidden; }

.com-source-com-post-type-conversation { background: #eff6ff; border-bottom-color: #3b82f6; }

.com-source-com-post-type-event        { background: #ecfdf5; border-bottom-color: #10b981; }

.com-source-com-post-type-poll         { background: #f5f3ff; border-bottom-color: #8b5cf6; }

.com-source-com-post-type-document     { background: #fffbeb; border-bottom-color: #f59e0b; }

.com-source-meta { display: flex; align-items: center; margin-bottom: 10px; }

.com-source-type-badge {    display: inline-flex; align-items: center; font-size: 0.68rem; font-weight: 700;    text-transform: uppercase; letter-spacing: 0.06em;    border-radius: 3px; padding: 2px 8px;}

.com-source-title {    font-size: 1.02rem; font-weight: 700; color: var(--com-navy);    margin: 0 0 10px; line-height: 1.35;}

.com-source-author-row { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }

.com-source-author-name { font-size: 0.82rem; font-weight: 600; color: var(--com-navy); display: block; }

.com-source-date { font-size: 0.72rem; color: var(--com-muted); }

.com-source-body { font-size: 0.86rem; color: var(--com-mid); line-height: 1.65; background: rgba(255,255,255,0.65); border-radius: var(--com-radius); padding: 10px 14px; flex: 1 1 auto; min-height: 0; overflow-y: scroll; scrollbar-width: thin; scrollbar-color: #b8c4d0 transparent; }
.com-source-body::-webkit-scrollbar { width: 4px; }
.com-source-body::-webkit-scrollbar-track { background: transparent; }
.com-source-body::-webkit-scrollbar-thumb { background: #b8c4d0; border-radius: 4px; }

.com-source-event-date {    display: inline-flex; align-items: center; gap: 6px;    font-size: 0.88rem; font-weight: 600; color: #059669;    margin-bottom: 8px;}

.com-source-poll { margin-top: 6px; }

.com-source-doc-card {    display: flex; align-items: center; gap: 14px;    background: rgba(255,255,255,0.70); border-radius: var(--com-radius);    padding: 12px 14px; margin-top: 6px;}

.com-source-doc-icon { flex-shrink: 0; }

.com-source-doc-info { flex: 1; min-width: 0; }

.com-source-doc-name { font-size: 0.88rem; font-weight: 600; color: var(--com-navy); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.com-source-doc-meta { font-size: 0.72rem; color: var(--com-muted); margin-top: 2px; display: flex; align-items: center; gap: 5px; }

/* == CommunautÃ© : sÃ©parateur ActivitÃ© ============================== */

.com-activity-separator {    display: flex; align-items: center; gap: 10px;    padding: 8px 20px; background: #f8f9fa;    border-top: 1px solid #e9ecef; border-bottom: 1px solid #e9ecef;    flex-shrink: 0;}

.com-activity-separator-label {    font-size: 0.68rem; font-weight: 700; text-transform: uppercase;    letter-spacing: 0.08em; color: var(--com-muted);    display: flex; align-items: center; gap: 6px;}

.com-activity-separator-label i { color: var(--com-teal); }

.com-activity-count {    font-size: 0.68rem; font-weight: 600; background: #e9ecef;    color: var(--com-mid); border-radius: 10px; padding: 1px 7px;}

/* == CommunautÃ© : picker Ã©moji (position:fixed) ==================== */

.com-reaction-picker {    position: fixed; z-index: 1060;    background: #fff; border: 1px solid #e2e8f0; border-radius: 24px;    padding: 6px 10px; box-shadow: 0 4px 16px rgba(0,0,0,0.14);    display: flex; align-items: center; gap: 4px; white-space: nowrap;}

.com-reaction-pick-btn {    font-size: 1.35rem; cursor: pointer; padding: 3px 5px; border-radius: 8px;    transition: transform 0.1s, background 0.1s;    background: none; border: none; line-height: 1;}

.com-reaction-pick-btn:hover { transform: scale(1.25); background: #f1f3f5; }

/* == CommunautÃ© : rÃ©sumÃ© rÃ©actions (chips) ========================= */

.com-reactions-summary {    display: flex; align-items: center; flex-wrap: wrap; gap: 5px;    margin-top: 10px;}

.com-reaction-chip {    display: inline-flex; align-items: center; gap: 3px;    font-size: 0.85rem; cursor: pointer;    background: #f1f3f5; border: 1px solid #e2e8f0; border-radius: 12px;    padding: 2px 8px; transition: background 0.12s, border-color 0.12s;    user-select: none;}

.com-reaction-chip:hover { background: var(--com-teal-light); border-color: var(--com-teal); }

.com-reaction-chip.active { background: var(--com-teal-light); border-color: var(--com-teal); font-weight: 600; }

.com-reaction-chip-count { font-size: 0.72rem; color: var(--com-muted); }

.com-reaction-chip.active .com-reaction-chip-count { color: var(--com-teal); }

.com-reaction-add-btn {    display: inline-flex; align-items: center;    font-size: 1rem; color: #c8d3dd; cursor: pointer;    padding: 2px 6px; border-radius: 12px; border: 1px solid transparent;    transition: color 0.12s, border-color 0.12s, background 0.12s;}

.com-reaction-add-btn:hover { color: var(--com-teal); border-color: var(--com-teal); background: var(--com-teal-light); }

/* == CommunautÃ© : toolbar hover sur les rÃ©ponses =================== */

.com-activity-item:hover /* == CommunautÃ© : panel docs â€” lien "Voir tout" ==================== */

.com-panel-see-all,
a.com-panel-see-all { height: 24px; font-size: 0.65rem; font-weight: 500; color: var(--com-teal) !important; text-decoration: none !important; text-transform: none !important; letter-spacing: 0 !important; white-space: nowrap; display: inline-flex; align-items: center; gap: 4px; border: 1px solid #e5e7eb; border-radius: var(--com-radius); padding: 0 9px; background: #fff; transition: background 0.15s, color 0.15s, border-color 0.15s; }
.com-panel-see-all i { color: inherit !important; width: auto !important; font-size: 0.65rem !important; }

.com-panel-see-all:hover,
a.com-panel-see-all:hover { background: var(--com-teal-light); color: var(--com-teal) !important; border-color: var(--com-teal); text-decoration: none !important; }

.com-docs-see-all-link {    font-size: 0.74rem; font-weight: 600; color: var(--com-teal); text-decoration: none;    display: inline-flex; align-items: center; gap: 5px;}

.com-docs-see-all-link:hover { text-decoration: underline; }

/* == CommunautÃ© : bouton retour header ============================= */

.com-btn-back {    font-size: 0.78rem; font-weight: 600; padding: 6px 14px;    border-radius: var(--com-radius); color: rgba(255,255,255,0.85);    border: 1px solid rgba(255,255,255,0.30); background: rgba(255,255,255,0.12);    display: inline-flex; align-items: center; gap: 5px;    transition: background 0.14s;}

.com-btn-back:hover { background: rgba(255,255,255,0.22); color: #fff; text-decoration: none; }

/* == Base documentaire : page dÃ©diÃ©e =============================== */

.com-docs-page-body { padding: 20px 24px; }

.com-docs-toolbar { margin-bottom: 20px; }

.com-docs-search-wrap {    position: relative; margin-bottom: 12px;}

.com-docs-search-wrap .form-control {    padding-left: 34px; font-size: 0.86rem;    border-radius: var(--com-radius); border: var(--com-border);}

.com-docs-search-icon {    position: absolute; left: 11px; top: 50%; transform: translateY(-50%);    color: var(--com-muted); font-size: 0.80rem; pointer-events: none;}

.com-docs-filters-wrap { display: flex; flex-direction: column; gap: 4px; }

.com-docs-grid { display: flex; flex-direction: column; gap: 0; }

.com-docs-grid-item {    display: flex; align-items: center; gap: 14px;    padding: 12px 0; border-bottom: 1px solid #f3f4f6;    transition: background 0.12s;}

.com-docs-grid-item:last-child { border-bottom: none; }

.com-docs-grid-item:hover { background: #fafbfc; margin: 0 -8px; padding: 12px 8px; }

.com-docs-grid-icon { font-size: 1.4rem; flex-shrink: 0; width: 28px; text-align: center; }

.com-docs-grid-info { flex: 1; min-width: 0; }

.com-docs-grid-name {    display: block; font-size: 0.88rem; font-weight: 600; color: var(--com-navy);    text-decoration: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;}

.com-docs-grid-name:hover { color: var(--com-teal); text-decoration: underline; }

.com-docs-grid-meta {    display: flex; align-items: center; gap: 6px; flex-wrap: wrap;    font-size: 0.70rem; color: var(--com-muted); margin-top: 3px;}

.com-docs-grid-dl {    flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%;    display: flex; align-items: center; justify-content: center;    color: var(--com-muted); background: #f1f3f5;    font-size: 0.82rem; text-decoration: none; transition: background 0.12s, color 0.12s;}

.com-docs-grid-dl:hover { background: var(--com-teal-light); color: var(--com-teal); }

.com-docs-empty-search { text-align: center; padding: 40px; color: var(--com-muted); }

.com-docs-empty-search i { font-size: 2rem; margin-bottom: 12px; display: block; color: #c8d3dd; }

.com-docs-empty-search p { font-size: 0.84rem; }

/* == CommunautÃ© : bouton Base documentaire header ================== */

.com-btn-docs-lib {    background: rgba(255,255,255,0.15); color: rgba(255,255,255,0.90);    border: 1px solid rgba(255,255,255,0.30);}

.com-btn-docs-lib:hover { background: rgba(255,255,255,0.25); color: #fff; text-decoration: none; }

/* == CommunautÃ© : palette corrigÃ©e â€” alignement design system ======   Ancien choix (bleu/vert/violet/orange) remplacÃ© par dÃ©rivÃ©es   navy/teal conformes Ã  la charte : 3 couleurs, mÃªme famille.   Ce bloc surcharge les valeurs prÃ©cÃ©dentes.   ================================================================= *//* Couleurs de rÃ©fÃ©rence :   Conversation : teal      #0d9488  bg #e6f7f5   Ã‰vÃ©nement    : teal-dark #0f766e  bg #e0f4f1   Sondage      : navy      #2D3E50  bg #edf0f3   Document     : slate     #475569  bg #f1f4f7   *//* Boutons action header */

.com-btn-conversation { background: #0d9488 !important; }

.com-btn-event        { background: #0f766e !important; }

.com-btn-poll         { background: #2D3E50 !important; }

.com-btn-document     { background: #475569 !important; }

/* Stripes latÃ©rales post-item */

.com-post-type-conversation .com-post-type-stripe { background: #0d9488 !important; }

.com-post-type-event        .com-post-type-stripe { background: #0f766e !important; }

.com-post-type-poll         .com-post-type-stripe { background: #2D3E50 !important; }

.com-post-type-document     .com-post-type-stripe { background: #475569 !important; }

/* Fond du post-item par type */

.com-post-type-conversation { background: #f0fafa; color: var(--com-navy); }

.com-post-type-event        { background: #f0f5f4; color: var(--com-navy); }

.com-post-type-poll         { background: #edf0f3; color: var(--com-navy); }

.com-post-type-document     { background: #f1f4f7; color: var(--com-navy); }

/* Badges de type (tags colorÃ©s) */

.com-post-type-conversation-tag { background: #e6f7f5 !important; color: #0d9488 !important; border-color: #99d0cb !important; }

.com-post-type-event-tag        { background: #e0f4f1 !important; color: #0f766e !important; border-color: #8ec9c2 !important; }

.com-post-type-poll-tag         { background: #edf0f3 !important; color: #2D3E50 !important; border-color: #b8c5d0 !important; }

.com-post-type-document-tag     { background: #f1f4f7 !important; color: #475569 !important; border-color: #c4cdd8 !important; }

/* Bordure supÃ©rieure header drawer par type */

.com-post-type-conversation-header { border-top-color: #0d9488 !important; }

.com-post-type-event-header         { border-top-color: #0f766e !important; }

.com-post-type-poll-header          { border-top-color: #2D3E50 !important; }

.com-post-type-document-header      { border-top-color: #475569 !important; }

/* EncadrÃ© source drawer */

.com-source-com-post-type-conversation { background: #f0fafa !important; border-bottom-color: #0d9488 !important; }

.com-source-com-post-type-event        { background: #f0f5f4 !important; border-bottom-color: #0f766e !important; }

.com-source-com-post-type-poll         { background: #edf0f3 !important; border-bottom-color: #2D3E50 !important; }

.com-source-com-post-type-document     { background: #f1f4f7 !important; border-bottom-color: #475569 !important; }

.com-source-event-date { color: #0f766e !important; }

/* Modal headers */

.com-modal-header-conversation { background: #0d9488 !important; }

.com-modal-header-event        { background: #0f766e !important; }

.com-modal-header-poll         { background: #2D3E50 !important; }

.com-modal-header-document     { background: #475569 !important; }

/* Boutons de soumission modals */

.com-btn-submit-conversation { background: #0d9488 !important; }

.com-btn-submit-conversation:hover { background: #0b7c72 !important; }

.com-btn-submit-event { background: #0f766e !important; }

.com-btn-submit-event:hover { background: #0a5f59 !important; }

.com-btn-submit-poll { background: #2D3E50 !important; }

.com-btn-submit-poll:hover { background: #243343 !important; }

.com-btn-submit-document { background: #475569 !important; }

.com-btn-submit-document:hover { background: #374151 !important; }

/* == CommunautÃ© : barre d'actions ================================== */

.com-action-bar {    display: flex; align-items: center; justify-content: space-between;    padding: 10px 20px; background: #fff;    border-bottom: 1px solid #e9ecef;    flex-wrap: wrap; gap: 8px;}

.com-action-bar-create { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.com-action-bar-docs {    display: inline-flex; align-items: center; gap: 5px;    font-size: 0.78rem; font-weight: 600; color: var(--com-muted);    border: 1px solid #e2e8f0; border-radius: var(--com-radius);    padding: 5px 12px; text-decoration: none; background: #f9fafb;    transition: color 0.12s, border-color 0.12s, background 0.12s;}

.com-action-bar-docs:hover { color: var(--com-teal); border-color: var(--com-teal); background: var(--com-teal-light); text-decoration: none; }

/* == Base documentaire : lignes cliquables ========================= */

.com-docs-grid-item { cursor: pointer; }

.com-docs-grid-item.com-doc-selected { background: var(--com-teal-light); margin: 0 -8px; padding: 12px 8px; }

/* == CommunautÃ© : Option A â€” palette 4 types muted/earthy =========   Conversation : bleu-acier sobre  #4b7bb5  bg #eef2f8   Ã‰vÃ©nement    : vert-sauge        #4d8c6f  bg #eef4f1   Sondage      : mauve-gris        #6b5fa5  bg #f0eef7   Document     : amber-terracotta  #a07840  bg #f7f0e8   Surcharge le bloc DS monochrome prÃ©cÃ©dent.   ================================================================= *//* Boutons action bar */

.com-btn-conversation { background: #4b7bb5 !important; }

.com-btn-event        { background: #4d8c6f !important; }

.com-btn-poll         { background: #6b5fa5 !important; }

.com-btn-document     { background: #a07840 !important; }

/* Stripes latÃ©rales post-item */

.com-post-type-conversation .com-post-type-stripe { background: #4b7bb5 !important; }

.com-post-type-event        .com-post-type-stripe { background: #4d8c6f !important; }

.com-post-type-poll         .com-post-type-stripe { background: #6b5fa5 !important; }

.com-post-type-document     .com-post-type-stripe { background: #a07840 !important; }

/* Fond du post-item par type */

.com-post-type-conversation { background: #eef2f8 !important; }

.com-post-type-event        { background: #eef4f1 !important; }

.com-post-type-poll         { background: #f0eef7 !important; }

.com-post-type-document     { background: #f7f0e8 !important; }

/* Badges de type */

.com-post-type-conversation-tag { background: #eef2f8 !important; color: #4b7bb5 !important; border-color: #b0c4de !important; }

.com-post-type-event-tag        { background: #eef4f1 !important; color: #4d8c6f !important; border-color: #a8cbb9 !important; }

.com-post-type-poll-tag         { background: #f0eef7 !important; color: #6b5fa5 !important; border-color: #bdb5d8 !important; }

.com-post-type-document-tag     { background: #f7f0e8 !important; color: #a07840 !important; border-color: #d4bc94 !important; }

/* Bordure supÃ©rieure header drawer par type */

.com-post-type-conversation-header { border-top-color: #4b7bb5 !important; }

.com-post-type-event-header        { border-top-color: #4d8c6f !important; }

.com-post-type-poll-header         { border-top-color: #6b5fa5 !important; }

.com-post-type-document-header     { border-top-color: #a07840 !important; }

/* EncadrÃ© source drawer */

.com-source-com-post-type-conversation { background: #eef2f8 !important; border-bottom-color: #4b7bb5 !important; }

.com-source-com-post-type-event        { background: #eef4f1 !important; border-bottom-color: #4d8c6f !important; }

.com-source-com-post-type-poll         { background: #f0eef7 !important; border-bottom-color: #6b5fa5 !important; }

.com-source-com-post-type-document     { background: #f7f0e8 !important; border-bottom-color: #a07840 !important; }

.com-source-event-date { color: #4d8c6f !important; }

/* Modal headers */

.com-modal-header-conversation { background: #4b7bb5 !important; }

.com-modal-header-event        { background: #4d8c6f !important; }

.com-modal-header-poll         { background: #6b5fa5 !important; }

.com-modal-header-document     { background: #a07840 !important; }

/* Boutons de soumission modals */

.com-btn-submit-conversation       { background: #4b7bb5 !important; }

.com-btn-submit-conversation:hover { background: #3d6699 !important; }

.com-btn-submit-event              { background: #4d8c6f !important; }

.com-btn-submit-event:hover        { background: #3d7059 !important; }

.com-btn-submit-poll               { background: #6b5fa5 !important; }

.com-btn-submit-poll:hover         { background: #574d8a !important; }

.com-btn-submit-document           { background: #a07840 !important; }

.com-btn-submit-document:hover     { background: #866535 !important; }

/* == CommunautÃ© : ancrage type-badge Ã  droite ======================   Le type-tag est maintenant dernier dans .com-post-item-badges.   justify-content: flex-end garantit l'ancrage bord droit.   .com-post-actions a un min-width fixe pour stabiliser la position   du type-tag mÃªme quand pin/poubelle sont prÃ©sents.   ================================================================= */

.com-post-item-badges { justify-content: flex-end !important; }

.com-post-actions { min-width: 56px; justify-content: flex-end; }

/* == CommunautÃ© : type-badge en haut Ã  droite, meta en dessous =====   Remplace le layout flex horizontal badges+actions par une colonne   droite (com-post-item-right) : badge en haut, bottom-row en bas.   ================================================================= */

.com-post-item-header { align-items: flex-start !important; }

.com-post-item-author { padding-top: 1px; }

.com-post-item-right {    display: flex;    flex-direction: column;    align-items: flex-end;    gap: 5px;    flex-shrink: 0;    min-width: 0;}

.com-post-item-right-bottom {    display: flex;    align-items: center;    gap: 4px;    min-height: 22px;}

/* Annule les surcharges du bloc prÃ©cÃ©dent qui ne s'appliquent plus */

.com-post-item-badges { justify-content: initial !important; }

.com-post-actions { min-width: 0 !important; }

/* == Base documentaire : design system (sp-item-row style) =========   InspirÃ© de l'onglet Documents des Projets.   Carte blanche, border-radius 2px, micro-ombre, actions au hover.   ================================================================= *//* Corps de page */

.com-docs-page-body { padding: 20px 24px; max-width: 960px; }

/* Barre de filtres â€” card lÃ©gÃ¨re */

.com-docs-toolbar {    display: flex; align-items: flex-start; gap: 16px; flex-wrap: wrap;    background: #fff;    border: 1px solid #e2e8f0;    border-radius: 2px;    box-shadow: 0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);    padding: 12px 16px;    margin-bottom: 12px;}

.com-docs-search-wrap {    position: relative; flex-shrink: 0; width: 220px;}

.com-docs-search-icon {    position: absolute; left: 9px; top: 50%; transform: translateY(-50%);    font-size: 0.72rem; color: #8fa1b3; pointer-events: none;}

.com-docs-toolbar input {    width: 100%; padding: 5px 10px 5px 28px;    font-size: 0.78rem; color: #2D3E50;    border: 1px solid #e2e8f0; border-radius: 2px;    background: #f9fafb; outline: none;    transition: border-color 0.12s, background 0.12s;}

.com-docs-toolbar input:focus { border-color: #0d9488; background: #fff; }

.com-docs-filters-wrap { display: flex; flex-direction: column; gap: 6px; flex: 1; }

/* Section liste â€” card DS */

.com-docs-section {    background: #fff;    border: 1px solid #e2e8f0;    border-radius: 2px;    box-shadow: 0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);    overflow: hidden;}

/* Ligne de document */

.com-docs-row {    display: flex; align-items: center; gap: 12px;    padding: 9px 16px;    border-bottom: 1px solid #f3f4f6;    cursor: pointer; position: relative;    transition: background 0.10s;}

.com-docs-row:last-child { border-bottom: none; }

.com-docs-row:hover { background: #fafafa; }

.com-docs-row.com-doc-selected { background: #e6f7f5; }

/* IcÃ´ne de fichier â€” nue, sans conteneur */

.com-docs-row-icon { flex-shrink: 0; width: 20px; text-align: center; font-size: 1rem; }

/* Corps de ligne */

.com-docs-row-body { flex: 1; min-width: 0; }

.com-docs-row-name {    font-size: 0.79rem; font-weight: 500; color: #2D3E50;    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;}

.com-docs-row-meta {    display: flex; align-items: center; flex-wrap: wrap; gap: 4px;    font-size: 0.68rem; color: #8fa1b3; margin-top: 2px;}

.com-docs-row-sep { color: #c4cdd8; }

/* Actions â€” invisibles par dÃ©faut, apparaissent au hover */

.com-docs-row-actions {    display: flex; align-items: center; gap: 4px;    flex-shrink: 0; opacity: 0;    transition: opacity 0.12s;}

.com-docs-row:hover .com-docs-row-actions { opacity: 1; }

.com-docs-row.com-doc-selected .com-docs-row-actions { opacity: 1; }

.com-docs-row-btn {    display: inline-flex; align-items: center; justify-content: center;    width: 26px; height: 26px; border-radius: 2px;    border: 1px solid #e5e7eb; background: #fff;    color: #8fa1b3; font-size: 0.72rem; cursor: pointer;    text-decoration: none; transition: color 0.12s, border-color 0.12s, background 0.12s;}

.com-docs-row-btn:hover { color: #0d9488; border-color: #0d9488; background: #e6f7f5; }

/* Empty states dans la section */

.com-docs-section .sp-empty-state { padding: 40px 20px; }

.com-docs-empty-search { padding: 32px 20px; text-align: center; }

.com-docs-empty-search .sp-empty-state-icon,.com-docs-empty-search .sp-empty-state-title,.com-docs-empty-search .sp-empty-state-hint { display: block; }

/* == CommunautÃ© : scroll interne colonnes + items compacts ==========   ================================================================= *//* Colonnes â€” hauteur fixe pour scroll interne (header 64 + action 52 + switcher 42 = 158px) */

.com-columns {    height: calc(100vh - 160px) !important;    min-height: 0 !important;    overflow: hidden;    align-items: stretch;}

.com-col-feed {    display: flex !important;    flex-direction: column;    overflow: hidden !important;    padding-bottom: 0 !important;}

.com-filters { flex-shrink: 0; }

.com-feed-list {    flex: 1;    min-height: 0;    overflow-y: auto;    overflow-x: hidden;    padding: 12px 16px;}

/* Retire le padding direct de la col qui est maintenant sur le feed-list */

.com-col-feed { padding: 0 !important; }

/* Scrollbar DS â€” feed gauche */

.com-feed-list::-webkit-scrollbar { width: 3px; background: transparent; }

.com-feed-list::-webkit-scrollbar-track { background: transparent; border: none; }

.com-feed-list::-webkit-scrollbar-thumb { background: transparent; border-radius: 4px; transition: background 0.25s; }

.com-feed-list.ctx-scrolling::-webkit-scrollbar-thumb,.com-feed-list.ctx-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0; }

.com-feed-list::-webkit-scrollbar-thumb:hover { background: #9ca3af !important; }

.com-feed-list { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.com-feed-list.ctx-scrolling,.com-feed-list.ctx-scrollbar-hover { scrollbar-color: #c4c9d0 transparent; }

/* Scrollbar DS â€” panneau droit (remplace la version basique) */

.com-col-right::-webkit-scrollbar { width: 3px !important; background: transparent !important; }

.com-col-right::-webkit-scrollbar-track { background: transparent !important; border: none !important; }

.com-col-right::-webkit-scrollbar-thumb { background: transparent !important; border-radius: 4px; transition: background 0.25s; }

.com-col-right.ctx-scrolling::-webkit-scrollbar-thumb,.com-col-right.ctx-scrollbar-hover::-webkit-scrollbar-thumb { background: #c4c9d0 !important; }

.com-col-right::-webkit-scrollbar-thumb:hover { background: #9ca3af !important; }

.com-col-right { scrollbar-width: thin !important; scrollbar-color: transparent transparent !important; }

.com-col-right.ctx-scrolling,.com-col-right.ctx-scrollbar-hover { scrollbar-color: #c4c9d0 transparent !important; }

/* Post items â€” plus compacts */

.com-post-item { margin-bottom: 8px !important; }

.com-post-item-header { padding: 7px 12px !important; gap: 8px !important; }

.com-post-item-body { padding: 6px 12px 8px !important; }

.com-post-title { font-size: 0.82rem !important; margin-bottom: 2px !important; }

.com-post-preview { font-size: 0.73rem !important; -webkit-line-clamp: 1 !important; }

.com-post-author { font-size: 0.75rem !important; }

.com-post-date { font-size: 0.67rem !important; }

.com-post-type-tag { font-size: 0.64rem !important; padding: 1px 6px !important; }

.com-post-new-badge { font-size: 0.60rem !important; padding: 1px 5px !important; }

.com-post-replies { font-size: 0.67rem !important; }

/* Badge "Nouveau" â€” alignement dans la ligne haute */

.com-post-item-right-top { display: flex; align-items: center; gap: 4px; }

/* Retire padding-top 1px sur author (ajoutÃ© pour align-items: flex-start) */

.com-post-item-author { padding-top: 0 !important; align-items: center; }

/* == Base documentaire : fond blanc ================================ */

#main-content-community-docs { background: #fff !important; }

/* == CommunautÃ© : fix hauteur colonnes pour scroll interne ==========   Bootstrap col-md-* ne propage pas la height du row parent   sans height: 100% explicite sur les enfants.   ================================================================= */

.com-columns { flex-wrap: nowrap !important; }

.com-col-feed  { height: 100% !important; }

.com-col-right { height: 100% !important; }

/* == CommunautÃ© : suppression traits gris + alignement colonne droite   - border-right de com-col-feed : trait visible Ã  gauche des panneaux   - padding-top de com-col-right : espace vide au-dessus de la 1re carte   ================================================================= */

.com-col-feed  { border-right: none !important; }

.com-col-right { padding-top: 0 !important; padding-left: 12px !important; padding-right: 12px !important; }

/* == CommunautÃ© : alignement bord droit filtres / post items ========   com-filters est bord Ã  bord (col padding=0), com-feed-list a 16px   de padding horizontal. On donne le mÃªme inset aux filtres.   ================================================================= */

.com-filters { margin: 12px 16px 10px !important; }

/* == CommunautÃ© : suppression trait sous les onglets switcher ======= */

.com-switcher-bar { border-bottom: none !important; box-shadow: none !important; }

/* == CommunautÃ© : alignement bord droit filtres/items + haut colonnes   Padding horizontal sur com-col-feed (pas sur les enfants) â†’ mÃªme   bord droit pour filtres et post-items malgrÃ© la scrollbar 3px.   padding-top sur com-col-right = margin-top des filtres = 12px.   ================================================================= */

.com-col-feed  { padding: 0 16px !important; }

.com-filters   { margin: 12px 0 10px !important; }

.com-feed-list { padding: 0 !important; }

.com-col-right { padding-top: 12px !important; }

/* == CommunautÃ© : boutons d'ajout centrÃ©s dans le header =========== */

.com-page-header { position: relative; }

.com-header-center {    position: absolute; left: 50%; transform: translateX(-50%);    display: flex; align-items: center; gap: 8px;}

/* == CommunautÃ© : bord droit boutons header alignÃ© sur post-items ==   right: 33.333% (col-md-4) + 16px (padding com-col-feed)   ancre le bord DROIT du groupe de boutons au mÃªme x que le bord   droit de la zone de filtre et des Ã©lÃ©ments de liste.   ================================================================= */

.com-header-center {    position: absolute;    right: calc(33.333% + 16px);    left: auto !important;    transform: none !important;}

/* == CommunautÃ© : suppression barre gauche "nouveau" + fix Ã©pinglÃ© ==   1. border-left sur com-post-unread supprimÃ© (doublon avec la stripe)   2. Fond bleu header Ã©pinglÃ© remplacÃ© par ombre renforcÃ©e + liserÃ© top   ================================================================= */

.com-post-item.com-post-unread { border-left: none !important; }

.com-post-item.com-post-pinned .com-post-item-header { background: inherit !important; }

.com-post-item.com-post-pinned {    box-shadow: 0 2px 10px rgba(0,0,0,0.13), 0 1px 3px rgba(0,0,0,0.07) !important;    border-top: 2px solid rgba(13,148,136,0.35) !important;}

/* == CommunautÃ© : compensation scrollbar 3px pour alignement droit ==   La scrollbar de com-feed-list rÃ©duit le contenu de 3px Ã  droite.   Post-items right edge = col right - 16px (padding) - 3px (scrollbar).   On dÃ©cale filtres et boutons header de 3px supplÃ©mentaires.   ================================================================= */

.com-filters { margin-right: 19px !important; }

.com-header-center { right: calc(33.333% + 19px) !important; }

/* == CommunautÃ© : alignement droit â€” approche dÃ©finitive ============   Scrollbar toujours rÃ©servÃ©e (overflow-y:scroll) â†’ espace constant 3px.   Post-items right = col right - 16px (padding col) - 3px (scrollbar) = col right - 19px.   Filtre   : margin-right: 3px dans le content area â†’ col right - 16 - 3 = col right - 19px. âœ“   Bouton   : right: calc(33.333% + 19px) depuis la droite du header. âœ“   ================================================================= */

.com-feed-list { overflow-y: scroll !important; }

.com-filters   { margin-right: 3px !important; }

.com-header-center { right: calc(33.333% + 19px) !important; }

/* â”€â”€ Community : carte Ã©vÃ©nement Ã  venir â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-event-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-bottom: 1px solid #f3f4f6;
    cursor: pointer;
    transition: background 0.10s;
}
.com-event-card:last-child { border-bottom: none; }
.com-event-card:hover { background: #f8fafc; }
.com-event-date-chip {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    background: rgba(77,140,111,0.12);
    border-radius: 4px;
    padding: 3px 5px;
    flex-shrink: 0;
}
.com-event-day {
    font-size: 0.9rem;
    font-weight: 700;
    color: #4d8c6f;
    line-height: 1;
}
.com-event-month {
    font-size: 0.58rem;
    font-weight: 600;
    color: #4d8c6f;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.com-event-info { flex: 1; min-width: 0; }
.com-event-title {
    font-size: 0.77rem;
    font-weight: 500;
    color: #2D3E50;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.com-event-time {
    font-size: 0.68rem;
    color: #8fa1b3;
    margin-top: 2px;
}
/* â”€â”€ Community : barre d'actions sous les onglets â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-action-bar {    display: flex;    align-items: center;    gap: 8px;    flex-shrink: 0;    padding: 12px 0 0;    margin-right: 3px;}

/* â”€â”€ Community : alignement bord droit barre actions + filtres â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   com-feed-list rÃ©serve toujours 3px pour la scrollbar (overflow-y:scroll).
   Les post-items s'arrÃªtent donc Ã  (col width - 3px).
   com-action-bar et com-filters doivent avoir le mÃªme inset droit = 3px.
   On neutralise aussi les anciens styles parasites de com-action-bar.
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-action-bar {
    background: transparent !important;
    border: none !important;
    padding: 10px 0 0 !important;
    margin-right: 3px !important;
    justify-content: flex-start !important;
}
.com-filters { margin-right: 3px !important; }
/* â”€â”€ Community : correction hauteur colonnes + action-bar + boutons â”€â”€â”€â”€â”€â”€â”€   La barre d'actions est maintenant DANS la colonne, pas au-dessus.   Ancienne calc : header 64 + action 52 + switcher 42 = 158 â†’ 160px.   Nouvelle calc : header 64 + switcher 42 = 106 â†’ 110px.   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

.com-columns { height: calc(100vh - 110px) !important; }

/* Barre d'actions : rassemblÃ©e Ã  gauche, sans fond ni bordure */

.com-action-bar {    justify-content: flex-start !important;    background: transparent !important;    border: none !important;    padding: 10px 0 0 !important;    margin-right: 3px !important;    flex-wrap: nowrap !important;}

/* 4 boutons de mÃªme largeur */

.com-action-bar .com-btn-action {    flex: 0 0 auto;    min-width: 128px;    justify-content: center;    text-align: center;}

/* â”€â”€ Community : couleurs icÃ´nes titres panneaux droits â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-panel-icon-poll     { color: #6b5fa5; }
.com-panel-icon-event    { color: #4d8c6f; }
.com-panel-icon-document { color: #a07840; }

/* â”€â”€ Community : trait gris collÃ© Ã  droite du scrollbar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-feed-list { border-right: 1px solid #e2e8f0; }
/* â”€â”€ Community : trait sous titre des panneaux droits colorÃ© par type â”€â”€â”€â”€ */

.com-panel-poll     .com-panel-title { border-bottom-color: #6b5fa5; }

.com-panel-event    .com-panel-title { border-bottom-color: #4d8c6f; }

.com-panel-document .com-panel-title { border-bottom-color: #a07840; }

/* â”€â”€ Community : icÃ´nes format fichier attÃ©nuÃ©es dans panneau Documents rÃ©cents â”€
   On neutralise les couleurs vives (PDF rouge, Excel vertâ€¦) uniquement dans
   la carte du panneau droit. La base documentaire conserve ses couleurs. */
.com-panel-document .com-doc-icon i { color: #8fa1b3 !important; }
/* â”€â”€ Community : couleurs icÃ´nes titres panneaux â€” override com-panel-title i â”€ */

.com-panel-poll     .com-panel-title i.com-panel-icon-poll     { color: #6b5fa5 !important; }

.com-panel-event    .com-panel-title i.com-panel-icon-event    { color: #4d8c6f !important; }

.com-panel-document .com-panel-title i.com-panel-icon-document { color: #a07840 !important; }

/* â”€â”€ Community : header post-item ligne unique + compacitÃ© â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   com-post-item-right : plus de colonne Ã  deux niveaux, tout sur une ligne.
   com-post-item-header : padding rÃ©duit pour une ligne de titre plus fine. */
.com-post-item-header {
    padding: 5px 10px !important;
    min-height: 0 !important;
    align-items: center !important;
}
.com-post-item-right {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 5px !important;
    flex-shrink: 0;
}
/* â”€â”€ Community : barres de progression sondages en violet type-poll â”€â”€â”€â”€â”€â”€â”€ */

.com-poll-bar { background: #6b5fa5 !important; }

/* â”€â”€ Community : icÃ´ne format document dans l'aperÃ§u du fil â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Couleur unifiÃ©e type Document + fond jaune pÃ¢le attÃ©nuÃ©. */
.com-post-doc-preview i {
    color: #a07840 !important;
    background: rgba(160, 120, 64, 0.10);
    padding: 2px 4px;
    border-radius: 3px;
    font-size: 0.70rem !important;
    vertical-align: middle;
}
/* â”€â”€ Community : carte Membres fixÃ©e en bas de la colonne droite â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€   com-col-right en flex-column, margin-top: auto pousse Membres vers le bas. */

.com-col-right {    display: flex !important;    flex-direction: column !important;}

.com-col-right .com-panel:last-child {    margin-top: auto !important;    margin-bottom: 0 !important;}

/* â”€â”€ Community : icÃ´nes doc dans carte Documents rÃ©cents â€” fond jaune pÃ¢le â”€
   Override du prÃ©cÃ©dent gris (#8fa1b3) vers la couleur type Document. */
.com-panel-document .com-doc-icon i {
    color: #a07840 !important;
    background: rgba(160, 120, 64, 0.10) !important;
    padding: 4px 5px !important;
    border-radius: 4px !important;
    font-size: 0.80rem !important;
}

/* â”€â”€ Community : bouton Supprimer en bas Ã  droite de l'Ã©lÃ©ment â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-post-item-footer {
    display: flex;
    justify-content: flex-end;
    padding: 0 10px 5px;
}
.com-post-item-footer .com-post-action-delete {
    opacity: 0;
    transition: opacity 0.15s;
}
.com-post-item:hover .com-post-item-footer .com-post-action-delete { opacity: 1; }
/* â”€â”€ Community : listes scrollables des cartes panneau droit â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€   MÃªme pattern que ctx-section-list dans l'onglet Contexte.   max-height calibrÃ©e pour ~2 Ã©lÃ©ments visibles par type. */

.com-panel-list {    overflow-y: auto;    padding-top: 2px;    padding-bottom: 2px;}

.com-panel-list-poll  { max-height: 260px; } /* ~2 sondages (variables en hauteur) */

.com-panel-list-event { max-height: 112px; } /* ~2 Ã©vÃ©nements (~52px chacun)       */

.com-panel-list-doc   { max-height: 120px; } /* ~2 documents  (~56px chacun)        *//* Scrollbar interne â€” 3px, transparente par dÃ©faut, visible au survol du panneau */

.com-panel-list::-webkit-scrollbar              { width: 3px; }

.com-panel-list::-webkit-scrollbar-track        { background: transparent; }

.com-panel-list::-webkit-scrollbar-thumb        { background: transparent; border-radius: 3px; transition: background 0.2s; }

.com-panel:hover .com-panel-list::-webkit-scrollbar-thumb { background: #c4c9d0; }

.com-panel-list::-webkit-scrollbar-thumb:hover  { background: #9ca3af; }

.com-panel-list { scrollbar-width: thin; scrollbar-color: transparent transparent; }

.com-panel:hover .com-panel-list { scrollbar-color: #c4c9d0 transparent; }

/* Chevron â€” rotation 180Â° Ã  l'Ã©tat expanded */

.com-panel.com-panel-expanded .ctx-expand-btn { background: var(--ctx-teal-light); color: var(--ctx-teal); border-color: var(--ctx-teal); }

.com-panel.com-panel-expanded .ctx-expand-btn i { transform: rotate(180deg); }

.com-panel .ctx-expand-btn i { transition: transform 0.22s ease; }

/* â”€â”€ Community : correctifs scroll panneau droit â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   1/ flex-shrink: 0 sur chaque panneau â†’ les panneaux prennent leur hauteur
      naturelle et dÃ©bordent dans com-col-right (overflow-y: auto = scroll).
   2/ max-heights augmentÃ©es pour que les 2 Ã©lÃ©ments soient TOTALEMENT visibles.
   3/ Panneau expanded â†’ max-height none sans compression.
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-col-right .com-panel { flex-shrink: 0; }

/* max-heights recalibrÃ©es (padding liste 2px Ã— 2 inclus) */
.com-panel-list-event { max-height: 124px !important; } /* 2 Ã— ~56px + 12px marge */
.com-panel-list-doc   { max-height: 132px !important; } /* 2 Ã— ~60px + 12px marge */
.com-panel-list-poll  { max-height: 280px !important; } /* 2 sondages variables  *//* Ã‰tat expanded : hauteur libre */
.com-panel.com-panel-expanded .com-panel-list {
    max-height: none !important;
    overflow-y: visible !important;
}
/* â”€â”€ Community : stack d'avatars membres dans le header â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€   Avatars superposÃ©s (-8px margin-left), bague blanche sur fond navy,   badge +N pour le surplus. */

.com-header-members {    display: flex;    align-items: center;    flex-direction: row-reverse; /* derniers avatars derriÃ¨re les premiers */    margin-right: 8px;}

.com-header-avatar {    margin-left: -8px;    position: relative;    flex-shrink: 0;}

.com-header-avatar img,.com-header-avatar .user-picture-sm {    width: 26px !important;    height: 26px !important;    border-radius: 50% !important;    border: 2px solid rgba(255,255,255,0.30) !important;    display: block !important;    transition: transform 0.12s;}

.com-header-avatar:hover img,.com-header-avatar:hover .user-picture-sm { transform: translateY(-2px); z-index: 10; }

.com-header-avatar-more {    flex-shrink: 0;    width: 26px;    height: 26px;    border-radius: 50%;    background: rgba(255,255,255,0.15);    border: 2px solid rgba(255,255,255,0.30);    color: rgba(255,255,255,0.85);    font-size: 0.58rem;    font-weight: 700;    display: flex;    align-items: center;    justify-content: center;    margin-left: -8px;}

/* Annule le margin-top: auto sur le dernier panneau (carte Membres supprimÃ©e) */

.com-col-right .com-panel:last-child { margin-top: 0 !important; }

/* â”€â”€ Community : sondage â€” 1 seul visible par dÃ©faut (poll cards plus denses) */
.com-panel-list-poll { max-height: 145px !important; }

/* â”€â”€ Community : popover liste membres â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-popover-members {
    min-width: 170px;
    max-height: 220px;
    overflow-y: auto;
    padding: 2px 0;
}
.com-popover-members-title {
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #8fa1b3;
    margin-bottom: 6px;
    padding-bottom: 5px;
    border-bottom: 1px solid #f0f2f5;
}
.com-popover-member {
    font-size: 0.75rem;
    color: #2D3E50;
    padding: 3px 0;
    display: flex;
    align-items: center;
    gap: 5px;
}
.com-popover-member i { color: #8fa1b3; font-size: 0.70rem; }
/* == Community : avatar stack inline dans meta row ===================== */
.com-page-header-meta .com-header-members {
    margin-right: 0;
    margin-left: 4px;
    flex-direction: row-reverse;
}
.com-page-header-meta .com-header-avatar { margin-left: -5px; }
.com-page-header-meta .com-header-avatar img,
.com-page-header-meta .com-header-avatar .user-picture-sm {
    width: 18px !important;
    height: 18px !important;
    border: 1.5px solid rgba(255,255,255,0.30) !important;
}
.com-page-header-meta .com-header-avatar-more {
    width: 18px;
    height: 18px;
    margin-left: -5px;
    font-size: 0.50rem;
}

/* == Community : bouton suppression sans ligne dÃ©diÃ©e (position absolue) */
.com-post-item-footer {
    position: absolute !important;
    bottom: 3px;
    right: 10px;
    padding: 0 !important;
    display: block !important;
}
/* == Community : fix avatar stack taille rÃ©elle (macro gÃ©nÃ¨re .circled 30px) */
.com-page-header-meta .com-header-avatar .circled {
    width: 18px !important;
    height: 18px !important;
    margin-right: 0 !important;
    background: transparent !important;
    border: 1.5px solid rgba(255,255,255,0.45) !important;
    line-height: 17px !important;
    font-size: 0.42rem !important;
    overflow: hidden;
}
.com-page-header-meta .com-header-avatar .circled img {
    width: 18px !important;
    height: 18px !important;
    object-fit: cover;
    border-radius: 50% !important;
}
.com-page-header-meta .com-header-avatar .circled .pt-1 {
    padding: 0 !important;
    line-height: 16px !important;
    color: rgba(255,255,255,0.85) !important;
}

/* == Community : avatars plus compacts dans le fil et le drawer (30 â†’ 24px) == */
.com-post-item-author .circled,
.com-source-author-row .circled,
.com-activity-avatar .circled {
    width: 24px !important;
    height: 24px !important;
    line-height: 22px !important;
    font-size: 0.60rem !important;
    flex-shrink: 0;
}
.com-post-item-author .circled img,
.com-source-author-row .circled img,
.com-activity-avatar .circled img {
    width: 22px !important;
    height: 22px !important;
}
.com-post-item-author .circled .pt-1,
.com-source-author-row .circled .pt-1,
.com-activity-avatar .circled .pt-1 {
    padding: 0 !important;
    line-height: 22px !important;
}

/* == Community : couleur panel Conversation */
.com-panel-conversation .com-panel-title { border-bottom-color: var(--com-teal) !important; }
.com-panel-icon-conversation { color: var(--com-teal) !important; }

/* == Community : carte conversation */
.com-panel-list-conv { max-height: 110px !important; }
.com-conv-card {
    padding: 6px 10px;
    cursor: pointer;
    border-bottom: 1px solid #f0f4f8;
    transition: background 0.12s;
}
.com-conv-card:last-child { border-bottom: none; }
.com-conv-card:hover { background: #f5f8fc; }
.com-conv-title {
    font-size: 0.78rem;
    font-weight: 500;
    color: #2d3748;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.com-conv-meta {
    font-size: 0.70rem;
    color: #8fa1b3;
    display: flex;
    align-items: center;
    gap: 3px;
    margin-top: 2px;
}
.com-conv-author { color: #607d8b; font-weight: 500; }
.com-conv-replies { color: var(--com-teal); }

/* == Community : empty state panels droite */
.com-panel-empty {
    padding: 14px 16px 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 4px;
}
.com-panel-empty-icon {
    font-size: 1.4rem;
    color: #d1dce8;
    margin-bottom: 2px;
    display: block;
}
.com-panel-empty-title {
    font-size: 0.76rem;
    font-weight: 500;
    color: #8fa1b3;
    line-height: 1.3;
}
.com-panel-empty-hint {
    font-size: 0.68rem;
    color: #adbdcc;
    line-height: 1.5;
    max-width: 200px;
}
/* == Community : aÃ©ration header/onglets/actions/filtres ============== *//* Onglets switcher : plus de respiration verticale */
.com-switcher-tab { padding: 13px 18px !important; }

/* Colonnes : ajuste le calc pour la hauteur de l'onglet switcher Ã©largie */
.com-columns { height: calc(100vh - 116px) !important; }

/* Action bar : espace au-dessus et en-dessous des boutons */
.com-action-bar { padding: 16px 0 10px !important; }

/* Filtres : espace sous la barre de filtres avant le fil */
.com-filters { margin-bottom: 14px !important; }

/* == Community : carte DerniÃ¨res conversations â€” mÃªme hauteur qu'Ã‰vÃ©nements */
.com-panel-list-conv { max-height: 124px !important; }

/* == Community : couleur type Conversation sur le panneau droit */
.com-panel-conversation .com-panel-title { border-bottom-color: #4b7bb5 !important; }
.com-panel-conversation .com-panel-title .com-panel-icon-conversation { color: #4b7bb5 !important; }
.com-conv-replies { color: #4b7bb5 !important; }
/* == Community feed : badges type mÃªme largeur ======================== */
.com-post-type-tag {
    min-width: 102px !important;
    justify-content: center !important;
}

/* == Community feed : icÃ´ne "non visible manager" ===================== */
.com-post-hidden-badge {
    display: inline-flex;
    align-items: center;
    font-size: 0.72rem;
    color: #8fa1b3;
    padding: 2px 4px;
    border-radius: 3px;
    background: #f0f4f8;
    cursor: default;
}
.com-post-hidden-badge i { font-size: 0.68rem; }

/* == Base documentaire : badge source conversation =================== */
.com-doc-source-badge {
    display: inline-flex;
    align-items: center;
    font-size: 0.66rem;
    font-weight: 600;
    color: #4b7bb5;
    background: #eef2f8;
    border: 1px solid #b0c4de;
    border-radius: 3px;
    padding: 1px 5px;
}

/* == Base documentaire : bouton favori ================================ */
.com-doc-fav-btn { color: #c8d3dd !important; }
.com-doc-fav-btn:hover,
.com-doc-fav-btn.active { color: #f59e0b !important; }
.com-doc-fav-btn.active:hover { color: #d97706 !important; }

/* == Base documentaire : chip filtre Favoris ========================= */
.com-doc-fav-filter {
    display: inline-flex;
    align-items: center;
    font-size: 0.75rem;
    font-weight: 500;
    color: #8fa1b3;
    background: #fff;
    border: 1px solid #d1dce8;
    border-radius: 2px;
    padding: 3px 10px;
    cursor: pointer;
    transition: all 0.12s;
    white-space: nowrap;
}
.com-doc-fav-filter:hover { border-color: #f59e0b; color: #d97706; background: #fffbeb; }
.com-doc-fav-filter.active { border-color: #f59e0b; color: #d97706; background: #fffbeb; font-weight: 600; }
.com-doc-fav-filter.active i { color: #f59e0b; }

/* == CommunautÃ© feed : filtres alignÃ©s Ã  droite ====================== */
.com-filters { justify-content: flex-end !important; }

/* -- Fix: empty-state centering in doc library + filters full-width -- */
.com-docs-empty-search { display: flex; flex-direction: column; align-items: center; }
.com-filters { justify-content: space-between !important; }

/* -- Filtres communautÃ© : largeur Ã©gale -- */
.com-filter { flex: 1; text-align: center; justify-content: center; }

/* â”€â”€ Base documentaire : lignes compactes ligne unique â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-docs-row {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    height: 44px !important;
    min-height: unset !important;
    padding: 0 16px !important;
    gap: 10px !important;
    cursor: pointer;
    border-bottom: 1px solid #f0f3f6;
    transition: background 0.12s;
}
.com-docs-row:hover { background: #f7f9fb !important; }
.com-docs-row.com-doc-selected { background: #edf3ff !important; }

.com-docs-row-icon {
    flex: 0 0 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 15px !important;
}
/* Suppression du .com-docs-row-body intermÃ©diaire */
.com-docs-row-body { display: contents !important; }

.com-docs-row-name {
    flex: 2 1 0 !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    font-weight: 500 !important;
    font-size: 13.5px !important;
    color: #2d3a4a !important;
}
.com-docs-row-tags {
    flex: 0 0 auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
}
.com-docs-row-info {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    font-size: 11.5px !important;
    color: #8fa1b3 !important;
}
.com-docs-row-actions {
    flex: 0 0 auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 2px !important;
}
/* Masquer les anciens sÃ©parateurs et mÃ©ta */
.com-docs-row-meta,
.com-docs-row-sep { display: none !important; }
/* -- Base documentaire : pleine largeur -- */
.com-docs-page-body { max-width: none !important; }
#docLibGrid, .com-docs-section { width: 100% !important; }

/* Surcharge display: flex !important pour permettre d-none de fonctionner sur les lignes */
.com-docs-row.d-none { display: none !important; }

/* Etoile favori toujours visible + couleur forcee directement sur l'icone */
.com-docs-row[data-fav="1"] .com-docs-row-actions { opacity: 1 !important; }
.com-docs-row[data-fav="1"] .com-docs-row-btn:not(.com-doc-fav-btn) { opacity: 0; transition: opacity 0.12s; }
.com-docs-row[data-fav="1"]:hover .com-docs-row-btn:not(.com-doc-fav-btn) { opacity: 1; }
.com-docs-row[data-fav="1"] .com-doc-fav-btn > i { color: #f59e0b !important; }
.com-docs-row[data-fav="1"] .com-doc-fav-btn:hover > i { color: #d97706 !important; }
/* â”€â”€ Base documentaire â€“ Refonte tableau + toolbar (2026-05-15) â”€â”€ *//* Toolbar unifiÃ©e */
.com-docs-toolbar-v2 { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-bottom: 20px; }
.com-docs-search-wrap-v2 { position: relative; width: 280px; flex-shrink: 0; }
.com-docs-search-wrap-v2 input { width: 100%; padding: 7px 12px 7px 34px; border: 1px solid #d5dde6; border-radius: 6px; font-size: 0.85rem; background: #f7f9fb; outline: none; transition: border-color 0.15s, background 0.15s; }
.com-docs-search-wrap-v2 input:focus { border-color: #0d9488; background: #fff; }
.com-docs-search-icon-v2 { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: #8fa1b3; font-size: 0.8rem; pointer-events: none; }
.com-docs-filters-line { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; flex: 1; }
.com-docs-filter-sep { width: 1px; height: 18px; background: #d5dde6; margin: 0 2px; flex-shrink: 0; }

/* Table */
.com-docs-table { width: 100%; border-collapse: collapse; }
.com-docs-table thead th { font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: #8fa1b3; padding: 0 12px 10px; text-align: left; border-bottom: 2px solid #edf0f4; }
.com-docs-table thead th:first-child { padding-left: 6px; }
.com-docs-table thead th:last-child { padding-right: 6px; text-align: right; }
.com-docs-table tbody tr { border-bottom: 1px solid #f0f3f6; cursor: pointer; transition: background 0.1s; }
.com-docs-table tbody tr:last-child { border-bottom: none; }
.com-docs-table tbody tr:hover { background: #f7f9fb; }
.com-docs-table tbody tr.com-doc-selected { background: #edf3ff; }
.com-docs-table tbody tr.d-none { display: none !important; }
.com-docs-table td { padding: 10px 12px; vertical-align: middle; }
.com-docs-table td:first-child { padding-left: 6px; }
.com-docs-table td:last-child { padding-right: 6px; }

/* Colonnes */
.com-docs-col-icon { font-size: 1.05rem; text-align: center; color: #8fa1b3; }
.com-docs-col-name { font-size: 0.875rem; font-weight: 500; color: #1e293b; }
.com-docs-col-scope { }
.com-docs-col-cat { font-size: 0.8rem; color: #64748b; }
.com-docs-col-info { font-size: 0.78rem; color: #8fa1b3; white-space: nowrap; }
.com-docs-col-actions { text-align: right; opacity: 0; transition: opacity 0.12s; white-space: nowrap; }
.com-docs-table tbody tr:hover .com-docs-col-actions { opacity: 1; }
.com-docs-table tbody tr.com-doc-selected .com-docs-col-actions { opacity: 1; }

/* Badge "issu d'une conversation" */
.com-doc-conv-tag { display: inline-flex; align-items: center; font-size: 0.68rem; color: #6366f1; background: #ede9fe; border-radius: 3px; padding: 1px 5px; margin-left: 6px; vertical-align: middle; }

/* Favoris â€“ colonne actions (table) */
.com-docs-table tbody tr[data-fav="1"] .com-docs-col-actions { opacity: 1; }
.com-docs-table tbody tr[data-fav="1"] .com-docs-row-btn:not(.com-doc-fav-btn) { opacity: 0; transition: opacity 0.12s; }
.com-docs-table tbody tr[data-fav="1"]:hover .com-docs-row-btn:not(.com-doc-fav-btn) { opacity: 1; }
.com-docs-table tbody tr[data-fav="1"] .com-doc-fav-btn > i { color: #f59e0b !important; }
.com-docs-table tbody tr[data-fav="1"] .com-doc-fav-btn:hover > i { color: #d97706 !important; }
/* â”€â”€ Base documentaire â€“ UX refonte toolbar + tableau (2026-05-15 v2) â”€â”€ *//* Barre de recherche principale */
.com-docs-search-bar { position: relative; margin-bottom: 8px; }
.com-docs-search-bar input { width: 100%; padding: 10px 14px 10px 40px; border: 1.5px solid #d5dde6; border-radius: 8px; font-size: 0.9rem; background: #fff; outline: none; transition: border-color 0.15s, box-shadow 0.15s; color: #1e293b; }
.com-docs-search-bar input:focus { border-color: #0d9488; box-shadow: 0 0 0 3px rgba(13,148,136,.10); }
.com-docs-search-bar input::placeholder { color: #a0aec0; }
.com-docs-search-bar-icon { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); color: #a0aec0; font-size: 0.85rem; pointer-events: none; }

/* Barre de filtres groupÃ©s */
.com-docs-filter-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; background: #f7f9fb; border: 1px solid #edf0f4; border-radius: 8px; padding: 8px 14px; }
.com-docs-filter-group { display: flex; align-items: center; gap: 7px; }
.com-docs-filter-label { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: #94a3b8; white-space: nowrap; }
.com-docs-filter-vsep { width: 1px; height: 20px; background: #dde3ea; flex-shrink: 0; }
.com-doc-fav-filter.ml-auto { margin-left: auto; }

/* En-tÃªtes de colonnes triables */
.com-docs-th-sort { cursor: pointer; user-select: none; white-space: nowrap; }
.com-docs-th-sort:hover { color: #0d9488; }
.com-docs-th-sort.com-th-sorted { color: #0d9488; }
.com-sort-icon { font-size: 0.65rem; opacity: 0.35; vertical-align: middle; }
.com-sort-icon.com-sort-active { opacity: 1; color: #0d9488; }
.com-docs-th-fixed { }

/* Cellules tableau */
.com-docs-col-name { }
.com-docs-col-name-text { font-size: 0.875rem; font-weight: 500; color: #1e293b; }
.com-docs-col-name-sub { font-size: 0.72rem; color: #94a3b8; margin-top: 1px; }
.com-docs-col-scope { }
.com-docs-col-cat { }
.com-docs-col-author { font-size: 0.82rem; color: #475569; white-space: nowrap; }
.com-docs-col-date { font-size: 0.82rem; color: #64748b; white-space: nowrap; }
.com-docs-col-empty { color: #c4cdd8; }

/* Badge catÃ©gorie */
.com-doc-cat-badge { display: inline-flex; align-items: center; font-size: 0.72rem; font-weight: 500; padding: 2px 8px; border-radius: 4px; background: #f1f5f9; color: #475569; border: 1px solid #e2e8f0; white-space: nowrap; }

/* Badge conversation (mini) */
.com-doc-conv-tag { display: inline-flex; align-items: center; font-size: 0.67rem; color: #6366f1; background: #ede9fe; border-radius: 3px; padding: 1px 5px; margin-left: 6px; vertical-align: middle; white-space: nowrap; }
/* â”€â”€ Base documentaire â€“ toolbar v3 + tableau v3 (2026-05-15) â”€â”€ *//* Toolbar v3 */
.com-docs-toolbar-v3 { display: flex; flex-direction: column; gap: 0; margin-bottom: 20px; }

/* Ligne 1 : recherche + favoris */
.com-docs-tb-row1 { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.com-docs-search-v3 { flex: 1; position: relative; }
.com-docs-search-v3 input { width: 100%; padding: 7px 12px 7px 34px; border: 1.5px solid #d5dde6; border-radius: 2px; font-size: 0.875rem; background: #fff; outline: none; color: #1e293b; transition: border-color 0.15s, box-shadow 0.15s; }
.com-docs-search-v3 input:focus { border-color: #0d9488; box-shadow: 0 0 0 3px rgba(13,148,136,.09); }
.com-docs-search-v3 input::placeholder { color: #b0bec8; }
.com-docs-search-v3-icon { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: #b0bec8; font-size: 0.78rem; pointer-events: none; }

/* Bloc filtres (lignes 2 et 3) */
.com-docs-filter-rows { display: flex; flex-direction: column; gap: 0; border: 1px solid #edf0f4; border-radius: 8px; overflow: hidden; background: #f8fafc; }
.com-docs-filter-row { display: flex; align-items: center; gap: 10px; padding: 7px 14px; border-bottom: 1px solid #edf0f4; }
.com-docs-filter-row:last-child { border-bottom: none; }
.com-docs-filter-row-label { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: #94a3b8; width: 90px; flex-shrink: 0; }

/* Ajustement chips dans la filter bar : plus compacts */
.com-docs-filter-rows .com-doc-cat,
.com-docs-filter-rows .com-doc-scope { padding: 3px 10px; font-size: 0.78rem; }

/* En-tÃªtes triables */
.com-docs-th-sort { cursor: pointer; user-select: none; white-space: nowrap; }
.com-docs-th-sort:hover { color: #0d9488; }
.com-docs-th-sort.com-th-sorted { color: #0d9488; }
.com-sort-icon { font-size: 0.62rem; opacity: 0.3; vertical-align: middle; }
.com-sort-icon.com-sort-active { opacity: 1; color: #0d9488; }

/* Colonnes tableau */
.com-docs-col-icon { font-size: 1rem; text-align: center; color: #8fa1b3; width: 28px; }
.com-docs-col-name { }
.com-docs-col-name-text { font-size: 0.875rem; font-weight: 500; color: #1e293b; display: flex; align-items: center; gap: 6px; }
.com-docs-col-name-sub { font-size: 0.71rem; color: #94a3b8; margin-top: 2px; }
.com-docs-col-cat { }
.com-docs-col-scope { }
.com-docs-col-author { }
.com-docs-col-date { font-size: 0.82rem; color: #64748b; white-space: nowrap; }
.com-docs-col-empty { color: #c4cdd8; font-size: 0.82rem; }

/* Badge catÃ©gorie */
.com-doc-cat-badge { display: inline-flex; align-items: center; font-size: 0.72rem; font-weight: 500; padding: 2px 8px; border-radius: 4px; background: #f1f5f9; color: #475569; border: 1px solid #e2e8f0; white-space: nowrap; max-width: 140px; overflow: hidden; text-overflow: ellipsis; }

/* Badge conversation */
.com-doc-conv-tag { display: inline-flex; align-items: center; font-size: 0.67rem; color: #6366f1; background: #ede9fe; border-radius: 3px; padding: 1px 5px; white-space: nowrap; flex-shrink: 0; }

/* Avatar auteur */
.com-docs-author-cell { display: flex; align-items: center; gap: 7px; }
.com-docs-author-avatar { width: 22px; height: 22px; border-radius: 50%; color: #fff; font-size: 0.62rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; line-height: 1; }
.com-docs-author-name { font-size: 0.82rem; color: #475569; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* â”€â”€ Base documentaire â€“ ajustements UI (2026-05-15) â”€â”€ *//* Barre de recherche rÃ©duite de moitiÃ© */
.com-docs-search-v3 { flex: 0 0 auto; width: 48%; }

/* Bouton Favoris : mÃªme hauteur que la recherche + plus large */
.com-docs-tb-row1 .com-doc-fav-filter { padding: 6px 22px; font-size: 0.8rem; display: inline-flex; align-items: center; align-self: stretch; }

/* Badge catÃ©gorie : texte complet, sans troncature */
.com-doc-cat-badge { max-width: none !important; overflow: visible !important; text-overflow: unset !important; white-space: normal !important; }

/* En-tÃªtes tableau : alignement vertical centrÃ© */
.com-docs-table thead th { vertical-align: middle; padding-top: 8px; padding-bottom: 8px; }
/* â”€â”€ Avatar auteur dans le tableau documents â”€â”€ */
.com-docs-author-cell { display: flex; align-items: center; gap: 7px; }
.com-docs-author-cell .circled { width: 26px !important; height: 26px !important; min-width: 26px; font-size: 0.62rem; line-height: 26px !important; flex-shrink: 0; }
.com-docs-author-cell .circled img { width: 24px !important; height: 24px !important; }
.com-docs-author-name { font-size: 0.82rem; color: #475569; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* â”€â”€ Community: badge documents joints sur post Conversation â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-post-docs-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    color: #6c757d;
    background: #f0f4fa;
    border: 1px solid #d0daea;
    border-radius: 10px;
    padding: 1px 7px;
    margin-left: 4px;
    font-weight: 500;
}
.com-post-docs-badge i { font-size: 10px; }
/* â”€â”€ Community: chips rÃ©actions toujours visibles, attÃ©nuÃ©es Ã  0 â”€â”€â”€ */
.com-reaction-chip .com-reaction-chip-count:empty ~ *,
.com-reaction-chip:not(.active) .com-reaction-chip-count:empty {
    /* pas de rÃ¨gle nÃ©cessaire â€” gÃ©rÃ© via opacity ci-dessous */
}
.com-reaction-chip:not(.active) {
    opacity: 0.55;
}
.com-reaction-chip:not(.active):hover {
    opacity: 1;
}
/* â”€â”€ Community drawer: zone rÃ©actions dÃ©crochÃ©e â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-reactions-row {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px 4px 16px;
}
.com-reactions-row .com-reaction-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 18px;
    padding: 4px 10px;
    border-radius: 20px;
    border: 1.5px solid #e0e6f0;
    background: #fff;
    cursor: pointer;
    transition: border-color .15s, background .15s, opacity .15s;
    user-select: none;
}
.com-reactions-row .com-reaction-chip .com-reaction-chip-count {
    font-size: 12px;
    font-weight: 600;
    color: #5a6a85;
    min-width: 8px;
}
.com-reactions-row .com-reaction-chip:not(.active) {
    opacity: 0.5;
}
.com-reactions-row .com-reaction-chip:not(.active):hover {
    opacity: 1;
    border-color: #b0bdd4;
    background: #f4f7fb;
}
.com-reactions-row .com-reaction-chip.active {
    opacity: 1;
    border-color: #4a7fd4;
    background: #eef3fc;
}
.com-reactions-row .com-reaction-chip.active .com-reaction-chip-count {
    color: #2d5aa0;
}
/* â”€â”€ Community drawer: lien agenda inline avec la date Ã©vÃ©nement â”€â”€â”€ */
.com-source-event-date {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
}
.com-ics-inline-btn {
    display: inline-flex;
    align-items: center;
    font-size: 12px;
    color: #28a745;
    border: 1px solid #28a745;
    border-radius: 12px;
    padding: 1px 10px;
    text-decoration: none;
    white-space: nowrap;
    transition: background .15s, color .15s;
}
.com-ics-inline-btn:hover {
    background: #28a745;
    color: #fff;
    text-decoration: none;
}
/* â”€â”€ Community drawer: titre post mis en valeur â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-source-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--com-navy, #1a2b4a);
    margin: 0 0 10px;
    line-height: 1.35;
}
/* â”€â”€ Community drawer: titre post â€” override forcÃ© â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-source-card .com-source-title {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: #1a2b4a !important;
    margin: 0 0 10px !important;
    line-height: 1.35;
}
/* â”€â”€ Community: sondage â€” options visuelles, input natif masquÃ© â”€â”€â”€â”€ */
.com-poll-vote-option input[type="radio"],
.com-poll-vote-option input[type="checkbox"] {
    display: none;
}
.com-poll-vote-option:has(input:checked) {
    background: var(--com-teal-light, #e8f5f3);
    border-color: var(--com-teal, #2a9d8f);
    color: var(--com-navy, #1a2b4a);
    font-weight: 500;
}
/* â”€â”€ Community: rÃ©sultats sondage â€” votants sous la barre â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-poll-option-wrap { margin-bottom: 6px; }
.com-poll-voters {
    font-size: 0.72rem;
    color: var(--com-mid, #6c757d);
    padding-left: 86px;
    margin-top: 1px;
}
/* â”€â”€ Community: sondage choix multiple â€” indication â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-poll-multiple-hint {
    font-size: 0.75rem;
    font-style: italic;
    color: var(--com-mid, #6c757d);
    margin-top: 2px;
    margin-bottom: 6px;
}
/* â”€â”€ Community: boutons d'action â€” style outlined â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-btn-action {
    background: #fff !important;
    font-size: 0.78rem;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: var(--com-radius, 6px);
    border-width: 1.5px !important;
    border-style: solid !important;
    transition: background .15s, color .15s;
}
.com-btn-action:hover {
    opacity: 1;
    transform: translateY(-1px);
    text-decoration: none;
}
.com-btn-conversation {
    background: #fff !important;
    border-color: #4b7bb5 !important;
    color: #4b7bb5 !important;
}
.com-btn-conversation:hover {
    background: #eef3fb !important;
    color: #4b7bb5 !important;
}
.com-btn-event {
    background: #fff !important;
    border-color: #4d8c6f !important;
    color: #4d8c6f !important;
}
.com-btn-event:hover {
    background: #edf7f3 !important;
    color: #4d8c6f !important;
}
.com-btn-poll {
    background: #fff !important;
    border-color: #6b5fa5 !important;
    color: #6b5fa5 !important;
}
.com-btn-poll:hover {
    background: #f2f0fa !important;
    color: #6b5fa5 !important;
}
.com-btn-document {
    background: #fff !important;
    border-color: #a07840 !important;
    color: #a07840 !important;
}
.com-btn-document:hover {
    background: #faf4ec !important;
    color: #a07840 !important;
}
/* â”€â”€ Community: fond des cartes fil â€” blanc uniforme (option A) â”€â”€â”€â”€ */
.com-post-type-conversation,
.com-post-type-event,
.com-post-type-poll,
.com-post-type-document {
    background: #fff !important;
}
/* â”€â”€ Community modales: alignement design system â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-modal-header .modal-title {
    font-size: 0.95rem;
    font-weight: 600;
}
.com-modal-header + .modal-body {
    padding: 24px 28px 20px;
}
.com-modal-header ~ .modal-footer {
    padding: 12px 28px 20px;
    border-top: 1px solid #e2e8f0;
}
.modal-content .form-group {
    margin-bottom: 18px;
}
.modal-content .field-label {
    display: block;
    font-size: 0.72rem;
    font-weight: 400;
    color: #8fa1b3;
    text-transform: none;
    letter-spacing: 0;
    margin-bottom: 5px;
}
.modal-content .form-control,
.modal-content select.form-control {
    border-radius: 2px;
    border-color: #e2e8f0;
    font-size: 0.85rem;
    color: #2D3E50;
}
.modal-content .form-control:focus {
    border-color: #0d9488;
    box-shadow: 0 0 0 2px rgba(13,148,136,0.12);
}
/* â”€â”€ Community modales: espacement vertical entre champs â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.modal-content .form-group {
    margin-bottom: 24px;
}
/* â”€â”€ Community modales: espacement vertical entre champs (forcÃ©) â”€â”€â”€ */
.modal-content .form-group {
    margin-bottom: 28px !important;
}
.modal-content .form-group.mb-0 {
    margin-bottom: 0 !important;
}
/* â”€â”€ Community modales: espacement vertical entre champs (ajustÃ©) â”€â”€ */
.modal-content .form-group {
    margin-bottom: 20px !important;
}
/* â”€â”€ Community: section Ã©pinglÃ©s â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-pinned-section {
    margin-bottom: 8px;
}
.com-pinned-header {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 7px 14px;
    background: #f0fafa;
    border: 1px solid #c8e6e3;
    border-radius: 6px;
    cursor: pointer;
    user-select: none;
    margin-bottom: 6px;
    transition: background .15s;
}
.com-pinned-header:hover { background: #e6f7f5; }
.com-pinned-icon { font-size: 0.72rem; color: #0d9488; }
.com-pinned-label { font-size: 0.78rem; font-weight: 600; color: #0d9488; }
.com-pinned-count {
    font-size: 0.68rem;
    font-weight: 600;
    background: #0d9488;
    color: #fff;
    border-radius: 10px;
    padding: 1px 7px;
}
.com-pinned-chevron {
    font-size: 0.72rem;
    color: #0d9488;
    transition: transform .2s;
}
.com-pinned-section.collapsed .com-pinned-chevron { transform: rotate(-90deg); }
.com-pinned-section.collapsed .com-pinned-body { display: none; }
/* â”€â”€ Community: sÃ©parateur fin de section Ã©pinglÃ©s â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-pinned-section {
    padding-bottom: 14px;
    margin-bottom: 14px;
    border-bottom: 1.5px solid #c8e6e3;
}
.com-pinned-section.collapsed {
    padding-bottom: 14px;
}
/* â”€â”€ Community: espacement sÃ©parateur Ã©pinglÃ©s â€” centrage du trait â”€ */
.com-pinned-section {
    padding-bottom: 4px;
    margin-bottom: 10px;
}
.com-pinned-section.collapsed {
    padding-bottom: 4px;
}
/* â”€â”€ Community: sÃ©parateur Ã©pinglÃ©s â€” margin-bottom 14px â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-pinned-section {
    padding-bottom: 4px;
    margin-bottom: 14px;
}
/* â”€â”€ Community: sÃ©parateur Ã©pinglÃ©s â€” fond teal sur padding bas â”€â”€â”€â”€ */
.com-pinned-section {
    padding-bottom: 6px;
    margin-bottom: 16px;
    background: linear-gradient(to bottom, transparent calc(100% - 6px), #f0fafa calc(100% - 6px));
}
/* â”€â”€ Community: suppression border-top teal sur epingles + badge reduit â”€â”€ */
.com-post-item.com-post-pinned { border-top: none !important; }
.com-pinned-count {
    font-size: 0.62rem;
    padding: 0px 5px;
}

/* â”€â”€ Community â€” pins personnels et modale portÃ©e â”€â”€ */
.com-post-item.com-post-pinned-personal .com-post-item-header { background: #eef1f5; }
/* Section "Mes mÃ©morisÃ©s" â€” thÃ¨me navy complet */
.com-pinned-personal-section .com-pinned-header {
    background: #eef1f5;
    border-color: #b8c4d0;
}
.com-pinned-personal-section .com-pinned-header:hover { background: #e2e8f0; }
.com-pinned-personal-section .com-pinned-icon,
.com-pinned-personal-section .com-pinned-chevron { color: #2D3E50; }
.com-pinned-personal-section .com-pinned-label { color: #2D3E50; }
.com-pinned-personal-section .com-pinned-count { background: #2D3E50; }
.com-pinned-personal-section {
    border-bottom-color: #b8c4d0;
    background: linear-gradient(to bottom, transparent calc(100% - 6px), #eef1f5 calc(100% - 6px));
}
.com-post-pin-locked { cursor: default; pointer-events: none; }
.com-pin-scope-btn {
    display: flex; align-items: center; gap: 0.75rem;
    width: 100%; padding: 1rem 1.25rem; border: 0;
    background: transparent; text-align: left; cursor: pointer;
    border-bottom: 1px solid #e5e7eb; transition: background 0.15s;
}
.com-pin-scope-btn:last-child { border-bottom: 0; }
.com-pin-scope-btn:hover { background: #f0f9ff; }
.com-pin-scope-icon { font-size: 1.1rem; color: #0d9488; flex-shrink: 0; width: 1.5rem; text-align: center; }
.com-pin-scope-label { font-size: 0.85rem; font-weight: 600; color: #1f2937; }
.com-pin-scope-hint { font-size: 0.75rem; color: #6b7280; margin-top: 0.1rem; }

/* â”€â”€ Community: modale pin â€” Ã©tape 2 (choix de la durÃ©e d'Ã©pinglage) â”€â”€ */
.com-pin-step-back-row {
    padding: 8px 12px 0;
    border-bottom: 1px solid #f1f3f5;
    margin-bottom: 4px;
}
.com-pin-step-back {
    background: transparent;
    border: none;
    color: #64748b;
    font-size: 0.75rem;
    cursor: pointer;
    padding: 4px 6px;
    border-radius: 4px;
    transition: background .12s, color .12s;
}
.com-pin-step-back:hover {
    background: #f1f5f9;
    color: #2D3E50;
}
.com-pin-duration-intro {
    padding: 12px 14px 4px;
    font-size: 0.75rem;
    color: #6b7280;
}
.com-pin-duration-list {
    display: flex;
    flex-direction: column;
    padding: 4px 10px 12px;
    gap: 4px;
}
.com-pin-duration-btn {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 9px 12px;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 2px;
    font-size: 0.82rem;
    font-weight: 500;
    color: #1f2937;
    cursor: pointer;
    transition: background .12s, border-color .12s, color .12s;
    text-align: left;
}
.com-pin-duration-btn:hover,
.com-pin-duration-btn:focus {
    background: #eef9f7;
    border-color: var(--com-teal, #0d9488);
    color: var(--com-teal, #0d9488);
    outline: none;
}
.com-pin-duration-permanent {
    background: #fff;
    border-style: dashed;
    color: #64748b;
    font-style: italic;
}
.com-pin-duration-permanent:hover,
.com-pin-duration-permanent:focus {
    background: #f1f5f9;
    border-color: #94a3b8;
    color: #1f2937;
    font-style: normal;
}

/* â”€â”€ Community: variante compacte du tooltip Bootstrap (police rÃ©duite) â”€â”€ */
.tooltip.com-tooltip-compact .tooltip-inner {
    font-size: 0.70rem;
    padding: 4px 8px;
    line-height: 1.3;
}

/* â”€â”€ SÃ©lecteur de vue liste Projets (Ã©tape 6b redesign V1) â”€â”€ */

.prj-list-view-selector .prj-list-view-btn { background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.35); color: #fff; font-size: 0.78rem; font-weight: 400; padding: 3px 10px; border-radius: 3px; line-height: 1.3; }

.prj-list-view-selector .prj-list-view-btn:hover, .prj-list-view-selector .prj-list-view-btn:focus, .prj-list-view-selector.show .prj-list-view-btn { background: rgba(255,255,255,0.22); border-color: rgba(255,255,255,0.55); color: #fff; box-shadow: none; outline: none; }

.prj-list-view-selector .dropdown-menu { background: #fff !important; font-size: 0.82rem; min-width: 170px; padding: 4px 0; border: 1px solid #e2e8f0; border-radius: 4px; box-shadow: 0 4px 12px rgba(0,0,0,0.08); }

.prj-list-view-selector .dropdown-item { padding: 6px 14px 6px 30px; color: #2D3E50 !important; font-weight: 300; position: relative; }

.prj-list-view-selector .dropdown-item:hover { background: #e6f7f5 !important; color: #0d9488 !important; }

.prj-list-view-selector .dropdown-item.active, .prj-list-view-selector .dropdown-item.active:hover { background: #fff !important; color: #0d9488 !important; font-weight: 500; }

.prj-list-view-selector .dropdown-item.active::before { content: "\f00c"; font-family: "Font Awesome 5 Free"; font-weight: 900; position: absolute; left: 11px; top: 50%; transform: translateY(-50%); font-size: 0.72rem; color: #0d9488; }

/* â”€â”€ Cartes ligne projet liste (Ã©tape 6c redesign V1) â”€â”€ */

#item-list .prj-list-card { position: relative; padding: 6px 2px; background: transparent; cursor: pointer; transition: background 0.12s, border-color 0.12s; }
#item-list .prj-list-card:hover { background: #eef7f4 !important; }
#item-list .prj-list-card.active, #item-list .prj-list-card.active:hover { background: #d6e9e1 !important; box-shadow: none; }
#item-list .prj-list-card.active::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: #0d9488; z-index: 2; }
#item-list .prj-list-card.prj-list-child.active::before { left: -3px; }

/* Slot enfant â€” barre verticale fine alignÃ©e sous le chevron du parent (Ã©tape 6c.1) */
.prj-list-child { border-color: #cbd5e1 !important; border-width: 2px !important; }
.prj-list-child-l2 { margin-left: 11px !important; }
.prj-list-child-l3 { margin-left: 27px !important; }
.prj-list-child-l4 { margin-left: 43px !important; }

.prj-list-fresh-dot { width: 9px; height: 9px; border-radius: 50%; background: #0d9488; flex-shrink: 0; box-shadow: 0 0 0 2px rgba(13,148,136,0.18); }

.prj-list-body { display: flex; align-items: flex-start; min-width: 0; }

.prj-list-orphan-bar { width: 6px; flex: 0 0 6px; margin-right: 10px; border-left-style: dashed !important; border-left-width: 3px !important; min-height: 40px; }

/* Slot gauche vertical : ligne 1 = point activitÃ©, ligne 2 = chevron dÃ©plier */
.prj-list-left-slot { width: 22px; flex: 0 0 22px; display: flex; flex-direction: column; align-items: center; padding-top: 0; gap: 0; }
.prj-list-left-row1 { height: 1.14rem; display: flex; align-items: center; justify-content: center; }
.prj-list-left-row2 { display: flex; align-items: center; justify-content: center; margin-top: 1px; }

.prj-list-content { flex: 1; min-width: 0; }

.prj-list-row1 { gap: 8px; min-width: 0; }
.prj-list-row2 { margin-top: 1px; }
.prj-list-row3 { gap: 4px; margin-top: 4px; flex-wrap: wrap; }

.prj-list-title-wrapper { min-width: 0; flex: 1 1 auto; overflow: hidden; }
.prj-list-title { font-size: 0.88rem; font-weight: 500; color: #2D3E50; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.prj-list-chevron { color: #8fa1b3; font-size: 0.7rem; text-decoration: none; line-height: 1; transition: color 0.12s, transform 0.18s ease; display: inline-block; }
.prj-list-chevron:hover { color: #0d9488; text-decoration: none; }
.prj-list-chevron.expanded { transform: rotate(90deg); color: #0d9488; }

.prj-list-date { font-size: 0.75rem; font-weight: 400; color: #8fa1b3; flex-shrink: 0; white-space: nowrap; }

.prj-list-favorite { flex-shrink: 0; width: 12px; text-align: center; font-size: 0.8rem; }
.prj-list-favorite a { color: inherit; text-decoration: none; }
.prj-list-favorite .fa-star.fas { color: #0d9488; }
.prj-list-favorite .fa-star.far { color: transparent; transition: color 0.12s; }
.list-item-row:hover .prj-list-favorite .fa-star.far { color: #cfd8dc; }
.list-item-row:hover .prj-list-favorite .fa-star.far:hover { color: #0d9488; }

.prj-list-phase { font-size: 0.74rem; font-weight: 300; color: #6b7a8d; line-height: 1.3; }

.prj-list-alert-pill { display: inline-flex; align-items: center; gap: 4px; padding: 2px 7px; font-size: 0.65rem; font-weight: 500; border-radius: 2px; color: var(--pill-color, #2D3E50); background: color-mix(in srgb, var(--pill-color, #2D3E50) 10%, #fff); border: 1px solid color-mix(in srgb, var(--pill-color, #2D3E50) 30%, transparent); white-space: nowrap; line-height: 1.3; }
.prj-list-alert-pill .fas { font-size: 0.6rem; }

/* Wrapper li : trait fin discret entre projets, espace inter-lignes rÃ©duit */
.prj-list-item-wrapper { background: #fff; border-bottom: 1px solid #e2e8f0 !important; }
.prj-list-item-wrapper:last-child { border-bottom: none !important; }

/* Liste projets : fond blanc partout (Ã©tape 6c.1) */
#item-list.item-list-bg-color-generic { background-color: #fff !important; border-radius: 0 !important; }
#item-list .item-list-generic { background-color: #fff !important; border-radius: 0 !important; }

/* Scrollbar fine (3px) visible uniquement au hover de la zone de liste â€” cohÃ©rent avec onglet Contexte */
#item-list .container-scrollable::-webkit-scrollbar { width: 3px; background: transparent; }
#item-list .container-scrollable::-webkit-scrollbar-track { background: transparent !important; border: none !important; }
#item-list .container-scrollable::-webkit-scrollbar-thumb { background: transparent; border-radius: 4px; transition: background 0.25s; }
#item-list .container-scrollable:hover::-webkit-scrollbar-thumb { background: #c4c9d0; }
#item-list .container-scrollable { scrollbar-width: thin; scrollbar-color: transparent transparent; }
#item-list .container-scrollable:hover { scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€ SÃ©parateurs de groupes liste projets (Ã©tape 6d redesign V1) â”€â”€ */

#item-list .prj-list-group-header { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-bottom: 1px solid #cbd5e1; border-top: 1px solid #cbd5e1; background: linear-gradient(to bottom, #f8fafc, #f1f5f9); cursor: pointer; user-select: none; transition: background 0.12s; }
#item-list .prj-list-group-header:first-child { border-top: none; }
#item-list .prj-list-group-header:hover { background: linear-gradient(to bottom, #f1f5f9, #e6f7f5); }

.prj-list-group-icon { font-size: 0.8rem; flex-shrink: 0; width: 16px; text-align: center; }

.prj-list-group-label { font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: #1f2937; line-height: 1; }

.prj-list-group-count { display: inline-flex; align-items: center; justify-content: center; min-width: 16px; height: 14px; padding: 0 5px; font-size: 0.62rem; font-weight: 600; color: #fff; background: #8fa1b3; border-radius: 8px; line-height: 1; }

.prj-list-group-toggle { font-size: 0.7rem; color: #6b7a8d; transition: transform 0.18s ease; }
#item-list .prj-list-group-header.collapsed .prj-list-group-toggle { transform: rotate(180deg); }

/* â”€â”€ Colonne liste Projets : fond blanc + ombre bord droit (Ã©tape 6.6 redesign V1) â”€â”€
   L'ombre est portÃ©e par un pseudo-Ã©lÃ©ment absolu pour passer au-dessus du fond blanc
   de .col-right (qui sinon masque la box-shadow). SymÃ©trique avec l'ombre gauche du
   #side-panel (box-shadow: -3px 0 12px rgba(0,0,0,0.08)). Pseudo-Ã©lÃ©ment absolu pour
   garantir le rendu au-dessus du fond blanc de .col-right. #}
.col-left.prj-list-bg-white { background: #fff !important; padding-top: 0 !important; }
/* Relief sur le bord gauche de col-right via pseudo-element absolu â€” z-index 50 pour
   passer au-dessus des enfants opaques de col-right (#project-container avec son fond gris,
   etc.) qui masquaient l'inset shadow. Reste sous le #list-toggle (z-index 400) qui s'y colle. */
.col-left.prj-list-bg-white ~ .col-right { position: relative; }
.col-left.prj-list-bg-white ~ .col-right::before { content: ''; position: absolute; top: 0; bottom: 0; left: 0; width: 12px; background: linear-gradient(to right, rgba(45,62,80,0.17), rgba(45,62,80,0)); z-index: 50; pointer-events: none; }

/* â”€â”€ Header colonne liste Projets â”€â”€ */

.prj-list-page-header { padding: 12px 18px 14px; background: #fff; }

.prj-list-page-title { font-size: 1.65rem; font-weight: 400; color: #1f2937 !important; margin: 0 0 14px; letter-spacing: 0.5px; line-height: 1; }

.prj-list-search-wrapper { position: relative; }

.prj-list-search-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: #8fa1b3; font-size: 0.85rem; pointer-events: none; z-index: 2; }

.prj-list-search-wrapper input[type="text"], .prj-list-search-wrapper input[type="search"] { width: 100%; padding: 6px 14px 6px 36px !important; font-size: 0.82rem !important; font-weight: 300 !important; color: #2D3E50 !important; background: #fff !important; border: 1px solid #cbd5e1 !important; border-radius: 2px !important; box-shadow: none !important; transition: border-color 0.12s, box-shadow 0.12s; }

.prj-list-search-wrapper input[type="text"]:focus, .prj-list-search-wrapper input[type="search"]:focus { border-color: #0d9488 !important; box-shadow: 0 0 0 2px rgba(13,148,136,0.15) !important; outline: none !important; }

/* â”€â”€ Toolbar pills (Filtres, Refresh, Vue, Arbre) â”€â”€ */

.prj-list-toolbar { padding: 0 18px 8px; background: #fff; }

.prj-list-toolbar-chips { display: flex; flex-wrap: nowrap; align-items: center; gap: 5px; margin-bottom: 10px; }

.prj-list-chip { display: inline-flex; align-items: center; gap: 5px; padding: 5px 9px; font-size: 0.78rem; font-weight: 400; color: #475569; background: #fff; border: 1px solid #cbd5e1; border-radius: 2px; cursor: pointer; transition: background 0.12s, border-color 0.12s, color 0.12s; white-space: nowrap; line-height: 1.3; }

.prj-list-chip:hover, .prj-list-chip:focus, .prj-list-chip[aria-expanded="true"], .show > .prj-list-chip { background: #f1f5f9; border-color: #94a3b8; color: #2D3E50; outline: none; box-shadow: none; text-decoration: none; }

.prj-list-chip[disabled] { opacity: 0.4; cursor: not-allowed; }

.prj-list-chip .fas { font-size: 0.78rem; color: inherit; }

.prj-list-chip-icon { padding: 5px 8px; min-width: 32px; justify-content: center; }

.prj-list-chip-caret { font-size: 0.6rem !important; margin-left: 2px; color: inherit; }

.prj-list-chip-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 16px; height: 16px; padding: 0 5px; font-size: 0.62rem; font-weight: 700; color: #fff; background: #0d9488; border-radius: 2px; line-height: 1; margin-left: 2px; }

.prj-list-chip-view::after { display: none; }

.prj-list-chip-toggle { flex: 1 1 auto; }
.prj-list-view-selector.dropdown { flex: 1 1 auto; }
.prj-list-chip-view { width: 100%; padding-right: 20px; position: relative; }

.prj-list-chip-view::before { content: "\f078"; font-family: "Font Awesome 5 Free"; font-weight: 900; font-size: 0.6rem; position: absolute; right: 11px; top: 50%; transform: translateY(-50%); color: inherit; }

/* â”€â”€ Tabs Tous / Mes / Favoris â”€â”€ */

.prj-list-tabs.nav-tabs { border-bottom: 1px solid #e2e8f0; background: #fff; flex-wrap: nowrap; padding: 0; margin: 6px 0 0; gap: 18px; }

.prj-list-tabs.nav-tabs .nav-item { flex: 0 0 auto; }

.prj-list-tabs.nav-tabs .nav-link.prj-list-tab { position: relative; border: none; background: transparent; color: #6b7a8d; font-size: 0.85rem !important; font-weight: 400 !important; font-family: inherit !important; padding: 10px 2px; margin: 0; transition: color 0.12s; }

.prj-list-tabs.nav-tabs .nav-link.prj-list-tab:hover { color: #0d9488; font-weight: 400 !important; }

.prj-list-tabs.nav-tabs .nav-link.prj-list-tab.active, .prj-list-tabs.nav-tabs .nav-link.prj-list-tab.active:hover { color: #0d9488 !important; font-weight: 600 !important; background: transparent; }

.prj-list-tabs.nav-tabs .nav-link.prj-list-tab::after { content: ''; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: #0d9488; transform: scaleX(0); transform-origin: center; transition: transform 0.15s ease; }

.prj-list-tabs.nav-tabs .nav-link.prj-list-tab:hover::after, .prj-list-tabs.nav-tabs .nav-link.prj-list-tab.active::after { transform: scaleX(1); }

.prj-list-tabs.nav-tabs .nav-link.prj-list-tab:focus { outline: none; box-shadow: none; }

/* â”€â”€ Filtres avancÃ©s (collapse) â”€â”€ */

.prj-list-filters-collapse { padding: 12px 0 4px; background: #fff; }

/* â”€â”€ Footer colonne liste â”€â”€ */

.prj-list-footer { display: flex; align-items: center; gap: 10px; padding: 12px 16px 14px; background: #fff; border-top: 1px solid #e2e8f0; }

.prj-list-footer-btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 9px 14px; font-size: 0.85rem; font-weight: 500; color: #0d9488; background: #fff; border: 1px solid #cbd5e1; border-radius: 2px; cursor: pointer; transition: background 0.12s, color 0.12s, border-color 0.12s; text-decoration: none; line-height: 1.3; }

.prj-list-footer-btn:hover, .prj-list-footer-btn:focus { background: #f0fafa; color: #0d9488; border-color: #0d9488; text-decoration: none; outline: none; box-shadow: none; }

.prj-list-footer-btn-icon { padding: 9px 12px; flex: 0 0 auto; color: #475569; }

.prj-list-footer-btn-icon:hover { color: #0d9488; }

.prj-list-footer-btn-icon .fas { font-size: 0.95rem; }

.prj-list-footer-btn-add { flex: 1 1 auto; }

/* sortPanel vidÃ© en 6.6 (vue + arbre dÃ©placÃ©s dans la toolbar) â€” supprimer la zone vide
   qui subsiste entre les tabs et la liste. Scope projet uniquement via parent col-left. */
.col-left.prj-list-bg-white #sortPanel { display: none !important; }

/* Bouton arbre : poussÃ© Ã  droite + Ã©tat actif */
#display_all_projects_childs { margin-left: auto; }
#display_all_projects_childs.prj-list-chip.active { background: #e6f7f5; border-color: #0d9488; color: #0d9488; }

/* EmpÃªcher le wrap inopinÃ© des chips quand un bouton change d'Ã©tat (icÃ´ne mÃ©trics diffÃ©rentes) */
.prj-list-toolbar-chips { flex-wrap: nowrap; }
.prj-list-chip-icon { min-width: 36px; height: 32px; }
.prj-list-chip { height: 32px; }

/* Search bar fixed height to match chips */
.prj-list-search-wrapper input[type="text"], .prj-list-search-wrapper input[type="search"] { height: 32px !important; line-height: 1.2 !important; }

/* Titre Projets : padding rÃ©duit pour alignement prÃ©cis avec le titre du header projet droit
   (qui est Ã  top + 12px avec font-size 1.05rem). Anton Ã  1.65rem occupe plus de hauteur,
   donc on remonte le padding-top pour aligner les baselines visuelles. */
.prj-list-page-header { padding: 8px 18px 12px !important; }
.prj-list-page-title { font-size: 1.4rem !important; line-height: 1 !important; margin: 0 0 12px !important; }

/* Filtres avancÃ©s (collapse) sur fond blanc â€” Ã©tape 6.6 fix lisibilitÃ©.
   Override des couleurs blanches hÃ©ritÃ©es du thÃ¨me sombre historique. */
.prj-list-filters-collapse { padding: 10px 8px 12px; background: #fff; color: #2D3E50; }
/* Quand dÃ©pliÃ© : ligne fine + ombre douce vers le bas pour matÃ©rialiser la zone repliable */
.prj-list-filters-collapse.show { border-bottom: 1px solid #e2e8f0; box-shadow: 0 6px 8px -4px rgba(45,62,80,0.15); }
.prj-list-filters-collapse label { color: #475569 !important; font-size: 0.78rem; font-weight: 500; }
.prj-list-filters-collapse input[type="text"], .prj-list-filters-collapse input[type="number"], .prj-list-filters-collapse input[type="date"], .prj-list-filters-collapse select, .prj-list-filters-collapse textarea { color: #2D3E50 !important; background: #fff !important; border: 1px solid #cbd5e1 !important; width: 100% !important; }
.prj-list-filters-collapse .bootstrap-select { width: 100% !important; }
.prj-list-filters-collapse .bootstrap-select > .btn { color: #2D3E50 !important; background: #fff !important; border: 1px solid #cbd5e1 !important; width: 100% !important; }
.prj-list-filters-collapse .form-check-label, .prj-list-filters-collapse .form-check-input { color: #2D3E50 !important; }
/* Grille 2 colonnes serrÃ©e bord Ã  bord (alignÃ©e sur padding 8px du conteneur) */
.prj-list-filters-collapse .row.no-gutters { margin: 0 -3px; }
.prj-list-filters-collapse .col-md-6 { padding: 3px 3px; }
/* Form-group dropdowns full width */
.prj-list-filters-collapse .form-group { margin-bottom: 0; width: 100%; }

/* â”€â”€â”€ drw-prj â€” Drawer projet redesign (Ã©tape 4c4) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */

/* Corps */
.drw-prj-body { padding: 12px 16px 0; }

/* â”€â”€ Boutons footer â”€â”€ */
.drawer-project .btn-navy {
    background-color: #0d9488; border-color: #0d9488; color: #fff;
    padding: 0.42rem 1.2rem; font-size: 0.84rem; border-radius: 2px; font-weight: 500;
}
.drawer-project .btn-navy:hover,
.drawer-project .btn-navy:focus { background-color: #0f766e; border-color: #0f766e; color: #fff; }
.drawer-project .btn-cancel {
    border: 1px solid rgba(45,62,80,0.25); color: #415873; background: transparent;
    padding: 0.42rem 1.2rem; font-size: 0.84rem; border-radius: 2px;
}
.drawer-project .btn-cancel:hover { background-color: #f8fafb; border-color: rgba(45,62,80,0.45); color: #2D3E50; }

/* â”€â”€ Labels de champs (style drawer Action) â”€â”€ */
.drw-prj-field-label,
.drawer-project .form-group > label,
.drawer-project .form-group > legend.col-form-label {
    display: block; font-size: 0.72rem; font-weight: 600;
    color: #8fa1b3; text-transform: uppercase; letter-spacing: 0.04em;
    margin-bottom: 4px; padding-bottom: 0;
}
/* Labels des champs OBLIGATOIRES : navy pour mieux les distinguer (classe ajoutÃ©e par JS au chargement) */
.drawer-project .drw-prj-label-required { color: #2D3E50 !important; }
/* Petit espace de 3px avant l'Ã©toile rouge */
.drawer-project label .text-danger,
.drawer-project legend .text-danger,
.drawer-project .drw-prj-field-label .text-danger { margin-left: 3px; }

/* Lien switch vers l'espace Projets dans le footer du drawer (Ã©tape #1 2026-05-23).
   Style discret type lien : teal, soulignÃ© au hover, pas de fond. */
.drw-prj-switch-link { color: var(--ctx-teal, #0d9488) !important; font-size: 0.82rem; font-weight: 500; text-decoration: none !important; padding: 4px 8px; }
.drw-prj-switch-link:hover { color: #0f766e !important; text-decoration: underline !important; }
.drw-prj-switch-link:focus { box-shadow: none !important; }

/* â”€â”€ RESET ALIGNEMENT : tous les labels et widgets dÃ©marrent Ã  x=0 â”€â”€ */
/* Annule toutes les marges/paddings horizontaux hÃ©ritÃ©s de Bootstrap (col-*, .row, fieldset) */
.drawer-project .form-group,
.drawer-project .form-group.row,
.drawer-project fieldset.form-group {
    margin-left: 0 !important; margin-right: 0 !important;
    padding-left: 0 !important; padding-right: 0 !important;
    padding-top: 0 !important; padding-bottom: 0 !important;
    border: 0; min-width: 0;
}
.drawer-project .form-group > label,
.drawer-project .form-group > legend,
.drawer-project .form-group.row > label,
.drawer-project .form-group.row > legend,
.drawer-project fieldset.form-group > legend {
    flex: 0 0 100% !important; max-width: 100% !important; width: 100% !important;
    padding: 0 0 4px 0 !important; margin: 0 !important;
    float: none;
}
.drawer-project .form-group > div[class*="col-"],
.drawer-project .form-group.row > div[class*="col-"],
.drawer-project fieldset.form-group > div[class*="col-"] {
    flex: 0 0 100% !important; max-width: 100% !important;
    padding-left: 0 !important; padding-right: 0 !important;
    margin-left: 0 !important; margin-right: 0 !important;
}
/* Reset global de Bootstrap .row et col-* dans le corps du drawer */
.drawer-project .drw-prj-body .row { margin-left: 0 !important; margin-right: 0 !important; }
.drawer-project .drw-prj-body [class*="col-"] { padding-left: 0 !important; padding-right: 0 !important; }

/* Row des dates DÃ©but / Fin : 2 inputs cÃ´te Ã  cÃ´te, 50/50 avec gap (comme classification) */
.drawer-project .drw-prj-body > #main-content-edition > .row.mb-3 {
    display: flex !important; gap: 8px !important; margin: 0 !important;
}
.drawer-project .drw-prj-body > #main-content-edition > .row.mb-3 > .col-6 {
    flex: 1 1 0 !important; max-width: none !important; padding: 0 !important;
}
.drawer-project .drw-prj-body > #main-content-edition > .row.mb-3 > .col-6 > input,
.drawer-project .drw-prj-body > #main-content-edition > .row.mb-3 > .col-6 .form-control { width: 100% !important; }

/* â”€â”€ Champs (border + radius uniformes) â”€â”€ */
.drawer-project .form-control {
    border: 1px solid #dde1e7; border-radius: 2px;
    font-size: 0.84rem; padding: 0.32rem 0.6rem;
}
.drawer-project .form-control:focus { border-color: #0d9488; box-shadow: 0 0 0 2px rgba(13,148,136,0.12); }
.drawer-project .bootstrap-select > .btn {
    border: 1px solid #dde1e7 !important; border-radius: 2px !important;
    font-size: 0.84rem !important;
}
.drawer-project .bootstrap-select > .btn:focus,
.drawer-project .bootstrap-select.show > .btn { border-color: #0d9488 !important; }
/* Bootstrap Select copie .form-control sur le wrapper div â€” on retire sa bordure */
.drawer-project .bootstrap-select.form-control { border: none !important; padding: 0 !important; box-shadow: none !important; }
/* Annule aussi la bordure du <select> cachÃ© Ã  l'intÃ©rieur */
.drawer-project .bootstrap-select > select.form-control { border: none !important; box-shadow: none !important; }
.drawer-project .input-group .form-control { border-radius: 2px !important; }
.drawer-project .form-group { margin-bottom: 0; }
.drawer-project .bootstrap-select { width: 100% !important; }

/* â”€â”€ Espacement uniforme garanti via flex + gap â”€â”€ */
.drawer-project #main-content-edition,
.drawer-project .drw-prj-ctx-body {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}
/* Annule toutes marges sur les enfants directs (le gap gÃ¨re tout) */
.drawer-project #main-content-edition > *,
.drawer-project .drw-prj-ctx-body > * {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    flex-shrink: 0;
}
.drw-prj-body > div,
.drw-prj-body .mb-3,
.drw-prj-body .mb-2 { margin-bottom: 0 !important; }
/* Annule le padding-top: 1.1em ajoutÃ© par app.css ligne 2085 sur les .form-group dans #main-content-edition */
.drawer-project #main-content-edition .form-group { padding-top: 0 !important; }

/* â”€â”€ Ligne propriÃ©taire inline â”€â”€ */
.drw-prj-owner-inline {
    display: flex; flex-wrap: nowrap; align-items: baseline; gap: 4px;
    width: 100%;
    font-size: 0.82rem; padding: 5px 0 7px; border-bottom: 1px solid #f0f4f8;
}
/* SpÃ©cificitÃ© plus haute pour battre le reset .drawer-project #main-content-edition > * (qui force margin-top: 0) */
/* Gap parent flex = 18px, ramenÃ© Ã  ~6px effectif */
.drawer-project #main-content-edition > .drw-prj-owner-inline { margin-top: -12px !important; }
/* L'icÃ´ne Ã©dition est repoussÃ©e Ã  droite de la ligne */
.drw-prj-owner-inline .drw-prj-owner-edit-icon { margin-left: auto; }

/* Mode Ã©dition : les 2 selectpickers user/department cÃ´te Ã  cÃ´te, espacÃ©s (comme classification) */
/* Le :not(.d-none) Ã©vite que mon flex Ã©crase la classe Bootstrap d-none Ã  l'Ã©tat initial */
.drw-prj-owner-fields-row:not(.d-none) {
    display: flex !important;
    gap: 8px !important;
}
.drw-prj-owner-fields-row > .drw-prj-owner-field {
    flex: 1 1 0 !important;
    min-width: 0 !important;
}
.drw-prj-owner-fields-row .bootstrap-select { width: 100% !important; }
/* Corrige le data-style="text-white btn-sm" hÃ©ritÃ© de l'ancien drawer : invisible sur fond clair */
.drw-prj-owner-fields-row .bootstrap-select > .btn { color: #415873 !important; background: #fff !important; }
.drw-prj-owner-fields-row .bootstrap-select > .btn .filter-option { color: #415873 !important; }
.drw-prj-owner-fields-row .bootstrap-select > .btn .bs-caret { color: #415873 !important; }
.drw-prj-owner-label { color: #8fa1b3; font-size: 0.74rem; }
.drw-prj-owner-value { color: #2D3E50; font-weight: 400; font-size: 0.78rem; }
.drw-prj-owner-sep { color: #cbd5e1; font-size: 0.70rem; padding: 0 1px; }
.drw-prj-owner-modify { color: #0d9488; font-size: 0.78rem; font-weight: 500; }
.drw-prj-owner-modify:hover { color: #0f766e; text-decoration: none; }
/* IcÃ´ne Ã©dition PropriÃ©taire/Equipe : visible uniquement au hover de la ligne, gris â†’ teal au hover direct */
.drw-prj-owner-edit-icon {
    visibility: hidden;
    color: #9ca3af;
    font-size: 0.78rem;
    margin-left: 6px;
    padding: 2px 4px;
    text-decoration: none !important;
    transition: color 0.15s ease;
}
.drw-prj-owner-inline:hover .drw-prj-owner-edit-icon { visibility: visible; }
.drw-prj-owner-edit-icon:hover { color: #0d9488; text-decoration: none !important; }

/* â”€â”€ Lignes Collection (Prescripteurs, Groupesâ€¦) â”€â”€ */
.drawer-project .ordering-department-row,
.drawer-project .ordering-organization-row {
    display: flex !important; flex-wrap: nowrap !important;
    align-items: center; gap: 4px; margin-bottom: 4px;
}
/* Selectpicker prend toute la place disponible */
.drawer-project .ordering-department-row .col-6,
.drawer-project .ordering-organization-row .col-6 {
    flex: 1 1 0; max-width: none; padding: 0;
}
/* Colonne trash : taille fixe */
.drawer-project .ordering-department-row .col-1,
.drawer-project .ordering-organization-row .col-1 {
    flex: 0 0 28px; max-width: 28px; width: 28px; padding: 0;
}
/* Trash : invisible par dÃ©faut, visible au hover de la ligne */
.drawer-project .ordering-department-row .btnDelete,
.drawer-project .ordering-organization-row .btnDelete {
    visibility: hidden; border: none; background: none;
    color: #9ca3af; padding: 3px 5px; line-height: 1; border-radius: 2px;
    font-size: 0.80rem;
}
.drawer-project .ordering-department-row:hover .btnDelete,
.drawer-project .ordering-organization-row:hover .btnDelete { visibility: visible; }
.drawer-project .ordering-department-row .btnDelete:hover,
.drawer-project .ordering-organization-row .btnDelete:hover {
    color: #ef4444 !important; background: rgba(239,68,68,0.07);
}

/* â”€â”€ SystÃ¨me de tags pour collections (orderingDepartments, orderingOrganizations) â”€â”€ */
/* Force masquage du CollectionType existant (le rendu form_row est conservÃ© pour la soumission) */
.drw-prj-tag-collection-wrapper { display: none !important; }
.drw-prj-tag-list {
    display: flex; flex-wrap: wrap; gap: 4px;
    margin-top: 6px;
}
.drw-prj-tag-list:empty { display: none; }
.drw-prj-tag {
    display: inline-flex; align-items: center; gap: 4px;
    background: #e6f7f5; color: #0d9488;
    border: 1px solid rgba(13,148,136,0.25);
    border-radius: 2px;
    padding: 2px 2px 2px 8px;
    font-size: 0.74rem; line-height: 1.4;
    max-width: 100%;
}
.drw-prj-tag .drw-prj-cat-tag-dot { margin: 0; }
.drw-prj-tag-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.drw-prj-tag-remove {
    color: #0d9488; opacity: 0.55;
    padding: 0 5px; margin-left: 2px;
    font-weight: 700; font-size: 1rem; line-height: 1;
    text-decoration: none !important;
}
.drw-prj-tag-remove:hover { opacity: 1; color: #ef4444; text-decoration: none !important; }

/* â”€â”€â”€ Ã‰tape 4c.2 â€” Multi-tags Familles d'achats (composer + tags + drag-and-drop) â”€â”€â”€ */
/* Le widget Symfony CollectionType brut est masquÃ© (rendu dans <template> inerte par le JS) */
.drw-prj-cat-field .drw-prj-categories-collection { display: none !important; }
/* Composer : 2 selects + bouton sur une ligne */
.drw-prj-cat-composer {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: 6px;
    align-items: center;
    margin-bottom: 6px;
}
.drw-prj-cat-composer .bootstrap-select { width: 100% !important; }
.drw-prj-cat-composer .bootstrap-select > .btn {
    background: #fff !important;
    border: 1px solid #cbd5e1 !important;
    color: #2D3E50 !important;
    font-size: 0.78rem;
    height: 30px;
}
.drw-prj-cat-add {
    background: #0d9488;
    color: #fff;
    border: 1px solid #0d9488;
    border-radius: 4px;
    padding: 0 12px;
    height: 30px;
    font-size: 0.78rem;
    font-weight: 500;
    white-space: nowrap;
    cursor: pointer;
    transition: background 0.15s ease;
}
.drw-prj-cat-add:hover:not(:disabled) { background: #0b7c72; border-color: #0b7c72; }
.drw-prj-cat-add:disabled {
    background: #e2e8f0;
    color: #94a3b8;
    border-color: #e2e8f0;
    cursor: not-allowed;
}
/* Zone tags : aucun espace rÃ©servÃ© tant qu'aucun tag n'a Ã©tÃ© ajoutÃ© */
.drw-prj-cat-tags {
    display: flex; flex-wrap: wrap; gap: 4px;
}
.drw-prj-cat-tags:not(:empty) {
    margin-top: 4px;
}
.drw-prj-cat-tag {
    display: inline-flex; align-items: center; gap: 4px;
    background: #e6f7f5; color: #0d9488;
    border: 1px solid rgba(13,148,136,0.25);
    border-radius: 2px;
    padding: 2px 4px 2px 6px;
    font-size: 0.74rem; line-height: 1.4;
    max-width: 100%;
    cursor: grab;
    user-select: none;
}
.drw-prj-cat-tag.dragging { opacity: 0.4; cursor: grabbing; }
.drw-prj-cat-tag.drag-over { box-shadow: 0 0 0 2px #0d9488; }
.drw-prj-cat-tag-dot {
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 1px;
    flex-shrink: 0;
}
/* Ã‰toile marqueur "famille principale" â€” remplace l'ancien badge PRINCIPALE plus criard (4c.2-bis) */
.drw-prj-cat-tag-star {
    color: #0d9488;
    font-size: 0.72rem;
    line-height: 1;
    flex-shrink: 0;
    cursor: help;
}
/* Conserve l'ancien selector au cas oÃ¹ il est encore appelÃ© ailleurs â€” invisible */
.drw-prj-cat-tag-badge {
    display: none;
}
.drw-prj-cat-tag.main { background: #d4f0ec; border-color: rgba(13,148,136,0.5); }
.drw-prj-cat-tag-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.drw-prj-cat-tag-remove {
    color: #0d9488; opacity: 0.55;
    padding: 0 4px; margin-left: 2px;
    font-weight: 700; font-size: 1rem; line-height: 1;
    text-decoration: none !important;
    cursor: pointer;
}
.drw-prj-cat-tag-remove:hover { opacity: 1; color: #ef4444; text-decoration: none !important; }
/* Texte d'aide sous les tags â€” explique le drag-and-drop + rÃ´le de la famille principale (4c.2-bis) */
.drw-prj-cat-help {
    margin-top: 6px;
    font-size: 0.68rem;
    color: #94a3b8;
    line-height: 1.4;
    display: none; /* affichÃ© par JS dÃ¨s qu'au moins 1 tag est prÃ©sent */
}
.drw-prj-cat-help i { color: inherit; font-size: 0.66rem; }

/* === Tooltip dark gÃ©nÃ©rique (DS) â€” rÃ©utilise le pattern .fin-btn[data-tooltip] mais factorisÃ© ===
   Usage : ajouter class="ds-tt" + data-tooltip="texte" sur n'importe quel Ã©lÃ©ment.
   PositionnÃ© en haut par dÃ©faut. Pour placer en bas : ajouter class="ds-tt-bottom" (utile quand le parent
   a overflow:hidden et que l'Ã©lÃ©ment est proche du haut de la zone visible â€” ex. display Contexte). */
.ds-tt { position: relative; cursor: help; }
.ds-tt[data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%);
    background: #1f2937; color: #fff;
    font-size: 0.72rem; font-weight: 400; line-height: 1.4;
    padding: 6px 10px; border-radius: 6px;
    width: max-content; max-width: 260px;
    text-align: center; white-space: normal;
    box-shadow: 0 4px 14px rgba(0,0,0,0.18);
    opacity: 0; pointer-events: none;
    transition: opacity 0.18s; z-index: 1100;
}
.ds-tt[data-tooltip]::before {
    content: '';
    position: absolute;
    bottom: calc(100% + 2px); left: 50%; transform: translateX(-50%);
    border: 5px solid transparent; border-top-color: #1f2937;
    opacity: 0; pointer-events: none;
    transition: opacity 0.18s; z-index: 1100;
}
.ds-tt[data-tooltip]:hover::after,
.ds-tt[data-tooltip]:hover::before { opacity: 1; }
/* Variante "tooltip en bas" â€” pour Ã©lÃ©ments proches du haut de leur scrollable container */
.ds-tt-bottom[data-tooltip]::after {
    bottom: auto; top: calc(100% + 8px);
}
.ds-tt-bottom[data-tooltip]::before {
    bottom: auto; top: calc(100% + 2px);
    border-top-color: transparent; border-bottom-color: #1f2937;
}
/* Variante "ancrage Ã  gauche du trigger" â€” tooltip extends VERS LA DROITE plutÃ´t que centrÃ©.
   Utile quand l'Ã©lÃ©ment est proche du bord gauche d'un conteneur Ã  overflow:hidden (drawer, scroll). */
.ds-tt-left[data-tooltip]::after {
    left: 0; transform: none;
}
.ds-tt-left[data-tooltip]::before {
    left: 8px; transform: none;
}
/* â”€â”€â”€ Mode lecture seule du drawer projet (contributeur sans droit edit) â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Le wrapper .drawer-body porte la classe .drw-prj-readonly-mode quand isReadOnly=true.
   Masque les affordances d'Ã©dition (composer Familles, +Ajouter, source dropdowns,
   bouton Ã—, drag) tout en gardant l'affichage des valeurs. Le 'disabled' Symfony grise
   dÃ©jÃ  les inputs/selects natifs. */
.drw-prj-readonly-mode .drw-prj-cat-composer,
.drw-prj-readonly-mode .drw-prj-cat-help,
.drw-prj-readonly-mode .drw-prj-tag-field .drw-prj-tag-source,
.drw-prj-readonly-mode .drw-prj-tag-field > .bootstrap-select { display: none !important; }
.drw-prj-readonly-mode .drw-prj-tag-remove,
.drw-prj-readonly-mode .drw-prj-cat-tag-remove { display: none !important; }
.drw-prj-readonly-mode .drw-prj-cat-tag,
.drw-prj-readonly-mode .drw-prj-tag { cursor: default !important; }
.drw-prj-readonly-mode .drw-prj-cat-tag[draggable="true"] { -webkit-user-drag: none; }
.drw-prj-readonly-mode .drw-prj-owner-edit-icon { display: none !important; }

/* Ã‰tat erreur : bordure rouge sur le composer + zone tags. Le "!" form_errors est rendu inline dans le label. */
.drw-prj-cat-field.has-error .drw-prj-cat-composer .bootstrap-select > .btn,
.drw-prj-cat-field.has-error .drw-prj-cat-tags,
.drw-prj-tag-field.has-error .bootstrap-select > .btn,
.drw-prj-tag-field.has-error .drw-prj-tag-list {
    border: 1px solid #ef4444 !important;
}
.drw-prj-cat-field.has-error .drw-prj-cat-tags,
.drw-prj-tag-field.has-error .drw-prj-tag-list {
    border-radius: 4px;
    padding: 4px;
    min-height: 32px;
    display: flex !important;
}
.drw-prj-cat-field.has-error .drw-prj-field-label,
.drw-prj-tag-field.has-error .drw-prj-field-label,
.drw-prj-date-field.has-error .drw-prj-field-label { color: #ef4444 !important; }
.drw-prj-date-field.has-error input,
.drw-prj-date-field.has-error .form-control,
.drw-prj-name-field.has-error input,
.drw-prj-name-field.has-error .form-control { border: 1px solid #ef4444 !important; }
/* Message d'erreur INLINE (toujours visible sous le champ, remplace les popovers d'erreur sur "!").
   Ã‰vite la collision avec les popovers descriptifs "?" + plus accessible. UtilisÃ© via la macro errInline()
   au top de templates/frontend/project/_form.html.twig. */
.drw-prj-err-inline {
    color: #ef4444;
    font-size: 0.74rem;
    line-height: 1.3;
    margin-top: 4px;
}

/* â”€â”€ Indicateur de complÃ©tude (carte Contexte) â”€â”€ */
.ctx-completion {
    display: inline-flex; align-items: center; justify-content: center;
    width: 18px; height: 18px; cursor: help;
    transition: transform 0.15s ease;
}
.ctx-completion:hover { transform: scale(1.15); }
.ctx-completion svg { width: 100%; height: 100%; display: block; }

/* â”€â”€ Tags read-only (mode display onglet Contexte) â”€â”€ */
.drw-prj-tag-display { display: flex; flex-wrap: wrap; gap: 4px; align-items: center; }
.drw-prj-tag-readonly {
    display: inline-flex; align-items: center; gap: 4px;
    background: #e6f7f5; color: #0d9488;
    border: 1px solid rgba(13,148,136,0.25);
    border-radius: 2px;
    padding: 2px 8px;
    font-size: 0.74rem; line-height: 1.4;
    max-width: 100%;
}
.drw-prj-tag-readonly .drw-prj-cat-tag-dot { margin: 0; }
.drw-prj-tag-readonly-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.drw-prj-tag-more {
    display: inline-flex; align-items: center;
    background: #f1f5f9; color: #64748b;
    border: 1px solid #cbd5e1;
    border-radius: 2px;
    padding: 2px 8px;
    font-size: 0.74rem; line-height: 1.4;
    cursor: help;
}
.drw-prj-tag-more:hover { background: #e2e8f0; color: #475569; }

/* Bouton Ajouter des collections */
.drawer-project .add_element_link.btn.btn-primary {
    background: transparent !important; color: #0d9488 !important;
    border: 1px solid #0d9488 !important; border-radius: 2px !important;
    font-size: 0.78rem !important; padding: 3px 10px !important;
    font-weight: 500; margin-top: 3px;
}
.drawer-project .add_element_link.btn.btn-primary:hover {
    background: rgba(13,148,136,0.08) !important; color: #0d9488 !important;
}

/* Classification (Famille d'achats) : 2 selects cÃ´te Ã  cÃ´te avec gap (override du reset global .drw-prj-body .row) */
.drawer-project .classification_widget .row {
    display: flex !important;
    gap: 8px !important;
    margin: 0 !important;
}
.drawer-project .classification_widget .col-md-6 {
    flex: 1 1 0 !important;
    max-width: none !important;
    padding: 0 !important;
}
.drawer-project .classification_widget .bootstrap-select { width: 100% !important; }

/* â”€â”€ Slider (pleine largeur, rectangles serrÃ©s) â”€â”€ */
.drw-prj-slider-section { margin-bottom: 10px; }
.drw-prj-slider { display: flex; width: 100%; gap: 1px; margin-bottom: 3px; padding-left: 0; }
/* Cache les wrappers .form-check des radios cachÃ©s du slider (ils crÃ©ent un padding-left visible) */
.drw-prj-slider > .form-check,
.drw-prj-slider > .radio { display: none !important; }
.drw-prj-slider-btn {
    flex: 1; height: 28px; min-width: 0;
    border: 1px solid #dde1e7; border-radius: 2px;
    background: #fff; color: #415873;
    font-size: 0.82rem; font-weight: 500;
    cursor: pointer; padding: 0; margin: 0;
    display: flex; align-items: center; justify-content: center;
    transition: border-color 0.12s, background 0.12s, color 0.12s;
}
.drw-prj-slider-btn:first-child { margin-left: 0 !important; }
.drw-prj-slider-btn:hover { border-color: #0d9488; color: #0d9488; }
.drw-prj-slider-btn.active {
    background: #0d9488; border-color: #0d9488; color: #fff; font-weight: 600;
}
/* Variante read-only pour le display (onglet Contexte) â€” pas de hover/cursor */
.drw-prj-slider-display { max-width: 280px; }
/* La lÃ©gende sous le slider display suit la mÃªme largeur (sinon "ElevÃ©" dÃ©borde Ã  droite) */
.drw-prj-slider-display + .drw-prj-slider-legend { max-width: 280px; font-weight: 300 !important; color: #9ca3af !important; }
.drw-prj-slider-display + .drw-prj-slider-legend span { font-weight: 300 !important; }

/* Espace au-dessus du row "Objectif Achats" pour le dÃ©tacher des sliders au-dessus */
.ctx-row-after-slider { padding-top: 4px !important; }
/* Boutons non sÃ©lectionnÃ©s du slider DISPLAY : ton trÃ¨s clair pour signaler que c'est en lecture seule */
.drw-prj-slider-btn-readonly {
    cursor: default !important; pointer-events: none;
    border-color: #e2e8f0;
    color: #cbd5e1;
    font-weight: 400;
}
.drw-prj-slider-btn-readonly:hover { border-color: #e2e8f0; color: #cbd5e1; }
/* Le bouton sÃ©lectionnÃ© garde le teal franc pour bien ressortir */
.drw-prj-slider-btn-readonly.active,
.drw-prj-slider-btn-readonly.active:hover { background: #0d9488; border-color: #0d9488; color: #fff; font-weight: 600; }
/* LÃ©gende : Faible collÃ© Ã  gauche du rectangle 1, Ã‰levÃ© collÃ© Ã  droite du rectangle 5 */
.drw-prj-slider-legend {
    display: flex; justify-content: space-between;
    font-size: 0.64rem; color: #8fa1b3; margin-top: 2px;
}
.drw-prj-slider-legend span:first-child { text-align: left; }
.drw-prj-slider-legend span:last-child  { text-align: right; }

/* CKEditor (Description / Contexte) : hauteur rÃ©duite dans le drawer */
/* Mode inline (fos_ck_editor.yaml : inline: true) â†’ cible UNIQUEMENT le contenteditable visible pour Ã©viter de cumuler avec les wrappers */
.drawer-project .cke_editable_inline,
.drawer-task .cke_editable_inline {
    height: 80px !important;
    max-height: 80px !important;
    min-height: 80px !important;
    overflow-y: auto !important;
    /* EmpÃªche le scroll de propager au drawer parent quand on scrolle dans le champ */
    overscroll-behavior: contain;
    /* Scrollbar fine (Firefox + Chromium standard) */
    scrollbar-width: thin;
    scrollbar-color: #c4c9d0 transparent;
}
/* Scrollbar fine WebKit (Chrome, Safari, Edge) */
.drawer-project .cke_editable_inline::-webkit-scrollbar,
.drawer-task .cke_editable_inline::-webkit-scrollbar { width: 4px; }
.drawer-project .cke_editable_inline::-webkit-scrollbar-track,
.drawer-task .cke_editable_inline::-webkit-scrollbar-track { background: transparent; }
.drawer-project .cke_editable_inline::-webkit-scrollbar-thumb,
.drawer-task .cke_editable_inline::-webkit-scrollbar-thumb { background: #c4c9d0; border-radius: 2px; }
.drawer-project .cke_editable_inline::-webkit-scrollbar-thumb:hover,
.drawer-task .cke_editable_inline::-webkit-scrollbar-thumb:hover { background: #9ca3af; }

/* â”€â”€ Section Contexte et qualification â”€â”€ */
/* MÃªme look que .drawer-section du drawer Action */
.drw-prj-ctx-section {
    margin: 0 -16px;
    background: #f8fafb;
    border-top: 1px solid #e2e8f0;
    border-bottom: 1px solid #e2e8f0;
}
.drw-prj-ctx-toggle {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 16px; cursor: pointer; text-decoration: none !important;
    border-radius: 0;
    transition: background-color 0.15s ease;
}
.drw-prj-ctx-toggle:hover { background-color: #eef4f5; text-decoration: none !important; }
.drw-prj-ctx-toggle:hover .drw-prj-ctx-title { color: #0f766e; }
.drw-prj-ctx-toggle:hover .drw-prj-ctx-icon { color: #0f766e; }
/* Marqueur "(facultatif)" sur label */
.drw-prj-optional-mark { color: #94a3b8; font-weight: 400; font-size: 0.66rem; text-transform: none; letter-spacing: 0; margin-left: 4px; }

/* Adoucit le titre/nom du projet dans le drawer (.item-edit-title est trÃ¨s gras/grand par dÃ©faut dans app.css) */
.drawer-project .item-edit-title {
    font-size: 1.05rem !important;
    font-weight: 400 !important;
    border-bottom: 1px solid #dde1e7 !important;
    padding: 6px 4px !important;
    color: #2D3E50;
}
.drawer-project .item-edit-title::placeholder { font-weight: 300 !important; color: #94a3b8 !important; font-size: 0.95rem; }
/* Vendor specific (placeholder shadow) pour le poids 300 */
.drawer-project .item-edit-title::-webkit-input-placeholder { font-weight: 300 !important; }
.drawer-project .item-edit-title::-moz-placeholder { font-weight: 300 !important; opacity: 1; }
.drawer-project .item-edit-title:-ms-input-placeholder { font-weight: 300 !important; }
.drw-prj-ctx-title {
    font-size: 0.79rem; font-weight: 600; color: #0d9488;
}
.drw-prj-ctx-opt {
    font-size: 0.69rem; color: #8fa1b3; font-weight: 400; margin-left: 5px;
}
.drw-prj-ctx-icon { font-size: 0.80rem; color: #0d9488; }
.drw-prj-ctx-body { padding: 2px 16px 14px; }

/* Radio buttons dans le drawer projet â€” curseur cohÃ©rent partout pour Ã©viter clignotement */
.drawer-project .form-check { padding-left: 1.35rem; margin-bottom: 2px; cursor: pointer; }
.drawer-project .form-check-input { cursor: pointer; }
.drawer-project .form-check-label { font-size: 0.82rem; color: #415873; cursor: pointer; }
.drawer-project input[type="radio"]:checked + .form-check-label { color: #2D3E50; font-weight: 500; }
/* Radio button â€” override du global app.css (input radio masquÃ© + fake radio via .radio-label::before)
   Le PHP ProjectType.php ajoute la classe .radio-label au label quand DISPLAY_MODE_RADIO_VERTICAL.
   Cible le pseudo-Ã©lÃ©ment ::before du label, pas l'input natif (qui est opacity:0). */
.drawer-project input[type="radio"] + .radio-label::before {
    background: #fff;
    border: 1px solid #cbd5e1;
    width: 14px; height: 14px;
    margin-right: 8px;
    top: 0.15em;
    transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}
.drawer-project input[type="radio"] + .radio-label:hover::before { border-color: #0d9488; }
.drawer-project input[type="radio"]:checked + .radio-label::before {
    background-color: #0d9488;
    border-color: #0d9488;
    box-shadow: inset 0 0 0 3px #fff;
}
.drawer-project input[type="radio"]:focus + .radio-label::before { border-color: #0d9488; }
/* DÃ©sactive les tooltips Bootstrap qui pourraient s'ouvrir sur les radios (suppression dÃ©finitive) */
.drawer-project .form-check [data-toggle="tooltip"],
.drawer-project .form-check [data-toggle="popover"] { pointer-events: auto; }

/* â”€â”€ CommunautÃ© â€” FineUploader chunked (Ã©tape 6b.2 du 2026-05-22) â”€â”€
   Style du conteneur uploader FineUploader pour les modales et drawer post.
   RÃ©utilise les classes natives qq-* fournies par fine-uploader-new.css. */

/* Mode "ajout document" : la dropzone couvre la zone d'activitÃ© (full-width, sans encart latÃ©ral)
   et masque temporairement les commentaires. Toggle via la classe `com-doc-mode` sur `.com-thread`. */
.com-thread.com-doc-mode .com-activity-feed,
.com-thread.com-doc-mode .com-activity-separator,
.com-thread.com-doc-mode .com-thread-reactions { display: none !important; }
.com-thread.com-doc-mode .com-thread-reply-form { flex: 1 1 auto; display: flex; flex-direction: column; padding: 0; }
.com-thread.com-doc-mode .com-doc-upload-form { flex: 1 1 auto; margin: 0; padding: 16px 16px 12px; border-radius: 0; border-top: var(--com-border); border-bottom: var(--com-border); display: flex; flex-direction: column; }
.com-thread.com-doc-mode .com-doc-upload-form > .com-doc-uploader { flex: 1 1 auto; display: flex; flex-direction: column; }
.com-thread.com-doc-mode .com-doc-upload-form > .com-doc-uploader .qq-uploader { height: 100%; display: flex; flex-direction: column; }
.com-thread.com-doc-mode .com-doc-upload-form > .com-doc-uploader .qq-upload-button { flex: 1 1 auto; display: flex !important; align-items: center; justify-content: center; }
.com-thread.com-doc-mode .com-compose-bar { padding: 8px 12px; border-top: none; }
/* Hint sous la dropzone â€” explication glisser-dÃ©poser */
.com-doc-upload-hint { margin-top: 6px; font-size: 0.74rem; color: var(--com-muted); text-align: center; font-style: italic; }

.com-doc-uploader { display: block; width: 100%; }
/* Neutralise les styles natifs FineUploader (padding 20px, min-height 200px, border dashed gris)
   pour que la dropzone occupe toute la largeur sans gros encart visuel autour. */
.com-doc-uploader .qq-uploader { padding: 0 !important; min-height: 0 !important; max-height: none !important; border: none !important; background: transparent !important; width: 100% !important; overflow: visible !important; }
.com-doc-uploader .qq-uploader:before { display: none !important; }
.com-doc-uploader .qq-upload-button { display: block !important; float: none !important; width: 100% !important; min-height: 70px; margin: 0 !important; background: var(--com-bg) !important; border: 1px dashed var(--com-border-color, #d1d5db) !important; color: var(--com-navy) !important; padding: 18px 16px !important; border-radius: var(--com-radius); cursor: pointer; transition: background 0.12s, border-color 0.12s; text-align: center; box-shadow: none !important; }
.com-doc-uploader .qq-upload-button:hover { background: #eef2f6; border-color: var(--com-teal); }
.com-doc-uploader .qq-upload-list { list-style: none; padding: 0; margin: 8px 0 0; font-size: 0.85rem; }
.com-doc-uploader .qq-upload-list li { padding: 6px 10px; background: #f8fafc; border: 1px solid #eef2f6; border-radius: 6px; margin-top: 4px; display: flex; align-items: center; gap: 8px; }
.com-doc-uploader .qq-upload-file { color: var(--com-navy); font-weight: 500; }
.com-doc-uploader .qq-upload-size { color: var(--com-muted); font-size: 0.75rem; }
.com-doc-uploader .qq-progress-bar { background: var(--com-teal); height: 3px; border-radius: 2px; }
.com-doc-uploader .qq-progress-bar-container { background: #e5e7eb; height: 3px; border-radius: 2px; margin-top: 3px; }
.com-doc-uploader .qq-upload-cancel, .com-doc-uploader .qq-upload-delete { color: #ef4444; cursor: pointer; font-size: 0.75rem; margin-left: auto; }
.com-doc-uploader .qq-upload-status-text { color: var(--com-muted); font-size: 0.75rem; }

/* Variante compacte pour le drawer post (input zone rÃ©duite) */
.com-doc-uploader-sm .qq-upload-button { padding: 16px 16px; font-size: 0.85rem; min-height: 64px; }

/* â”€â”€ Community: dropdown "Ajouter" dans la barre d'onglets â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-switcher-bar {
    justify-content: space-between !important;
}
.com-switcher-actions {
    display: flex;
    align-items: center;
    padding-right: 4px;
}
.com-add-dropdown {
    position: relative;
}
.com-add-dropdown-btn {
    display: inline-flex;
    align-items: center;
    font-size: 0.78rem;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: var(--com-radius, 6px);
    background: var(--com-teal, #0d9488);
    color: #fff;
    border: none;
    box-shadow: 0 1px 2px rgba(0,0,0,0.08);
    transition: background .15s, transform .1s, box-shadow .15s;
    cursor: pointer;
}
.com-add-dropdown-btn:hover,
.com-add-dropdown-btn:focus {
    background: #0b7a70;
    color: #fff;
    text-decoration: none;
    box-shadow: 0 2px 6px rgba(13,148,136,0.25);
}
.com-add-dropdown-btn:focus { outline: none; }
.com-add-dropdown-caret {
    font-size: 0.65rem;
    transition: transform .15s;
}
.com-add-dropdown.show .com-add-dropdown-caret {
    transform: rotate(180deg);
}
.com-add-dropdown-menu {
    min-width: 220px;
    padding: 6px;
    margin-top: 6px;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    box-shadow: 0 6px 20px rgba(0,0,0,0.10);
}
.com-add-item {
    display: flex !important;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: 6px;
    font-size: 0.82rem;
    font-weight: 500;
    color: #1f2937;
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background .12s, color .12s;
}
.com-add-item + .com-add-item { margin-top: 2px; }
.com-add-item-icon {
    width: 22px;
    text-align: center;
    font-size: 0.95rem;
}
.com-add-item-conversation .com-add-item-icon { color: #4b7bb5; }
.com-add-item-event        .com-add-item-icon { color: #4d8c6f; }
.com-add-item-poll         .com-add-item-icon { color: #6b5fa5; }
.com-add-item-document     .com-add-item-icon { color: #a07840; }

.com-add-item-conversation:hover,
.com-add-item-conversation:focus {
    background: #eef3fb;
    color: #4b7bb5;
}
.com-add-item-event:hover,
.com-add-item-event:focus {
    background: #edf7f3;
    color: #4d8c6f;
}
.com-add-item-poll:hover,
.com-add-item-poll:focus {
    background: #f2f0fa;
    color: #6b5fa5;
}
.com-add-item-document:hover,
.com-add-item-document:focus {
    background: #faf4ec;
    color: #a07840;
}

/* â”€â”€ Community: badges sur le header des sections Ã©pinglÃ©es â”€â”€â”€â”€â”€â”€ */
.com-pinned-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 16px;
    padding: 0 6px;
    border-radius: 10px;
    font-size: 0.62rem;
    font-weight: 700;
    color: #fff;
    line-height: 1;
    margin-left: 2px;
}
.com-pinned-badge-unread { background: #dc2626; }
.com-pinned-badge-due    { background: #d97706; }
.com-pinned-badge-vote   { background: #6b5fa5; }

/* â”€â”€ Community Documents: scroll interne sur le tableau â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Layout identique au feed : container 100vh, header/toolbar figÃ©s,
   tbody scrollable, thead sticky. Ã‰vite la scrollbar de page globale. */
#main-content-community-docs {
    height: 100vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
#main-content-community-docs .com-page-header { flex-shrink: 0; }
#main-content-community-docs .com-docs-page-body {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding-bottom: 0;
}
#main-content-community-docs .com-docs-toolbar-v3 { flex-shrink: 0; }
#main-content-community-docs .com-docs-section {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    margin-bottom: 20px;
}
#main-content-community-docs .com-docs-table thead th {
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 2;
}
/* Scrollbar fine, cohÃ©rente avec le feed Community */
#main-content-community-docs .com-docs-section::-webkit-scrollbar { width: 6px; background: transparent; }
#main-content-community-docs .com-docs-section::-webkit-scrollbar-track { background: transparent; }
#main-content-community-docs .com-docs-section::-webkit-scrollbar-thumb { background: #c4c9d0; border-radius: 4px; }
#main-content-community-docs .com-docs-section::-webkit-scrollbar-thumb:hover { background: #9ca3af; }
#main-content-community-docs .com-docs-section { scrollbar-width: thin; scrollbar-color: #c4c9d0 transparent; }

/* â”€â”€ Community: flash highlight aprÃ¨s crÃ©ation d'un post â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-post-flash {
    animation: comPostFlash 1.8s ease-out;
}
@keyframes comPostFlash {
    0%   { box-shadow: 0 0 0 0 rgba(13, 148, 136, 0.55); background-color: #e6f7f5; }
    60%  { box-shadow: 0 0 0 10px rgba(13, 148, 136, 0.0); background-color: #e6f7f5; }
    100% { box-shadow: 0 0 0 0 rgba(13, 148, 136, 0); background-color: transparent; }
}

/* â”€â”€ Community: aÃ©ration onglets + Ã©cart vers filtres â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-switcher { gap: 6px !important; }
.com-switcher-tab { padding: 18px 22px !important; }

/* Marge supÃ©rieure des filtres et du panneau droit alignÃ©e (24px) */
.com-filters   { margin-top: 24px !important; }
.com-col-right { padding-top: 24px !important; }

/* Hauteur des colonnes : compense les ~10px ajoutÃ©s au switcher */
.com-columns { height: calc(100vh - 130px) !important; }

/* â”€â”€ Community: label discret sur le cadre des filtres â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.com-filters-wrap {
    position: relative;
    margin-top: 24px;
}
.com-filters-wrap .com-filters {
    margin-top: 0 !important;
}
.com-filters-label {
    position: absolute;
    top: -7px;
    left: 12px;
    padding: 0 6px;
    background: var(--com-bg, #f5f7fa);
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--com-muted, #8fa1b3);
    line-height: 1;
    z-index: 1;
    pointer-events: none;
}

/* â”€â”€ Community: redesign onglets Ã‰quipe/Entreprise (v2) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   - Underline plus Ã©pais (3px) et plus visible
   - IcÃ´ne plus grosse et colorÃ©e selon l'Ã©tat
   - Ã‰tat hover et actif avec lÃ©ger fond teintÃ©
   - Badge non-lus repensÃ© : pastille ronde rouge cohÃ©rente avec sidebar */
.com-switcher-tab {
    position: relative;
    gap: 8px;
    font-size: 0.82rem !important;
    font-weight: 500 !important;
    color: var(--com-muted, #8fa1b3) !important;
    border-bottom: 3px solid transparent !important;
    border-radius: 4px 4px 0 0;
    transition: color .15s, background .15s, border-color .15s !important;
}
.com-switcher-tab i {
    font-size: 0.95rem;
    color: var(--com-muted, #8fa1b3);
    transition: color .15s;
}
/* Style unifie avec .tdl-tab (refonte 2026-05-31) :
   - hover : fond teal tres clair, texte teal
   - actif : fond teal clair plus marque, texte teal, gras, pas de soulignement teal fonce. */
.com-switcher-tab:hover {
    color: #0d9488 !important;
    background: #f0fbf9 !important;
}
.com-switcher-tab:hover i {
    color: #0d9488;
}
.com-switcher-tab.active {
    color: #0d9488 !important;
    font-weight: 600 !important;
    background: #e6f7f5 !important;
    border-bottom-color: transparent !important;
}
.com-switcher-tab.active i {
    color: #0d9488;
}

/* Underline animÃ© au hover sur les onglets non actifs (pseudo-Ã©lÃ©ment qui grandit depuis le centre) */
.com-switcher-tab::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: -3px;
    width: 0;
    height: 3px;
    background: var(--com-teal, #0d9488);
    transform: translateX(-50%);
    transition: width .28s ease;
    opacity: 0.5;
    border-radius: 2px 2px 0 0;
    pointer-events: none;
}
.com-switcher-tab:not(.active):hover::after {
    width: 100%;
}

/* Couleurs d'icÃ´ne : navy attÃ©nuÃ© par dÃ©faut, teal sur onglet actif */
.com-switcher-tab i { color: #64748b !important; }
.com-switcher-tab.active i { color: var(--com-teal, #0d9488) !important; }

/* Onglet : limite la largeur du texte et tronque avec ellipsis pour les noms longs.
   Le tooltip natif (attribut title) permet de voir le nom complet au survol. */
.com-switcher-tab {
    max-width: 260px;
    min-width: 0;
    flex-shrink: 0;
}
.com-switcher-tab-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
    flex: 0 1 auto;
}

/* â”€â”€ Layout overflow : onglets ne wrappent jamais, espace rÃ©servÃ© Ã  droite pour Ajouter â”€â”€ */
.com-switcher-left {
    display: flex;
    align-items: center;
    flex: 1 1 auto;
    min-width: 0;
}
.com-switcher {
    flex-wrap: nowrap;
    overflow: hidden;
    min-width: 0;
    flex: 0 1 auto;
}
.com-switcher-actions { flex-shrink: 0; }

/* Bouton "+" overflow tabs : positionnÃ© juste aprÃ¨s le dernier onglet visible
   (et non collÃ© au bouton Ajouter Ã  droite) â€” dÃ©clenche le dropdown des onglets cachÃ©s */
.com-switcher-overflow {
    flex-shrink: 0;
    margin-left: 12px;
    align-self: stretch;
    display: flex;
    align-items: center;
}
.com-switcher-overflow-btn {
    padding: 6px 10px;
    background: transparent;
    border: none;
    border-radius: 4px;
    color: #64748b;
    cursor: pointer;
    transition: background .15s, color .15s;
    font-size: 0.95rem;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
/* Badge non-lus cumulÃ© sur les onglets cachÃ©s sous le "+" â€” mÃªme style que les badges d'onglet */
.com-switcher-overflow-badge {
    background: #fee2e2;
    color: #b91c1c;
    border-radius: 999px;
    min-width: 18px;
    height: 18px;
    padding: 0 6px;
    font-size: 0.65rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.com-switcher-overflow-btn:hover,
.com-switcher-overflow-btn:focus,
.com-switcher-overflow.show .com-switcher-overflow-btn {
    background: rgba(13, 148, 136, 0.08);
    color: var(--com-teal, #0d9488);
    outline: none;
}
.com-switcher-overflow-menu {
    min-width: 220px;
    padding: 6px;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.10);
    margin-top: 6px;
}
.com-switcher-overflow-item {
    display: flex !important;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 0.82rem;
    color: #1f2937;
    transition: background .12s, color .12s;
}
.com-switcher-overflow-item:hover,
.com-switcher-overflow-item:focus {
    background: rgba(13, 148, 136, 0.06);
    color: #1f2937;
    text-decoration: none;
}
.com-switcher-overflow-item.active {
    background: rgba(13, 148, 136, 0.10);
    color: var(--com-navy, #2D3E50);
    font-weight: 600;
}
.com-switcher-overflow-item .com-switcher-tab-text {
    overflow: visible;
    white-space: normal;
    word-break: break-word;
}
.com-switcher-overflow-item .com-badge {
    margin-left: auto !important;
    background: #fee2e2 !important;
    color: #b91c1c !important;
    border-radius: 999px !important;
    min-width: 18px !important;
    height: 18px !important;
    padding: 0 6px !important;
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    box-shadow: none;
}

/* SÃ©parateur visuel entre le groupe "Ã©quipes" et l'onglet "Entreprise" */
.com-switcher-divider {
    align-self: center;
    width: 1px;
    height: 22px;
    background: #d1d5db;
    margin: 0 10px;
    flex-shrink: 0;
}

/* Badge non-lus : pastille two-tone discrÃ¨te (fond rouge trÃ¨s clair, texte rouge soutenu) */
/* â”€â”€ Community: nouvelle hiÃ©rarchie du header â€” nom de la communautÃ© en titre principal */
.com-page-header-title-name {
    font-family: 'Anton', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 1.25rem !important;
    font-weight: 400 !important;
    letter-spacing: 0.02em;
    line-height: 1.15;
    max-width: 600px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-bottom: 2px !important;
    cursor: default;
}
.com-page-header-subline {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.com-page-header-subtitle {
    font-family: 'Anton', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 0.72rem;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.70);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    line-height: 1;
}
.com-page-header-subline-sep { color: rgba(255, 255, 255, 0.35); }
.com-page-header-subline .com-page-header-meta { margin: 0; }

.com-switcher-tab .com-badge {
    background: #fee2e2 !important;
    color: #b91c1c !important;
    border-radius: 999px !important;
    min-width: 18px !important;
    height: 18px !important;
    padding: 0 6px !important;
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    margin-left: 8px !important;
    box-shadow: none;
}
/* â”€â”€â”€ Filtres onglet Actions (chantier Jalon-as-Task) â”€â”€â”€ */
#project_tasks_tasks.filter-completed-hidden .task-completed { display: none !important; }
#project_tasks_tasks.filter-milestones-hidden [data-sort-priorite="999"] { display: none !important; }

/* â”€â”€â”€ Tooltip CSS pur pour erreur inline d'Ã©dition (row task) â”€â”€â”€ */
/* Override des rÃ¨gles gÃ©nÃ©riques .task-col-echeance span / .task-col-echeance span:hover qui ajoutent
   padding + border et dÃ©calent visuellement le ! dans la cellule suivante. */
.task-col-echeance .task-row-err-tip-wrap,
.task-col-echeance .task-row-err-tip-wrap:hover {
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
}
.task-row-err-tip-wrap { position: relative; display: inline-block; margin-left: 4px; vertical-align: middle; }
.task-row-err-tip-icon { cursor: help; font-size: 0.78rem; line-height: 1; }
.task-row-err-tip-msg {
    position: absolute;
    top: 100%;
    right: 0;
    transform: translateY(6px);
    background: #1f2937;
    color: #fff;
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 0.78rem;
    line-height: 1.35;
    white-space: normal;
    width: max-content;
    max-width: 260px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s;
    z-index: 9999;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.task-row-err-tip-wrap:hover .task-row-err-tip-msg { opacity: 1; }

/* â”€â”€â”€ Page admin ModÃ¨le Planning â€” application DS reference â”€â”€â”€ */
.sm-title { font-size: 1.5rem; font-weight: 500; color: #2D3E50; margin: 0; }
.sm-name-edit { color: #8fa1b3; font-size: 0.9rem; line-height: 1; padding: 2px 4px; border-radius: 2px; }
.sm-name-edit:hover { color: #0d9488; text-decoration: none; background: #f0fafa; }
/* Badge mode (chrono/rÃ©tro) â€” navy lÃ©ger, distinct du teal de la lÃ©gende */
.sm-mode-badge {
    background: #f1f5f9; color: #2D3E50; border: 1px solid #e2e8f0;
    border-radius: 2px; padding: 4px 10px; font-size: 0.75rem; font-weight: 500;
    text-transform: none; letter-spacing: 0.02em;
}
/* Badge lÃ©gende J â€” teal clair (accent rare cf. DS reference) */
.sm-j-legend-badge {
    background: #e6f7f5; color: #0d9488;
    border-radius: 2px; padding: 4px 10px; font-size: 0.72rem; font-weight: 500;
    display: inline-block;
}
.sm-counter { color: #8fa1b3; font-size: 0.78rem; }
.sm-counter strong { color: #2D3E50; font-weight: 600; }
.sm-counter-sep { margin: 0 8px; color: #cbd5e1; }
.sm-tasks-card {
    background: #fff; border: 1px solid #e2e8f0; border-radius: 2px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
    margin-top: 16px; overflow: hidden;
}
.sm-tasks-card .tasks-list-header {
    border-bottom: 1px solid rgba(45,62,80,0.35);
    padding: 12px 16px; color: #2D3E50; font-size: 0.8rem; font-weight: 500;
}
.sm-tasks-card .task-item { border-bottom: 1px solid #f3f4f6; transition: background 0.12s; }
.sm-tasks-card .task-item:last-child { border-bottom: none; }
.sm-tasks-card .task-item:hover { background: #f9fafb; cursor: pointer; }
.sm-tasks-card .tasks-list-row { padding: 10px 16px; }
.sm-tasks-card .task-name-text { color: #415873; font-size: 0.85rem; }
.sm-tasks-card .task-col-priorite { padding-left: 16px; text-align: left; }
/* Largeur Ã©largie pour que "DÃ©but (J+) / Fin (J+)" tienne sur une seule ligne */
.sm-tasks-card .task-col-echeance { padding-right: 16px; width: 200px; text-align: left; white-space: nowrap; }

/* Sous-ligne du header admin : toggle actif (Ã  gauche, sans encadrÃ©) + langues (encadrÃ© navy clair) */
.sm-controls-row {
    display: flex; align-items: center;
    gap: 24px;
    margin-top: 10px;
    flex-wrap: wrap;
}
.sm-active-toggle-flat {
    display: inline-flex; align-items: center; gap: 8px;
    margin: 0; padding: 0;
    font-size: 0.9rem; color: #2D3E50; cursor: pointer;
}
.sm-active-toggle-flat input[type="checkbox"] {
    position: static; opacity: 1; margin: 0; cursor: pointer;
    width: 16px; height: 16px;
    accent-color: #0d9488;
}
.sm-active-toggle-flat .sm-active-tooltip {
    color: #8fa1b3; font-size: 0.8rem; cursor: help;
}
/* EncadrÃ© navy clair regroupant les langues */
.sm-locales-group {
    display: inline-flex; align-items: center; gap: 12px;
    background: #f1f5f9; border: 1px solid #e2e8f0; border-radius: 2px;
    padding: 6px 12px;
}
.sm-locales-label {
    font-size: 0.78rem; font-weight: 500; color: #2D3E50;
}
.sm-locales-label .sm-locales-tooltip {
    color: #8fa1b3; font-size: 0.72rem; cursor: help; margin-left: 4px;
}
.sm-locales-checks {
    display: inline-flex; align-items: center; gap: 10px;
}
.sm-locale-toggle-flat {
    display: inline-flex; align-items: center; gap: 5px;
    margin: 0; padding: 0;
    font-size: 0.74rem; color: #415873; cursor: pointer;
}
.sm-locale-toggle-flat input[type="checkbox"] {
    position: static; opacity: 1; margin: 0; cursor: pointer;
    width: 13px; height: 13px;
    accent-color: #0d9488;
}

/* Page liste des modÃ¨les â€” marges 40px gauche/droite (DS reference) pour Ã©largir la table */
.sm-index-page { padding-left: 0; padding-right: 0; }
.sm-index-content { padding-left: 40px; padding-right: 40px; }

/* Liste index des modÃ¨les â€” table compacte + colonnes nb / langues / actions */
.sm-index-table { font-size: 0.85rem; }
.sm-index-table thead th {
    padding: 8px 12px; font-size: 0.78rem; font-weight: 500; color: #2D3E50;
    border-bottom: 1px solid rgba(45,62,80,0.35); background: #fff;
}
.sm-index-table tbody td { padding: 8px 12px; vertical-align: middle; border-top: 1px solid #f3f4f6; }
.sm-index-table tbody tr:first-child td { border-top: none; }
.sm-index-name { color: #2D3E50; font-weight: 500; }
.sm-index-badge-inactive {
    margin-left: 8px; background: #fef3c7; color: #92400e; border-radius: 2px;
    padding: 2px 8px; font-size: 0.68rem; font-weight: 600;
    border: 1px solid #fde68a;
}
.sm-index-counts { color: #2D3E50; font-size: 0.82rem; }
.sm-index-counts strong { color: #2D3E50; font-weight: 600; }
.sm-index-sep { margin: 0 6px; color: #cbd5e1; }
.sm-index-locales { font-size: 0; }
.sm-index-table thead th:nth-child(3),
.sm-index-table tbody td:nth-child(3) { width: 300px; }
.sm-index-table thead th:nth-child(2),
.sm-index-table tbody td.sm-index-counts { white-space: nowrap; }
.sm-index-table thead th:nth-child(4),
.sm-index-table tbody td:nth-child(4) { white-space: nowrap; width: 1%; }
.sm-index-locale {
    display: inline-block; margin-right: 4px; padding: 2px 8px;
    background: #e6f7f5; color: #0d9488; border-radius: 2px;
    font-size: 0.72rem; font-weight: 500;
}
.sm-index-locale-off { background: #f1f5f9; color: #cbd5e1; font-weight: 400; text-decoration: line-through; }
.sm-index-action { color: #0d9488; margin-right: 14px; font-size: 0.82rem; }
.sm-index-action:hover { color: #0b7a6f; text-decoration: underline; }
.sm-index-delete { color: #8fa1b3; font-size: 0.78rem; padding: 2px 4px; }
.sm-index-delete:hover { color: #dc3545; }

/* Toolbar boutons + Action / + Jalon â€” palette DS (navy + teal) */
.sm-toolbar { margin-top: 24px; margin-bottom: 16px; gap: 8px; }
.sm-btn {
    display: inline-flex; align-items: center;
    padding: 7px 14px; font-size: 0.82rem; font-weight: 500;
    border-radius: 2px; border: 1px solid transparent;
    text-decoration: none; transition: background 0.15s, border-color 0.15s, color 0.15s;
    cursor: pointer;
}
.sm-btn-navy { background: #2D3E50; color: #fff; border-color: #2D3E50; }
.sm-btn-navy:hover { background: #1f2937; color: #fff; text-decoration: none; }
.sm-btn-teal { background: #0d9488; color: #fff; border-color: #0d9488; }
.sm-btn-teal:hover { background: #0b7a6f; color: #fff; text-decoration: none; }

/* Drawer en mode template admin : checklist en display-only (les cases sont visibles
   mais ne peuvent pas Ãªtre cochÃ©es/dÃ©cochÃ©es â€” un template n'a pas d'Ã©tat).
   Cibler toute la zone des checkbox + leur label pseudo-element pour bloquer le clic. */
.drw-task-checklist-template input[type="checkbox"],
.drw-task-checklist-template input[type="checkbox"] + label,
.drw-task-checklist-template label[class*="radio-label"],
.drw-task-checklist-template .form-check-input,
.drw-task-checklist-template .form-check-label {
    pointer-events: none;
}
.drw-task-checklist-template .form-check-input { opacity: 0.6; }
/* La fake-checkbox (duplicate visuel) est masquÃ©e â€” l'item se gÃ¨re via le bouton supprimer.
   "Ajouter" et "supprimer" restent visibles pour permettre la composition du template. */
.drw-task-checklist-template .fake-checkbox {
    display: none !important;
}

/* Badge "par rapport Ã  la date de dÃ©but/fin du projet" â€” centrÃ© sous les champs nDay dans le drawer template */
.drw-jref-badge-wrap { text-align: center; margin-top: -4px; }
.drw-jref-badge {
    display: inline-block;
    background: #e6f7f5; color: #0d9488;
    border-radius: 2px; padding: 4px 10px;
    font-size: 0.72rem; font-weight: 500; font-style: italic;
}

/* Bouton "Appliquer un modÃ¨le" + dropdown enrichi.
   Le bouton hÃ©rite de .fin-btn pour s'aligner sur la hauteur des autres boutons de la barre. */
.sm-apply-wrap .dropdown { position: relative; }
.sm-apply-toggle { background: #fff; color: #2D3E50; border-color: #d1d5db; }
.sm-apply-toggle:hover, .sm-apply-toggle:focus { background: #f8fafc; color: #0d9488; border-color: #0d9488; outline: none; }
.sm-apply-toggle[aria-expanded="true"] { background: #f8fafc; color: #0d9488; border-color: #0d9488; }
.sm-apply-chevron { font-size: 0.62rem; margin-left: 4px; transition: transform 0.18s; }
.sm-apply-toggle[aria-expanded="true"] .sm-apply-chevron { transform: rotate(180deg); }
.sm-apply-menu {
    min-width: 360px; padding: 6px 0; margin-top: 4px;
    border: 1px solid #e2e8f0; border-radius: 4px;
    box-shadow: 0 6px 20px rgba(15,23,42,0.08);
    font-size: 0.76rem;
}
.sm-apply-item {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 14px; color: #2D3E50; white-space: normal;
}
.sm-apply-item:hover, .sm-apply-item:focus { background: #f1f5f9; color: #0d9488; text-decoration: none; }
.sm-apply-menu .sm-apply-badge {
    flex-shrink: 0 !important; display: inline-block !important;
    width: 56px !important; padding: 1px 0 !important;
    border-radius: 2px; font-size: 0.6rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.03em; line-height: 1.5;
    text-align: center !important;
}
.sm-apply-badge-chrono { background: #e6f7f5; color: #0d9488; border: 1px solid #b8e5df; }
.sm-apply-badge-retro  { background: #e7eaef; color: #2D3E50; border: 1px solid #cbd5e1; }
.sm-apply-name { flex: 1; font-weight: 500; font-size: 0.78rem; }
.sm-apply-duration { flex-shrink: 0; color: #8fa1b3; font-size: 0.68rem; font-weight: 500; }

/* Modale de confirmation d'application â€” palette DS, layout repensÃ© */
#applyScheduleModelModal .modal-content { border-radius: 4px; }
.apply-sm-dialog { max-width: 520px; }
#applyScheduleModelModal .modal-header.apply-sm-header {
    display: flex !important; align-items: center; justify-content: space-between;
    padding: 16px 20px !important; border-bottom: 1px solid #e2e8f0;
}
#applyScheduleModelModal h5.apply-sm-title,
#applyScheduleModelModal .apply-sm-title { color: #2D3E50 !important; font-weight: 600 !important; font-size: 1.15rem !important; line-height: 1.3 !important; margin: 0 !important; }
.apply-sm-cancel {
    background: #fff; color: #2D3E50; border: 1px solid #cbd5e1;
    border-radius: 2px; padding: 4px 12px; font-size: 0.78rem; font-weight: 500;
}
.apply-sm-cancel:hover { background: #f8fafc; color: #2D3E50; border-color: #2D3E50; }
.apply-sm-body { color: #2D3E50; font-size: 0.86rem; padding: 16px 20px; }
.apply-sm-mt-3 { margin-top: 16px; }
.apply-sm-overflow {
    background: #fef3c7; color: #92400e; border: 1px solid #fde68a;
    border-radius: 2px; padding: 10px 12px; font-size: 0.82rem;
    display: flex; gap: 8px; align-items: flex-start;
}
.apply-sm-overflow i { margin-top: 2px; }
.apply-sm-footer {
    display: flex; flex-direction: column; align-items: stretch;
    gap: 8px; padding: 12px 20px 18px; border-top: 1px solid #e2e8f0;
}
.apply-sm-action-btn {
    width: 100%; text-align: center;
    background: #0d9488; color: #fff; border: 1px solid #0d9488;
    border-radius: 2px; padding: 8px 14px; font-size: 0.86rem; font-weight: 500;
    transition: background 0.15s, border-color 0.15s;
}
.apply-sm-action-btn:hover:not(:disabled) { background: #0b7a6f; border-color: #0b7a6f; color: #fff; }
.apply-sm-action-btn:disabled { opacity: 0.65; cursor: not-allowed; }
.apply-sm-loading { background: #2D3E50; border-color: #2D3E50; }
/* Badge "Migration incomplÃ¨te" sur la liste des modÃ¨les de planning admin */
.sm-index-badge-incomplete {
    margin-left: 8px; background: #fef3c7; color: #92400e; border-radius: 2px;
    padding: 2px 8px; font-size: 0.68rem; font-weight: 600;
    border: 1px solid #fde68a; cursor: help;
}
.sm-index-badge-incomplete i { font-size: 0.62rem; margin-right: 3px; }

/* Bandeau "Migration incomplÃ¨te" en haut de l'Ã©cran d'Ã©dition d'un modÃ¨le */
.sm-incomplete-banner {
    display: flex; gap: 12px; align-items: flex-start;
    background: #fef3c7; border: 1px solid #fde68a; border-radius: 2px;
    padding: 12px 16px; margin: 8px 0 16px;
}
.sm-incomplete-icon { color: #92400e; font-size: 1rem; margin-top: 2px; flex-shrink: 0; }
.sm-incomplete-body { color: #92400e; font-size: 0.82rem; flex: 1; }
.sm-incomplete-title { font-weight: 600; margin-bottom: 4px; }
.sm-incomplete-text { font-weight: 400; margin-bottom: 6px; }
.sm-incomplete-list { margin: 0; padding-left: 18px; font-weight: 500; }
.sm-incomplete-list li { margin-bottom: 2px; }

/* Toggle "ModÃ¨le actif" bloquÃ© quand jalons incomplets */
.sm-active-toggle-blocked { opacity: 0.6; cursor: not-allowed; }
.sm-active-toggle-blocked input { cursor: not-allowed; }

/* "Laisser dÃ©border" : option neutre/secondaire (pas d'ajustement des dates projet) */
#apply-sm-overflow-keep { background: #e6f7f5; color: #0d9488; border-color: #b8e5df; }
#apply-sm-overflow-keep:hover:not(:disabled) { background: #d2efeb; color: #0b7a6f; border-color: #0d9488; }

/* Point 6 : aligner le spacing vertical de la checklist drawer Admin sur celui du drawer User.
   CÃ´tÃ© user, les rows sont en form-group sans margin-bottom supplÃ©mentaire ; cÃ´tÃ© admin, le
   form prototype peut introduire un margin par dÃ©faut. On force une valeur rÃ©duite. */
.drw-task-checklist-template .form-group { margin-bottom: 4px; }
.drw-task-checklist-template .row { margin-bottom: 0; }
.drw-task-checklist-template .col-sm-12,
.drw-task-checklist-template [class^="col-"] { padding-top: 2px; padding-bottom: 2px; }

/* =========================================================================
   Todo/Plannings â€” vue Liste refondue (DS navy/teal/blanc)
   PrÃ©fixe .tdl-* (Todo List). RÃ©utilise au maximum les classes existantes
   .fin-btn, .fin-filter-btn, .view-switch, .tasks-fin-card, .tasks-list-header,
   .task-item, .task-col-* â€” pas de duplication.
   ========================================================================= */

/* â”€â”€ Panneau de filtres avancÃ©s (collapse) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tdl-filters-panel {
    margin: 8px 40px 16px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 2px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
    padding: 16px 20px;
}
.tdl-filters-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px 20px;
    margin-bottom: 12px;
}
.tdl-filter-cell { display: flex; flex-direction: column; gap: 4px; }
.tdl-filter-cell label {
    font-size: 0.72rem; font-weight: 400; color: #8fa1b3; margin: 0;
}
.tdl-filter-cell-wide { grid-column: span 2; }
.tdl-filter-cell-checkbox { flex-direction: row; align-items: center; gap: 6px; align-self: end; padding-bottom: 6px; }
.tdl-filter-cell-checkbox label { font-size: 0.79rem; color: #2D3E50; font-weight: 500; }
.tdl-filters-actions { display: flex; justify-content: flex-end; gap: 8px; }
.tdl-filters-count {
    display: inline-block; min-width: 16px; padding: 0 5px; margin-left: 4px;
    background: #0d9488; color: #fff; border-radius: 8px;
    font-size: 0.62rem; font-weight: 600; text-align: center; line-height: 16px;
}

/* â”€â”€ Sections temporelles â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Scroll interne sur .tdl-sections (overflow-y:auto + max-height) pour que le
   toolbar/filtres en haut restent fixes et que les sticky internes (section header,
   columns header) s'ancrent dans ce conteneur scrollable. */
/* Zone scrollable unifiee : englobe le panneau Filtres avances + .tdl-sections.
   L'ouverture du panel est absorbee par ce scroll interne, plus de scrollbar page parasite.
   Estimation chrome au-dessus : navbar (~48) + subbar (~50) + onglets (~40) + action row (~50) + marges = ~200px. */
.tdl-scroll-zone {
    max-height: calc(100vh - 200px);
    overflow-y: auto;
}
.tdl-scroll-zone::-webkit-scrollbar { width: 6px; }
.tdl-scroll-zone::-webkit-scrollbar-track { background: transparent; }
.tdl-scroll-zone::-webkit-scrollbar-thumb { background: #c4c9d0; border-radius: 3px; }
.tdl-scroll-zone::-webkit-scrollbar-thumb:hover { background: #9ca3af; }

.tdl-sections {
    padding: 0 40px 24px;
}
.tdl-sections::-webkit-scrollbar { width: 6px; }
.tdl-sections::-webkit-scrollbar-track { background: transparent; }
.tdl-sections::-webkit-scrollbar-thumb { background: #c4c9d0; border-radius: 3px; }
.tdl-sections::-webkit-scrollbar-thumb:hover { background: #9ca3af; }

/* Section header sticky en haut du scroll container.
   IMPORTANT : .tdl-section ne doit PAS avoir overflow:hidden (dÃ©jÃ  retirÃ© plus haut).
   On lui donne une bordure top + cÃ´tÃ©s pour visuellement prolonger la box du section
   quand le scroll fait disparaitre la vraie bordure-top du section. */
.tdl-section-header {
    position: sticky;
    top: 0;
    z-index: 6;
    background: #fff;
    border-top: 1px solid #e2e8f0;
    border-left: 1px solid #e2e8f0;
    border-right: 1px solid #e2e8f0;
    border-radius: 2px 2px 0 0;
    margin: -1px -1px 0; /* compense les bordures pour aligner sur la box du section au repos */
}
/* Header de colonnes sticky DIRECTEMENT sous le header de section (sans gap 1px).
   On utilise 41px (au lieu de 42) + bordure top pour overlap parfait. */
.tdl-section .tasks-list-header {
    position: sticky;
    top: 41px;
    z-index: 5;
    background: #fff;
    border-top: 1px solid rgba(45,62,80,0.35); /* prolonge la bordure-bottom du section header */
    margin-top: -1px;
}
.tdl-section {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 2px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
    margin-bottom: 12px;
    /* PAS d'overflow:hidden : casserait position:sticky des headers internes */
}
.tdl-section-header {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 16px;
    background: #fff;
    border-bottom: 1px solid rgba(45,62,80,0.35);
    cursor: pointer;
    user-select: none;
    transition: background 0.12s;
}
.tdl-section-header:hover { background: #f9fafb; }
.tdl-section-header i:first-child { font-size: 0.88rem; width: 18px; text-align: center; }
.tdl-section-title { flex: 1; font-size: 0.86rem; font-weight: 500; color: #2D3E50; }
.tdl-section-count {
    display: inline-block; min-width: 22px; padding: 2px 8px;
    background: #e6f7f5; color: #0d9488; border-radius: 2px;
    font-size: 0.7rem; font-weight: 600; text-align: center;
}
.tdl-section-chevron { font-size: 0.62rem; color: #8fa1b3; transition: transform 0.18s; }
.tdl-section-collapsed .tdl-section-chevron { transform: rotate(-90deg); }
.tdl-section-collapsed .tdl-section-body { display: none; }
.tdl-section-empty { display: none; }
.tdl-section-body { padding: 0; }

/* IcÃ´nes thÃ©matiques par tranche */
.tdl-icon-late  { color: #dc3545; }
.tdl-icon-today { color: #fd7e14; }
.tdl-icon-near  { color: #0d9488; }
.tdl-icon-mid   { color: #6b7280; }
.tdl-icon-far   { color: #94a3b8; }
.tdl-icon-completed { color: #0d9488; }
.tdl-section-hint { font-size: 0.7rem; color: #8fa1b3; font-style: italic; font-weight: 400; margin-left: 8px; }

/* â”€â”€ Conteneur de lignes (rÃ©utilise .tasks-fin-card du projet) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tdl-section .tasks-fin-card { border: none; box-shadow: none; border-radius: 0; max-height: none; overflow: visible; }
.tdl-section-rows { background: #fff; }

/* â”€â”€ Colonne Projet/Fournisseur (spÃ©cifique Todo) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.task-col-projet {
    width: 280px; flex-shrink: 0;
    padding: 0 8px;
    display: flex; align-items: center;
    font-size: 0.75rem; color: var(--fin-text-mid);
    overflow: hidden;
}
.task-col-projet .tdl-projet-link,
.task-col-projet .tdl-supplier-link {
    color: var(--fin-text-mid);
    text-decoration: none;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    width: 100%;
    transition: color 0.12s;
}
.task-col-projet .tdl-projet-link:hover,
.task-col-projet .tdl-supplier-link:hover { color: #0d9488; text-decoration: underline; }
.task-col-projet .tdl-projet-orphan { color: #cbd5e1; font-style: italic; }
.tasks-list-header .task-col-projet { font-size: 0.72rem; color: var(--fin-text-muted); font-weight: 500; }
/* La row elle-mÃªme ne doit pas reprendre les fonds violets/bleus du module Todo */
.tdl-row.task-delegated, .tdl-row.task-other { background-color: #fff !important; }
.tdl-row.task-delegated .tasks-list-row, .tdl-row.task-other .tasks-list-row { background-color: #fff !important; }

/* Style row TerminÃ©e : titre barrÃ©, couleur muted â€” uniforme sur Action ET Jalon */
.tdl-row.task-completed .task-name-input,
.tdl-row.task-completed .task-name-text {
    text-decoration: line-through;
    color: #8fa1b3 !important;
}
.tdl-row.task-completed .task-col-titre .task-row-open-eye { opacity: 0.5; }

/* Le form theme custom `bootstrap_4.html.twig` enveloppe certains form_widget dans
   un <div class="input-group">. Sur les rows Todo (layout flex), ce wrapper crÃ©e un
   bloc flex inattendu qui peut faire dÃ©border le widget (notamment le selectpicker
   priority qui apparaissait flottant entre les rows). `display: contents` rend ces
   wrappers transparents au layout : leurs enfants hÃ©ritent du flex de .tasks-list-row. */
.tdl-row .tasks-list-row .input-group { display: contents !important; }

/* Garde-fou : tout enfant direct du <form> de la row qui n'est PAS .tasks-list-row
   est masquÃ©. Cible le bug du widget priority rendu hors de sa cellule par form_rest
   (input-group wrapper avec selectpicker flottant). Le _token hidden reste fonctionnel
   pour la soumission (les inputs hidden n'ont pas besoin d'Ãªtre visibles). */
.tdl-row > form > *:not(.tasks-list-row) { display: none !important; }

/* â”€â”€ Sous-titre Contrat (â€”Fin / â€”PrÃ©avis) dans la cellule titre â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tdl-contract-sub { color: #8fa1b3; font-size: 0.72rem; font-weight: 400; }

/* â”€â”€ Badge type Contrat (icÃ´ne) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.task-col-type .contract-flag-badge { font-size: 13px; color: #fd7e14; display: flex; align-items: center; justify-content: center; }
.tdl-row-contract { border-left: 3px solid #fd7e14; }

/* â”€â”€ Badge type Jalon legacy (flag outline + couleur tamisÃ©e) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.task-col-type .milestone-flag-badge-legacy { color: #94a3b8 !important; }

/* â”€â”€ Badge statut Contrat (mini pilule colorÃ©e) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.contract-status-badge {
    display: inline-block; padding: 1px 8px;
    border: 1px solid;
    border-radius: 2px;
    font-size: 0.66rem; font-weight: 500;
    line-height: 1.5;
}

/* â”€â”€ Filtres typologies client-side (cache les lignes hors typologie) â”€â”€â”€â”€ */
.tdl-filter-action    .tdl-row-milestone,
.tdl-filter-action    .tdl-row-contract     { display: none; }
.tdl-filter-milestone .tdl-row-action,
.tdl-filter-milestone .tdl-row-contract     { display: none; }
.tdl-filter-contract  .tdl-row-action,
.tdl-filter-contract  .tdl-row-milestone    { display: none; }

/* â”€â”€ Ã‰tat vide â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tdl-empty {
    margin: 40px 40px;
    padding: 48px 24px;
    background: #fff;
    border: 1px dashed #e2e8f0;
    border-radius: 2px;
    text-align: center;
    color: #8fa1b3;
}
.tdl-empty i { font-size: 2.5rem; color: #b8e5df; margin-bottom: 16px; }
.tdl-empty-title { font-size: 1rem; font-weight: 500; color: #2D3E50; margin-bottom: 8px; }
.tdl-empty-text { font-size: 0.86rem; color: #8fa1b3; }



/* â”€â”€â”€ Todo/Plannings : Header navy + subbar + onglets (refonte 2026-05) â”€â”€â”€ */
.tdl-page-header { display: flex; align-items: center; justify-content: space-between; padding: 0 40px; min-height: 64px; background: var(--com-navy-dark, #1a3347); color: #fff; gap: 16px; }
.tdl-page-header-left { display: flex; align-items: center; gap: 14px; }
.tdl-page-header-icon { width: 36px; height: 36px; border-radius: 2px; background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.90); display: flex; align-items: center; justify-content: center; font-size: 0.95rem; }
.tdl-page-header-info { display: flex; flex-direction: column; }
.tdl-page-header-title { font-size: 0.90rem; font-weight: 700; color: #fff; }
.tdl-page-header-right { display: flex; align-items: center; gap: 16px; }

.tdl-view-switch { display: inline-flex; align-items: center; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); border-radius: 2px; padding: 2px; gap: 2px; }
.tdl-view-switch-item { display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; font-size: 0.78rem; font-weight: 500; color: rgba(255,255,255,0.75); text-decoration: none; border-radius: 2px; cursor: pointer; }
.tdl-view-switch-item:hover { color: #fff; background: rgba(255,255,255,0.08); text-decoration: none; }
.tdl-view-switch-item.active { background: rgba(255,255,255,0.18); color: #fff; }
.tdl-view-switch-item i { font-size: 0.75rem; }

.tdl-period-filter { display: inline-flex; align-items: center; gap: 6px; }
.tdl-period-label { font-size: 0.74rem; color: rgba(255,255,255,0.70); margin: 0 6px 0 0; text-transform: uppercase; letter-spacing: 0.5px; }
.tdl-period-input, .tdl-period-filter input { background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.20); color: #fff; border-radius: 2px; padding: 4px 8px; font-size: 0.78rem; width: 96px; }
.tdl-period-input::placeholder { color: rgba(255,255,255,0.55); }
.tdl-period-sep { color: rgba(255,255,255,0.55); font-size: 0.8rem; }
.tdl-period-mode-btn { background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.25); color: #fff; border-radius: 2px; padding: 4px 10px; font-size: 0.74rem; cursor: pointer; }
.tdl-period-mode-btn:hover { background: rgba(255,255,255,0.25); }

/* â”€â”€â”€ Subbar : Filtres + Affichage pills + TerminÃ©es â”€â”€â”€ */
.tdl-subbar { display: flex; align-items: center; gap: 8px; padding: 12px 40px 0; flex-wrap: wrap; }
.tdl-subbar-filter-btn { margin-right: 8px; }
.tdl-subbar-label { font-size: 0.74rem; font-weight: 600; color: #8fa1b3; text-transform: uppercase; letter-spacing: 0.5px; margin-left: 4px; }
.tdl-subbar-sep { display: inline-block; width: 1px; height: 22px; background: #e2e8f0; margin: 0 6px; }
.tdl-filters-count { background: #0d9488; color: #fff; border-radius: 100px; padding: 1px 7px; font-size: 0.70rem; font-weight: 600; margin-left: 4px; }

/* â”€â”€â”€ Onglets â”€â”€â”€ */
.tdl-tabs { border-bottom: 1px solid #e2e8f0; padding: 12px 40px 0; margin: 0; flex-wrap: wrap; }
.tdl-tabs .nav-item { margin-bottom: -1px; }
.tdl-tab.nav-link { color: #8fa1b3; font-size: 0.84rem; font-weight: 500; padding: 8px 16px; border: 1px solid transparent; border-radius: 2px 2px 0 0; }
.tdl-tab.nav-link:hover { color: #2D3E50; border-color: transparent; background: transparent; }
.tdl-tab.nav-link.active { color: #2D3E50; font-weight: 600; background: #fff; border-color: #e2e8f0 #e2e8f0 #fff; }

/* â”€â”€â”€ Bouton + Ajouter sous les onglets â”€â”€â”€ */
.tdl-add-action { padding: 16px 40px 0; display: flex; justify-content: flex-end; }


/* â”€â”€â”€ Todo/Plannings : bandeau d'aide sous les onglets + flag perso â”€â”€â”€ */
.tdl-tab-hint { display: flex; align-items: center; gap: 8px; padding: 12px 40px 0; font-size: 0.78rem; color: #64748b; }
.tdl-tab-hint i { color: #94a3b8; }
.tdl-projet-flag-perso { display: inline-flex; align-items: center; gap: 4px; font-size: 0.72rem; font-weight: 500; padding: 2px 8px; border-radius: 100px; background: #fef9c3; color: #92670a; border: 1px solid #fde68a; white-space: nowrap; }
/* Badge "stand by" : pour les actions/jalons des projets STATUS_PAUSED. Style neutre gris
   (information secondaire, pas une alerte) — visuellement discret a cote du nom du projet. */
.tdl-projet-standby { display: inline-flex; align-items: center; font-size: 0.66rem; font-weight: 500; padding: 1px 6px; margin-left: 6px; border-radius: 2px; background: #f1f5f9; color: #64748b; border: 1px solid #e2e8f0; white-space: nowrap; text-transform: uppercase; letter-spacing: 0.04em; }


/* â”€â”€â”€ Project activity toolbar : icÃ´nes "+ Action / + Document / + Note" â”€â”€â”€ */
#sp-body-activity .spa-add-btn { font-size: 13px; color: #cfd8dc; cursor: pointer; transition: color .15s; line-height: 1; padding: 0 2px; }
#sp-body-activity .spa-add-btn:hover { color: #00695c; }
.spa-add-btn { font-size: 13px; color: #cfd8dc; cursor: pointer; transition: color .15s; line-height: 1; padding: 0 2px; }
.spa-add-btn:hover { color: #00695c; }


/* â”€â”€â”€ Todo/Plannings : redesign top de page (2026-05-27) â”€â”€â”€ */

/* Subbar ligne 1 : Filtres + Reset + PÃ©riode */
.tdl-subbar { padding: 14px 40px 0; gap: 8px; }
.tdl-reset-btn { padding: 6px 9px; }
.tdl-reset-btn.is-disabled { opacity: 0.4; pointer-events: none; }
.tdl-reset-btn i { font-size: 0.78rem; }
.tdl-subbar .tdl-period-filter { margin-left: 8px; }

/* PÃ©riode : couleurs claires (subbar fond clair, plus le navy du header) */
.tdl-subbar .tdl-period-label { color: #64748b; }
.tdl-subbar .tdl-period-input { background: #fff; border: 1px solid #e2e8f0; color: #2D3E50; }
.tdl-subbar .tdl-period-input::placeholder { color: #94a3b8; }
.tdl-subbar .tdl-period-sep { color: #94a3b8; }
/* Texte en gris medium (#64748b) au lieu de navy (#2D3E50) pour reduire le poids visuel
   et laisser la priorite aux dates et a l'onglet actif. */
.tdl-subbar .tdl-period-mode-btn { background: #fff; border: 1px solid #e2e8f0; color: #64748b; }
.tdl-subbar .tdl-period-mode-btn:hover { background: #f1f5f9; color: #475569; }

/* Affichage : encadrÃ© sur le pattern .com-filters-wrap */
.tdl-display-wrap { position: relative; margin: 24px 40px 0; }
.tdl-display-label { position: absolute; top: -7px; left: 12px; padding: 0 6px; background: #fff; font-size: 0.62rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: #8fa1b3; line-height: 1; z-index: 1; pointer-events: none; }
.tdl-display-box { background: #fff; border: 1px solid #e2e8f0; border-radius: 2px; box-shadow: 0 1px 4px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04); padding: 8px 14px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.tdl-display-pill { font-size: 0.73rem; font-weight: 500; color: #a0aec0; padding: 3px 10px; border-radius: 2px; background: #f1f3f5; text-decoration: none; border: 1px solid transparent; transition: color 0.12s, background 0.12s; display: inline-flex; align-items: center; gap: 4px; }
.tdl-display-pill i { font-size: 0.72rem; }
/* Hover : texte teal (au lieu du navy fonce qui faisait trop "noir"), bg teal tres clair. */
.tdl-display-pill:hover { color: #0d9488; background: #f0fbf9; text-decoration: none; }
.tdl-display-pill.active, .tdl-display-pill.filter-on { background: #e6f7f5; color: #0d9488; border-color: #0d9488; font-weight: 600; }
.tdl-display-sep { display: inline-block; width: 1px; height: 18px; background: #e2e8f0; margin: 0 4px; }

/* Action row : hint Ã  gauche + bouton Ajouter Ã  droite, alignÃ© bords tableau */
.tdl-action-row { display: flex; justify-content: space-between; align-items: center; padding: 16px 40px 0; gap: 16px; }
.tdl-action-row .tdl-tab-hint { padding: 0; flex: 1; min-width: 0; }
.tdl-add-btn { flex-shrink: 0; white-space: nowrap; }


/* â”€â”€â”€ Todo/Plannings : ajustements design 2026-05-27 (itÃ©ration suite screenshot) â”€â”€â”€ */

/* #4 â€” Label "Dates dÃ©but et fin de projets" : mÃªme style que "AFFICHAGE" */
.tdl-subbar .tdl-period-label {
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #8fa1b3;
    margin: 0 8px 0 4px;
}

/* #2 â€” Bouton Filtres et Reset : hauteur alignÃ©e sur l'encadrÃ© Affichage (~38px) */
.tdl-subbar .tdl-subbar-filter-btn,
.tdl-subbar .tdl-reset-btn { padding: 8px 14px; min-height: 34px; display: inline-flex; align-items: center; }
.tdl-subbar .tdl-reset-btn { padding: 8px 12px; }

/* Subbar pour aligner verticalement les Ã©lÃ©ments enfants */
.tdl-subbar { align-items: center; }
.tdl-subbar .tdl-period-filter { align-items: center; }

/* #3 â€” Pills Affichage : largeur Ã©gale + espacement */
.tdl-display-box { gap: 8px; padding: 8px 14px; }
.tdl-display-pill { min-width: 110px; justify-content: center; padding: 6px 12px; }
.tdl-display-pill:last-child { min-width: 150px; } /* "Actions rÃ©alisÃ©es" est plus long */

/* #1 â€” Hint + Bouton "Ajouter" alignÃ©s sur les bords de la box .tdl-section.
   .tdl-sections a padding 40px et la section box est Ã  left=40px de la page.
   Le padding de l'action-row doit donc Ãªtre 40px aussi. Si l'alignement visuel
   reste off, c'est dÃ» Ã  un padding parent â†’ utiliser margin pour matcher .tdl-section. */
.tdl-action-row { padding: 16px 40px 0; }
.tdl-action-row .tdl-tab-hint { padding: 0 !important; margin: 0; }


/* â”€â”€â”€ Todo/Plannings : fine-tuning design 2026-05-27 (itÃ©ration 3) â”€â”€â”€ */

/* #1 â€” Alignement hint+bouton sur les bords du tableau.
   .tasks-outer-wrapper a un padding 40px cachÃ© qui dÃ©cale .tdl-sections de 40px de plus.
   Total padding du tableau = 40 (outer-wrapper) + 40 (.tdl-sections) = 80px depuis l'edge page.
   Pour aligner l'action-row, on porte son padding horizontal Ã  80px. */
.tdl-action-row { padding: 16px 80px 0 !important; }

/* On uniformise tabs + display-wrap + subbar pour cohÃ©rence visuelle (tous Ã  40px reste OK,
   c'est juste la box .tdl-section qui est plus rÃ©trÃ©cie Ã  cause du wrapper imbriquÃ©). */

/* #2 â€” DÃ©cale le bloc PÃ©riode Ã  droite dans la subbar (margin-left: auto pousse Ã  droite). */
.tdl-subbar .tdl-period-filter { margin-left: auto; }

/* Placeholders visibles avec couleur plus claire */
.tdl-subbar .tdl-period-input::placeholder { color: #94a3b8; font-style: normal; }

/* #3 â€” Espace doublÃ© entre pills + "Actions clÃ´turÃ©es" tout Ã  droite (margin-left: auto) */
.tdl-display-box { gap: 16px; }
.tdl-display-pill.tdl-display-completed { margin-left: auto; }

/* #4 â€” Onglets : tous mÃªme largeur via flex-grow, espace augmentÃ© */
.tdl-tabs { gap: 8px; padding: 12px 40px 0; }
.tdl-tabs .nav-item { flex: 1 1 0; }
.tdl-tab.nav-link { text-align: center; padding: 10px 16px; }


/* â”€â”€â”€ Todo/Plannings : fine-tuning design 2026-05-27 (itÃ©ration 4 : final align) â”€â”€â”€ */

/* #1 â€” Alignement parfait : .tdl-action-row maintenant INSIDE .tasks-outer-wrapper >
   .col-md-12 (sibling de .tdl-sections). Le parent immÃ©diat .col-md-12 sans padding
   donne x=0 relatif au wrapper. Le wrapper a padding 40px â†’ action-row outer-left Ã  40px
   depuis page-left. .tdl-sections a padding 40px â†’ .tdl-section box Ã  80px depuis page-left.
   On porte le padding de .tdl-action-row Ã  40px pour matcher la position interne. */
.tdl-action-row { padding: 16px 40px 0 !important; }

/* #2 â€” PÃ©riode RESTE Ã  la suite du bouton Filtres + Reset, avec un sÃ©parateur visuel. */
.tdl-subbar .tdl-period-filter { margin-left: 0; }
.tdl-period-sep-vertical { display: inline-block; width: 1px; height: 22px; background: #e2e8f0; margin: 0 8px; }

/* #4 â€” Onglets : mÃªme largeur via min-width sur chaque onglet, sans stretching forcÃ©.
   On retire flex-grow et on impose une largeur minimum confortable. Le centrage du
   contenu est conservÃ©. */
.tdl-tabs { gap: 12px; padding: 12px 40px 0; flex-wrap: wrap; }
.tdl-tabs .nav-item { flex: 0 0 auto; }
.tdl-tab.nav-link { min-width: 220px; text-align: center; padding: 10px 16px; }


/* â”€â”€â”€ Todo/Plannings : itÃ©ration 5 (alignement strict + onglets teal) â”€â”€â”€ */

/* Kill l'ancien .tdl-tab-hint padding qui s'ajoutait au padding de l'action-row.
   Cause de "hint trop dÃ©calÃ© Ã  droite" : 40 (wrapper) + 40 (action-row) + 40 (hint padding) = 120. */
.tdl-tab-hint { padding: 0 !important; }

/* Forcer le wrapper d'action sans padding-bottom 0 pour ne pas coller au tableau. */
.tdl-action-row { padding: 16px 40px 12px !important; align-items: center; }

/* Le bouton "Ajouter" ne doit pas avoir de marge Ã  droite. */
.tdl-add-btn { margin: 0 !important; }

/* â”€â”€â”€ Onglets : couleur teal au hover et sur actif â”€â”€â”€ */
/* Style unifie onglets Todo/Plannings + Communaute (refonte 2026-05-31) :
   - repos : texte gris CLAIR (#94a3b8), fond transparent, bordure transparente
   - hover : fond teal tres clair, texte teal
   - actif : fond teal clair (plus marque que hover), texte teal, gras
   Pas de soulignement teal fonce sur l'actif → preservation du look "onglet". */
.tdl-tab.nav-link { color: #a0aec0 !important; }
.tdl-tab.nav-link:hover { color: #0d9488 !important; background: #f0fbf9; border-color: transparent; }
.tdl-tab.nav-link.active { color: #0d9488 !important; font-weight: 600; background: #e6f7f5; border-color: transparent !important; }
.tdl-tab.nav-link.active:hover { color: #0d9488 !important; background: #e6f7f5; }


/* â”€â”€â”€ Todo/Plannings : itÃ©ration 6 (taille bouton Ajouter + alignement strict) â”€â”€â”€ */

/* #2 â€” Bouton "+ Ajouter" : mÃªme padding vertical que .tdl-display-pill (padding 6px 12px)
   pour atteindre une hauteur similaire visuellement. */
.tdl-add-btn { padding: 6px 14px !important; font-size: 0.75rem; line-height: 1.4; margin: 0 !important; }

/* #3 â€” Alignement strict : on cible la rÃ¨gle par sÃ©lecteur de parent pour garantir
   qu'elle prime sur toute autre, et on harmonise box-sizing. */
.tasks-outer-wrapper > .col-md-12 > .tdl-action-row {
    box-sizing: border-box !important;
    padding: 16px 40px 12px !important;
    margin: 0 !important;
}
.tasks-outer-wrapper > .col-md-12 > .tdl-action-row > .tdl-tab-hint {
    padding: 0 !important;
    margin: 0 !important;
}


/* â”€â”€â”€ Todo/Plannings : itÃ©ration 7 (alignement via margin strict + bouton clear dates) â”€â”€â”€ */

/* Alignement strict en utilisant margin au lieu de padding. Plus prÃ©visible : l'action-row
   est positionnÃ©e Ã  exactement margin-left depuis col-md-12 (qui est Ã  40px du bord page),
   donc action-row outer-left = 40 + 40 = 80px = mÃªme que le bord gauche du .tdl-section.
   Pas de padding interne â†’ les enfants (hint Ã  gauche, bouton Ã  droite) sont collÃ©s
   aux bords sans aucune marge propre. */
.tasks-outer-wrapper > .col-md-12 > .tdl-action-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin: 16px 40px 12px 40px !important;
    padding: 0 !important;
    background: transparent !important;
    gap: 8px !important;
    box-sizing: border-box !important;
}
.tasks-outer-wrapper > .col-md-12 > .tdl-action-row > .tdl-tab-hint {
    margin: 0 !important;
    flex: 1 1 auto;
    min-width: 0;
}
.tasks-outer-wrapper > .col-md-12 > .tdl-action-row > .tdl-add-btn {
    margin: 0 !important;
    flex: 0 0 auto;
}

/* Bouton "Ã— Effacer dates" : style discret, hauteur alignÃ©e sur les inputs date */
.tdl-period-clear-btn {
    background: transparent;
    border: 1px solid transparent;
    color: #94a3b8;
    padding: 4px 8px;
    border-radius: 2px;
    cursor: pointer;
    font-size: 0.7rem;
    line-height: 1;
}
.tdl-period-clear-btn:hover { color: #ef4444; background: #fef2f2; }


/* â”€â”€â”€ Todo/Plannings : bouton chevron collapse/expand zone Affichage â”€â”€â”€ */

.tdl-subbar { position: relative; }
.tdl-collapse-toggle {
    margin-left: auto;
    background: transparent;
    border: 1px solid #e2e8f0;
    color: #64748b;
    padding: 6px 10px;
    border-radius: 2px;
    cursor: pointer;
    font-size: 0.8rem;
    line-height: 1;
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.tdl-collapse-toggle:hover { background: #f1f5f9; color: #2D3E50; border-color: #cbd5e1; }
.tdl-collapse-toggle i { transition: transform 0.18s ease; }

/* Quand body.tdl-collapsed : icÃ´ne inversÃ©e + zone Affichage/Onglets/hint masquÃ©e */
body.tdl-collapsed .tdl-collapse-toggle i { transform: rotate(180deg); }
body.tdl-collapsed .tdl-display-wrap,
body.tdl-collapsed .tdl-tabs,
body.tdl-collapsed .tasks-outer-wrapper > .col-md-12 > .tdl-action-row { display: none !important; }

/* Quand collapsÃ©, on rapproche le tableau vers le haut (sinon trop de margin top accumulÃ©s). */
body.tdl-collapsed .tasks-outer-wrapper { padding-top: 0 !important; }


/* â”€â”€â”€ Todo/Plannings : indicateurs en mode collapsed + marge â”€â”€â”€ */

/* Indicateurs : cachÃ©s en mode normal, visibles en mode collapsed.
   Placement : entre le bouton +/- 6 mois et le chevron, Ã  droite. */
.tdl-subbar-summary { display: none; margin-left: auto; align-items: center; gap: 8px; font-size: 0.78rem; color: #475569; }
body.tdl-collapsed .tdl-subbar-summary { display: inline-flex; }
.tdl-summary-chip { display: inline-flex; align-items: center; gap: 6px; }
.tdl-summary-label { font-size: 0.62rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: #8fa1b3; }
.tdl-summary-value { color: #2D3E50; font-weight: 500; }
.tdl-summary-sep { color: #cbd5e1; padding: 0 4px; }
.tdl-summary-chip-completed { color: #0d9488; font-weight: 500; }
.tdl-summary-chip-completed i { font-size: 0.7rem; }

/* Quand collapsed : chevron reste Ã  droite, mais le summary l'aspire avec margin-left: auto
   donc on retire le margin-left: auto du chevron en mode collapsed. */
body.tdl-collapsed .tdl-collapse-toggle { margin-left: 0; }

/* Marge sous la subbar en mode collapsed pour que les Filtres ne soient pas collÃ©s au tableau. */
body.tdl-collapsed .tdl-subbar { margin-bottom: 16px; }


/* â”€â”€â”€ Todo/Plannings : icÃ´ne info hint en teal pÃ¢le (subtle, non flashy) â”€â”€â”€ */
.tdl-tab-hint i.fa-info-circle { color: #99d3c8 !important; font-size: 0.95rem; }


/* â”€â”€â”€ Todo/Plannings : itÃ©ration 11 (fix scroll page + style chevron actif + badges + scrollbar table) â”€â”€â”€ */

/* Refonte 2026-05-30 : Affichage zone deplacee a l'interieur de .tdl-scroll-zone,
   chrome au-dessus reduit a header (~64) + subbar (~50) + onglets (~40) + marges = ~190px.
   En mode collapsed, onglets masques, chrome = ~130px. */
.tdl-scroll-zone { max-height: calc(100vh - 200px) !important; }
/* Collapsed : Affichage masquee (display:none) + onglets masquees, mais besoin de plus de
   marge sur la deduction car la navbar principale + chrome global de l'app n'est pas comprise
   dans nos 100vh. Le calcul empirique : 170px evite le debordement sous la navbar. */
body.tdl-collapsed .tdl-scroll-zone { max-height: calc(100vh - 170px) !important; }

/* === Filtrage par onglet en CSS pur (refonte 2026-05-30) ===========================
   Le serveur renvoie maintenant TOUTES les rows voter-autorisees. Chaque row est
   annotee avec data-tab-myprojects/myresp/perso. La bascule entre onglets devient une
   simple operation de classe sur <body> : zero requete, zero swap DOM, instantanee.
   Tab 'all' : pas de regle (toutes rows visibles).
   Tab 'completed' : geree separement (cas serveur dedie). */
body.tdl-tab-myprojects .tdl-row[data-tab-myprojects="0"] { display: none !important; }
body.tdl-tab-myresp .tdl-row[data-tab-myresp="0"] { display: none !important; }
body.tdl-tab-perso .tdl-row[data-tab-perso="0"] { display: none !important; }

/* Pills Affichage contextuelles : on masque celles qui n'ont aucune ligne possible sur
   l'onglet courant (evite le bug de combinaison vide observe sur myProjects x Contrats). */
body.tdl-tab-myprojects #tdl-filter-type-contract { display: none !important; }
body.tdl-tab-perso #tdl-filter-type-milestone,
body.tdl-tab-perso #tdl-filter-type-contract { display: none !important; }
/* Perso : seul reste "Tous" + "Actions" → 2 pills equivalentes, on masque toute la zone. */
body.tdl-tab-perso .tdl-display-wrap { display: none !important; }

/* Affichage zone : placee dans .tdl-scroll-zone, entre le panneau Filtres et .tdl-sections.
   Suppression de l'encadre (box) et du label "AFFICHAGE :" — les pills sont auto-explicites.
   Padding horizontal 40px pour aligner avec .tdl-sections (qui a aussi padding 40px).
   Sticky top:0 pour rester visible quand on scrolle dans .tdl-scroll-zone (z-index 7 pour
   passer au-dessus des section-header qui sont sticky top:0 z-index:6). */
.tdl-display-wrap {
    margin: 0 !important;
    padding: 12px 40px 8px !important;
    display: flex !important;
    align-items: center;
    gap: 6px;
    position: sticky;
    top: 0;
    z-index: 7;
    background: #fff;
}
/* Section header : sticky en-dessous de la zone Affichage (offset = hauteur Affichage ~45px).
   Quand l'Affichage est masque (onglets Perso / Terminees / collapsed), le top revient a 0
   pour eviter une zone blanche fantome au-dessus de la 1re section + le chevauchement
   header/1re ligne du tableau. */
.tdl-scroll-zone .tdl-section-header { top: 45px !important; }
body.tdl-tab-perso .tdl-scroll-zone .tdl-section-header,
body.tdl-tab-completed .tdl-scroll-zone .tdl-section-header,
body.tdl-collapsed .tdl-scroll-zone .tdl-section-header { top: 0 !important; }
.tdl-display-box {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

/* Onglet "Terminees" : cas serveur dedie, pas de pills Affichage ni de bouton +Ajouter. */
body.tdl-tab-completed .tdl-display-wrap,
body.tdl-tab-completed .tdl-action-row,
body.tdl-tab-completed #open-new-task-modal-button { display: none !important; }

/* Bouton "+ Ajouter" deplace dans la subbar (refonte 2026-05-30) : taille reduite pour
   matcher la hauteur du chevron Collapse et autres elements de la subbar. */
.tdl-add-btn-subbar {
    /* margin-left: auto pousse le bouton tout a droite. Le chevron Collapse a aussi
       margin-left:auto par defaut → on l'override en sibling selector ci-dessous pour
       eviter une distribution equitable de l'espace (sinon gap entre +Ajouter et chevron). */
    margin-left: auto !important;
    margin-right: 0 !important;
    padding: 6px 14px !important;
    font-size: 0.78rem;
    line-height: 1.2;
    height: 32px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.tdl-add-btn-subbar i { font-size: 0.72rem; }
/* Le chevron Collapse, quand precede par +Ajouter, perd son margin-left:auto et se colle
   au bouton (gap 8px du flex container). */
.tdl-add-btn-subbar + .tdl-collapse-toggle { margin-left: 0 !important; }
/* Quand collapse est replie : le .tdl-subbar-summary prend le margin-left auto, le bouton
   suit immediatement derriere (margin gauche normal, pas auto). */
body.tdl-collapsed .tdl-add-btn-subbar { margin-left: 8px !important; }

/* Separateur visuel entre les 4 onglets de perimetre et l'onglet Terminees. */
.tdl-tab-separator {
    width: 24px;
    pointer-events: none;
}

/* Action row sans bandeau hint : aligne le bouton +Ajouter a droite (le hint est
   remplace par les tooltips Bootstrap sur chaque onglet, cf .tdl-tab data-toggle). */
.tdl-action-row-end { justify-content: flex-end !important; }

/* === UX de chargement : barre de progression fine top (refonte 2026-05-30) =========
   Affichee pendant toute requete AJAX en vol (tdlRefresh, tdlLazyLoadRest, filter
   submit). Pattern Turbo/GitHub : 3px fixe top, gradient teal, animation indeterminee.
   Cachee par defaut, .is-active pour la rendre visible. */
.tdl-progress-bar {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: transparent;
    z-index: 10000;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s ease;
}
.tdl-progress-bar::before {
    content: '';
    position: absolute;
    top: 0; bottom: 0;
    left: -40%;
    width: 40%;
    background: linear-gradient(90deg, transparent 0%, #0d9488 50%, transparent 100%);
    animation: tdl-progress-slide 1.1s ease-in-out infinite;
}
.tdl-progress-bar.is-active { opacity: 1; }
@keyframes tdl-progress-slide {
    0%   { left: -40%; }
    100% { left: 100%; }
}

/* Overlay localise sur la zone scrollable : montre pendant la soumission du form filtres
   (rechargement serveur). Garde les rows visibles mais grisees pour signifier "remplacement". */
.tdl-scroll-zone { position: relative; }
.tdl-scroll-zone.is-loading::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, 0.55);
    z-index: 5;
    pointer-events: none;
}

/* #1 â€” Chevron collapsed : style teal actif (cohÃ©rence avec pills Affichage actives) */
body.tdl-collapsed .tdl-collapse-toggle {
    background: #e6f7f5;
    color: #0d9488;
    border-color: #0d9488;
}
body.tdl-collapsed .tdl-collapse-toggle:hover { background: #d4f1ee; color: #0d9488; border-color: #0d9488; }

/* #3 â€” Badge style pour les valeurs du summary + alignement vertical + marge avant chevron */
.tdl-subbar-summary { gap: 12px; }
.tdl-summary-chip { display: inline-flex; align-items: center; gap: 8px; line-height: 1; }
.tdl-summary-label { font-size: 0.62rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: #8fa1b3; line-height: 1; }
.tdl-summary-value {
    background: #f1f5f9;
    color: #2D3E50;
    padding: 4px 10px;
    border-radius: 100px;
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1.2;
    display: inline-block;
}
body.tdl-collapsed .tdl-collapse-toggle { margin-left: 16px; }

/* #4 â€” Compensation scrollbar interne (.tdl-sections custom 6px) : padding-right rÃ©duit
   de 6px cÃ´tÃ© droit pour que la box .tdl-section ait visuellement la mÃªme marge Ã  gauche
   et Ã  droite (la scrollbar mange 6px de l'intÃ©rieur). */
.tdl-sections { padding-right: 34px !important; }


/* â”€â”€â”€ Todo/Plannings : itÃ©ration 12 (border-radius 2px badges + outline focus + marge) â”€â”€â”€ */

/* #1 â€” Border-radius 2px (Design system reference) sur tous les badges */
.tdl-summary-value { border-radius: 2px !important; }
.tdl-projet-flag-perso { border-radius: 2px !important; }

/* #3 â€” Retire l'outline noir focus/active sur boutons chevron et annÃ©e pleine */
#tdl-collapse-toggle:focus,
#tdl-collapse-toggle:active,
#tdl-collapse-toggle:focus-visible,
#tdl-period-mode-btn:focus,
#tdl-period-mode-btn:active,
#tdl-period-mode-btn:focus-visible,
#tdl-period-clear-btn:focus,
#tdl-period-clear-btn:active,
#tdl-period-clear-btn:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}

/* #4 â€” RÃ©duit la marge top entre la zone Onglets et l'Action row (hint + bouton Ajouter) */
.tasks-outer-wrapper > .col-md-12 > .tdl-action-row {
    margin-top: 8px !important;
}


/* â”€â”€â”€ Todo/Plannings : border-radius 2px sur badge "PrivÃ©" (Design system reference) â”€â”€â”€ */
.task-access-badge { border-radius: 2px !important; }


/* â”€â”€â”€ Todo/Plannings : panneau filtres avancÃ©s â€” titre + compact alignÃ© gauche â”€â”€â”€ */

/* Panel : moins large + alignÃ© Ã  gauche au lieu d'occuper toute la largeur */
.tdl-filters-panel {
    max-width: 720px !important;
    margin: 8px 40px 16px !important;
    padding: 16px 20px 12px !important;
    position: relative;
}

/* Titre "Filtres" en coin haut-gauche, style cohÃ©rent avec les labels uppercase */
.tdl-filters-title {
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #8fa1b3;
    margin-bottom: 10px;
}

/* Grid 2 colonnes pour une zone plus compacte (au lieu de 3) */
.tdl-filters-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px 16px !important; }


/* â”€â”€â”€ Todo/Plannings : bouton Filtres en Ã©tat actif (panel ouvert) â”€â”€â”€ */
.tdl-subbar-filter-btn.is-open {
    background: #e6f7f5 !important;
    color: #0d9488 !important;
    border-color: #0d9488 !important;
}
.tdl-subbar-filter-btn.is-open:hover {
    background: #d4f1ee !important;
    color: #0d9488 !important;
    border-color: #0d9488 !important;
}
.tdl-subbar-filter-btn .fa-chevron-down { transition: transform 0.18s ease; }
.tdl-subbar-filter-btn.is-open .fa-chevron-down { transform: rotate(180deg); }


/* â”€â”€â”€ Todo/Plannings : champs de sÃ©lection des filtres â€” moins larges + contour gris â”€â”€â”€ */
.tdl-filters-panel .tdl-filter-cell { max-width: 240px; }
.tdl-filters-panel .tdl-filter-cell .bootstrap-select { width: 100% !important; }
.tdl-filters-panel .tdl-filter-cell .bootstrap-select > .dropdown-toggle,
.tdl-filters-panel .tdl-filter-cell .bootstrap-select > .btn {
    border: 1px solid #d1d5db !important;
    background: #fff !important;
    color: #2D3E50 !important;
    box-shadow: none !important;
    border-radius: 2px !important;
    padding: 5px 10px !important;
    font-size: 0.78rem !important;
    min-height: 32px !important;
}
.tdl-filters-panel .tdl-filter-cell .bootstrap-select > .dropdown-toggle:hover,
.tdl-filters-panel .tdl-filter-cell .bootstrap-select > .btn:hover {
    border-color: #94a3b8 !important;
}
.tdl-filters-panel .tdl-filter-cell .bootstrap-select > .dropdown-toggle:focus,
.tdl-filters-panel .tdl-filter-cell .bootstrap-select > .btn:focus {
    border-color: #0d9488 !important;
    outline: none !important;
}
/* Grid : on rÃ©duit le gap horizontal pour la cohÃ©rence avec les champs moins larges */
.tdl-filters-grid { gap: 10px 12px !important; }


/* â”€â”€â”€ CommunautÃ© : refonte onglets Ã‰quipe/Entreprise au style Todo/Plannings (2026-05-28) â”€â”€â”€
   Reproduit le style des onglets .tdl-tabs/.tdl-tab : carte underlined teal (#0d9488),
   fond blanc sur actif, fusion avec le contenu via border-bottom blanc.
   On ne touche PAS au markup .com-switcher-tab â†’ toute la mÃ©canique existante (max-width,
   ellipsis .com-switcher-tab-text, overflow "+" dropdown, badges non-lus) reste en place. */

/* Reset visuel : annule les anciens styles "bordure basse 3px + fond teintÃ©" */
.com-switcher-tab,
.com-switcher-tab:hover,
.com-switcher-tab.active {
    background: transparent !important;
    border-bottom: 1px solid transparent !important;
    border-radius: 2px 2px 0 0 !important;
}
/* DÃ©sactive l'underline animÃ© du pseudo-Ã©lÃ©ment (incompatible avec le style "carte") */
.com-switcher-tab::after { display: none !important; }

/* Ligne sous toute la barre d'onglets : remplace le border-bottom de .com-switcher-bar
   pour que les onglets actifs viennent s'y "coller" en cassant la ligne (effet carte). */
.com-switcher-bar { border-bottom: none !important; box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important; }
.com-switcher { border-bottom: 1px solid #e2e8f0; padding: 12px 0 0; gap: 12px; align-items: flex-end; }
.com-switcher-left { padding: 0 20px; border-bottom: 1px solid transparent; align-items: flex-end; }

/* Tabs : repos = texte gris CLAIR (#a0aec0), sans bordure visible. Aligne sur .tdl-tab. */
.com-switcher-tab {
    color: #a0aec0 !important;
    font-size: 0.84rem !important;
    font-weight: 500 !important;
    padding: 10px 16px !important;
    margin-bottom: -1px;
    border: 1px solid transparent !important;
    border-bottom: 1px solid transparent !important;
}

/* Hover : fond teal tres clair + texte teal (refonte 2026-05-31, aligne sur .tdl-tab). */
.com-switcher-tab:hover {
    color: #0d9488 !important;
    background: #f0fbf9 !important;
    border-color: transparent !important;
    text-decoration: none;
}

/* Actif : fond teal clair (plus marque que hover) + texte teal + gras, pas de soulignement
   ni de bordure. Identique a .tdl-tab.nav-link.active pour coherence inter-modules. */
.com-switcher-tab.active {
    color: #0d9488 !important;
    font-weight: 600 !important;
    background: #e6f7f5 !important;
    border: 1px solid transparent !important;
    border-bottom: 1px solid transparent !important;
}
.com-switcher-tab.active:hover {
    color: #0d9488 !important;
    background: #e6f7f5 !important;
}

/* IcÃ´ne Entreprise (fa-building) : navy en repos, teal en actif. Pas d'icÃ´ne sur Ã‰quipes. */
.com-switcher-tab i { color: #8fa1b3 !important; font-size: 0.85rem; }
.com-switcher-tab.active i,
.com-switcher-tab:hover i { color: #0d9488 !important; }


/* â”€â”€â”€ CommunautÃ© : ajustements onglets (2026-05-28 â€” itÃ©ration 2) â”€â”€â”€
   Fix 1: trait gris pleine largeur de la page â†’ portÃ© sur .com-switcher-bar.
   Fix 2: trait sous l'onglet actif â†’ align-items: flex-end sur le bar + margin-bottom:-1px
          sur tab permettent au border-bottom:#fff de l'onglet actif de masquer la ligne. */

.com-switcher-bar {
    border-bottom: 1px solid #e2e8f0 !important;
    box-shadow: none !important;
    align-items: flex-end !important;
}
/* La barre d'actions Ã  droite (+ Ajouter, Documents) garde son alignement vertical centrÃ©. */
.com-switcher-actions { align-self: center !important; }

/* Retire la ligne posÃ©e sur .com-switcher Ã  l'itÃ©ration 1 (la ligne est maintenant sur le bar). */
.com-switcher { border-bottom: none !important; }
.com-switcher-left { border-bottom: none !important; }


/* â”€â”€â”€ CommunautÃ© : ajustements onglets (2026-05-28 â€” itÃ©ration 3) â”€â”€â”€
   Fix: la ligne grise du bar reste visible sous l'onglet actif car .com-switcher avait
   overflow:hidden qui clippait verticalement le border-bottom:#fff de l'onglet actif.
   On passe Ã  overflow-x: clip (modern CSS) â†’ horizontal toujours clippÃ© pour le systÃ¨me
   de troncature "+", vertical autorisÃ© â†’ l'onglet actif dÃ©borde de 1px pour masquer le trait.

   Largeur: aligne sur le module Todo/Plannings (min-width: 220px). */

.com-switcher {
    overflow: visible !important;
    overflow-x: clip !important;
    overflow-y: visible !important;
}

/* Largeur des onglets identique au module Todo/Plannings (.tdl-tab min-width: 220px). */
.com-switcher-tab {
    min-width: 220px !important;
    max-width: 260px !important;
    justify-content: center;
}


/* â”€â”€â”€ CommunautÃ© : compactage des posts en 2 lignes (2026-05-28) â”€â”€â”€
   Fusion ligne 2 (titre) + ligne 3 (aperÃ§u/event/sondage/doc) en une seule ligne.
   .com-post-item-body devient un flex row : titre Ã  gauche tronquÃ© Ã  45% max,
   contenu Ã  droite occupant l'espace restant avec ellipsis si dÃ©bord. */

.com-post-item-body {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 5px 12px 7px !important;
    flex-wrap: nowrap;
    min-width: 0;
    overflow: hidden;
}

.com-post-title {
    flex: 0 1 auto !important;
    max-width: 45%;
    margin-bottom: 0 !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.3 !important;
}

/* Tous les contenus secondaires (preview / event / poll / doc) :
   prennent l'espace restant, single-line avec ellipsis. */
.com-post-preview {
    flex: 1 1 auto !important;
    min-width: 0;
    margin-top: 0 !important;
    display: block !important;
    -webkit-line-clamp: unset !important;
    -webkit-box-orient: unset !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.com-post-event-info,
.com-post-poll-preview,
.com-post-doc-preview {
    flex: 1 1 auto !important;
    min-width: 0;
    margin-top: 0 !important;
    flex-wrap: nowrap !important;
    overflow: hidden;
    white-space: nowrap;
}

/* Event : date Ã  gauche, ICS icÃ´ne seule Ã  droite (le texte est conservÃ© via title="...") */
.com-post-event-info .com-post-event-date {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
    flex: 1 1 auto;
}
.com-post-event-info .com-post-ics-link {
    flex: 0 0 auto;
    margin-left: auto;
}

/* Sondage : ne pas afficher l'aperÃ§u du body si une question de sondage est rendue
   (la question du sondage occupe dÃ©jÃ  la ligne et est plus pertinente). */
.com-post-type-poll .com-post-preview { display: none !important; }
.com-post-poll-preview {
    overflow: hidden;
    text-overflow: ellipsis;
}
.com-post-poll-preview .com-post-poll-votes { flex: 0 0 auto; margin-left: auto; }

/* Document : label tronquÃ©, catÃ©gorie et taille restent visibles Ã  droite */
.com-post-doc-preview .com-post-doc-label {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.com-post-doc-preview .com-doc-cat-tag,
.com-post-doc-preview .com-post-doc-size { flex: 0 0 auto; }


/* â”€â”€â”€ CommunautÃ© : ajustements posts compacts (2026-05-28 â€” itÃ©ration 2) â”€â”€â”€
   1. Zone titre = 30% fixe pour TOUS les types (cohÃ©rence visuelle d'alignement).
   2. Event : ICS juste aprÃ¨s la date (avant le body), pas Ã  l'extrÃªme droite. */

.com-post-title {
    flex: 0 0 30% !important;
    max-width: 30% !important;
}

/* Event-info ne mange plus tout l'espace : shrink Ã  son contenu (date + icÃ´ne ICS).
   Le com-post-preview (body) qui suit prend le flex:1 restant. */
.com-post-event-info {
    flex: 0 0 auto !important;
    gap: 8px;
}
.com-post-event-info .com-post-event-date {
    flex: 0 0 auto !important;
}
/* ICS : icÃ´ne juste aprÃ¨s la date (suppression du margin-left:auto qui le poussait Ã  droite). */
.com-post-event-info .com-post-ics-link {
    margin-left: 0 !important;
    flex: 0 0 auto;
}


/* â”€â”€â”€ CommunautÃ© : poubelle dÃ©placÃ©e dans le header, juste aprÃ¨s la date (2026-05-28) â”€â”€â”€
   La poubelle quitte .com-post-item-footer (supprimÃ© du markup) pour se placer dans
   .com-post-item-author aprÃ¨s la date. Hover-fade conservÃ©. */

.com-post-item-author .com-post-action-delete {
    flex: 0 0 auto;
    margin-left: 4px;
    opacity: 0;
    transition: opacity 0.15s;
}
.com-post-item:hover .com-post-item-author .com-post-action-delete { opacity: 1; }

/* L'ancienne rÃ¨gle .com-post-item-footer reste sans effet (plus rendue), pas d'override
   nÃ©cessaire â€” le bloc footer est supprimÃ© du Twig. */


/* â”€â”€â”€ CommunautÃ© : badges actionnables sur le header de post (2026-05-28) â”€â”€â”€
   Miroir visuel des pastilles compteurs des sections Ã‰pinglÃ©s / MÃ©morisÃ©s.
   Couleurs alignÃ©es : orange pour Ã©chÃ©ance proche, violet pour sondage Ã  voter. */

.com-post-due-badge,
.com-post-vote-badge {
    display: inline-flex;
    align-items: center;
    font-size: 0.60rem;
    font-weight: 700;
    color: #fff;
    border-radius: 2px;
    padding: 1px 5px;
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}
.com-post-due-badge  { background: #d97706; }  /* Ã©chÃ©ance â‰¤ 7 jours â€” orange (.com-pinned-badge-due) */
.com-post-vote-badge { background: #6b5fa5; }  /* sondage Ã  voter â€” violet (.com-pinned-badge-vote)  */
.com-post-due-badge i,
.com-post-vote-badge i { font-size: 0.62rem; }


/* â”€â”€â”€ CommunautÃ© : badge "ExpirÃ©" sur events passÃ©s et sondages clos (2026-05-28) â”€â”€â”€
   Gris muted (â‰  rouge non-lus, â‰  orange Ã©chÃ©ance proche) pour signaler le statut "terminÃ©". */
.com-post-expired-badge {
    display: inline-flex;
    align-items: center;
    font-size: 0.60rem;
    font-weight: 700;
    color: #fff;
    border-radius: 2px;
    padding: 1px 5px;
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    background: #94a3b8;
}
.com-post-expired-badge i { font-size: 0.62rem; }


/* â”€â”€â”€ CommunautÃ© : badge "Nouvelle(s) rÃ©ponse(s)" (2026-05-28) â”€â”€â”€
   Post dÃ©jÃ  lu mais une reply est arrivÃ©e depuis. Cyan distinct du teal "Nouveau". */
.com-post-newreplies-badge {
    display: inline-flex;
    align-items: center;
    font-size: 0.60rem;
    font-weight: 700;
    color: #fff;
    border-radius: 2px;
    padding: 1px 5px;
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    background: #0891b2;  /* cyan-600 â€” distinct du teal des non-lus */
}
.com-post-newreplies-badge i { font-size: 0.62rem; }


/* â”€â”€â”€ CommunautÃ© : bouton "auto-unpin Ã  l'Ã©chÃ©ance + 1 semaine" dans la modale pin (2026-05-28) â”€â”€â”€
   Style "recommandÃ©" pour attirer l'Å“il : fond teal lÃ©ger, border teal, en haut de la liste. */
.com-pin-duration-auto {
    background: rgba(13, 148, 136, 0.10) !important;
    border: 1px solid var(--com-teal, #0d9488) !important;
    color: var(--com-teal, #0d9488) !important;
    font-weight: 600 !important;
    margin-bottom: 10px !important;
    width: 100%;
    /* PAS de display:block !important : laisse .hide()/.show() de jQuery contrÃ´ler la visibilitÃ©
       (inline style="display:none" perd contre un !important CSS â†’ bouton fantÃ´me persistant). */
}
.com-pin-duration-auto:hover {
    background: rgba(13, 148, 136, 0.18) !important;
}
.com-pin-duration-auto.is-default {
    box-shadow: 0 0 0 2px rgba(13, 148, 136, 0.20);
}


/* â”€â”€â”€ CommunautÃ© : ligne d'Ã©chÃ©ance du sondage dans le drawer (2026-05-28) â”€â”€â”€ */
.com-poll-closedat-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    margin: 10px 0;
    background: #fef3c7;
    border-left: 3px solid #d97706;
    border-radius: 2px;
    font-size: 0.85rem;
    color: #78350f;
}
.com-poll-closedat-icon { color: #d97706; font-size: 0.95rem; }
.com-poll-closedat-label { font-weight: 500; }


/* â”€â”€â”€ CommunautÃ© : mÃ©ta-infos sondage inline (drawer post type 3) (2026-05-28) â”€â”€â”€
   Affiche anonymat / choix multiple / date clÃ´ture lus Ã  la crÃ©ation. */
.com-poll-inline-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 6px 0 10px;
}
.com-poll-meta-chip {
    display: inline-flex;
    align-items: center;
    font-size: 0.72rem;
    color: #64748b;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    border-radius: 2px;
    padding: 2px 8px;
    line-height: 1.4;
}
.com-poll-meta-chip-closed {
    background: #fef3c7;
    color: #78350f;
    border-color: #fcd34d;
}
.com-poll-meta-chip i { font-size: 0.70rem; }


/* â”€â”€â”€ CommunautÃ© : date+heure sÃ©parÃ©s dans les modales (2026-05-28) â”€â”€â”€
   Date Ã  gauche (datepicker text + auto-close), heure Ã  droite (HTML5 time native).
   Plus simple que sideBySide qui ne s'active pas correctement en v4.17 du lib. */
.com-date-time-row {
    display: flex;
    gap: 8px;
    align-items: center;
}
.com-date-time-row .com-date-picker { flex: 1 1 auto; min-width: 0; }
.com-date-time-row .com-time-picker { flex: 0 0 110px; }


/* â”€â”€â”€ CommunautÃ© : hourpicker en blanc + bordure + date plus compacte (2026-05-28) â”€â”€â”€ */

/* Date plus compacte : ne grandit plus jusqu'Ã  occuper tout l'espace. */
.com-date-time-row .com-date-picker { flex: 0 0 200px; }

/* Hourpicker (Bootstrap-Select) : fond blanc + bordure identique aux .form-control. */
.com-date-time-row .bootstrap-select > .dropdown-toggle.com-time-btn,
.com-date-time-row .bootstrap-select > .dropdown-toggle.btn-light {
    background-color: #fff !important;
    border: 1px solid #ced4da !important;
    color: #495057 !important;
    box-shadow: none !important;
}
.com-date-time-row .bootstrap-select > .dropdown-toggle.com-time-btn:hover,
.com-date-time-row .bootstrap-select > .dropdown-toggle.com-time-btn:focus,
.com-date-time-row .bootstrap-select > .dropdown-toggle.btn-light:hover,
.com-date-time-row .bootstrap-select > .dropdown-toggle.btn-light:focus {
    background-color: #fff !important;
    border-color: #80bdff !important;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.15) !important;
}
.com-date-time-row .bootstrap-select > .dropdown-toggle .filter-option-inner-inner { color: #495057; }
.com-date-time-row .bootstrap-select > .dropdown-toggle.com-time-btn[title="HH:MM"]:not(.bs-placeholder) .filter-option-inner-inner { color: #495057; }


/* â”€â”€â”€ CommunautÃ© : nettoyage halo/placeholder Bootstrap-Select hourpicker (2026-05-28) â”€â”€â”€ */

/* Wrapper .bootstrap-select : transparent, pas d'ombre, pas de bordure rÃ©siduelle. */
.com-date-time-row .bootstrap-select {
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
}

/* Ã‰tat "placeholder" (.bs-placeholder ajoutÃ© par Bootstrap-Select quand aucune option choisie) :
   force le fond blanc + bordure standard, comme l'Ã©tat sÃ©lectionnÃ©. */
.com-date-time-row .bootstrap-select > .dropdown-toggle.bs-placeholder,
.com-date-time-row .bootstrap-select > .dropdown-toggle.bs-placeholder:hover,
.com-date-time-row .bootstrap-select > .dropdown-toggle.bs-placeholder:focus,
.com-date-time-row .bootstrap-select > .dropdown-toggle.bs-placeholder:active {
    background-color: #fff !important;
    border: 1px solid #ced4da !important;
    color: #94a3b8 !important;   /* placeholder slate-400, cohÃ©rent avec les autres inputs (cf. .tdl-period-input::placeholder) */
    box-shadow: none !important;
    outline: 0 !important;
}
/* La couleur du texte du placeholder est portÃ©e par .filter-option-inner-inner (Bootstrap-Select v1.13+). */
.com-date-time-row .bootstrap-select > .dropdown-toggle.bs-placeholder .filter-option-inner-inner {
    color: #94a3b8 !important;
}

/* Override final du focus : pas de halo bleu Bootstrap-Select (qui s'ajoute aux autres). */
.com-date-time-row .bootstrap-select.show > .dropdown-toggle,
.com-date-time-row .bootstrap-select > .dropdown-toggle:focus {
    outline: 0 !important;
    box-shadow: 0 0 0 0.15rem rgba(0, 123, 255, 0.15) !important;
}


/* â”€â”€â”€ CommunautÃ© : ligne Titre + Date de clÃ´ture cÃ´te Ã  cÃ´te dans modale Sondage (2026-05-28) â”€â”€â”€ */
.com-poll-title-row { align-items: flex-start; }
.com-poll-title-row .col-auto .com-date-picker { width: 160px; }


/* â”€â”€â”€ CommunautÃ© : Ã©dition inline des champs de post / poll dans les drawers (2026-05-28) â”€â”€â”€ */

.com-editable-field { position: relative; }

/* View mode : flex avec icÃ´ne crayon Ã  droite, visible au hover sur la zone. */
.com-editable-view {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}
.com-editable-view > h5,
.com-editable-view > .com-source-body { flex: 1 1 auto; min-width: 0; margin-bottom: 0; }

.com-edit-pencil {
    flex: 0 0 auto;
    background: none;
    border: 0;
    padding: 4px 6px;
    color: #94a3b8;
    cursor: pointer;
    border-radius: 4px;
    opacity: 0;
    transition: opacity .15s, color .15s, background .15s;
    font-size: 0.85rem;
}
.com-editable-field:hover .com-edit-pencil { opacity: 1; }
.com-edit-pencil:hover { color: #0d9488; background: rgba(13, 148, 136, 0.08); }
.com-edit-pencil.com-edit-locked { color: #d97706; cursor: not-allowed; }
.com-edit-pencil.com-edit-locked:hover { background: transparent; color: #d97706; }

/* Edit mode : input/textarea + actions */
.com-editable-edit { width: 100%; }
.com-editable-input { width: 100%; margin-bottom: 8px; }
textarea.com-editable-input { min-height: 80px; resize: vertical; }
.com-editable-actions { display: flex; gap: 6px; justify-content: flex-end; }

/* Placeholder body vide */
.com-source-body-placeholder { font-style: italic; }

/* Bandeau "ModifiÃ© le ..." */
.com-editable-updated {
    margin-top: 4px;
    font-size: 0.70rem;
    color: #94a3b8;
    font-style: italic;
}
.com-editable-updated i { font-size: 0.65rem; }



/* ─── Communauté : édition inline drawer post — refonte propre (2026-05-28) ───
   Principe :
   - .com-source-card garde son layout flex column overflow:hidden (cassé par mes itérations
     précédentes — on RESTAURE strictement le comportement d'origine).
   - .com-editable-body (wrapper du body) reste un BLOC simple, prenant la place restante via
     flex naturel. Pas de display:block !important qui forçait edit + view visibles ensemble.
   - .com-source-body conserve son rôle natif : flex:1 1 auto, scroll interne si débord.
   - Picker date : position:fixed via JS au show (calculé sur viewport).
*/

/* 1. Wrapper body : BLOC SIMPLE, pas de flex pour éviter les bugs de hauteur. */
.com-source-card .com-editable-body {
    display: block;
    width: 100%;
    position: relative;
}

/* 2. View mode du body : position relative pour permettre pencil en absolute.
   Pas de flex → body prend la largeur naturelle, pas de conflit avec max-height. */
.com-source-card .com-editable-body .com-editable-view {
    display: block;
    position: relative;
    padding-right: 36px;  /* place réservée au pencil à droite */
}

/* 3. .com-source-body : bloc normal avec hauteur plafonnée à 40% du source-card.
   Source-card max-height: 42vh → body max ~17vh (≈ 40%). Scrollbar interne si débord. */
.com-source-card .com-editable-body .com-editable-view > .com-source-body {
    display: block;
    width: 100%;
    max-height: 17vh;
    overflow-y: auto;
    overflow-x: hidden;
    margin: 0;
    flex: none;
}

/* Pencil en absolute en haut-droite de la view. */
.com-source-card .com-editable-body .com-editable-view > .com-edit-pencil {
    position: absolute;
    top: 4px;
    right: 0;
}

/* 4. Bandeau "Modifié le" : block normal en flux, marge claire au-dessus.
   12px = vraie respiration entre la box body (fond blanc) et le texte gris. */
.com-source-card .com-editable-body .com-editable-updated {
    display: block;
    margin-top: 12px;
    flex: none;
}

/* 5. Auteur sur une ligne au-dessus du card (sortie du .com-source-card). */
.com-source-author-row-top {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 0 6px 4px;
    margin-bottom: 0 !important;   /* override le 12px hérité de .com-source-author-row */
    font-size: 0.70rem;
    color: #94a3b8;
}
.com-source-author-row-top .circled,
.com-source-author-row-top .circled img { width: 20px !important; height: 20px !important; line-height: 18px !important; }
.com-source-author-row-top .com-source-author-name { font-size: 0.72rem !important; font-weight: 500 !important; color: #64748b !important; }
.com-source-author-row-top .com-source-date { font-size: 0.70rem; color: #94a3b8; }

/* 6. Edit mode du body : textarea avec max-height + scroll interne ; pas de display:block !important
   qui forçait les 2 vues simultanées. Le .com-editable-edit a un style="display:none" inline
   et est uniquement affiché via JS au clic crayon. */
.com-source-card .com-editable-body .com-editable-edit { width: 100%; }
textarea.com-editable-input {
    width: 100%;
    min-height: 80px;
    max-height: 17vh;     /* aligné avec le display : ~40% du source-card (42vh) */
    overflow-y: auto;
    resize: vertical;
}
/* Scrollbar fin sans flèches haut/bas (Windows native arrows masquées). */
textarea.com-editable-input::-webkit-scrollbar,
.com-source-body::-webkit-scrollbar { width: 6px; }
textarea.com-editable-input::-webkit-scrollbar-button,
.com-source-body::-webkit-scrollbar-button { display: none; height: 0; width: 0; }
textarea.com-editable-input::-webkit-scrollbar-thumb,
.com-source-body::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 3px; }
textarea.com-editable-input, .com-source-body { scrollbar-width: thin; scrollbar-color: #cbd5e1 transparent; }

/* 7. Row inline eventDate : date + hour + 2 icônes sur une seule ligne compacte. */
.com-editable-inline-row { display: flex; align-items: center; gap: 8px; }
.com-editable-inline-row .com-date-picker { flex: 0 0 150px; }
.com-editable-inline-row .com-time-picker,
.com-editable-inline-row .bootstrap-select { width: 100px !important; min-width: 0; }
.com-editable-inline-row .bootstrap-select > .dropdown-toggle { padding: 5px 10px; }
.com-edit-icon-btn {
    flex: 0 0 28px;
    width: 28px;
    height: 28px;
    border: 1px solid #e2e8f0;
    background: #fff;
    border-radius: 4px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #94a3b8;
    transition: all .15s;
}
.com-edit-icon-btn:hover { background: #f8fafc; }
.com-edit-cancel-btn:hover { color: #dc2626; border-color: #fecaca; }
.com-edit-save-btn:hover { color: #0d9488; border-color: #5eead4; background: #ccfbf1; }

/* 8. Datepicker widget : juste z-index élevé. Laisse la lib gérer la position absolute
   par défaut (la source-card est maintenant overflow:auto, donc le widget peut se déployer). */
.bootstrap-datetimepicker-widget {
    z-index: 10050 !important;
}

/* 9. Autosave focus highlight (sans bouton save explicite, signal visuel d'édition active). */
.com-editable-autosave:focus {
    background: #f0fdfa;
    border-color: #0d9488;
    box-shadow: 0 0 0 0.15rem rgba(13, 148, 136, 0.18);
}


/* ─── Communauté : espacements titre / "Modifié le" / description (2026-05-28) ─── */
/* "Modifié le" du titre : pas de marge haute, collé au titre. */
.com-source-card .com-editable-field[data-field="title"] .com-editable-updated {
    margin-top: 0;
}
/* 16px entre "Modifié le" du titre et le champ description (et autres fields suivants) */
.com-source-card .com-editable-field[data-field="title"] {
    margin-bottom: 16px;
}


/* ─── Communauté : retire la marge basse h5 du titre du drawer (2026-05-28) ─── */
.com-source-card h5.com-source-title { margin-bottom: 0 !important; }


/* ─── Communauté : scrollbar fine de secours sur source-card (2026-05-28) ───
   Au cas où le contenu dépasse 42vh (sondage avec longue description par exemple),
   la card scrolle elle-même au lieu de masquer du contenu. Scrollbar invisible
   par défaut, apparait au hover direct du card ou pendant le scroll. */
.com-source-card {
    overflow-y: auto !important;
    overflow-x: hidden;
    /* Firefox : scrollbar fin masqué par défaut, gris au survol. */
    scrollbar-width: thin;
    scrollbar-color: transparent transparent;
    transition: scrollbar-color .2s;
}
.com-source-card:hover {
    scrollbar-color: #cbd5e1 transparent;
}
/* Webkit : track transparent toujours, thumb visible uniquement au hover du card. */
.com-source-card::-webkit-scrollbar { width: 6px; }
.com-source-card::-webkit-scrollbar-button { display: none; height: 0; width: 0; }
.com-source-card::-webkit-scrollbar-track { background: transparent; }
.com-source-card::-webkit-scrollbar-thumb { background: transparent; border-radius: 3px; transition: background .2s; }
.com-source-card:hover::-webkit-scrollbar-thumb { background: #cbd5e1; }
.com-source-card:hover::-webkit-scrollbar-thumb:hover { background: #94a3b8; }


/* ─── Communauté : protéger les boutons × ✓ d'éventuels overlays bootstrap-select (2026-05-28) ───
   Le wrapper .bootstrap-select peut étendre sa zone cliquable au-delà du button visible.
   On force position:relative + z-index élevé sur × et ✓ pour qu'ils captent les clics. */
.com-editable-inline-row .com-edit-icon-btn {
    position: relative;
    z-index: 5;
}
/* Pattern projet (cf. .task-col-priorite, .task-col-porteur) : masquer le <select> SOUS-JACENT
   uniquement quand il est descendant d'un wrapper .bootstrap-select déjà créé.
   Avec le combinator `>`, la règle ne s'applique qu'APRÈS l'init de Bootstrap-Select,
   évitant de masquer le select natif avant que la lib ait pu l'envelopper. */
.com-editable-inline-row .bootstrap-select > select { display: none !important; }


/* ─── Communauté : "Ajouter à mon agenda" sur sa propre ligne sous l'icône date (2026-05-28) ───
   Le bouton wrap sur la ligne suivante (flex-basis 100%), aligné à gauche, avec marge basse
   pour respiration avant la zone description. */
.com-source-event-date .com-ics-inline-btn {
    flex-basis: 100%;
    width: fit-content;
    max-width: fit-content;
    margin-left: 0 !important;
    margin-top: 6px;
    margin-bottom: 0;
    align-self: flex-start;
    border-radius: 2px !important;
}
/* Le champ eventDate a déjà margin-bottom 14px (.com-editable-field) qui donne la respiration
   vers la zone description. En mode édition, .com-editable-inline-row apporte sa propre
   margin-bottom: 16px → les marges restent propres dans les 2 modes. */


/* ─── Communauté : marge sous la row date/heure en édition (2026-05-28) ───
   Quand le pencil eventDate est cliqué et que la row date+heure+×+✓ s'affiche,
   ajoute une respiration avant le champ description en dessous. */
.com-editable-inline-row { margin-bottom: 16px; }


/* ─── Communauté : variante "pas d'échéance" du bandeau closedAt sondage (2026-05-28) ───
   Le sondage à durée indéfinie : info neutre gris (pas ambré qui suggère urgence). */
.com-poll-closedat-row-none {
    background: #f1f5f9 !important;
    border-left-color: #94a3b8 !important;
    color: #64748b !important;
}
.com-poll-closedat-row-none .com-poll-closedat-icon { color: #94a3b8 !important; }


/* ─── Communauté : pastille date compacte sur les posts Événement dans le fil (2026-05-28) ───
   Style chip jour/mois à gauche du titre, cohérent avec le panel Événements à venir. */
.com-post-event-chip {
    flex: 0 0 auto;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    padding: 2px 4px;
    margin-right: 8px;
    background: rgba(77, 140, 111, 0.10);
    border: 1px solid rgba(77, 140, 111, 0.30);
    border-radius: 4px;
    color: #4d8c6f;
    line-height: 1;
}
.com-post-event-chip-day { font-size: 0.95rem; font-weight: 700; line-height: 1.05; }
.com-post-event-chip-month { font-size: 0.58rem; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }

/* Le post-item-body est déjà en flex row (titre + preview) : la pastille s'aligne à gauche
   avant le titre, le titre garde flex:1 et tronque à 30%. */
.com-post-item-body { align-items: center; }


/* ─── Communauté : chip closedAt sondage dans le meta du drawer post (2026-05-28) ───
   Aligné à droite sur la ligne du badge SONDAGE, look discret cohérent avec les autres chips. */
.com-source-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; }
.com-source-poll-closedat-wrap { display: inline-flex; align-items: center; }
.com-source-poll-closedat {
    display: inline-flex;
    align-items: center;
    font-size: 0.72rem;
    color: #78350f;
    background: #fef3c7;
    border: 1px solid #fcd34d;
    border-radius: 3px;
    padding: 2px 8px;
    line-height: 1.4;
}
.com-source-poll-closedat i { font-size: 0.72rem; color: #d97706; }
/* Variante "pas d'échéance" : ton neutre gris. */
.com-source-poll-closedat-wrap .com-source-poll-closedat-text:only-child + i { display: none; }


/* ─── Communauté : chip closedAt sous le titre (2026-05-28 it.2) ───
   Plus dans le meta (manquait de place) — sur sa propre ligne, aligné à gauche,
   "Modifié le" rebascule juste en dessous. */
.com-source-card .com-source-poll-closedat-wrap {
    display: block;
    margin: 6px 0;
}
.com-source-card .com-source-poll-closedat {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    max-width: 100%;
}
.com-source-card .com-source-poll-closedat .com-edit-pencil { margin-left: 4px; }
.com-source-title-updated { margin-top: 2px; }


/* ─── Communauté : "Modifié le" du eventDate entre la date et le bouton agenda (2026-05-28) ───
   Le bandeau prend toute la largeur (flex-basis:100%) → s'insère naturellement entre la date
   et le bouton "Ajouter à mon agenda", sans gap parasite. */
.com-source-event-date .com-source-event-updated {
    flex-basis: 100%;
    margin-top: 2px;
    margin-bottom: 4px;
}


/* ─── Communauté : pastille date sur post Événement dans le fil — fond teal clair (2026-05-28) ───
   Remplace le chip jour/mois précédent. Le bloc com-post-event-info reçoit un fond pâle teal
   pour mettre en valeur la date de l'événement dans le post. */
.com-post-event-chip { display: none !important; }   /* on cache l'ancien chip jour/mois */
.com-post-item .com-post-event-info {
    background: rgba(13, 148, 136, 0.08) !important;
    border: 1px solid rgba(13, 148, 136, 0.20) !important;
    border-radius: 3px !important;
    padding: 3px 8px !important;
}
.com-post-item .com-post-event-info .com-post-event-date,
.com-post-item .com-post-event-info .com-post-event-date i {
    color: #0d9488 !important;
    font-weight: 600;
}


/* ─── Communauté : section "Activité" (2026-05-28) ───
   Même structure que .com-pinned-section (épinglés / mémorisés) mais icône et accents navy
   pour signaler le statut "fil principal", pas une catégorie spéciale. */
.com-activity-section .com-pinned-icon.com-activity-icon { color: #2D3E50; }
.com-activity-section .com-pinned-count { background: #2D3E50; }


/* ─── Communauté : marge horizontale 80px (alignement Todo/Plannings) (2026-05-28) ───
   .com-columns reçoit 80px à gauche et à droite, comme la zone .tasks-outer-wrapper +
   .tdl-sections du module Todo. Les paddings internes des colonnes sont reset côté
   bord-page pour rester pile à 80px ; on garde 16px à l'intérieur entre les 2 colonnes. */
.com-page .com-columns {
    padding-left: 80px !important;
    /* 80px - largeur visuelle scrollbar fine (≈6px) → l'extrémité droite des cartes
       s'aligne visuellement avec l'extrémité gauche du fil (80px du bord). */
    padding-right: 74px !important;
    background: #fff;
}
.com-page .com-col-feed {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
/* Gap 80px entre fil et cartes, intégralement appliqué sur le côté gauche de la colonne
   cartes → réduit la largeur effective des cartes sans toucher au fil. */
.com-page .com-col-right {
    padding-left: 80px !important;
    padding-right: 0 !important;
}


/* ─── Communauté : "Tout" plus compact pour donner plus de place aux autres filtres (2026-05-28) ───
   Sans flex:1 pour ne pas être étiré à la même largeur. ~20px de moins. */
.com-filters .com-filter[data-filter="all"] {
    flex: 0 0 auto;
    padding-left: 12px;
    padding-right: 12px;
    min-width: 48px;
}


/* ─── Communauté : marge 80px gauche/droite sur le tableau de la Base documentaire (2026-05-28) ───
   Alignement visuel avec la liste Communauté (et le tableau Todo/Plannings). */
#main-content-community-docs .com-docs-page-body {
    padding-left: 80px !important;
    padding-right: 80px !important;
    max-width: none !important;
}


/* ─── Communauté : message d'erreur de validation sous les champs des modales (2026-05-28) ─── */
.com-field-error {
    color: #dc2626;
    font-size: 0.72rem;
    font-weight: 500;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}
.com-field-error::before {
    content: '\f06a';   /* fa-exclamation-circle */
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 0.78rem;
}


/* ─── Communauté : retire le focus persistant sur les boutons d'action des rows docs (2026-05-28) ───
   :focus:not(:focus-visible) → on retire l'outline pour les clics souris (qui laissaient
   un encadré noir persistant) tout en gardant l'outline pour la navigation clavier (a11y). */
.com-docs-row-btn:focus:not(:focus-visible),
.com-doc-fav-btn:focus:not(:focus-visible) {
    outline: none;
    box-shadow: none;
}


/* ─── Communauté : édition inline des options de sondage (2026-05-28) ─── */
/* Override sans !important : la double-classe (.com-editable-poll-options + .com-poll-options-view)
   est plus spécifique que .com-editable-view, donc on bat le flex sans casser le display:none inline
   appliqué par jQuery .hide() au moment du passage en mode édition. */
.com-editable-poll-options .com-poll-options-view {
    display: block;
    position: relative;
    padding-right: 36px;
}
.com-editable-poll-options .com-edit-pencil-options {
    position: absolute;
    top: 0;
    right: 0;
}
.com-poll-options-edit .com-poll-option-row {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 6px;
}
.com-poll-options-edit .com-poll-option-input { flex: 1 1 auto; min-width: 0; }
.com-poll-options-edit .com-poll-option-add { margin-top: 4px; }
.com-poll-options-edit .com-editable-actions {
    display: flex;
    justify-content: flex-end;
    gap: 6px;
}


/* ─── Communauté : "+ Ajouter une option" et boutons × ✓ sur la même ligne (2026-05-28) ─── */
.com-poll-options-bottom-row {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
}


/* ─── Communauté : bouton "+ Ajouter" — large, hauteur modérée, + et chevron espacés du texte (2026-05-28) ─── */
.com-add-dropdown-btn {
    font-size: 0.86rem !important;
    padding: 7px 40px !important;       /* hauteur modérée + beaucoup d'espace horizontal */
    letter-spacing: 0.02em;
}
.com-add-dropdown-btn i { font-size: 0.92rem; }
.com-add-dropdown-btn > i.fa-plus { margin-right: 14px !important; }
.com-add-dropdown-btn > i.com-add-dropdown-caret { margin-left: 14px !important; }


/* ─── Communauté : espacement entre cartes droite augmenté x1,5 (2026-05-28) ─── */
.com-col-right .com-panel { margin-bottom: 21px !important; }
