*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #131316;--bg-secondary: #1a1a1e;--bg-tertiary: #222226;--text-primary: #ffffff;--text-secondary: #a0a0a8;--text-muted: #666670;--border: #2a2a30;--border-light: #333338;--accent: #6366f1;--accent-hover: #5558e6;--status-paid: #3E9B62;--status-paid-bg: rgba(62, 155, 98, .12);--status-pending: #BE851B;--status-pending-bg: rgba(190, 133, 27, .12);--status-late: #CB4A39;--status-late-bg: rgba(203, 74, 57, .12);--status-progress: #3E6FB0;--status-progress-bg: rgba(62, 111, 176, .12);--radius: 8px;--radius-lg: 12px;--sidebar-w: 260px;--topbar-h: 64px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--danger: #ef4444;--danger-hover: #dc2626;color-scheme:dark}[data-theme=light]{--bg-primary: #F3F2EF;--bg-secondary: #ffffff;--bg-tertiary: #f0f0f0;--text-primary: #1a1a1a;--text-secondary: #666666;--text-muted: #999999;--border: #e5e5e5;--border-light: #d5d5d5;--status-paid-bg: rgba(62, 155, 98, .1);--status-pending-bg: rgba(190, 133, 27, .1);--status-late-bg: rgba(203, 74, 57, .1);--status-progress-bg: rgba(62, 111, 176, .1);color-scheme:light}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}.app{display:flex;min-height:100vh}.main{flex:1;display:flex;flex-direction:column;min-width:0}.content{flex:1;padding:24px 32px;overflow-y:auto}.sidebar{width:var(--sidebar-w);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 12px;flex-shrink:0}.brand{display:flex;align-items:center;gap:12px;padding:0 8px 20px;border-bottom:1px solid var(--border);margin-bottom:20px}.brand-mark{width:36px;height:36px;background:var(--accent);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#fff}.brand-name{font-weight:600;font-size:15px}.brand-sub{font-size:12px;color:var(--text-muted)}.nav-group-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:0 12px;margin:16px 0 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);color:var(--text-secondary);text-decoration:none;font-size:14px;transition:all .15s;cursor:pointer}.nav-item svg{width:18px;height:18px;flex-shrink:0}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--accent);color:#fff}.nav-item .tag{margin-left:auto;font-size:10px;padding:2px 6px;border-radius:4px;background:var(--bg-tertiary);color:var(--text-muted)}.nav-spacer{flex:1}.side-user{display:flex;align-items:center;gap:10px;padding:12px 8px;border-top:1px solid var(--border);margin-top:8px}.avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:#fff;flex-shrink:0}.side-user .nm{font-size:13px;font-weight:500}.side-user .rl{font-size:11px;color:var(--text-muted)}.topbar{height:var(--topbar-h);padding:0 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.page-h1{font-size:20px;font-weight:600}.page-sub{font-size:13px;color:var(--text-secondary)}.topbar-actions{display:flex;align-items:center;gap:10px}.search-box{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius);border:1px solid var(--border);color:var(--text-muted);font-size:13px;cursor:pointer;background:var(--bg-tertiary)}.search-box svg{width:16px;height:16px}.search-box:hover{border-color:var(--border-light)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn svg{width:16px;height:16px}.btn:hover{background:var(--bg-tertiary)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-danger{background:transparent;border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s}.icon-btn svg{width:18px;height:18px}.icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;padding:10px 14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.table tbody tr:hover{background:var(--bg-tertiary)}.table tfoot td{padding:12px 14px;border-top:2px solid var(--border);border-bottom:none;font-weight:600;color:var(--text-primary)}.table-wrap{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.rowact{display:flex;gap:6px}.rowact button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s}.rowact button svg{width:15px;height:15px}.rowact button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.rowact button.danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.rowact button:disabled{opacity:.4;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge.paid{background:var(--status-paid-bg);color:var(--status-paid)}.badge.pending{background:var(--status-pending-bg);color:var(--status-pending)}.badge.late{background:var(--status-late-bg);color:var(--status-late)}.badge.progress{background:var(--status-progress-bg);color:var(--status-progress)}.badge.discussion{background:var(--status-pending-bg);color:var(--status-pending)}.badge.estimation_sent,.badge.in_progress{background:var(--status-progress-bg);color:var(--status-progress)}.badge.invoice_paid,.badge.completed{background:var(--status-paid-bg);color:var(--status-paid)}.badge.cancelled{background:var(--status-late-bg);color:var(--status-late)}.badge.estimation{background:var(--status-progress-bg);color:var(--status-progress)}.badge.acompte{background:var(--status-pending-bg);color:var(--status-pending)}.badge.facture,.badge.facture_unique{background:var(--status-paid-bg);color:var(--status-paid)}.form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:500;color:var(--text-secondary)}.field input,.field textarea,.field select{padding:9px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;font-family:var(--font);outline:none;transition:border-color .15s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent)}.field input:disabled,.field textarea:disabled,.field select:disabled{opacity:.6;cursor:not-allowed}.field small{font-size:12px;color:var(--text-muted)}.field-check{display:flex;align-items:center;gap:8px}.field-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.field-check label{font-size:14px;color:var(--text-secondary);cursor:pointer}.summary-block{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:6px;font-size:13px}.summary-row{display:flex;justify-content:space-between;color:var(--text-secondary)}.summary-row.total{border-top:1px solid var(--border);padding-top:8px;margin-top:4px;font-weight:600;color:var(--text-primary)}.form-error{background:var(--status-late-bg);color:var(--status-late);padding:10px 14px;border-radius:var(--radius);font-size:13px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:17px;font-weight:600}.modal-body{padding:24px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:14px}.filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:20px}.filter-bar select{padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;outline:none}.filter-bar select:focus{border-color:var(--accent)}.section-header{font-size:16px;font-weight:600;margin:24px 0 12px;color:var(--text-primary)}.section-header:first-child{margin-top:0}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:8px}.dash-card{display:flex;flex-direction:column;gap:8px;padding:20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);text-decoration:none;color:var(--text-primary);transition:all .15s}.dash-card:hover{border-color:var(--accent);transform:translateY(-1px)}.dash-card svg{width:24px;height:24px;color:var(--accent)}.dash-card .dash-label{font-size:14px;font-weight:500}.dash-card .dash-sub{font-size:12px;color:var(--text-muted)}.amount{text-align:right;font-variant-numeric:tabular-nums}.state-msg{padding:24px;text-align:center;color:var(--text-muted);font-size:14px}.state-msg.error{color:var(--status-late)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.detail-header-info h2{font-size:22px;font-weight:600;margin-bottom:4px}.detail-header-info p{color:var(--text-secondary);font-size:14px}.detail-actions{display:flex;gap:8px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.detail-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.detail-card h3{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);margin-bottom:12px}.detail-card p{font-size:14px;color:var(--text-secondary);margin-bottom:6px}.detail-card p strong{color:var(--text-primary);font-weight:500}.detail-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.detail-card-header h3{margin-bottom:0}.detail-list{list-style:none;padding:0;margin:0}.detail-list li{padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--text-secondary);transition:color .15s}.detail-list li:last-child{border-bottom:none}.detail-list li:hover{color:var(--text-primary)}.detail-list li strong{color:var(--text-primary);font-weight:500}.detail-notes{white-space:pre-wrap;color:var(--text-secondary);font-size:14px;min-height:80px;line-height:1.6}.detail-notes-textarea{width:100%;min-height:160px;padding:12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;font-family:var(--font);line-height:1.6;outline:none;resize:vertical;transition:border-color .15s}.detail-notes-textarea:focus{border-color:var(--accent)}.detail-notes-actions{display:flex;gap:8px;margin-top:12px}.table tbody tr.clickable{cursor:pointer}.btn-mark-paid{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;border:1px solid var(--status-paid);background:transparent;color:var(--status-paid);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-mark-paid:hover{background:var(--status-paid);color:#fff}.btn-mark-paid:disabled{opacity:.5;cursor:not-allowed}
