/* ════════════════════════════════════════════════
   WHO AFRO Communication — Charte graphique officielle
   WHO Brand Guidance July 2025 :
     Navy  #00205C (Pantone 281C)  — couleur primaire, 70% des layouts
     Blue  #009ADE (Pantone 2925C) — couleur secondaire / interactive
     Orange #F26829 (Pantone 165C) — accent / CTA
   Police officielle : Noto Sans Regular / Bold
   ════════════════════════════════════════════════ */
:root {
	/* WHO Brand colors */
	--brand-cyan:        #009ADE;   /* WHO Blue — interactive */
	--brand-cyan-dark:   #007DB6;
	--brand-cyan-darker: #005E8A;
	--brand-green:       #F26829;   /* WHO Orange — accent / CTA */
	--brand-green-dark:  #D85C20;

	/* Design tokens */
	--accent:        var(--brand-cyan);
	--accent-light:  #5AC8EC;
	--accent-dark:   var(--brand-cyan-darker);
	--accent-soft:   rgba(0, 154, 222, 0.10);
	--secondary:     var(--brand-green);
	--secondary-dark:var(--brand-green-dark);
	--secondary-soft:rgba(242, 104, 41, 0.10);

	--ink:       #0F172A;
	--ink-soft:  #334155;
	--muted:     #64748B;
	--line:      #E2E8F0;
	--line-soft: #F1F5F9;
	--canvas:    #F5F7FA;
	--paper:     #FFFFFF;

	--notification-bg: linear-gradient(135deg, #00205C 0%, #003B8E 100%);

	--shadow-sm: 0 1px 2px rgba(0, 32, 92, 0.06), 0 1px 1px rgba(0, 32, 92, 0.04);
	--shadow-md: 0 4px 12px rgba(0, 32, 92, 0.08), 0 2px 4px rgba(0, 32, 92, 0.05);
	--shadow-lg: 0 16px 40px rgba(0, 32, 92, 0.10), 0 4px 12px rgba(0, 32, 92, 0.06);

	/* Rayon uniforme dans toute l'application : 5 px */
	--radius-sm: 5px;
	--radius:    5px;
	--radius-lg: 5px;

	--font-stack: "Noto Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;

	/* Bootstrap overrides */
	--bs-primary:          var(--brand-cyan);
	--bs-primary-rgb:      0, 154, 222;
	--bs-link-color:       var(--brand-cyan-dark);
	--bs-link-hover-color: var(--brand-cyan-darker);
}

html, body {
	font-family: var(--font-stack);
	color: var(--ink);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
/* Fond porté par html (canvas) + body::after (moitié droite assombrie) — défini dans imanage.css */
html { background: var(--canvas); }
body { background: transparent; }

a, a:hover { color: var(--accent-dark); }
a { text-decoration: none; }

::selection { background: var(--accent-soft); color: var(--accent-dark); }

/* ─── Top notification bar ───────────────────────────────── */
#notification_main_bar { background: var(--notification-bg); }
#notification_box .navbar-brand img { height: 32px; }
#notification_box .navbar-brand {
	color: #fff;
	font-weight: 700;
	letter-spacing: 0.02em;
	font-size: 1.05rem;
}

/* ─── Footer : pas de logo Digits dans whocomafr ───────── */
#page_footer .footer-digits-logo,
#page_footer .footer-brand { display: none; }

/* Notifications slide-in : aligne les bg-* sur la palette de marque */
#notification_message_bar.bg-success { background: var(--notification-bg) !important; }
#notification_message_bar.bg-info    { background: var(--notification-bg) !important; }
#notification_message_bar.bg-warning { background-color: #B45309 !important; }
#notification_message_bar.bg-danger  { background-color: #B91C1C !important; }

.notification_main_content .navbar-brand {
	color: #FFFFFF;
	font-weight: 700;
	letter-spacing: 0.18em;
	font-size: 14px;
	text-decoration: none;
}
.notification_main_content .navbar-brand:hover { color: #FFFFFF; }

#content_title {
	color: rgba(255, 255, 255, 0.92);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-align: center;
}

.session_controls {
	font-size: 15px;
	opacity: 0.7;
	transition: opacity 0.15s ease, transform 0.15s ease;
}
.session_controls:hover { opacity: 1; transform: translateY(-1px); cursor: pointer; }

/* ─── Notification bar : ordre visuel [langue] [thème] [print] [reload] ── */
#language_switcher       { order: 1; }
#imanage_theme_toggle    { order: 2; }
#expand_content          { order: 3; }
#reload_content          { order: 4; }

/* ─── Navigation principale ──────────────────────────────── */
.navbar {
	background: var(--paper);
	border-bottom: 1px solid var(--line);
	padding: 6px 0;
}
.navbar .navbar-nav { align-items: center; column-gap: 0; }
.navbar .navbar-nav .nav-item.dropdown {
	position: relative;
	display: flex;
	align-items: center;
}
.navbar .navbar-nav .nav-item.dropdown + .nav-item.dropdown::before {
	content: "";
	width: 1px; height: 18px;
	background: var(--line);
	margin: 0 4px;
	align-self: center;
	opacity: 0.7;
}
.navbar .nav-link {
	color: var(--ink-soft);
	font-weight: 500;
	font-size: 13.5px;
	line-height: 1;
	padding: 9px 14px !important;
	border-radius: 6px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: background 0.12s ease, color 0.12s ease;
}
.navbar .nav-link:hover {
	background: var(--line-soft);
	color: var(--accent-dark);
}
.navbar .nav-link.dropdown-toggle.show,
.navbar .nav-link.dropdown-toggle[aria-expanded="true"] {
	background: var(--accent-soft);
	color: var(--accent-dark);
}
.navbar .nav-link.dropdown-toggle.show .fa-regular,
.navbar .nav-link.dropdown-toggle.show .fa-solid,
.navbar .nav-link.dropdown-toggle[aria-expanded="true"] .fa-regular,
.navbar .nav-link.dropdown-toggle[aria-expanded="true"] .fa-solid {
	color: var(--accent);
}
.navbar .nav-link .fa-regular,
.navbar .nav-link .fa-solid {
	color: var(--muted);
	font-size: 14px;
	width: 18px;
	text-align: center;
	flex-shrink: 0;
}
.navbar .nav-link:hover .fa-regular,
.navbar .nav-link:hover .fa-solid { color: var(--accent); }
.navbar .nav-link.dropdown-toggle::after {
	margin-left: 4px;
	vertical-align: middle;
	opacity: 0.55;
}

.dropdown-menu {
	border: 1px solid var(--line);
	border-radius: var(--radius-sm);
	box-shadow: var(--shadow-md);
	padding: 6px;
	min-width: 220px;
	z-index: 1045;
}
.dropdown-item {
	padding: 7px 12px;
	border-radius: 6px;
	font-size: 13.5px;
	color: var(--ink-soft);
}
.dropdown-item:hover, .dropdown-item:focus {
	background: var(--accent-soft);
	color: var(--accent-dark);
}
.dropdown-divider {
	margin: 4px 6px;
	border-top: 1px solid var(--line-soft);
}

/* Zone utilisateur */
#user {
	font-size: 13px;
	color: var(--ink);
	display: inline-flex;
	align-items: center;
	gap: 5px;
}
#user strong { font-weight: 600; }
#user .fa-regular { color: var(--muted); font-size: 12px; }
#app_date {
	font-size: 11px;
	color: var(--muted);
	text-transform: capitalize;
}

/* ─── Buttons ────────────────────────────────────────────── */
.btn { border-radius: 8px; font-weight: 500; transition: all 0.15s ease; }
.btn-sm { font-size: 12.5px; padding: 5px 12px; }

.btn-primary {
	--bs-btn-bg:                    var(--brand-cyan);
	--bs-btn-border-color:          var(--brand-cyan);
	--bs-btn-hover-bg:              var(--brand-cyan-dark);
	--bs-btn-hover-border-color:    var(--brand-cyan-dark);
	--bs-btn-active-bg:             var(--brand-cyan-darker);
	--bs-btn-active-border-color:   var(--brand-cyan-darker);
	--bs-btn-disabled-bg:           var(--brand-cyan);
	--bs-btn-disabled-border-color: var(--brand-cyan);
	box-shadow: 0 1px 2px rgba(0, 154, 222, 0.18);
}
.btn-primary:hover, .btn-primary:active {
	box-shadow: 0 4px 10px rgba(0, 125, 182, 0.28);
}

.btn-outline-primary {
	--bs-btn-color:              var(--brand-cyan-dark);
	--bs-btn-border-color:       var(--line);
	--bs-btn-bg:                 var(--paper);
	--bs-btn-hover-bg:           var(--brand-cyan);
	--bs-btn-hover-border-color: var(--brand-cyan);
	--bs-btn-hover-color:        #fff;
	--bs-btn-active-bg:          var(--brand-cyan-dark);
}

.btn-accent {
	--bs-btn-color:                 #fff;
	--bs-btn-bg:                    var(--brand-green);
	--bs-btn-border-color:          var(--brand-green);
	--bs-btn-hover-bg:              var(--brand-green-dark);
	--bs-btn-hover-border-color:    var(--brand-green-dark);
	--bs-btn-active-bg:             var(--brand-green-dark);
}

.btn-outline-danger {
	--bs-btn-color:              #DC2626;
	--bs-btn-border-color:       var(--line);
	--bs-btn-bg:                 var(--paper);
	--bs-btn-hover-bg:           #DC2626;
	--bs-btn-hover-border-color: #DC2626;
	--bs-btn-hover-color:        #fff;
}

.btn-light {
	background: var(--paper);
	border-color: var(--line);
	color: var(--ink-soft);
}
.btn-light:hover { background: var(--line-soft); border-color: var(--line); color: var(--ink); }

/* ─── Cards ──────────────────────────────────────────────── */
.card {
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow-sm);
	background: var(--paper);
	transition: box-shadow 0.18s ease, transform 0.18s ease, border-color 0.18s ease;
}
.card:hover { box-shadow: var(--shadow-md); }

a.card { color: inherit; }
a.card:hover {
	border-color: var(--accent-light);
	transform: translateY(-1px);
}
a.card:hover h3 { color: var(--accent-dark); }

.card-body { padding: 16px; }
.card-header {
	background: var(--paper);
	border-bottom: 1px solid var(--line);
	border-top-left-radius: var(--radius);
	border-top-right-radius: var(--radius);
	padding: 12px 16px;
	font-size: 13.5px;
	font-weight: 500;
	color: var(--ink);
}
.card-header.bg-warning,
.card-header.bg-info { background: var(--paper) !important; }
.card.border-warning { border-color: var(--line) !important; }
.card.border-info    { border-color: var(--line) !important; }

.list-group-item {
	border-color: var(--line-soft);
	padding: 12px 16px;
	font-size: 13.5px;
}
.list-group-item:first-child { border-top: none; }
.list-group-item:last-child  { border-bottom: none; }

/* ─── Page title (content title) — plat, sans carte ────────── */
.content-title {
	color: var(--ink);
	font-weight: 600;
	font-size: 18px;
	letter-spacing: -0.01em;
	padding: 0;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	margin: 0 0 14px;
	display: flex;
	align-items: center;
	gap: 8px;
}
/* Pas d'icône à gauche du titre (style plat iManage) */
.content-title > .fa-solid:first-child,
.content-title > .fa-regular:first-child,
.content-title > .fa-brands:first-child {
	display: none;
}

/* Espacement régulier entre les boutons d'action du titre */
.content-title-actions {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}


/* ─── Rayon uniforme 5 px sur les contrôles d'interface ─── */
.btn,
.form-control,
.form-select,
.input-group-text,
.dropdown-menu,
.modal-content,
.card,
.alert,
.badge,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="number"],
input[type="date"],
textarea,
select {
	border-radius: 5px;
}

/* Tuiles (cards cliquables) */
a.card .card-body { padding: 18px 12px; }
a.card .fa-2x { font-size: 1.6em; opacity: 0.9; }
a.card h3 {
	font-size: 22px;
	font-weight: 700;
	color: var(--ink);
	margin: 8px 0 2px;
	letter-spacing: -0.02em;
}
a.card small {
	font-size: 11.5px;
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 500;
}

.text-primary { color: var(--accent-dark) !important; }
.text-accent  { color: var(--secondary-dark) !important; }
.text-info    { color: var(--accent-light) !important; }
.text-success { color: var(--secondary-dark) !important; }
.text-muted   { color: var(--muted) !important; }

/* ─── Badges (subtils) ───────────────────────────────────── */
.badge { padding: 4px 8px; border-radius: 6px; font-size: 11.5px; letter-spacing: 0.02em; font-weight: 500; }
.badge.bg-primary  { background: var(--brand-cyan) !important; color: #fff; }
.badge.bg-accent   { background: var(--brand-green) !important; color: #fff; }
.badge.bg-light    { background: var(--line-soft) !important; color: var(--ink-soft) !important; }
.badge.bg-warning  { background: rgba(245, 158, 11, 0.15) !important; color: #B45309 !important; }
.badge.bg-info     { background: var(--accent-soft) !important; color: var(--accent-dark) !important; }
.badge.bg-success  { background: var(--secondary-soft) !important; color: var(--secondary-dark) !important; }
.badge.bg-danger   { background: rgba(220, 38, 38, 0.12) !important; color: #B91C1C !important; }
.badge.bg-secondary{ background: var(--line-soft) !important; color: var(--muted) !important; }

/* ─── Form controls ──────────────────────────────────────── */
.form-control, .form-select {
	border: 1px solid var(--line);
	border-radius: 8px;
	padding: 8px 12px;
	font-size: 13.5px;
	color: var(--ink);
	background: var(--paper);
	transition: border-color 0.12s ease, box-shadow 0.12s ease;
}
.form-control:focus, .form-select:focus {
	border-color: var(--accent);
	box-shadow: 0 0 0 3px rgba(0, 154, 222, 0.15);
	outline: none;
}
.form-control-sm, .form-select-sm { font-size: 12.5px; padding: 6px 10px; }

.form-label {
	font-size: 12px;
	font-weight: 500;
	color: var(--ink-soft);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 4px;
}
.input-group-text {
	background: var(--line-soft);
	border-color: var(--line);
	color: var(--muted);
	font-size: 13px;
}

/* ─── Tabs ───────────────────────────────────────────────── */
.nav-tabs { border-bottom: 1px solid var(--line); }
.nav-tabs .nav-link {
	color: var(--muted);
	border: none;
	border-bottom: 2px solid transparent;
	padding: 9px 14px;
	font-size: 13px;
	font-weight: 500;
	background: transparent;
}
.nav-tabs .nav-link:hover { color: var(--ink); border-color: transparent; }
.nav-tabs .nav-link.active {
	color: var(--accent-dark);
	border-bottom-color: var(--accent);
	background: transparent;
}
.nav-pills .nav-link {
	color: var(--muted);
	background: var(--line-soft);
	font-size: 13px;
	padding: 7px 14px;
	border-radius: 8px;
}
.nav-pills .nav-link.active { background: var(--accent); color: #fff; }

/* List_view : styles propres au composant iManage (voir list-view.css) — pas de surcharge ici */

code {
	background: var(--line-soft);
	padding: 1px 5px;
	border-radius: 4px;
	font-size: 0.85em;
	color: var(--ink-soft);
}

/* ─── Modals ─────────────────────────────────────────────── */
.modal-content {
	border: none;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
}
.modal-header {
	border-bottom: 1px solid var(--line);
	padding: 16px 20px;
}
.modal-body { padding: 20px; }
.modal-footer { border-top: 1px solid var(--line); padding: 14px 20px; }

/* Note : le styling du #login_box (dialog, content, layout) vient du
   composant partagé iManage/css/login_box.css. */

/* ─── Detail (dl) ────────────────────────────────────────── */
dl.row dt {
	font-size: 12px;
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-weight: 500;
	padding: 6px 12px 6px 0;
}
dl.row dd { padding: 6px 0; font-size: 13.5px; color: var(--ink); }
.table-sm th, .table-sm td { padding: 6px 8px; font-size: 13px; }
.table-sm th { color: var(--muted); font-weight: 500; }

/* ─── Alerts ─────────────────────────────────────────────── */
.alert {
	border: 1px solid transparent;
	border-radius: var(--radius);
	padding: 12px 16px;
	font-size: 13.5px;
}
.alert-warning { background: rgba(245, 158, 11, 0.08); border-color: rgba(245, 158, 11, 0.25); color: #B45309; }
.alert-info    { background: var(--accent-soft); border-color: rgba(0, 180, 216, 0.25); color: var(--accent-dark); }
.alert-success { background: var(--secondary-soft); border-color: rgba(16, 185, 129, 0.25); color: var(--secondary-dark); }
.alert-danger  { background: rgba(220, 38, 38, 0.08); border-color: rgba(220, 38, 38, 0.2); color: #991B1B; }

/* ─── Pagination ────────────────────────────────────────── */
.page-item.active .page-link {
	background-color: var(--brand-cyan);
	border-color: var(--brand-cyan);
}

/* ─── Welcome / empty pane ──────────────────────────────── */
.welcome-pane {
	max-width: 520px;
	margin: 64px auto 0;
	padding: 48px 32px;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
}
.welcome-icon {
	width: 64px;
	height: 64px;
	margin: 0 auto;
	border-radius: 50%;
	background: var(--accent-soft);
	color: var(--accent);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
}
.welcome-title {
	font-size: 22px;
	font-weight: 600;
	letter-spacing: 0.06em;
	color: var(--ink);
}
.welcome-sub { font-size: 14px; line-height: 1.55; }

/* ════════════════════════════════════════════════
   Utilitaires MyQMa
   ════════════════════════════════════════════════ */
.brand-gradient { background: linear-gradient(135deg, var(--brand-cyan), var(--brand-green)); color: #fff; }

/* Catégories */
.cat-badge      { text-transform: capitalize; font-weight: 500; }
.cat-leadership { background: var(--brand-cyan);  color: #fff; }
.cat-core       { background: #00205C; color: #fff; }
.cat-support    { background: #64748b; color: #fff; }

/* KVP priorities */
.prio-low      { background: #6c757d; color: #fff; }
.prio-medium   { background: #0dcaf0; color: #000; }
.prio-high     { background: #ffc107; color: #000; }
.prio-critical { background: #dc3545; color: #fff; }

/* KPI status */
.status-on_track  { background: #10B981; color: #fff; }
.status-off_track { background: #dc3545; color: #fff; }
.status-no_data   { background: #e9ecef; color: #6c757d; }

/* ════════════════════════════════════════════════
   Dashboard v3 — Visual, modern, inspired by best-in-class
   ════════════════════════════════════════════════ */
.dashboard-v3 {
    --ink:     #0f172a;
    --mute:    #64748b;
    --line:    #e2e8f0;
    --surf:    #ffffff;
    --soft:    #f8fafc;
    --softer:  #f1f5f9;
    --ok:      #059669;
    --warn:    #d97706;
    --bad:     #dc2626;
    --cyan:    #009ADE;
    --green:   #80BC00;
    color: var(--ink);
    font-feature-settings: "tnum" 1, "ss01" 1;
    padding-bottom: 32px;
}
.dashboard-v3 h4 { font-size: 15px; font-weight: 600; margin: 0; letter-spacing: -0.01em; }

/* ───── Hero ────────────────────────────────────────────── */
.dashboard-v3 .g-hero {
    display: grid;
    grid-template-columns: 190px 1fr;
    gap: 28px;
    align-items: center;
    padding: 28px 32px;
    background:
        radial-gradient(circle at 15% 30%, rgba(0, 180, 216, 0.10), transparent 50%),
        radial-gradient(circle at 85% 70%, rgba(16, 185, 129, 0.08), transparent 50%),
        linear-gradient(135deg, #ffffff, #f8fafc);
    border: 1px solid var(--line);
    border-radius: 16px;
    margin-bottom: 20px;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}
.dashboard-v3 .g-hero-gauge { position: relative; width: 170px; height: 170px; text-align: center; }
.dashboard-v3 .g-hero-gauge-label {
    font-size: 12px; color: var(--mute); margin-top: 4px;
    text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500;
}
.dashboard-v3 .g-gauge { width: 140px; height: 140px; transform: rotate(-90deg); }
.dashboard-v3 .g-gauge-track {
    fill: none; stroke: var(--softer); stroke-width: 8;
}
.dashboard-v3 .g-gauge-fill {
    fill: none; stroke-width: 8; stroke-linecap: round;
    transition: stroke-dashoffset 900ms cubic-bezier(.2,.8,.2,1);
}
.dashboard-v3 .g-gauge-value {
    fill: var(--ink); font-size: 22px; font-weight: 600;
    transform: rotate(90deg); transform-origin: center;
    letter-spacing: -0.02em;
}

.dashboard-v3 .g-hero-body { min-width: 0; }
.dashboard-v3 .g-hero-greeting {
    font-size: 26px; font-weight: 600; letter-spacing: -0.02em;
    line-height: 1.15; color: var(--ink); margin-bottom: 4px;
}
.dashboard-v3 .g-hero-subtitle {
    font-size: 14px; color: var(--mute); margin-bottom: 14px;
}
.dashboard-v3 .g-hero-roles {
    display: flex; flex-wrap: wrap; gap: 6px;
}

/* Pills */
.dashboard-v3 .g-pill {
    display: inline-block; padding: 4px 12px; border-radius: 999px;
    background: rgba(0, 154, 222, 0.08); color: #007DB6;
    border: 1px solid rgba(0, 154, 222, 0.25);
    font-size: 12.5px; font-weight: 500;
}
.dashboard-v3 .g-pill-sm {
    padding: 1px 8px; font-size: 11.5px;
    background: var(--softer); color: var(--mute); border: 1px solid var(--line);
}
.dashboard-v3 .g-pill-empty {
    background: var(--softer); color: var(--mute); border-color: var(--line);
}

/* ───── KPI strip ──────────────────────────────────────── */
.dashboard-v3 .g-kpis {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
    margin-bottom: 22px;
}
.dashboard-v3 .g-kpi-card {
    background: var(--surf);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 16px 18px;
    /* Override iManage.css qui définit display:flex pour un layout icon+body :
       le template rprt_dashboard.php utilise plutôt head/value/viz/hint en stack vertical. */
    display: block;
    transition: box-shadow .2s, transform .2s;
}
.dashboard-v3 .g-kpi-card:hover {
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
    transform: translateY(-1px);
}
.dashboard-v3 .g-kpi-head {
    display: flex; align-items: center; gap: 8px;
    margin-bottom: 8px;
}
.dashboard-v3 .g-kpi-icon {
    width: 28px; height: 28px; border-radius: 7px;
    background: rgba(0, 154, 222, 0.10); color: #007DB6;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 13px;
}
.dashboard-v3 .g-kpi-label {
    font-size: 12px; color: var(--mute);
    text-transform: uppercase; letter-spacing: 0.05em; font-weight: 500;
}
.dashboard-v3 .g-kpi-value {
    font-size: 32px; font-weight: 600; letter-spacing: -0.02em;
    line-height: 1; color: var(--ink); margin-bottom: 10px;
}
.dashboard-v3 .g-kpi-viz { margin-bottom: 6px; }
.dashboard-v3 .g-kpi-hint { font-size: 12px; color: var(--mute); }

/* Progress bars */
.dashboard-v3 .g-bar {
    width: 100%; height: 6px; background: var(--softer); border-radius: 4px; overflow: hidden;
}
.dashboard-v3 .g-bar-fill {
    height: 100%; border-radius: 4px;
    transition: width 600ms cubic-bezier(.2,.8,.2,1);
}
.dashboard-v3 .g-bar-ok   .g-bar-fill { background: var(--ok); }
.dashboard-v3 .g-bar-warn .g-bar-fill { background: var(--warn); }
.dashboard-v3 .g-bar-bad  .g-bar-fill { background: var(--bad); }
.dashboard-v3 .g-bar-empty { background: var(--softer); }

/* Dots */
.dashboard-v3 .g-dot {
    display: inline-block; width: 8px; height: 8px; border-radius: 50%;
    vertical-align: middle;
}
.dashboard-v3 .g-dots { display: flex; align-items: center; gap: 6px; }

/* ───── Cards (generic) ────────────────────────────────── */
.dashboard-v3 .g-card {
    background: var(--surf);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 22px 24px;
    margin-bottom: 20px;
}
.dashboard-v3 .g-card-head {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 14px;
}
.dashboard-v3 .g-card-empty {
    display: flex; align-items: center; gap: 14px;
    color: var(--mute); font-size: 14px;
}
.dashboard-v3 .g-empty-ico {
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(16, 185, 129, 0.12); color: var(--green);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 16px;
}

/* List rows */
.dashboard-v3 .g-list { list-style: none; padding: 0; margin: 0; }
.dashboard-v3 .g-row {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--line);
}
.dashboard-v3 .g-row:last-child { border-bottom: 0; padding-bottom: 0; }
.dashboard-v3 .g-row:first-child { padding-top: 0; }
.dashboard-v3 .g-row-icon {
    width: 36px; height: 36px; border-radius: 9px;
    background: var(--softer); color: var(--mute);
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0; font-size: 14px;
}
.dashboard-v3 .g-row-main { flex: 1; min-width: 0; }
.dashboard-v3 .g-row-title {
    font-size: 14.5px; font-weight: 500; color: var(--ink); margin-bottom: 3px;
}
.dashboard-v3 .g-row-meta {
    font-size: 12.5px; color: var(--mute);
    display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.dashboard-v3 .g-row-actions { display: flex; gap: 6px; flex-shrink: 0; }

.dashboard-v3 .g-meta-tag {
    padding: 1px 8px; border-radius: 4px;
    background: rgba(0, 154, 222, 0.08); color: #007DB6;
    font-size: 11px; font-weight: 500;
}
.dashboard-v3 .g-meta-code {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 12px; color: var(--mute);
}

/* Buttons */
.dashboard-v3 .g-btn-primary {
    background: var(--ink); color: white; border: 0;
    padding: 6px 14px; border-radius: 7px; font-size: 13px; font-weight: 500;
    cursor: pointer; transition: background .15s;
}
.dashboard-v3 .g-btn-primary:hover { background: #1e293b; }
.dashboard-v3 .g-btn-ghost {
    background: transparent; color: var(--mute); border: 1px solid var(--line);
    padding: 6px 10px; border-radius: 7px; font-size: 13px;
    text-decoration: none; display: inline-flex; align-items: center;
    transition: background .15s, color .15s;
}
.dashboard-v3 .g-btn-ghost:hover { background: var(--softer); color: var(--ink); }

/* Tags */
.dashboard-v3 .g-tag {
    display: inline-block; padding: 2px 9px; border-radius: 999px;
    font-size: 11.5px; font-weight: 500; line-height: 1.5;
    background: var(--softer); color: var(--mute); border: 1px solid var(--line);
}
.dashboard-v3 .g-tag-ok      { background: rgba(16, 185, 129, 0.10); color: var(--ok); border-color: rgba(16, 185, 129, 0.25); }
.dashboard-v3 .g-tag-warn    { background: rgba(217, 119, 6, 0.10); color: var(--warn); border-color: rgba(217, 119, 6, 0.25); }
.dashboard-v3 .g-tag-bad     { background: rgba(220, 38, 38, 0.10); color: var(--bad); border-color: rgba(220, 38, 38, 0.25); }
.dashboard-v3 .g-tag-neutral { background: var(--softer); color: var(--mute); border-color: var(--line); }

/* Tables */
.dashboard-v3 .g-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.dashboard-v3 .g-table tbody td {
    padding: 12px 10px;
    border-bottom: 1px solid var(--line);
    vertical-align: middle;
}
.dashboard-v3 .g-table tbody tr:last-child td { border-bottom: 0; }
.dashboard-v3 .g-table tbody tr:hover { background: var(--soft); }
.dashboard-v3 .g-code {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 11.5px; color: var(--mute);
}
.dashboard-v3 .g-prio-cell { display: flex; align-items: center; gap: 8px; white-space: nowrap; }
.dashboard-v3 .g-prio-label { font-size: 12px; color: var(--mute); }
.dashboard-v3 .g-kvp-title { font-weight: 500; }
.dashboard-v3 .g-empty-text { color: var(--mute); padding: 16px 4px; margin: 0; }

/* Tabs (custom) */
.dashboard-v3 .g-tabs {
    display: flex; gap: 2px;
    border-bottom: 1px solid var(--line);
    margin-bottom: 10px;
}
.dashboard-v3 .g-tab {
    background: transparent; border: 0; border-bottom: 2px solid transparent;
    padding: 9px 14px; font-size: 13.5px; font-weight: 500; color: var(--mute);
    cursor: pointer; border-radius: 0;
    transition: color .15s, border-color .15s;
}
.dashboard-v3 .g-tab:hover { color: var(--ink); }
.dashboard-v3 .g-tab.active {
    color: var(--ink); border-bottom-color: var(--cyan);
}
.dashboard-v3 .g-tab-count {
    display: inline-block; padding: 1px 7px; border-radius: 999px;
    background: var(--softer); color: var(--mute);
    font-size: 11px; margin-left: 4px;
}
.dashboard-v3 .g-tab-pane { display: none; }
.dashboard-v3 .g-tab-pane.active { display: block; }

/* ───── KPI grid (cockpit) ──────────────────────────── */
.dashboard-v3 .g-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
}
.dashboard-v3 .g-kpi-box {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 16px;
    padding-bottom: 40px;
    background: var(--surf);
    position: relative;
}
.dashboard-v3 .g-kpi-box-ok   { background: rgba(16, 185, 129, 0.06);  border-color: rgba(16, 185, 129, 0.25); }
.dashboard-v3 .g-kpi-box-bad  { background: rgba(220, 38, 38, 0.06);   border-color: rgba(220, 38, 38, 0.25); }
.dashboard-v3 .g-kpi-box-mute { background: var(--soft);               border-color: var(--line); }
.dashboard-v3 .g-kpi-box-mission {
    font-size: 11px; color: var(--mute); text-transform: uppercase;
    letter-spacing: 0.06em; font-weight: 500; margin-bottom: 4px;
}
.dashboard-v3 .g-kpi-box-name {
    font-size: 14px; font-weight: 500; color: var(--ink); margin-bottom: 10px;
    line-height: 1.3;
}
.dashboard-v3 .g-kpi-box-value {
    font-size: 20px; font-weight: 600; letter-spacing: -0.015em;
    color: var(--ink); line-height: 1.1;
}
.dashboard-v3 .g-kpi-box-ok  .g-kpi-box-value { color: var(--ok); }
.dashboard-v3 .g-kpi-box-bad .g-kpi-box-value { color: var(--bad); }
.dashboard-v3 .g-kpi-box-unit {
    font-size: 13px; font-weight: 500; color: inherit; opacity: .7; margin-left: 2px;
}
.dashboard-v3 .g-kpi-box-target-line {
    font-size: 12px; color: var(--mute); margin-top: 6px;
}
.dashboard-v3 .g-kpi-box-target-line strong {
    color: var(--ink); font-weight: 600;
}
.dashboard-v3 .g-kpi-box-direction { font-size: 11px; color: var(--mute); }
.dashboard-v3 .g-kpi-box-period {
    position: absolute; top: 10px; right: 12px;
    font-size: 11px; color: var(--mute);
    font-variant-numeric: tabular-nums;
}
.dashboard-v3 .g-kpi-box-status {
    position: absolute; bottom: 10px; right: 10px;
}


/* ════════════════════════════════════════════════
   Dashboard v2 (kept for fallback, no longer used)
   ════════════════════════════════════════════════ */
.dashboard-v2 {
    --dash-ink:    #1f2937;
    --dash-mute:   #6b7280;
    --dash-line:   #e5e7eb;
    --dash-surf:   #ffffff;
    --dash-soft:   #f9fafb;
    --dash-ok:     #059669;
    --dash-warn:   #d97706;
    --dash-bad:    #dc2626;
    color: var(--dash-ink);
    font-feature-settings: "tnum" 1;
}

/* Stat strip */
.dashboard-v2 .dash-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}
.dashboard-v2 .dash-stat {
    background: var(--dash-surf);
    border: 1px solid var(--dash-line);
    border-radius: 10px;
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.dashboard-v2 .dash-stat-value {
    font-size: 34px;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.1;
    color: var(--dash-ink);
}
.dashboard-v2 .dash-stat-ok   .dash-stat-value { color: var(--dash-ok); }
.dashboard-v2 .dash-stat-warn .dash-stat-value { color: var(--dash-warn); }
.dashboard-v2 .dash-stat-bad  .dash-stat-value { color: var(--dash-bad); }
.dashboard-v2 .dash-stat-mute .dash-stat-value { color: var(--dash-mute); }
.dashboard-v2 .dash-stat-label {
    font-size: 13px;
    color: var(--dash-mute);
    font-weight: 500;
}
.dashboard-v2 .dash-stat-hint {
    font-size: 12px;
    color: var(--dash-mute);
    margin-top: 2px;
}

/* Active roles line */
.dashboard-v2 .dash-roles-line {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 20px;
    padding: 0 4px;
}
.dashboard-v2 .dash-roles-label {
    font-size: 12px;
    color: var(--dash-mute);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-right: 4px;
}
.dashboard-v2 .dash-pill {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 999px;
    background: var(--dash-soft);
    border: 1px solid var(--dash-line);
    font-size: 12.5px;
    color: var(--dash-ink);
}

/* Cards */
.dashboard-v2 .dash-card {
    background: var(--dash-surf);
    border: 1px solid var(--dash-line);
    border-radius: 12px;
    padding: 20px 22px;
    margin-bottom: 20px;
}
.dashboard-v2 .dash-card-empty {
    text-align: center;
    color: var(--dash-mute);
}
.dashboard-v2 .dash-card-head {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 14px;
}
.dashboard-v2 .dash-card-head h6 {
    margin: 0;
    font-size: 15px;
    font-weight: 600;
    color: var(--dash-ink);
    letter-spacing: -0.005em;
}
.dashboard-v2 .dash-count {
    font-size: 12px;
    font-weight: 500;
    padding: 1px 8px;
    background: var(--dash-soft);
    border: 1px solid var(--dash-line);
    border-radius: 999px;
    color: var(--dash-mute);
}
.dashboard-v2 .dash-count-inline {
    font-size: 11px;
    padding: 0 6px;
    border-radius: 999px;
    background: var(--dash-soft);
    color: var(--dash-mute);
    margin-left: 4px;
}

/* To-do list */
.dashboard-v2 .dash-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.dashboard-v2 .dash-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 0;
    border-bottom: 1px solid var(--dash-line);
}
.dashboard-v2 .dash-row:last-child { border-bottom: 0; }
.dashboard-v2 .dash-row-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: var(--dash-soft);
    color: var(--dash-mute);
    flex-shrink: 0;
}
.dashboard-v2 .dash-row-main { flex: 1; min-width: 0; }
.dashboard-v2 .dash-row-title {
    font-size: 14.5px;
    font-weight: 500;
    color: var(--dash-ink);
    margin-bottom: 2px;
}
.dashboard-v2 .dash-row-sub {
    font-size: 12.5px;
    color: var(--dash-mute);
}
.dashboard-v2 .dash-row-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

/* Tags */
.dashboard-v2 .dash-tag {
    display: inline-block;
    padding: 2px 9px;
    border-radius: 999px;
    font-size: 11.5px;
    font-weight: 500;
    background: var(--dash-soft);
    border: 1px solid var(--dash-line);
    color: var(--dash-mute);
    line-height: 1.4;
}
.dashboard-v2 .dash-tag-ok      { background: #ecfdf5; border-color: #a7f3d0; color: var(--dash-ok); }
.dashboard-v2 .dash-tag-warn    { background: #fffbeb; border-color: #fde68a; color: var(--dash-warn); }
.dashboard-v2 .dash-tag-bad,
.dashboard-v2 .dash-tag-danger  { background: #fef2f2; border-color: #fecaca; color: var(--dash-bad); }
.dashboard-v2 .dash-tag-info    { background: #eff6ff; border-color: #bfdbfe; color: #2563eb; }
.dashboard-v2 .dash-tag-mute    { background: var(--dash-soft); border-color: var(--dash-line); color: var(--dash-mute); }

/* Tables (compact, no stripes) */
.dashboard-v2 .dash-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13.5px;
}
.dashboard-v2 .dash-table thead th {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--dash-mute);
    font-weight: 500;
    padding: 8px 10px;
    border-bottom: 1px solid var(--dash-line);
    text-align: left;
}
.dashboard-v2 .dash-table tbody td {
    padding: 10px;
    border-bottom: 1px solid var(--dash-line);
    vertical-align: middle;
}
.dashboard-v2 .dash-table tbody tr:last-child td { border-bottom: 0; }
.dashboard-v2 .dash-kpi-name { font-weight: 500; }
.dashboard-v2 .dash-kpi-sub  { font-size: 12px; color: var(--dash-mute); margin-top: 1px; }
.dashboard-v2 .dash-kpi-value {
    font-variant-numeric: tabular-nums;
    font-weight: 500;
}
.dashboard-v2 .dash-empty {
    color: var(--dash-mute);
    font-size: 13.5px;
    padding: 16px 4px;
    margin: 0;
}

/* Tabs within cards */
.dashboard-v2 .dash-tabs {
    border-bottom: 1px solid var(--dash-line);
    gap: 4px;
    margin-bottom: 8px;
}
.dashboard-v2 .dash-tabs .nav-link {
    color: var(--dash-mute);
    background: transparent;
    border: 0;
    border-bottom: 2px solid transparent;
    padding: 8px 12px;
    font-size: 13.5px;
    font-weight: 500;
    border-radius: 0;
}
.dashboard-v2 .dash-tabs .nav-link.active {
    color: var(--dash-ink);
    background: transparent;
    border-bottom-color: var(--brand-cyan); /* WHO Blue */
}

/* Translations tab — grouped accordion */
.ts-group { border: 1px solid #e2e8f0; border-radius: 8px; margin-bottom: 10px; background: #fff; }
.ts-group[open] { box-shadow: 0 1px 2px rgba(15,23,42,.03); }
.ts-group-head {
    list-style: none; cursor: pointer; padding: 10px 14px;
    font-size: 13.5px; display: flex; align-items: center; gap: 8px;
    background: #f8fafc; border-radius: 8px 8px 0 0;
    border-bottom: 1px solid transparent;
    user-select: none;
}
.ts-group[open] > .ts-group-head { border-bottom-color: #e2e8f0; }
.ts-group-head::-webkit-details-marker { display: none; }
.ts-group-icon { font-size: 10px; transition: transform .2s; color: #64748b; }
.ts-group[open] > .ts-group-head .ts-group-icon { transform: rotate(90deg); }
.ts-group-count {
    margin-left: auto; font-size: 11.5px; font-weight: 500;
    padding: 1px 8px; background: #f1f5f9; color: #64748b; border-radius: 999px;
    border: 1px solid #e2e8f0;
}
.ts-table { margin: 0; border: 0; }
.ts-table thead th {
    font-size: 11px; text-transform: uppercase; letter-spacing: .05em;
    color: #64748b; font-weight: 500; background: #fff;
    border-bottom: 1px solid #e2e8f0;
}
.ts-key-cell code {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 12px; color: #0f172a;
}

/* Snapshot pastille (dashboard) */
.g-updated-at {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 11.5px; color: #64748b; font-weight: 500;
    padding: 2px 10px; border-radius: 999px;
    background: #f1f5f9; border: 1px solid #e2e8f0;
    margin-left: 10px; vertical-align: middle;
}
.g-updated-at .fa-clock { font-size: 10px; }

/* ─── Expansion accordéon page Rôles ──────────────────────────── */
.role-exp-stats {
    display: flex;
    gap: 24px;
    padding: 4px 0 14px;
    border-bottom: 1px dashed var(--line);
    margin-bottom: 14px;
}
.role-exp-stat { display: flex; align-items: baseline; gap: 6px; }
.role-exp-stat-num {
    font-size: 18px;
    font-weight: 700;
    color: var(--accent-dark, #007DB6);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}
.role-exp-stat-lbl {
    font-size: 11px;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.role-exp-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    margin-bottom: 10px;
}
.role-exp-missions {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.role-exp-mission {
    background: var(--paper, #ffffff);
    border: 1px solid var(--line);
    border-radius: 5px;
    padding: 10px 14px;
}
.role-exp-mission-head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}
.role-exp-mission-count {
    margin-left: 8px;
    font-size: 11px;
    color: var(--muted);
    font-weight: 500;
    white-space: nowrap;
}
.role-exp-mand { font-size: 12px; }
.role-exp-mand .fa-circle-exclamation { color: #b91c1c; }
.role-exp-mand--opt { opacity: 0.5; }
.role-exp-mission-name { font-size: 13.5px; color: var(--ink); }
.role-exp-mission-code {
    margin-left: auto;
    font-size: 11px;
    padding: 1px 6px;
    background: var(--line-soft, #f1f5f9);
    color: var(--muted);
    border-radius: 4px;
}

.role-exp-procs {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.role-exp-proc {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12.5px;
    color: var(--ink);
    padding: 4px 0;
}
.role-exp-proc-name { flex: 1; }
.role-exp-proc-code {
    font-size: 11px;
    color: var(--muted);
    background: transparent;
}
.role-exp-no-procs,
.role-exp-empty {
    margin: 0;
    color: var(--muted);
    font-size: 12.5px;
    font-style: italic;
}

/* Catégories de processus — pastilles colorées ISO 9001 */
.role-exp-proc .cat-badge {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 2px 7px;
    border-radius: 5px;
    color: #fff;
    line-height: 1.4;
    flex-shrink: 0;
}
..role-exp-proc .cat-leadership { background: var(--brand-cyan,  #009ADE); }
.role-exp-proc .cat-core       { background: var(--who-navy,    #00205C); }
.role-exp-proc .cat-support    { background: #94a3b8; }

/* ════════════════════════════════════════════════
   Mobile — Bottom Navigation Bar
   ════════════════════════════════════════════════ */
#mobile-bottom-nav {
    display: none; /* caché sur desktop */
}

@media (max-width: 640px) {

    /* ─── Bottom nav ─────────────────────────────────────── */
    #mobile-bottom-nav {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        z-index: 1050;
        background: var(--paper);
        border-top: 1px solid var(--line);
        /* safe-area pour les encoches iPhone */
        padding: 4px 0 max(6px, env(safe-area-inset-bottom));
        box-shadow: 0 -2px 16px rgba(0,0,0,.08);
    }

    .mbn-item {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 3px;
        padding: 6px 4px;
        background: none;
        border: 0;
        cursor: pointer;
        color: var(--muted);
        transition: color .15s ease;
        min-width: 0;
        -webkit-tap-highlight-color: transparent;
        font-family: inherit;
    }
    .mbn-item:active { opacity: .7; }

    .mbn-icon { font-size: 19px; line-height: 1; }

    .mbn-label {
        font-size: 10px;
        font-weight: 500;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 64px;
        line-height: 1.2;
    }

    .mbn-item.mbn-active        { color: var(--accent); }
    .mbn-item.mbn-active .mbn-icon { transform: translateY(-1px); }

    /* ─── Body : padding sous le contenu ─────────────────── */
    body.has-bottom-nav {
        padding-bottom: calc(58px + max(0px, env(safe-area-inset-bottom)));
    }

    /* ─── Navbar hamburger — drawer slide depuis le bas ───── */
    .navbar .navbar-collapse.show,
    .navbar .navbar-collapse.collapsing {
        background: var(--paper);
        position: fixed;
        bottom: calc(58px + max(0px, env(safe-area-inset-bottom)));
        left: 0;
        right: 0;
        z-index: 1049;
        max-height: 70vh;
        overflow-y: auto;
        border-top: 1px solid var(--line);
        border-radius: 12px 12px 0 0;
        box-shadow: 0 -4px 20px rgba(0,0,0,.12);
        padding: 12px 0 8px;
    }
    /* Ferme le drawer quand on clique en dehors */
    .navbar .navbar-nav { padding: 0 8px; }
    .navbar .navbar-nav .nav-link { padding: 10px 14px; border-radius: 8px; }
    .navbar .navbar-nav .dropdown-menu { position: static !important; box-shadow: none; border: 0; background: var(--canvas); margin: 0 0 0 12px; padding: 4px 0; border-radius: 8px; }

    /* ─── Notification bar : plus compact ─────────────────── */
    #notification_main_bar .notification_main_content { padding: 0 10px; }
    #content_title { font-size: 11px; max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

    /* ─── Icônes de session — taille tactile ──────────────── */
    .session_controls.visible { width: 38px; height: 38px; line-height: 38px; }
}

/* ════════════════════════════════════════════════
   whocomafr — Dashboard styles
   ════════════════════════════════════════════════ */
:root {
    /* WHO Brand Guidance July 2025 — valeurs officielles */
    --who-blue:       #009ADE;   /* Pantone 2925C */
    --who-blue-dark:  #007DB6;
    --who-blue-light: #5AC8EC;
    --who-navy:       #00205C;   /* Pantone 281C */
    --who-accent:     #009ADE;
    --who-orange:     #F26829;   /* Pantone 165C */
    --who-yellow:     #F4A81D;   /* Pantone 130C */
    --who-green:      #80BC00;   /* Pantone 376C */
    --who-magenta:    #A6228C;   /* Pantone 248C */
    --who-purple:     #5B2C86;   /* Pantone 2597C */
    --who-red:        #EF3842;   /* Pantone 032C — urgences uniquement */
    --tone-ok:   #059669;
    --tone-warn: #F4A81D;
    --tone-bad:  #EF3842;
}

.dashboard-who {
    /* Pas de background ni de padding — le dashboard s'aligne sur le menu/container parent.
       L'espace vertical en bas est conservé pour ne pas coller au footer. */
    padding: 0 0 32px;
    background: transparent;
}

/* Header */
.dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    flex-wrap: wrap;
    gap: 12px;
}
.period-tabs {
    display: inline-flex;
    background: #fff;
    border-radius: 10px;
    padding: 4px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.period-tab {
    background: transparent;
    border: 0;
    padding: 8px 18px;
    border-radius: 7px;
    font-weight: 600;
    color: #64748B;
    cursor: pointer;
    transition: all 0.15s;
}
.period-tab:hover { color: var(--who-blue); }
.period-tab.is-active {
    background: var(--who-blue);
    color: #fff;
}

/* KPI Row */
.kpi-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 18px;
}
.kpi-card {
    background: #fff;
    border-radius: 12px;
    padding: 16px 18px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
    border: 1px solid #E2E8F0;
}
.kpi-label {
    font-size: 12px;
    color: #64748B;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 6px;
}
.kpi-value {
    font-size: 32px;
    font-weight: 700;
    color: var(--who-navy);
    line-height: 1.1;
}
.kpi-sub {
    font-size: 12px;
    color: #94A3B8;
    margin-top: 4px;
}
.kpi-progress .progress-bar-wrap {
    height: 8px;
    background: #E2E8F0;
    border-radius: 4px;
    overflow: hidden;
    margin-top: 8px;
}
.progress-bar-fill {
    height: 100%;
    transition: width 0.4s ease;
    background: var(--who-blue);
}
.progress-bar-fill.tone-ok { background: var(--tone-ok); }
.progress-bar-fill.tone-warn { background: var(--tone-warn); }
.progress-bar-fill.tone-bad { background: var(--tone-bad); }

.kpi-flags {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: 4px;
}
.flag-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 3px 8px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    background: #F1F5F9;
}
.flag-pill .fa-solid { font-size: 11px; }
.flag-emergency { color: #B91C1C; background: #FEF2F2; }
.flag-donor { color: #0E7490; background: #ECFEFF; }
.flag-rd { color: #6D28D9; background: #F5F3FF; }

/* Cards */
.dashboard-card {
    background: #fff;
    border-radius: 12px;
    padding: 18px 20px;
    margin-bottom: 18px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
    border: 1px solid #E2E8F0;
}
.dashboard-card h4 {
    margin: 0 0 14px;
    font-size: 15px;
    font-weight: 700;
    color: var(--who-navy);
    display: flex;
    align-items: center;
    gap: 8px;
}

.dashboard-grid-2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-bottom: 18px;
}
.dashboard-grid-2col > .dashboard-card { margin-bottom: 0; }

/* Targets table */
.targets-table-wrap { max-height: 480px; overflow-y: auto; }
.targets-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.targets-table th {
    text-align: left;
    padding: 8px 12px;
    font-weight: 600;
    color: #64748B;
    border-bottom: 2px solid #E2E8F0;
    position: sticky;
    top: 0;
    background: #fff;
}
.targets-table td {
    padding: 8px 12px;
    border-bottom: 1px solid #F1F5F9;
}
.targets-table tr:hover td { background: #F8FAFC; }
.bar-cell {
    width: 100px;
    height: 8px;
    background: #E2E8F0;
    border-radius: 4px;
    overflow: hidden;
}
.bar-fill { height: 100%; background: var(--who-blue); }
.bar-fill.tone-ok { background: var(--tone-ok); }
.bar-fill.tone-warn { background: var(--tone-warn); }
.bar-fill.tone-bad { background: var(--tone-bad); }
.tone-ok { color: var(--tone-ok); }
.tone-warn { color: var(--tone-warn); }
.tone-bad { color: var(--tone-bad); }

/* ─── Onglets du dashboard ─────────────────────────────────── */
.dashboard-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin: 16px 0 12px;
    border-bottom: 1px solid #E2E8F0;
    padding: 0 4px;
}
.dash-tab {
    appearance: none;
    background: transparent;
    border: 0;
    color: #64748B;
    padding: 10px 16px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.01em;
    cursor: pointer;
    border-radius: 8px 8px 0 0;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.dash-tab:hover { color: var(--brand-cyan-dark, #007DB6); background: rgba(0, 154, 222, 0.06); }
.dash-tab.is-active {
    color: var(--who-navy, #00205C);
    border-bottom-color: var(--brand-cyan, #009ADE);
    background: #fff;
}
.dash-tab .fa-solid { font-size: 13px; }
.dash-pane { display: none; }
.dash-pane.is-active { display: block; }
.dash-pane > .dashboard-card + .dashboard-card,
.dash-pane > .dashboard-grid-2col + .dashboard-card,
.dash-pane > .dashboard-card + .dashboard-grid-2col { margin-top: 16px; }
.dashboard-grid-2col--wide { grid-template-columns: 1.6fr 1fr; }

/* ─── Synthèse réseaux sociaux + voix du Directeur Régional ─── */
.social-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.social-tile {
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    padding: 12px;
    text-align: center;
    transition: transform 0.15s, box-shadow 0.15s;
}
.social-tile:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 32, 92, 0.08);
}
.social-tile-icon {
    font-size: 22px;
    color: var(--brand-cyan, #009ADE);
    margin-bottom: 6px;
    line-height: 1;
}
.social-tile-label {
    font-size: 11px;
    color: #64748B;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
    margin-bottom: 4px;
}
.social-tile-n {
    font-size: 22px;
    font-weight: 700;
    color: var(--who-navy, #00205C);
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
}
.social-tile-rd {
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px solid #F1F5F9;
    font-size: 12px;
    color: #475569;
    font-weight: 600;
}
.social-tile-rd small {
    color: #94A3B8;
    font-weight: 500;
    text-transform: uppercase;
    font-size: 9px;
    letter-spacing: 0.05em;
}
.rd-voice {
    background: #F8FAFC;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    padding: 12px 16px;
}
.rd-voice-row {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
}
.rd-voice-stat {
    font-size: 12px;
    color: #64748B;
}
.rd-voice-stat strong {
    color: var(--who-navy, #00205C);
    font-size: 18px;
    font-weight: 700;
    margin-right: 4px;
    font-variant-numeric: tabular-nums;
}

/* ─── Cluster tiles (vue en tuiles colorées) ────────────── */
.cluster-tiles {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
}
.cluster-tile {
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    padding: 12px 14px;
    transition: transform 0.15s, box-shadow 0.15s;
    cursor: default;
}
.cluster-tile:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 32, 92, 0.08);
}
.cluster-tile-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
}
.cluster-acro {
    font-weight: 700;
    font-size: 18px;
    color: var(--brand-cyan-dark, #007DB6);
    letter-spacing: 0.02em;
}
.cluster-n {
    font-size: 20px;
    font-weight: 700;
    color: var(--who-navy, #00205C);
    font-variant-numeric: tabular-nums;
}
.cluster-name {
    font-size: 11px;
    color: #64748B;
    line-height: 1.35;
    margin-bottom: 8px;
    min-height: 2.7em;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.cluster-bar {
    background: #F1F5F9;
    height: 5px;
    border-radius: 999px;
    overflow: hidden;
    margin-bottom: 6px;
}
.cluster-bar-fill {
    height: 100%;
    background: var(--brand-cyan, #009ADE);
    border-radius: 999px;
    transition: width 0.4s ease;
}
.cluster-share {
    font-size: 10px;
    color: #94A3B8;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
}

/* ─── Rank list (top-N : pays / topics / clusters) ────────── */
.rank-list {
    list-style: none;
    margin: 0;
    padding: 0;
    counter-reset: rank;
}
.rank-item {
    display: grid;
    grid-template-columns: 24px 1fr 48px;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid #F1F5F9;
    font-size: 13px;
}
.rank-item:last-child { border-bottom: 0; }
.rank-pos {
    font-weight: 700;
    color: var(--brand-cyan-dark, #007DB6);
    text-align: center;
    font-size: 12px;
}
.rank-body { min-width: 0; }
.rank-label {
    display: block;
    color: var(--who-navy, #00205C);
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-bottom: 4px;
}
.rank-bar {
    display: block;
    background: #F1F5F9;
    height: 6px;
    border-radius: 999px;
    overflow: hidden;
}
.rank-bar-fill {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, var(--brand-cyan, #009ADE), var(--brand-cyan-dark, #007DB6));
    border-radius: 999px;
    transition: width 0.4s ease;
}
.rank-n {
    text-align: right;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    color: var(--who-navy, #00205C);
}

/* AFRO map — SVG géographique de l'Afrique (BlankMap-Africa, Wikimedia, domaine public).
   Les <g id="xx"> (ISO2 minuscule) sont taggés par JS avec lang-XX + tier-N + has-data. */
.afro-map-wrap {
    position: relative;
    width: 100%;
    max-height: 520px;
    overflow: hidden;
    display: flex;
    justify-content: center;
}
.afro-svg {
    width: 100%;
    height: auto;
    max-height: 520px;
    display: block;
}
/* Style par défaut des pays : gris clair, stroke blanc.
   Cible aussi bien les <path id="xx"> que les paths enfants de <g id="xx">.
   Transition longue (700ms) + delay piloté par JS via --map-delay → effet de vague
   quand on change d'année (pays les plus actifs s'animent en premier). */
.afro-svg path[id],
.afro-svg g[id] path {
    fill: #E5E7EB;
    stroke: #FFFFFF;
    stroke-width: 0.6;
    /* fill = cascade animée à chaque changement d'année (delay piloté par JS).
       filter = darken au survol (réponse rapide, pas de delay). */
    transition: fill 700ms ease-out, filter 220ms ease-out;
    transition-delay: var(--map-delay, 0ms), 0ms;
    cursor: default;
}
/* Variables de teintes WHO officielles par langue */
.afro-svg .lang-en  { --lang-color: #009ADE; }  /* anglophone — WHO Blue */
.afro-svg .lang-fr  { --lang-color: #EF3842; }  /* francophone — WHO Red */
.afro-svg .lang-pt  { --lang-color: #80BC00; }  /* lusophone — WHO Green */
.afro-svg .lang-other { --lang-color: #5B2C86; } /* WHO Purple */

/* Pays AFRO sans activité : teinté très clair de la langue */
.afro-svg path.is-afro.tier-0,
.afro-svg g.is-afro.tier-0 path { fill: color-mix(in srgb, var(--lang-color) 14%, #fff); }
.afro-svg path.is-afro.tier-1,
.afro-svg g.is-afro.tier-1 path { fill: color-mix(in srgb, var(--lang-color) 30%, #fff); }
.afro-svg path.is-afro.tier-2,
.afro-svg g.is-afro.tier-2 path { fill: color-mix(in srgb, var(--lang-color) 55%, #fff); }
.afro-svg path.is-afro.tier-3,
.afro-svg g.is-afro.tier-3 path { fill: color-mix(in srgb, var(--lang-color) 80%, #fff); }
.afro-svg path.is-afro.tier-4,
.afro-svg g.is-afro.tier-4 path { fill: var(--lang-color); }

/* Hover : on assombrit uniquement la couleur du pays survolé via filter (animé) */
.afro-svg path[id]:hover,
.afro-svg g[id]:hover path {
    filter: brightness(0.78);
}

/* Tooltip flottant au survol des pays */
.afro-tooltip {
    position: absolute;
    display: none;
    background: rgba(0, 32, 92, 0.92);
    color: #fff;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 500;
    pointer-events: none;
    white-space: nowrap;
    z-index: 10;
    box-shadow: 0 2px 8px rgba(0, 32, 92, 0.25);
}

.afro-legend {
    margin-top: 10px;
    font-size: 11px;
    color: #64748B;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
}
.afro-legend-group { display: inline-flex; align-items: center; gap: 10px; }
.afro-legend-spacer { flex: 1; }
.legend-dot {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-right: 4px;
    vertical-align: middle;
}
.legend-dot.lang-en  { background: #009ADE; }
.legend-dot.lang-fr  { background: #EF3842; }
.legend-dot.lang-pt  { background: #80BC00; }
.legend-dot.lang-other { background: #5B2C86; }
.legend-dot.lang-none { background: #CBD5E1; }

/* Item / donor lists */
.item-list, .donor-list {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 340px;
    overflow-y: auto;
}
.item-row {
    padding: 10px 8px;
    border-bottom: 1px solid #F1F5F9;
    cursor: pointer;
    transition: background 0.1s;
}
.item-row:hover { background: #F8FAFC; }
.item-row:last-child { border-bottom: 0; }
.item-meta {
    font-size: 11px;
    color: #64748B;
    margin-bottom: 2px;
}
.item-cat { color: var(--who-blue); font-weight: 600; }
.item-countries { color: #64748B; }
.item-title {
    font-size: 13px;
    color: var(--who-navy);
    font-weight: 500;
    line-height: 1.3;
}

.donor-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 8px;
    border-bottom: 1px solid #F1F5F9;
}
.donor-row:last-child { border-bottom: 0; }
.donor-logo {
    width: 40px;
    height: 40px;
    border-radius: 6px;
    background: var(--who-blue);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
}
.donor-logo img { width: 100%; height: 100%; object-fit: contain; border-radius: 6px; }
.donor-name { font-weight: 600; color: var(--who-navy); font-size: 13px; }
.donor-count { font-size: 12px; color: #64748B; }

/* Chartist overrides (utilisé seulement par d'éventuels graphiques résiduels) */
.chart-container { min-height: 280px; }
.chart-bar { min-height: 240px; }
.chart-hbar { min-height: 340px; }
.chart-donut { min-height: 340px; }

/* Sous-titre explicatif sous le h4 d'un dashboard-card */
.dashboard-card-sub {
    margin: -6px 0 14px;
    color: #64748B;
    font-size: 12px;
    line-height: 1.5;
}

/* Bandeau Bureau régional — onglet Production & targets */
.ro-strip {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 18px;
    margin: 0 0 16px;
    background: linear-gradient(135deg, var(--who-navy, #00205C) 0%, #003B8E 100%);
    color: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 32, 92, 0.15);
}
.ro-strip-icon {
    width: 44px; height: 44px;
    border-radius: 10px;
    background: rgba(255,255,255,0.14);
    display: flex; align-items: center; justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}
.ro-strip-body { flex: 1; min-width: 0; }
.ro-strip-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.85;
    margin-bottom: 4px;
    font-weight: 600;
}
.ro-strip-meta {
    font-size: 13px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px 0;
    align-items: center;
    color: rgba(255,255,255,0.92);
}
.ro-strip-meta strong {
    color: #fff;
    font-weight: 700;
    font-size: 15px;
    margin-right: 3px;
}
.ro-strip-meta .ro-sep {
    margin: 0 10px;
    opacity: 0.45;
}
.ro-strip-share {
    text-align: right;
    flex-shrink: 0;
    padding-left: 14px;
    border-left: 1px solid rgba(255,255,255,0.18);
}
.ro-strip-share-val {
    font-size: 24px;
    font-weight: 700;
    line-height: 1;
}
.ro-strip-share-lbl {
    font-size: 10px;
    opacity: 0.78;
    margin-top: 4px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
@media (max-width: 600px) {
    .ro-strip { flex-wrap: wrap; }
    .ro-strip-share { border-left: 0; padding-left: 0; width: 100%; text-align: left; border-top: 1px solid rgba(255,255,255,0.18); padding-top: 10px; margin-top: 4px; }
    .ro-strip-share-val { display: inline-block; }
    .ro-strip-share-lbl { display: inline-block; margin-top: 0; margin-left: 8px; vertical-align: middle; }
    .ro-strip-meta .ro-sep { display: none; }
    .ro-strip-meta { flex-direction: column; align-items: flex-start; gap: 4px; }
}

/* ─── Production by month — bar chart pur SVG ───────────── */
.prod-chart-head {
    font-size: 12px;
    color: #64748B;
    margin-bottom: 6px;
}
.prod-chart-head .prod-chart-total {
    font-size: 22px;
    font-weight: 700;
    color: var(--who-navy, #00205C);
    margin-right: 4px;
}
.prod-chart {
    display: block;
    width: 100%;
    height: 260px;
    font-family: var(--font-stack, "Noto Sans"), sans-serif;
}
.prod-chart .prod-grid {
    stroke: #E2E8F0;
    stroke-width: 1;
    stroke-dasharray: 2 3;
}
.prod-chart .prod-y {
    fill: #94A3B8;
    font-size: 10px;
    text-anchor: end;
}
.prod-chart .prod-x {
    fill: #64748B;
    font-size: 10px;
    text-anchor: middle;
    font-weight: 500;
}
.prod-chart .prod-val {
    fill: var(--who-navy, #00205C);
    font-size: 10px;
    font-weight: 700;
    text-anchor: middle;
}
.prod-chart .prod-bar {
    fill: #E5E7EB;
    transition: fill 0.18s;
}
.prod-chart .prod-bar.has-val {
    fill: var(--brand-cyan, #009ADE);
}
.prod-chart .prod-bar.has-val:hover {
    fill: var(--who-navy, #00205C);
}

.ct-series-a .ct-bar { stroke: var(--who-navy); stroke-width: 22px; }
.chart-hbar .ct-series-a .ct-bar { stroke-width: 16px; }
.ct-series-a .ct-slice-donut { stroke: var(--who-blue); }

/* Donut colors — palette secondaire officielle WHO */
.ct-series-a .ct-slice-donut { stroke: #009ADE; }  /* WHO Blue */
.ct-series-b .ct-slice-donut { stroke: #80BC00; }  /* WHO Green */
.ct-series-c .ct-slice-donut { stroke: #F4A81D; }  /* WHO Yellow */
.ct-series-d .ct-slice-donut { stroke: #5B2C86; }  /* WHO Purple */
.ct-series-e .ct-slice-donut { stroke: #F26829; }  /* WHO Orange */
.ct-series-f .ct-slice-donut { stroke: #A6228C; }  /* WHO Magenta */
.ct-series-g .ct-slice-donut { stroke: #5AC8EC; }  /* WHO Blue 65% */
.ct-series-h .ct-slice-donut { stroke: #B5DA7A; }  /* WHO Green 65% */
.ct-series-i .ct-slice-donut { stroke: #00205C; }  /* WHO Navy */
.ct-label { fill: var(--who-navy); font-size: 11px; font-family: "Noto Sans", sans-serif; }

/* Responsive */
@media (max-width: 900px) {
    .kpi-row { grid-template-columns: repeat(2, 1fr); }
    .dashboard-grid-2col { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════
   whocomafr — Content module styles
   ════════════════════════════════════════════════ */
.content-module { padding: 16px 20px 40px; background: #F8FAFC; min-height: 100%; }

.module-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 20px; flex-wrap: wrap; gap: 12px;
}
.module-header h2 {
    margin: 0; font-size: 22px; color: var(--who-navy); font-weight: 700;
    display: flex; align-items: center; gap: 10px;
}

.content-filters {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px;
    padding: 12px 14px; margin-bottom: 14px;
}
.filter-row {
    display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
}
.filter-row + .filter-row { margin-top: 10px; }
.filter-row-2 select { min-width: 140px; max-width: 220px; }
.filter-search { flex: 1; min-width: 200px; max-width: 320px; }
.filter-toggle {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 10px; background: #F1F5F9; border-radius: 6px;
    font-size: 13px; cursor: pointer; user-select: none;
}
.filter-toggle input { margin: 0; }

.content-stats {
    font-size: 13px; color: #64748B; margin-bottom: 10px;
}
.content-stats strong { color: var(--who-navy); }
.stat-sep { margin: 0 8px; color: #CBD5E1; }

.content-list-wrap { background: #fff; border: 1px solid #E2E8F0; border-radius: 10px; overflow: hidden; }
.content-list-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.content-list-table th {
    text-align: left; padding: 10px 14px; font-weight: 600; color: #64748B;
    background: #F8FAFC; border-bottom: 2px solid #E2E8F0;
}
.content-list-table td {
    padding: 10px 14px; border-bottom: 1px solid #F1F5F9; vertical-align: top;
}
.content-list-table tbody tr:hover td { background: #F8FAFC; cursor: pointer; }
.cell-date { color: #64748B; font-variant-numeric: tabular-nums; white-space: nowrap; }
.cell-flags { white-space: nowrap; }
.flag-mini {
    display: inline-flex; width: 18px; height: 18px; border-radius: 4px;
    align-items: center; justify-content: center; font-weight: 700; font-size: 10px;
    margin-right: 2px;
}
.flag-mini.flag-emergency { background: #FEF2F2; color: #B91C1C; }
.flag-mini.flag-donor     { background: #ECFEFF; color: #0E7490; }
.flag-mini.flag-rd        { background: #F5F3FF; color: #6D28D9; font-size: 9px; }
.flag-mini.flag-video     { background: #FEF3C7; color: #B45309; }

.row-title { color: var(--who-navy); font-weight: 600; line-height: 1.3; }
.row-meta { font-size: 11px; color: #94A3B8; margin-top: 2px; }
.cat-pill {
    display: inline-block; padding: 2px 10px; border-radius: 999px;
    background: rgba(0, 154, 222, 0.12); color: var(--who-navy, #00205C); font-size: 11px; font-weight: 600;
}
.status-pill {
    display: inline-block; padding: 3px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 600;
}
.cell-actions button { font-size: 14px; color: #64748B; }
.cell-actions button:hover { color: var(--who-blue); }

.content-pagination {
    margin-top: 14px; display: flex; gap: 4px; justify-content: center;
}
.pg-btn {
    min-width: 32px; height: 32px; border: 1px solid #E2E8F0;
    background: #fff; color: #475569; border-radius: 6px; font-size: 13px;
    cursor: pointer; transition: all 0.1s;
}
.pg-btn:hover:not(:disabled) { background: #F1F5F9; }
.pg-btn.is-active {
    background: var(--who-blue); color: #fff; border-color: var(--who-blue);
}
.pg-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ═══ Content form ═══════════════════════════════ */
.content-form { padding: 20px 24px; }
.content-form .form-title {
    font-size: 18px; color: var(--who-navy); margin: 0 0 18px;
    display: flex; align-items: center; gap: 8px;
}
.form-section {
    border: 1px solid #E2E8F0; border-radius: 8px;
    padding: 14px 16px; margin-bottom: 14px; background: #fff;
}
.form-section legend {
    font-size: 12px; font-weight: 700; color: var(--who-navy);
    text-transform: uppercase; letter-spacing: 0.04em;
    padding: 0 6px;
}
.form-section.collapsed .form-grid,
.form-section.collapsed > .form-field { display: none; }
.collapsible { cursor: pointer; }
.collapse-toggle { float: right; transition: transform 0.2s; }
.form-section.collapsed .collapse-toggle { transform: rotate(-90deg); }

.form-grid { display: grid; gap: 12px; }
.form-grid-2 { grid-template-columns: 1fr 1fr; }
.form-field { margin-bottom: 10px; }
.form-field label {
    display: block; font-size: 12px; font-weight: 600; color: #475569;
    margin-bottom: 4px;
}
.form-field .req { color: #DC2626; }
.form-field .hint { display: block; color: #94A3B8; font-size: 11px; margin-top: 3px; }
.form-field input[type="text"],
.form-field input[type="url"],
.form-field input[type="date"],
.form-field input[type="number"],
.form-field select,
.form-field textarea {
    width: 100%; padding: 7px 10px; border: 1px solid #CBD5E1; border-radius: 6px;
    font-size: 13px; background: #fff; color: #0F172A;
    font-family: inherit;
}
.form-field select[multiple] { height: 110px; }
.form-field select[multiple][size] { height: auto; min-height: 110px; }

/* Multi-select : note "plusieurs valeurs possibles" + barre de recherche */
.multi-hint {
    font-weight: 500;
    color: var(--brand-cyan-dark, #007DB6);
    font-size: 10px;
    text-transform: lowercase;
    letter-spacing: 0.02em;
    margin-left: 4px;
}
.picker-search {
    position: relative;
    margin-bottom: 4px;
}
.picker-search .fa-magnifying-glass {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: #94A3B8;
    font-size: 11px;
    pointer-events: none;
}
.picker-search-input {
    width: 100%;
    padding: 7px 10px 7px 28px !important;
    border: 1px solid #CBD5E1;
    border-radius: 6px;
    font-size: 12px;
    background: #fff;
    color: #0F172A;
    font-family: inherit;
}
.picker-search-input:focus {
    outline: none;
    border-color: var(--brand-cyan, #009ADE);
    box-shadow: 0 0 0 3px rgba(0, 154, 222, 0.15);
}
.picker-count {
    font-weight: 700;
    color: var(--who-navy, #00205C);
}

/* Empile en une colonne sur mobile/petit écran */
@media (max-width: 720px) {
    .form-grid-2 { grid-template-columns: 1fr; }
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
    outline: none; border-color: var(--who-blue); box-shadow: 0 0 0 3px rgba(0,147,213,0.15);
}

.toggle-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.toggle-row {
    display: flex; gap: 10px; padding: 10px 12px;
    background: #F8FAFC; border-radius: 6px; cursor: pointer;
    align-items: flex-start; user-select: none;
}
.toggle-row input { margin-top: 3px; }
.toggle-row span { font-size: 13px; color: var(--who-navy); }
.toggle-row small { color: #94A3B8; font-size: 11px; font-weight: normal; }

.form-actions {
    display: flex; gap: 10px; padding-top: 16px;
    border-top: 1px solid #E2E8F0; margin-top: 16px;
}

@media (max-width: 700px) {
    .form-grid-2 { grid-template-columns: 1fr; }
    .toggle-grid { grid-template-columns: 1fr; }
}

/* ═══ Content detail ════════════════════════════ */
.content-detail { padding: 20px 24px; }
.detail-head { margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid #E2E8F0; }
.detail-meta { margin-bottom: 10px; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; font-size: 13px; }
.detail-title { font-size: 20px; color: var(--who-navy); margin: 4px 0 8px; line-height: 1.3; }
.detail-rn { font-family: ui-monospace, monospace; font-size: 12px; color: #94A3B8; }
.detail-flags { margin-top: 10px; display: flex; gap: 6px; flex-wrap: wrap; }
.detail-section { margin: 14px 0; }
.detail-section h5 {
    font-size: 12px; color: #64748B; text-transform: uppercase;
    letter-spacing: 0.05em; font-weight: 700; margin-bottom: 6px;
}
.tag {
    display: inline-block; padding: 3px 10px; border-radius: 999px;
    background: #F1F5F9; color: var(--who-navy); font-size: 12px; margin: 2px 4px 2px 0;
}
.detail-links { list-style: none; padding: 0; margin: 0; }
.detail-links li { padding: 4px 0; font-size: 13px; }
.detail-links a { color: var(--who-blue); text-decoration: none; }
.detail-links a:hover { text-decoration: underline; }
.detail-text { font-size: 13px; color: #334155; line-height: 1.5; white-space: pre-wrap; }
.detail-actions {
    margin-top: 24px; padding-top: 16px; border-top: 1px solid #E2E8F0;
    display: flex; gap: 10px;
}

/* ════════════════════════════════════════════════
   whocomafr — Health topics module
   ════════════════════════════════════════════════ */
.topics-module { padding: 16px 20px 40px; background: #F8FAFC; min-height: 100%; }

.topics-filters {
    display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
    margin-bottom: 16px;
}
.view-tabs {
    display: inline-flex; background: #fff; border-radius: 10px; padding: 4px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05); gap: 2px;
}
.view-tab {
    background: transparent; border: 0; padding: 7px 14px;
    border-radius: 7px; font-size: 13px; font-weight: 500; color: #64748B;
    cursor: pointer; transition: all 0.15s; display: inline-flex; align-items: center; gap: 6px;
}
.view-tab:hover { color: var(--who-blue); }
.view-tab.is-active { background: var(--who-blue); color: #fff; }

.topics-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 12px;
}
.topic-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px;
    padding: 14px 16px; cursor: pointer; transition: all 0.15s;
}
.topic-card:hover {
    border-color: var(--who-blue);
    box-shadow: 0 2px 8px rgba(0,147,213,0.15);
    transform: translateY(-1px);
}
.topic-clusters {
    font-size: 11px; color: var(--who-blue); font-weight: 700;
    letter-spacing: 0.04em; margin-bottom: 4px;
}
.topic-name {
    font-size: 14px; font-weight: 600; color: var(--who-navy);
    line-height: 1.3; margin-bottom: 6px;
}
.topic-count {
    font-size: 12px; color: #64748B;
}

/* Radial chart legend */
.radial-chart { height: 360px; }
.radial-chart .ct-slice-donut { stroke-width: 28px; }
.radial-chart .ct-series-a .ct-slice-donut  { stroke: #0093D5; }
.radial-chart .ct-series-b .ct-slice-donut  { stroke: #10B981; }
.radial-chart .ct-series-c .ct-slice-donut  { stroke: #F59E0B; }
.radial-chart .ct-series-d .ct-slice-donut  { stroke: #8B5CF6; }
.radial-chart .ct-series-e .ct-slice-donut  { stroke: #EF4444; }
.radial-chart .ct-series-f .ct-slice-donut  { stroke: #06B6D4; }
.radial-chart .ct-series-g .ct-slice-donut  { stroke: #F97316; }
.radial-chart .ct-series-h .ct-slice-donut  { stroke: #6366F1; }
.radial-chart .ct-series-i .ct-slice-donut  { stroke: #14B8A6; }
.radial-chart .ct-series-j .ct-slice-donut  { stroke: #EC4899; }
.radial-chart .ct-series-k .ct-slice-donut  { stroke: #84CC16; }
.radial-chart .ct-series-l .ct-slice-donut  { stroke: #A855F7; }
.radial-chart .ct-series-m .ct-slice-donut  { stroke: #22D3EE; }
.radial-chart .ct-series-n .ct-slice-donut  { stroke: #FB7185; }
.radial-chart .ct-series-o .ct-slice-donut  { stroke: #FCD34D; }
.radial-chart .ct-series-p .ct-slice-donut  { stroke: #34D399; }
.radial-chart .ct-series-q .ct-slice-donut  { stroke: #60A5FA; }
.radial-chart .ct-series-r .ct-slice-donut  { stroke: #F472B6; }
.radial-chart .ct-series-s .ct-slice-donut  { stroke: #A78BFA; }
.radial-chart .ct-series-t .ct-slice-donut  { stroke: #FACC15; }

.radial-legend {
    margin-top: 12px;
    display: flex; flex-wrap: wrap; gap: 8px 14px;
    font-size: 12px; color: #475569;
}
.radial-item { display: inline-flex; align-items: center; gap: 4px; }
.radial-dot {
    display: inline-block; width: 10px; height: 10px; border-radius: 50%;
}

/* Topic detail */
.topic-period-cards {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
    margin: 18px 0;
}
.topic-period-card {
    background: #F8FAFC; border: 1px solid #E2E8F0; border-radius: 10px;
    padding: 12px; text-align: center;
}
.period-year { font-size: 12px; color: #64748B; font-weight: 600; }
.period-count { font-size: 28px; font-weight: 700; color: var(--who-navy); line-height: 1; margin: 4px 0; }
.period-label { font-size: 11px; color: #94A3B8; }

.cluster-pill {
    display: inline-block; padding: 2px 8px; border-radius: 4px;
    background: #DBEAFE; color: #1E40AF; font-size: 11px; font-weight: 700;
    letter-spacing: 0.04em; margin-right: 4px;
}

.topic-form { padding: 20px 24px; }
.topic-form .form-title {
    font-size: 18px; color: var(--who-navy); margin: 0 0 18px;
    display: flex; align-items: center; gap: 8px;
}

/* ════════════════════════════════════════════════
   whocomafr — Journalists module
   ════════════════════════════════════════════════ */
.journalists-module, .experts-module { padding: 16px 20px 40px; background: #F8FAFC; min-height: 100%; }

.journalists-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 12px;
}
.jn-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px;
    padding: 16px 12px; text-align: center; cursor: pointer; transition: all 0.15s;
}
.jn-card:hover {
    border-color: var(--who-blue);
    box-shadow: 0 2px 8px rgba(0,147,213,0.15);
    transform: translateY(-1px);
}
.jn-photo {
    width: 56px; height: 56px; margin: 0 auto 8px;
    border-radius: 50%; background: var(--who-blue); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 28px; overflow: hidden;
}
.jn-photo img { width: 100%; height: 100%; object-fit: cover; }
.jn-country {
    font-size: 10px; color: var(--who-blue); font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 2px;
}
.jn-name {
    font-size: 13px; font-weight: 600; color: var(--who-navy); line-height: 1.2;
    margin-bottom: 2px;
}
.jn-outlet { font-size: 11px; color: #64748B; }
.jn-badge {
    margin-top: 6px; font-size: 10px; color: var(--who-blue); font-weight: 600;
    background: #DBEAFE; padding: 2px 6px; border-radius: 4px; display: inline-block;
}

/* Journalist detail */
.jn-detail-head { display: flex; align-items: center; gap: 14px; }
.jn-photo-lg {
    width: 64px; height: 64px; flex-shrink: 0;
    border-radius: 50%; background: var(--who-blue); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 36px; overflow: hidden;
}
.jn-photo-lg img { width: 100%; height: 100%; object-fit: cover; }
.jn-detail-outlet {
    font-size: 11px; color: var(--who-blue); font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.05em;
}

/* ════════════════════════════════════════════════
   whocomafr — WHO Experts module
   ════════════════════════════════════════════════ */
.experts-list {
    list-style: none; padding: 0; margin: 0;
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px; overflow: hidden;
}
.expert-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 14px 18px; border-bottom: 1px solid #F1F5F9;
    cursor: pointer; transition: background 0.1s;
}
.expert-row:hover { background: #F8FAFC; }
.expert-row:last-child { border-bottom: 0; }
.expert-info { flex: 1; }
.expert-badge {
    font-size: 10px; color: var(--who-blue); font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 2px;
}
.expert-badge.is-empty { color: #CBD5E1; }
.expert-name {
    font-size: 14px; font-weight: 600; color: var(--who-navy);
    display: flex; align-items: center; gap: 6px;
}
.expert-job { font-size: 12px; color: #64748B; margin-top: 2px; }
.expert-meta { display: flex; align-items: center; gap: 8px; }
.spokes-pin {
    display: inline-flex; width: 20px; height: 20px;
    background: #FEF3C7; color: #B45309; border-radius: 50%;
    align-items: center; justify-content: center; font-size: 10px;
}

/* ════════════════════════════════════════════════
   whocomafr — Clusters / Donors / Targets / Regional
   ════════════════════════════════════════════════ */
.clusters-module, .donors-module, .targets-module, .regional-module {
    padding: 16px 20px 40px; background: #F8FAFC; min-height: 100%;
}

/* Clusters list */
.clusters-list {
    list-style: none; padding: 0; margin: 0;
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px; overflow: hidden;
}
.cluster-row {
    display: flex; align-items: center; gap: 16px; padding: 16px 20px;
    border-bottom: 1px solid #F1F5F9; cursor: pointer; transition: background 0.1s;
}
.cluster-row:hover { background: #F8FAFC; }
.cluster-row:last-child { border-bottom: 0; }
.cluster-acronym {
    background: var(--who-blue); color: #fff;
    font-weight: 700; font-size: 14px; letter-spacing: 0.05em;
    padding: 8px 12px; border-radius: 6px; min-width: 50px; text-align: center;
}
.cluster-info { flex: 1; }
.cluster-name { font-size: 15px; font-weight: 600; color: var(--who-navy); }
.cluster-stats { font-size: 12px; color: #64748B; margin-top: 4px; display: flex; gap: 12px; }
.cluster-arrow { color: #CBD5E1; }

.cluster-acronym-lg {
    display: inline-block; background: var(--who-blue); color: #fff;
    font-weight: 700; font-size: 18px; letter-spacing: 0.05em;
    padding: 10px 18px; border-radius: 8px; margin-bottom: 8px;
}

/* Line lists for cluster detail */
.line-list { list-style: none; padding: 0; margin: 0; }
.topic-line, .expert-line {
    display: flex; justify-content: space-between; align-items: center;
    padding: 8px 10px; border-bottom: 1px solid #F1F5F9; cursor: pointer;
    font-size: 13px;
}
.topic-line:hover, .expert-line:hover { background: #F8FAFC; }
.topic-line-count, .expert-line-count {
    background: #DBEAFE; color: #1E40AF; font-weight: 600; padding: 2px 8px;
    border-radius: 999px; font-size: 11px;
}
.expert-line { flex-wrap: wrap; }
.expert-line-name { font-weight: 600; color: var(--who-navy); flex: 1; }
.expert-line-job { color: #64748B; font-size: 12px; flex: 1; text-align: right; padding-right: 12px; }

.cat-distribution { display: flex; flex-direction: column; gap: 6px; }
.cat-line {
    display: grid; grid-template-columns: 1fr 60px 200px; gap: 10px;
    align-items: center; font-size: 13px;
}
.cat-line-name { color: var(--who-navy); }
.cat-line-count { color: #64748B; text-align: right; }
.cat-line-bar { background: #F1F5F9; height: 6px; border-radius: 3px; overflow: hidden; }
.cat-line-bar > div { background: var(--who-blue); height: 100%; }

/* Donors grid */
.donors-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px;
}
.donor-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px;
    padding: 16px; display: flex; gap: 12px; cursor: pointer; transition: all 0.15s;
    align-items: center;
}
.donor-card:hover {
    border-color: var(--who-blue);
    box-shadow: 0 2px 8px rgba(0,147,213,0.15);
}
.donor-logo-card {
    width: 56px; height: 56px; flex-shrink: 0;
    background: var(--who-blue); color: #fff; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 14px; overflow: hidden;
}
.donor-logo-card img { width: 100%; height: 100%; object-fit: contain; padding: 4px; background: #fff; border-radius: 8px; }
.donor-info-card { flex: 1; min-width: 0; }
.donor-name-card { font-size: 14px; font-weight: 600; color: var(--who-navy); }
.donor-acronym { font-size: 11px; color: #64748B; text-transform: uppercase; letter-spacing: 0.05em; }
.donor-stats-row { font-size: 12px; color: #475569; margin-top: 6px; display: flex; gap: 10px; flex-wrap: wrap; }
.donor-vis-badge {
    color: #0E7490; background: #ECFEFF; padding: 2px 8px; border-radius: 999px;
    font-weight: 600;
}

.donor-detail-head { display: flex; gap: 16px; align-items: flex-start; }
.donor-logo-lg {
    width: 72px; height: 72px; flex-shrink: 0;
    background: var(--who-blue); color: #fff; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 18px;
}
.mini-list { list-style: none; padding: 0; margin: 0; }
.line-item {
    display: flex; justify-content: space-between; padding: 6px 0;
    border-bottom: 1px solid #F1F5F9; font-size: 13px;
}
.line-item strong { color: var(--who-blue); }

/* Targets matrix */
.targets-matrix-wrap {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px;
    overflow: auto; max-height: 75vh;
}
.targets-matrix { width: 100%; border-collapse: collapse; font-size: 13px; }
.targets-matrix thead th {
    background: #F8FAFC; color: #64748B; font-weight: 600;
    padding: 10px; border-bottom: 2px solid #E2E8F0;
    position: sticky; top: 0; z-index: 2;
}
.targets-matrix thead tr:first-child th { font-size: 14px; color: var(--who-navy); }
.targets-matrix thead th.sub { font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; }
.targets-matrix .cat-col {
    text-align: left; padding: 10px 14px; font-weight: 500; color: var(--who-navy);
    background: #fff; position: sticky; left: 0; z-index: 1;
    min-width: 280px;
}
.targets-matrix thead .cat-col { background: #F8FAFC; z-index: 3; }
.targets-matrix tbody tr:hover .cat-col { background: #F8FAFC; }
.targets-matrix td { padding: 6px 10px; border-bottom: 1px solid #F1F5F9; text-align: center; }
.tgt-input {
    width: 70px; padding: 4px 8px; text-align: right; border: 1px solid #E2E8F0;
    border-radius: 4px; font-variant-numeric: tabular-nums;
    transition: all 0.2s;
}
.tgt-input:focus {
    outline: none; border-color: var(--who-blue);
    box-shadow: 0 0 0 3px rgba(0,147,213,0.15);
}
.tgt-input.is-saving { background: #FEF3C7; }
.tgt-input.is-saved  { background: #D1FAE5; border-color: #10B981; }
.tgt-input.is-error  { background: #FEE2E2; border-color: #EF4444; }
.prod-cell { color: var(--who-navy); font-weight: 600; font-variant-numeric: tabular-nums; min-width: 60px; }
.pct-cell  { min-width: 70px; font-weight: 600; }

/* Regional module */
.lang-tabs {
    display: flex; gap: 4px; flex-wrap: wrap;
    background: #fff; border: 1px solid #E2E8F0; border-radius: 10px;
    padding: 6px; margin-bottom: 16px;
}
.lang-tab {
    border: 0; background: transparent; padding: 8px 14px;
    border-radius: 7px; font-size: 13px; font-weight: 500; color: #475569;
    cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
    transition: all 0.15s;
}
.lang-tab:hover { background: #F1F5F9; }
.lang-tab.is-active { background: var(--who-blue); color: #fff; }
.lang-tab.is-active .lang-dot { box-shadow: 0 0 0 2px #fff inset; }

.lang-dot {
    display: inline-block; width: 10px; height: 10px; border-radius: 50%;
}
.lang-dot.lang-en  { background: #2563EB; }
.lang-dot.lang-fr  { background: #DC2626; }
.lang-dot.lang-pt  { background: #16A34A; }

.rg-donut-legend {
    display: flex; flex-wrap: wrap; gap: 8px 14px;
    margin-top: 12px; font-size: 12px;
}

.countries-perf-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 8px;
}
.country-perf-card {
    background: #fff; border: 1px solid #E2E8F0; border-radius: 8px;
    padding: 10px 12px; border-left: 4px solid var(--lang-color, #CBD5E1);
}
.country-perf-card.lang-en   { --lang-color: #2563EB; }
.country-perf-card.lang-fr   { --lang-color: #DC2626; }
.country-perf-card.lang-pt   { --lang-color: #16A34A; }
.country-perf-card.lang-other{ --lang-color: #9333EA; }
.country-perf-card.lang-none { --lang-color: #CBD5E1; opacity: 0.7; }

.country-perf-head { font-size: 11px; color: var(--who-blue); font-weight: 700; letter-spacing: 0.04em; }
.country-perf-head strong { font-size: 14px; color: var(--who-navy); margin-right: 4px; }
.country-perf-name { font-size: 13px; font-weight: 600; color: var(--who-navy); margin-top: 2px; }
.country-perf-stats { font-size: 11px; color: #64748B; margin-top: 4px; line-height: 1.5; }

/* ═══════════════════════════════════════════════════════════
   Settings WHO module
   ═══════════════════════════════════════════════════════════ */
.settings-who-module .module-header { margin-bottom: 16px; }
.settings-panel { background: #fff; border: 1px solid #e2e8f0; border-radius: 8px; overflow: hidden; margin-bottom: 20px; }
.settings-panel-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; background: #f8fafc; border-bottom: 1px solid #e2e8f0; }
.settings-panel-header h5 { margin: 0; font-size: 14px; font-weight: 600; color: var(--who-navy); }
.settings-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.settings-table th { background: #f1f5f9; border-bottom: 1px solid #e2e8f0; padding: 7px 10px; font-weight: 600; color: #475569; font-size: 12px; text-transform: uppercase; letter-spacing: 0.04em; }
.settings-table td { padding: 5px 10px; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.settings-table tr:last-child td { border-bottom: none; }
.settings-table .form-control-sm { font-size: 12px; padding: 3px 7px; }
.settings-table .font-mono { font-family: 'SFMono-Regular', Consolas, monospace; font-size: 11px; color: #0ea5e9; }
