:root{--color-primary:#c4762a;--color-secondary:#2c3e2d;--color-accent:#4a9b6f;--color-debit:#b94040;--color-bg:#f5f0e8;--color-surface:#fdfaf4;--color-row-alt:#ede8dc;--color-border:#ddd7c8;--color-text:#2c3e2d;--color-text-muted:#6b6455;--color-text-light:#9c9080;--font-heading:"Zilla Slab", serif;--font-body:"Source Serif 4", serif;--radius:4px;--sidebar-width:220px}.dark{--color-bg:#1c2420;--color-surface:#252e27;--color-row-alt:#2e3830;--color-border:#3a4a3c;--color-text:#ede8dc;--color-text-muted:#a8a090;--color-text-light:#7a7268}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{font-family:var(--font-body);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;line-height:1.6}h1,h2,h3,h4{font-family:var(--font-heading);color:var(--color-secondary);line-height:1.2}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}input,select,textarea{font-family:var(--font-body)}.amount-positive{color:var(--color-accent)}.amount-negative{color:var(--color-debit)}.amount-zero{color:var(--color-primary)}.text-muted{color:var(--color-text-muted)}.text-small{font-size:.8rem}.text-upper{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;font-weight:600}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);background:var(--color-bg);flex:1;min-height:100vh;padding:32px 32px 48px}@media (width<=768px){.main-content{margin-left:0;padding:16px 16px 80px}}.card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);padding:20px 24px}.btn{border-radius:var(--radius);border:1.5px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:opacity .15s,background .15s;display:inline-flex}.btn:hover{opacity:.88}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-accent{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-debit{background:var(--color-debit);color:#fff;border-color:var(--color-debit)}.btn-outline{color:var(--color-text);border-color:var(--color-border);background:0 0}.btn-ghost{color:var(--color-text-muted);background:0 0;border-color:#0000}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);font-size:.78rem;font-weight:600}.form-input{border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);padding:8px 12px;font-size:.9rem;transition:border-color .15s}.form-input:focus{border-color:var(--color-primary);outline:none}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table thead th{text-align:left;background:var(--color-row-alt);font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);border-bottom:1.5px solid var(--color-border);padding:10px 14px;font-size:.72rem;font-weight:600}.data-table thead th:last-child{text-align:right}.data-table tbody tr{border-bottom:1px solid var(--color-border);transition:background .1s}.data-table tbody tr:hover,.data-table tbody tr:nth-child(2n){background:var(--color-row-alt)}.data-table tbody tr:nth-child(2n):hover{background:var(--color-border)}.data-table tbody td{vertical-align:middle;padding:11px 14px}.data-table tbody td:last-child{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.badge{text-transform:uppercase;letter-spacing:.06em;border-radius:2px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-encaissement{color:var(--color-accent);background:#e8f4ee}.badge-depense{color:var(--color-debit);background:#f4e8e8}.toast{background:var(--color-secondary);color:#ede8dc;border-radius:var(--radius);z-index:1000;padding:12px 20px;font-size:.875rem;animation:.2s slideIn;position:fixed;bottom:24px;right:24px}@keyframes slideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-header h1{font-size:1.75rem;font-weight:700}.page-header p{color:var(--color-text-muted);margin-top:3px;font-size:.875rem}.kpi-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;display:grid}@media (width<=640px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);padding:20px 22px}.kpi-card .kpi-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:6px;font-size:.72rem;font-weight:600}.kpi-card .kpi-value{font-family:var(--font-heading);font-variant-numeric:tabular-nums;font-size:1.9rem;font-weight:700;line-height:1}.kpi-card .kpi-sub{color:var(--color-text-muted);margin-top:5px;font-size:.78rem}.modal-overlay{z-index:500;background:#2c3e2d73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);width:100%;max-width:480px;max-height:90vh;padding:28px 32px;overflow-y:auto}.modal h2{margin-bottom:20px;font-size:1.25rem}.modal-actions{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.empty-state{text-align:center;color:var(--color-text-muted);padding:48px 24px}.empty-state svg{opacity:.4;margin:0 auto 16px}.empty-state p{max-width:380px;margin:0 auto;font-size:.9rem;line-height:1.7}
