@import '/_content/Microsoft.FluentUI.AspNetCore.Components/css/reboot.css';

body {
    --body-font: "Segoe UI Variable", "Segoe UI", sans-serif;
    font-family: var(--body-font);
    font-size: var(--type-ramp-base-font-size);
    line-height: var(--type-ramp-base-line-height);
    margin: 0;
}

.navmenu-icon {
    display: none;
}

.main {
    min-height: calc(100dvh - 96px);
    color: var(--neutral-foreground-rest);
    align-items: stretch !important;
}

/* Top navigation buttons in the header — transparent background, white text. */
.nav-header-btn::part(control) {
    background: transparent !important;
    color: #ffffff !important;
    border: none !important;
    font-weight: 500;
}
.nav-header-btn::part(control):hover {
    background: rgba(255, 255, 255, 0.15) !important;
}
.nav-header-btn::part(control):active {
    background: rgba(255, 255, 255, 0.25) !important;
}

/* Brand "PA Gestion" — sur 1 ligne */
.brand-label {
    font-weight: 600;
    color: white;
    font-size: 1.05rem;
    margin: 0 16px 0 8px;
    white-space: nowrap;
}

/* Icônes en blanc à l'intérieur des FluentButton/FluentAnchor d'apparence
   accent (fond bleu). Par défaut Fluent UI ne propage pas la couleur du
   bouton vers les SVG des slots start/end → l'icône reste en couleur
   par défaut (souvent bleu sur fond bleu = invisible). On force le
   currentColor partout : fill, stroke, path. */
fluent-button[appearance="accent"] svg,
fluent-button[appearance="accent"] svg path,
fluent-button[appearance="accent"] svg rect,
fluent-button[appearance="accent"] svg circle,
fluent-button[appearance="accent"] svg polygon,
fluent-anchor[appearance="accent"] svg,
fluent-anchor[appearance="accent"] svg path,
fluent-anchor[appearance="accent"] svg rect,
fluent-anchor[appearance="accent"] svg circle,
fluent-anchor[appearance="accent"] svg polygon {
    fill: #fff !important;
}
.nav-header-btn fluent-icon {
    color: #ffffff !important;
}

.body-content {
    align-self: stretch;
    height: unset !important;
    display: flex;
}

.content {
    padding: 0.5rem 1.5rem;
    align-self: stretch !important;
}

.manage {
    width: 100dvw;
}

footer {
    display: grid;
    grid-template-columns: 10px auto auto 10px;
    background: var(--neutral-layer-4);
    color: var(--neutral-foreground-rest);
    align-items: center;
    padding: 10px 10px;
}
footer .link1 { grid-column: 2; justify-content: start; }
footer .link2 { grid-column: 3; justify-self: end; }
footer a { color: var(--neutral-foreground-rest); text-decoration: none; }
footer a:focus { outline: 1px dashed; outline-offset: 3px; }
footer a:hover { text-decoration: underline; }

.alert {
    border: 1px dashed var(--accent-fill-rest);
    padding: 5px;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}
.blazor-error-boundary::after { content: "An error has occurred." }

.darker-border-checkbox.form-check-input { border-color: #929292; }

.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}
.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* ============================================================
   MODERN SHARED STYLES — PA-AppliPAQT
   ============================================================ */

/* ---------- Page header ---------- */
.page-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 0 12px;
}
.page-header-title {
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--neutral-foreground-rest);
}
.page-header-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* ---------- Filter bar (consolidé : layout flex + permissivité popups) ----------
   Reproduit le look d'une FluentCard mais sans custom element : pas de
   stacking context emprisonnant, pas d'overflow:hidden. Les popups des
   FluentSelect / FluentDatePicker à l'intérieur peuvent déborder librement
   au-dessus de la grille sans z-index acrobatique. */
.filter-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 12px;
    padding: 12px 16px;
    margin-bottom: 16px;
    background-color: var(--neutral-layer-2);
    border: 1px solid var(--neutral-stroke-divider-rest);
    border-radius: 10px;
    position: relative;
    overflow: visible;
}
.filter-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.filter-group label {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--neutral-foreground-hint);
}

/* ---------- Syncfusion Grid modern overrides ---------- */
.e-grid {
    border: none !important;
    border-radius: 10px !important;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
    font-family: var(--body-font) !important;
}
.e-grid .e-headercell {
    background-color: var(--neutral-layer-2) !important;
    border-bottom: 2px solid var(--neutral-stroke-rest) !important;
}
.e-grid .e-headertext {
    font-weight: 600 !important;
    color: var(--neutral-foreground-hint) !important;
    font-size: 0.7rem !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.e-grid .e-rowcell {
    padding: 10px 12px !important;
    border-bottom: 1px solid var(--neutral-stroke-divider-rest) !important;
    font-size: 0.85rem;
}
.e-grid .e-row:hover .e-rowcell {
    background-color: color-mix(in srgb, var(--accent-fill-rest) 6%, transparent) !important;
    cursor: pointer;
}
.e-grid .e-altrow .e-rowcell {
    background-color: color-mix(in srgb, var(--neutral-layer-2) 50%, transparent);
}
.e-grid .e-toolbar {
    background: var(--neutral-layer-2) !important;
    border-bottom: 1px solid var(--neutral-stroke-divider-rest) !important;
    border-radius: 10px 10px 0 0;
    padding: 4px 8px;
}
.e-grid .e-pager {
    background: var(--neutral-layer-2) !important;
    border-top: 1px solid var(--neutral-stroke-divider-rest) !important;
    border-radius: 0 0 10px 10px;
}
.e-grid .e-command-column .e-icons { color: var(--accent-fill-rest); }
.btn-grid-action { color: var(--accent-fill-rest) !important; text-transform: none !important; }

/* ---------- Modern cards ---------- */
.info-card {
    background: var(--neutral-layer-floating);
    border: 1px solid var(--neutral-stroke-divider-rest);
    border-radius: 12px;
    padding: 20px;
    transition: box-shadow 0.15s ease;
}
.info-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}
.info-card-header {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--neutral-foreground-hint);
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.info-card-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.85rem;
}
.info-card-label { color: var(--neutral-foreground-hint); }
.info-card-value { font-weight: 600; }

/* ---------- Status bar ---------- */
.status-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
    padding: 10px 16px;
    margin-bottom: 16px;
    background: var(--neutral-layer-2);
    border-radius: 10px;
    border: 1px solid var(--neutral-stroke-divider-rest);
}
.status-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
}
.status-label { font-weight: 600; }
.status-value { font-weight: 500; }
.status-warning { color: var(--error); }

/* ---------- Summary / KPI cards (colored) ---------- */
.kpi-card {
    border-radius: 14px;
    padding: 20px 22px;
    color: #fff;
    min-height: 120px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    cursor: pointer;
}
.kpi-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.12);
}
.kpi-card-icon { margin-bottom: 6px; opacity: 0.9; }
.kpi-card-count { font-size: 2.2rem; font-weight: 700; line-height: 1; }
.kpi-card-label { font-size: 0.9rem; font-weight: 600; margin-top: 4px; }
.kpi-card-sublabel { font-size: 0.72rem; opacity: 0.75; }

.kpi-blue { background: linear-gradient(135deg, #1976d2, #1565c0); }
.kpi-orange { background: linear-gradient(135deg, #f57c00, #ef6c00); }
.kpi-red { background: linear-gradient(135deg, #e53935, #c62828); }
.kpi-purple { background: linear-gradient(135deg, #7b1fa2, #6a1b9a); }
.kpi-teal { background: linear-gradient(135deg, #00897b, #00796b); }
.kpi-cyan { background: linear-gradient(135deg, #0097a7, #00838f); }
.kpi-amber { background: linear-gradient(135deg, #ffa000, #ff8f00); }
.kpi-green { background: linear-gradient(135deg, #43a047, #388e3c); }
.kpi-indigo { background: linear-gradient(135deg, #3949ab, #303f9f); }
.kpi-pink { background: linear-gradient(135deg, #d81b60, #c2185b); }

/* Analytical KPI cards — sober, light theme, money emphasis */
.kpi-analytic { background: linear-gradient(135deg, #455a64, #37474f); }
.kpi-analytic-warn { background: linear-gradient(135deg, #ef6c00, #e65100); }
.kpi-card-count-money { font-size: 1.6rem; font-weight: 700; line-height: 1.1; margin-top: 4px; }

/* Ma journée — compact panel on home */
.ma-journee-pill {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    padding: 6px 14px;
    border-radius: 10px;
    min-width: 90px;
}
.ma-journee-pill .num { font-size: 1.4rem; font-weight: 700; line-height: 1; }
.ma-journee-pill .lbl { font-size: 0.7rem; text-transform: uppercase; opacity: 0.8; margin-top: 2px; }
.ma-journee-retard { background: rgba(229,57,53,0.15); color: #c62828; }
.ma-journee-aujourdhui { background: rgba(245,124,0,0.15); color: #ef6c00; }
.ma-journee-semaine { background: rgba(25,118,210,0.12); color: #1565c0; }
.ma-journee-apercu { margin: 10px 0 0 0; padding: 0 0 0 18px; font-size: 0.9rem; }
.ma-journee-apercu li { margin: 2px 0; }
.ma-journee-retard-flag { color: var(--error); margin-left: 4px; font-size: 0.85rem; }

/* ---------- Home — hero greeting ---------- */
.home-hero {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 20px;
    padding: 4px 0 4px 4px;
}
.home-hero-titre {
    font-size: 1.8rem;
    font-weight: 700;
    margin: 0 0 4px 0;
    line-height: 1.1;
}
.home-hero-wave {
    display: inline-block;
    animation: wave 1.5s ease-in-out;
    transform-origin: 70% 70%;
}
@keyframes wave {
    0%, 100% { transform: rotate(0deg); }
    20% { transform: rotate(-10deg); }
    40% { transform: rotate(14deg); }
    60% { transform: rotate(-8deg); }
    80% { transform: rotate(4deg); }
}
.home-hero-sub {
    font-size: 0.95rem;
    color: var(--neutral-foreground-hint);
}
.home-hero-retard {
    color: var(--error);
    font-weight: 600;
}

/* ---------- Tableau de bord — section header ---------- */
.section-header {
    display: flex;
    align-items: center;
    margin: 8px 0 14px 0;
}
.section-titre {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 700;
}
.section-sub {
    font-size: 0.85rem;
    color: var(--neutral-foreground-hint);
    margin-top: 2px;
}

/* ---------- KPI band — gros chiffres colorés style "stat" ---------- */
.kpi-band {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin-bottom: 8px;
}
.kpi-stat {
    background: var(--neutral-layer-1);
    border: 1px solid var(--neutral-stroke-rest);
    border-radius: 10px;
    padding: 18px 20px;
    text-align: left;
    transition: transform 0.12s, box-shadow 0.12s;
}
.kpi-stat-clickable { cursor: pointer; }
.kpi-stat-clickable:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0,0,0,0.08);
}
.kpi-stat-label {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--neutral-foreground-hint);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 6px;
}
.kpi-stat-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}
.kpi-stat-delta {
    font-size: 0.78rem;
    color: var(--neutral-foreground-hint);
    margin-top: 6px;
}
.kpi-color-green  { color: #2e7d32; }
.kpi-color-orange { color: #e65100; }
.kpi-color-blue   { color: #1565c0; }
.kpi-color-purple { color: #6a1b9a; }
.kpi-color-indigo { color: #283593; }
.kpi-color-red    { color: #c62828; }

.ma-journee-vide {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--neutral-foreground-hint);
    font-size: 0.9rem;
    padding: 4px 0 2px 0;
}

/* ---------- Opérations à traiter — tiles compactes ---------- */
.op-section-header {
    display: flex;
    align-items: center;
    margin: 8px 0 12px 0;
}
.op-groupe-titre {
    margin: 14px 0 8px 0;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--neutral-foreground-hint);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.op-tiles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 10px;
    margin-bottom: 16px;
}
.op-tile {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--neutral-layer-1);
    border: 1px solid var(--neutral-stroke-rest);
    border-radius: 8px;
    border-left-width: 4px;
    cursor: pointer;
    transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s;
    min-height: 64px;
}
.op-tile:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}
.op-tile.op-tile-zero {
    opacity: 0.55;
}
.op-tile-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}
/* Force le SVG de l'icône en blanc, peu importe son fill par défaut */
.op-tile-icon svg,
.op-tile-icon svg path,
.op-tile-icon svg rect,
.op-tile-icon svg circle,
.op-tile-icon svg polygon {
    fill: #fff !important;
    color: #fff !important;
}
.op-tile-body { flex: 1; min-width: 0; }
.op-tile-count {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
}
.op-tile-label {
    font-size: 0.88rem;
    font-weight: 500;
    margin-top: 2px;
}
.op-tile-sublabel {
    font-size: 0.75rem;
    color: var(--neutral-foreground-hint);
    margin-top: 1px;
}

/* Accents par couleur — bord gauche + fond icon */
.op-accent-blue   { border-left-color: #1976d2; }
.op-accent-blue   .op-tile-icon { background: #1976d2; }
.op-accent-orange { border-left-color: #f57c00; }
.op-accent-orange .op-tile-icon { background: #f57c00; }
.op-accent-red    { border-left-color: #e53935; }
.op-accent-red    .op-tile-icon { background: #e53935; }
.op-accent-purple { border-left-color: #7b1fa2; }
.op-accent-purple .op-tile-icon { background: #7b1fa2; }
.op-accent-teal   { border-left-color: #00897b; }
.op-accent-teal   .op-tile-icon { background: #00897b; }
.op-accent-cyan   { border-left-color: #0097a7; }
.op-accent-cyan   .op-tile-icon { background: #0097a7; }
.op-accent-amber  { border-left-color: #ffa000; }
.op-accent-amber  .op-tile-icon { background: #ffa000; }
.op-accent-green  { border-left-color: #43a047; }
.op-accent-green  .op-tile-icon { background: #43a047; }
.op-accent-indigo { border-left-color: #3949ab; }
.op-accent-indigo .op-tile-icon { background: #3949ab; }
.op-accent-pink   { border-left-color: #d81b60; }
.op-accent-pink   .op-tile-icon { background: #d81b60; }

/* Recherche rapide globale (header) */
.recherche-rapide {
    position: relative;
    flex: 0 1 360px;   /* shrink autorisé jusqu'à content min */
    min-width: 0;
    max-width: 100%;
}
.recherche-input-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 10px;
    background: rgba(255,255,255,0.15);
    border-radius: 18px;
    transition: background 0.15s;
}
.recherche-rapide.is-open .recherche-input-wrap,
.recherche-input-wrap:focus-within {
    background: rgba(255,255,255,0.25);
}
.recherche-input {
    flex: 1;
    background: transparent;
    border: 0;
    outline: 0;
    color: #fff;
    font-size: 0.9rem;
    padding: 4px 0;
}
.recherche-input::placeholder { color: rgba(255,255,255,0.65); }
.recherche-clear {
    background: transparent;
    border: 0;
    color: #fff;
    font-size: 1.2rem;
    line-height: 1;
    cursor: pointer;
    padding: 0 4px;
}
.recherche-panel {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    background: var(--neutral-layer-1);
    border: 1px solid var(--neutral-stroke-rest);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
    max-height: 420px;
    overflow-y: auto;
    z-index: 1000;
}
.recherche-cat {
    padding: 6px 12px 2px 12px;
    font-size: 0.7rem;
    color: var(--neutral-foreground-hint);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-top: 1px solid var(--neutral-stroke-rest);
}
.recherche-cat:first-child { border-top: 0; }
.recherche-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    color: var(--neutral-foreground-rest);
    text-decoration: none;
    cursor: pointer;
}
.recherche-item:hover { background: var(--neutral-layer-2); }
.recherche-item-text { flex: 1; min-width: 0; }
.recherche-item-lib { font-weight: 500; font-size: 0.9rem; }
.recherche-item-det { font-size: 0.78rem; color: var(--neutral-foreground-hint); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.recherche-empty { padding: 12px; color: var(--neutral-foreground-hint); text-align: center; font-size: 0.9rem; }

@media (max-width: 900px) {
    .recherche-rapide { width: 220px; }
}

/* ---------- Pieces dossier ---------- */
.pieces-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 8px;
    margin-top: 10px;
}
.piece-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    border-radius: 6px;
}
.piece-manquante { background-color: rgba(229, 57, 53, 0.08); }

.competences-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

/* ---------- Tabs modern ---------- */
.e-tab .e-tab-header .e-toolbar-item .e-tab-text {
    font-weight: 600 !important;
    font-size: 0.82rem !important;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* ---------- Finance summary ---------- */
.finance-summary {
    background: var(--neutral-layer-2);
    border: 1px solid var(--neutral-stroke-divider-rest);
    border-radius: 12px;
    padding: 20px;
}
.finance-row {
    display: flex;
    justify-content: flex-end;
    align-items: baseline;
    gap: 12px;
    padding: 6px 0;
}
.finance-label {
    font-size: 0.85rem;
    color: var(--neutral-foreground-hint);
    font-weight: 600;
}
.finance-value {
    font-size: 1.1rem;
    font-weight: 700;
}
.finance-total {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--accent-fill-rest);
}

/* Largeur des champs Fluent à l'intérieur d'un dialog/panel.
   FluentTextField/TextArea sont des web components avec leur propre largeur
   fixe (~280px par défaut). Style="width:100%" sur le composant Blazor
   n'atteint pas l'input HTML interne. On force avec !important pour
   surcharger les règles du thème Fluent, à la fois sur le host et sur la
   part shadow DOM. */
.fluent-large-field fluent-text-field,
.fluent-large-field fluent-text-area {
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
}
.fluent-large-field fluent-text-field::part(root),
.fluent-large-field fluent-text-area::part(root),
.fluent-large-field fluent-text-field::part(control),
.fluent-large-field fluent-text-area::part(control) {
    width: 100% !important;
    box-sizing: border-box !important;
}
/* Le champ accepte la largeur fournie en attribut HTML ; on l'utilise comme
   2e ceinture pour les versions de FluentUI qui n'exposent pas la part. */
.fluent-large-field fluent-text-field { min-width: 0 !important; }
.fluent-large-field fluent-text-area  { min-width: 0 !important; }

/* (le bloc .filter-bar fusionné est défini plus haut, ligne ~125) */