*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-sans:"DM Sans", sans-serif;--font-mono:"DM Mono", monospace;--bg:#f7f6f3;--surface:#fff;--surface2:#f0efe9;--border:#e2e0d8;--border2:#ccc9bc;--text:#1c1b18;--text2:#5c5a52;--text3:#9c9a90;--accent:#2d6a4f;--accent-bg:#d8f3dc;--accent-lt:#f0faf2;--danger:#c0392b;--danger-bg:#fef2f2;--warn:#d97706;--warn-bg:#fffbeb;--radius-sm:4px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 3px #00000014;--shadow:0 2px 8px #0000001a;--shadow-lg:0 8px 24px #0000001f;--nav-h:56px}html{font-size:15px}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}.app-nav{z-index:50;height:var(--nav-h);background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:0;padding:0 24px;display:flex;position:sticky;top:0}.nav-brand{font-family:var(--font-mono);color:var(--text2);letter-spacing:.02em;white-space:nowrap;margin-right:32px;font-size:13px;font-weight:500}.nav-brand span{color:var(--accent)}.nav-tabs{gap:0;display:flex}.nav-tab{cursor:pointer;font-family:var(--font-sans);color:var(--text3);height:var(--nav-h);background:0 0;border:none;border-bottom:2px solid #0000;padding:0 16px;font-size:14px;transition:color .15s,border-color .15s}.nav-tab:hover{color:var(--text)}.nav-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.page{width:100%;max-width:1200px;margin:0 auto;padding:28px}.page-title{margin-bottom:24px;font-size:22px;font-weight:500}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.card-sm{padding:14px 16px}.metric-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:28px;display:grid}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}.metric-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:6px;font-size:11px;font-weight:500}.metric-value{font-family:var(--font-mono);font-size:24px;font-weight:400}.metric-value.pos{color:var(--accent)}.metric-value.neg{color:var(--danger)}.metric-sub{color:var(--text3);margin-top:4px;font-size:12px}.btn{font-family:var(--font-sans);border-radius:var(--radius);cursor:pointer;border:1px solid var(--border2);background:var(--surface);color:var(--text);white-space:nowrap;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.btn:hover{background:var(--surface2)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:#245c42;border-color:#245c42}.btn-danger{color:var(--danger);border-color:#fca5a5}.btn-danger:hover{background:var(--danger-bg)}.btn-sm{padding:4px 10px;font-size:12px}.btn-icon{border-radius:var(--radius-sm);padding:6px}.form-grid{gap:14px;display:grid}.form-grid-2{grid-template-columns:1fr 1fr}.form-grid-3{grid-template-columns:1fr 1fr 1fr}.field{flex-direction:column;gap:5px;display:flex}.field label{color:var(--text2);font-size:12px;font-weight:500}input,select,textarea{font-family:var(--font-sans);background:var(--surface);color:var(--text);border:1px solid var(--border2);border-radius:var(--radius);outline:none;width:100%;padding:8px 11px;font-size:14px;transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2d6a4f1f}textarea{resize:vertical;min-height:72px}.checkbox-pills{flex-wrap:wrap;gap:8px;display:flex}.checkbox-pill{border:1px solid var(--border2);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:5px;padding:4px 12px;font-size:13px;transition:background .12s,border-color .12s;display:flex}.checkbox-pill input{display:none}.checkbox-pill.checked{border-color:var(--accent);background:var(--accent-lt);color:var(--accent);font-weight:500}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13.5px}thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);background:var(--surface2);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:500}tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 14px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--surface2)}.td-mono{font-family:var(--font-mono);font-size:13px}.td-right{text-align:right}.pos{color:var(--accent)}.neg{color:var(--danger)}.tag{white-space:nowrap;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.tag-banque{color:#1e429f;background:#ebf5ff}.tag-fg{color:#03543f;background:#def7ec}.tag-rm{color:#5521b5;background:#f3e8ff}.tag-flpb{color:#92400e;background:#fffbeb}.tag-membre{color:#9d174d;background:#fce7f3}.tag-cat{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.justif-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.justif-ok{background:var(--accent)}.justif-ko{background:var(--danger)}.justif-na{background:var(--text3)}.modal-overlay{z-index:200;background:#1c1b1880;justify-content:center;align-items:flex-start;padding:48px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:620px;max-width:100%;padding:28px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.modal-header h2{font-size:17px;font-weight:500}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:22px;padding-top:18px;display:flex}.filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px;padding:14px 16px;display:flex}.filter-bar .field{flex:1;min-width:140px}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.toast-wrap{z-index:999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--text);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:10px 16px;font-size:13px;animation:.2s slideIn}.toast.error{background:var(--danger)}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:none}}.empty{text-align:center;color:var(--text3);padding:60px 20px;font-size:14px}.empty-icon{opacity:.4;margin-bottom:12px;font-size:32px}.loader{justify-content:center;align-items:center;padding:60px;display:flex}.spinner{border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.solde-bar{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:28px;display:grid}.solde-card{border-radius:var(--radius-lg);border:1px solid #0000;padding:16px 18px}.solde-card .s-label{text-transform:uppercase;letter-spacing:.07em;opacity:.75;margin-bottom:8px;font-size:11px;font-weight:500}.solde-card .s-value{font-family:var(--font-mono);font-size:22px}.chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.divider{background:var(--border);height:1px;margin:20px 0}.text-sm{font-size:12px}.text-muted{color:var(--text3)}.gap-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}@media (width<=640px){.form-grid-2,.form-grid-3{grid-template-columns:1fr}.page{padding:16px}.modal{padding:20px}}
