:root{--bg: #F3F4F6;--surface: #FFFFFF;--surface2: #F9FAFB;--border: #E5E7EB;--border2: #D1D5DB;--text: #111827;--text2: #6B7280;--text3: #9CA3AF;--accent: #F0A500;--accent2: #FBD038;--green: #16A34A;--red: #DC2626;--blue: #2563EB;--purple: #7C3AED;--orange: #F0A500;--sidebar: 220px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}#root{height:100%;display:flex}body{font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);font-size:14px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:transparent;border-radius:20px;transition:background .3s}*:hover>::-webkit-scrollbar-thumb,:hover::-webkit-scrollbar-thumb{background:#0000001f}::-webkit-scrollbar-thumb:hover{background:#00000038}::-webkit-scrollbar-corner{background:transparent}*{scrollbar-width:thin;scrollbar-color:transparent transparent}*:hover{scrollbar-color:rgba(0,0,0,.12) transparent}.sidebar{width:var(--sidebar);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh}.sb-logo{padding:20px 18px 16px;border-bottom:1px solid var(--border)}.sb-logo-mark{display:flex;align-items:center;gap:10px}.sb-logo-icon{width:34px;height:34px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:Arial,Helvetica,sans-serif;font-weight:500;font-size:.75rem;color:#000;letter-spacing:-.03em}.sb-logo-img{width:34px;height:34px;object-fit:contain;border-radius:8px}.sb-logo-text{font-weight:800;font-size:1rem;letter-spacing:-.02em}.sb-logo-sub{font-size:.68rem;color:var(--text3);margin-top:1px;font-family:Arial,Helvetica,sans-serif}.sb-role{margin:12px 12px 6px;background:#f0a50014;border:1px solid rgba(240,165,0,.18);border-radius:8px;padding:8px 12px}.sb-role-label{font-size:.65rem;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}.sb-role-name{font-size:.82rem;font-weight:700;color:var(--accent)}.sb-nav{flex:1;padding:8px 0;overflow-y:auto;overscroll-behavior:contain}.sb-section{padding:6px 12px 2px;font-size:.65rem;color:var(--text3);text-transform:uppercase;letter-spacing:.1em}.sb-item{display:flex;align-items:center;gap:10px;padding:8px 18px;cursor:pointer;color:var(--text2);font-size:.85rem;font-weight:500;transition:all .15s;position:relative;border:none;background:none;width:100%;text-align:left;font-family:Arial,Helvetica,sans-serif}.sb-item:hover{color:var(--text);background:#0000000a}.sb-item.active{color:var(--text);background:#f0a50014}.sb-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.sb-item .icon{width:16px;height:16px;opacity:.6;flex-shrink:0}.sb-item.active .icon{opacity:1}.sb-badge{margin-left:auto;background:var(--red);color:#fff;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:10px;font-family:Arial,Helvetica,sans-serif}.sb-badge.amber{background:#f0a50026;color:var(--accent)}.sb-footer{padding:12px;border-top:1px solid var(--border)}.sb-user{display:flex;align-items:center;gap:10px}.sb-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#215fa9,#f0a500);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0;color:#fff}.sb-user-info{min-width:0}.sb-user-name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user-role{font-size:.7rem;color:var(--text3)}.main{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden}.topbar{height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.topbar-title{font-weight:800;font-size:1.05rem;letter-spacing:-.02em}.topbar-actions{display:flex;align-items:center;gap:10px}.content{flex:1;padding:24px;overflow-y:auto;overscroll-behavior:contain;scroll-behavior:smooth}.page-header{margin-bottom:20px}.page-title{font-size:1.1rem;font-weight:800;letter-spacing:-.02em}.page-sub{font-size:.82rem;color:var(--text2);margin-top:4px}.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.stat-card.alert{border-color:#dc26264d;background:#dc26260a}.stat-card.warn{border-color:#f0a5004d;background:#f0a5000a}.stat-val{font-family:Arial,Helvetica,sans-serif;font-size:1.8rem;font-weight:700;line-height:1;margin-bottom:4px}.stat-val.red{color:var(--red)}.stat-val.amber{color:var(--accent)}.stat-val.green{color:var(--green)}.stat-label{font-size:.75rem;color:var(--text3);font-weight:500}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.search-box{flex:1;min-width:200px;max-width:320px;background:var(--surface);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;gap:8px;padding:0 12px;height:36px}.search-box input{background:none;border:none;outline:none;color:var(--text);font-size:.85rem;width:100%;font-family:Arial,Helvetica,sans-serif}.search-box input::placeholder{color:var(--text3)}.filter-btn{height:36px;padding:0 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:Arial,Helvetica,sans-serif;display:flex;align-items:center;gap:6px}.filter-btn:hover{border-color:var(--border2);color:var(--text)}.filter-btn.active{border-color:var(--accent);color:var(--accent);background:#f0a5000f}.btn-primary{height:36px;padding:0 16px;border-radius:8px;border:none;background:var(--accent);color:#000;font-size:.85rem;font-weight:700;cursor:pointer;font-family:Arial,Helvetica,sans-serif;display:flex;align-items:center;gap:6px;transition:all .15s}.btn-primary:hover{background:var(--accent2)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{height:32px;padding:0 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);font-size:.8rem;font-weight:600;cursor:pointer;font-family:Arial,Helvetica,sans-serif;display:inline-flex;align-items:center;gap:6px;transition:all .15s}.btn-secondary:hover{border-color:var(--border2);color:var(--text);background:var(--surface)}.btn-secondary:disabled{opacity:.45;cursor:not-allowed}.loading-center{color:var(--text3);text-align:center;padding-top:40px}.btn-action{height:30px;padding:0 12px;border-radius:6px;border:none;font-size:.75rem;font-weight:600;cursor:pointer;font-family:Arial,Helvetica,sans-serif;display:inline-flex;align-items:center;gap:6px;transition:background .15s,box-shadow .15s,opacity .15s;box-shadow:0 1px 2px #00000014;letter-spacing:.01em;white-space:nowrap;line-height:1}.btn-action:hover{box-shadow:0 2px 6px #00000024}.btn-action:active{box-shadow:inset 0 1px 2px #0000001f}.btn-action:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-action.a-transfer{background:#3b82f6;color:#fff}.btn-action.a-transfer:hover{background:#2563eb}.btn-action.a-devis{background:#7c3aed;color:#fff}.btn-action.a-devis:hover{background:#6d28d9}.btn-action.a-reduction{background:#f59e0b;color:#1a1a1a}.btn-action.a-reduction:hover{background:#d97706}.btn-action.a-proforma{background:#10b981;color:#fff}.btn-action.a-proforma:hover{background:#059669}.btn-action.a-payment{background:#0891b2;color:#fff}.btn-action.a-payment:hover{background:#0e7490}.btn-action.a-danger{background:#ef4444;color:#fff}.btn-action.a-danger:hover{background:#dc2626}.btn-action.a-success{background:#22c55e;color:#fff}.btn-action.a-success:hover{background:#16a34a}.btn-action.a-pause{background:#f97316;color:#fff}.btn-action.a-pause:hover{background:#ea580c}.btn-action.a-decide{background:#a855f7;color:#fff}.btn-action.a-decide:hover{background:#9333ea}.btn-action.a-ghost{background:var(--surface);color:var(--text2);border:1px solid var(--border);box-shadow:none}.btn-action.a-ghost:hover{border-color:var(--border2);color:var(--text);background:var(--surface2);box-shadow:0 1px 3px #0000000f}.btn-icon-sm{width:26px;height:26px;padding:0;border-radius:5px;border:1px solid var(--border);background:var(--surface);color:var(--text3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s,background .15s}.btn-icon-sm:hover{border-color:var(--accent);color:var(--accent);background:#f0a5000f}.btn-icon-sm.btn-icon-danger:hover{border-color:#e53e3e;color:#e53e3e;background:#e53e3e14}.btn-icon-sm.btn-icon-danger:disabled{opacity:.5;cursor:not-allowed}.btn-csv{height:28px;padding:0 10px;border-radius:5px;border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:.72rem;font-weight:600;cursor:pointer;font-family:Arial,Helvetica,sans-serif;display:inline-flex;align-items:center;gap:6px;transition:all .15s}.btn-csv:hover{border-color:#22c55e;color:#22c55e;background:#22c55e0f}.section-title-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-badge{background:var(--surface2);color:var(--text3);font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px;min-width:20px;text-align:center}.upload-zone{border:1.5px dashed var(--border2);border-radius:8px;padding:14px 16px;margin-top:12px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;transition:border-color .15s,background .15s}.upload-zone:hover{border-color:var(--accent);background:#f0a50008}.upload-zone input[type=file]{display:none}.upload-zone-label{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 12px;border-radius:5px;background:var(--surface2);color:var(--text2);font-size:.73rem;font-weight:600;cursor:pointer;border:1px solid var(--border);transition:border-color .15s,color .15s}.upload-zone-label:hover{border-color:var(--accent);color:var(--accent)}.upload-zone-hint{font-size:.7rem;color:var(--text3)}.upload-zone-files{display:flex;flex-wrap:wrap;gap:6px;width:100%;padding-top:4px}.upload-zone-file{display:inline-flex;align-items:center;gap:4px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:.68rem;color:var(--text2)}.upload-zone-file button{background:none;border:none;cursor:pointer;color:var(--text3);font-size:.72rem;padding:0 2px;line-height:1}.upload-zone-file button:hover{color:#ef4444}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}thead th{padding:10px 16px;text-align:left;font-size:.72rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);background:var(--surface2)}tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#00000005}tbody td{padding:12px 16px;font-size:.85rem}.td-client strong{font-weight:700;display:block;margin-bottom:1px}.td-client span{font-size:.75rem;color:var(--text3)}.td-objet{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text2)}.td-montant{font-family:Arial,Helvetica,sans-serif;font-weight:600;font-size:.82rem}.status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;white-space:nowrap}.status:before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0}.s-brouillon{background:#9ca3af1f;color:#6b7280}.s-brouillon:before{background:#6b7280}.s-transmis{background:#2563eb1a;color:var(--blue)}.s-transmis:before{background:var(--blue)}.s-manquant{background:#dc26261a;color:var(--red)}.s-manquant:before{background:var(--red)}.s-preparation{background:#f0a5001a;color:var(--accent)}.s-preparation:before{background:var(--accent)}.s-devis{background:#16a34a1a;color:var(--green)}.s-devis:before{background:var(--green)}.s-proforma{background:#7c3aed1a;color:var(--purple)}.s-proforma:before{background:var(--purple)}.s-paiement{background:#16a34a1f;color:var(--green);border:1px solid rgba(22,163,74,.25)}.s-paiement:before{background:var(--green)}.s-autorise{background:#16a34a2e;color:#15803d;border:1px solid rgba(22,163,74,.35);font-weight:800}.s-autorise:before{background:#15803d}.s-cloture{background:#9ca3af14;color:var(--text3)}.s-cloture:before{background:var(--text3)}.timer{font-family:Arial,Helvetica,sans-serif;font-size:.78rem;font-weight:700;padding:3px 9px;border-radius:6px}.timer.ok{background:#16a34a1a;color:var(--green)}.timer.warn{background:#f0a5001a;color:var(--accent)}.timer.late{background:#dc26261a;color:var(--red);animation:blink 1.5s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.timer.na{background:transparent;color:var(--text3);font-weight:400}.tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:700;font-family:Arial,Helvetica,sans-serif}.tag-commercial{background:#2563eb1a;color:var(--blue)}.tag-exploitation{background:#f0a5001a;color:var(--accent)}.tag-admin{background:#7c3aed1a;color:var(--purple)}.tag-dg{background:#dc26261a;color:var(--red)}.notif-dot{width:8px;height:8px;background:var(--red);border-radius:50%;flex-shrink:0;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.analytics-row{display:flex;gap:16px;margin-top:24px}.analytics-card{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px}.analytics-card h3{font-size:.75rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}.health-gauge{display:flex;align-items:center;justify-content:center;padding:8px 0}.trend-chart{display:flex;align-items:flex-end;gap:8px;height:120px}.trend-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.trend-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.trend-bar{width:70%;min-height:4px;background:var(--accent);border-radius:4px 4px 0 0;transition:height .3s}.trend-val{font-family:Arial,Helvetica,sans-serif;font-size:.7rem;font-weight:700;color:var(--text)}.trend-label{font-size:.65rem;color:var(--text3);font-weight:500}.bars-list{display:flex;flex-direction:column;gap:12px}.bar-row-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.bar-row-label{font-size:.78rem;font-weight:600;color:var(--text2)}.bar-row-val{font-family:Arial,Helvetica,sans-serif;font-size:.78rem;font-weight:700;color:var(--text)}.bar-track{height:8px;background:var(--surface2);border-radius:4px;overflow:hidden;border:1px solid var(--border)}.bar-fill{height:100%;border-radius:4px;transition:width .4s}.form-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px}.form-section-title{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.alert-error{background:#dc262614;border:1px solid rgba(220,38,38,.2);border-radius:8px;padding:8px 12px;font-size:.82rem;color:var(--red)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px}.detail-card-title{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--surface2)}.detail-label{font-size:.78rem;color:var(--text3);font-weight:500}.detail-value{font-size:.85rem;font-weight:600}.action-grid{display:flex;flex-wrap:wrap;gap:10px}.empty-text{font-size:.85rem;color:var(--text3)}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:12px;padding:10px 0;position:relative}.timeline-item:not(:last-child):after{content:"";position:absolute;left:5px;top:28px;bottom:0;width:1px;background:var(--border)}.timeline-dot{width:11px;height:11px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:3px}.timeline-content{flex:1}.timeline-event{font-size:.82rem;font-weight:600;color:var(--text)}.timeline-detail{font-size:.78rem;color:var(--text2);margin-top:2px}.timeline-meta{font-size:.7rem;color:var(--text3);margin-top:4px}.kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;min-height:calc(100vh - 200px);overscroll-behavior-x:contain}.kanban-col{min-width:220px;flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;max-height:calc(100vh - 200px)}.kanban-col-header{display:flex;align-items:center;gap:8px;padding:12px 14px;font-size:.82rem;font-weight:700;border-bottom:1px solid var(--border)}.kanban-dot{width:8px;height:8px;border-radius:50%}.kanban-dot--brouillon{background:var(--text3)}.kanban-dot--transmis_exploitation{background:var(--blue)}.kanban-dot--preparation_devis{background:var(--accent)}.kanban-dot--devis_pret{background:var(--green)}.kanban-dot--proforma_emise{background:var(--purple)}.kanban-dot--paiement_confirme{background:var(--green)}.kanban-count{margin-left:auto;font-family:Arial,Helvetica,sans-serif;font-size:.7rem;font-weight:700;background:#0000000f;padding:2px 6px;border-radius:8px;color:var(--text2)}.kanban-cards{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px;overscroll-behavior:contain}.kanban-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px;cursor:pointer;transition:box-shadow .15s}.kanban-card:hover{box-shadow:0 2px 8px #00000014}.kanban-card-ref{font-family:Arial,Helvetica,sans-serif;font-size:.72rem;font-weight:700;color:var(--text3);margin-bottom:4px}.kanban-card-title{font-size:.82rem;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kanban-card-client{font-size:.75rem;color:var(--text2);margin-bottom:8px}.kanban-card-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.kanban-card-assign{font-size:.7rem;color:var(--text3)}.kanban-card-actions{display:flex;gap:4px;margin-top:6px}.kanban-move-btn{font-size:.65rem;padding:2px 6px;border:1px solid var(--border);border-radius:4px;background:var(--surface2);cursor:pointer;color:var(--text2);font-family:Arial,Helvetica,sans-serif}.kanban-move-btn:hover{border-color:var(--accent);color:var(--accent)}.kanban-empty{text-align:center;padding:20px;font-size:.78rem;color:var(--text3)}.kanban-page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.kanban-flux-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:.78rem;font-weight:600;border:1px solid var(--border);border-radius:8px;background:var(--surface2);color:var(--text2);cursor:pointer;transition:all .15s;font-family:Arial,Helvetica,sans-serif}.kanban-flux-toggle:hover{border-color:var(--accent);color:var(--accent);background:#f0a5000d}.kanban-flux-toggle.active{background:#f0a50014;color:var(--accent);border-color:#f0a50066}.kanban-flux-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:16px;overflow-x:auto}.kanban-flux-title{font-size:.78rem;font-weight:700;color:var(--text2);margin-bottom:12px;display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.04em}.kanban-flux-clock-icon{opacity:.65}.kanban-flux-track{display:flex;gap:0;overflow-x:auto;padding-bottom:2px;overscroll-behavior-x:contain}.kanban-flux-item{display:flex;flex-direction:column;align-items:center;min-width:140px;position:relative;padding:0 12px}.kanban-flux-item:not(:last-child):after{content:"";position:absolute;right:0;top:14px;width:1px;height:20px;background:var(--border)}.kanban-flux-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--surface);box-shadow:0 0 0 2px var(--accent);margin-bottom:6px;flex-shrink:0}.kanban-flux-content{display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}.kanban-flux-ref{font-size:.75rem;font-weight:700;font-family:Arial,Helvetica,sans-serif;color:var(--text2)}.kanban-flux-ref.clickable{color:var(--blue);cursor:pointer;text-decoration:underline}.kanban-flux-ref.clickable:hover{color:var(--accent)}.kanban-flux-arrow{font-size:.65rem;color:var(--text3)}.kanban-flux-col{font-size:.72rem;color:var(--text);font-weight:600}.kanban-flux-user{font-size:.68rem;color:var(--text3);margin-top:2px}.kanban-flux-time{font-size:.65rem;color:var(--text3);margin-top:4px;font-style:italic}.btn-icon-inline{vertical-align:-1px}.pipe-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:0;margin-bottom:12px;overflow:hidden}.pipeline-stage{display:grid;grid-template-columns:200px 1fr 140px;align-items:center;gap:14px;padding:14px 18px}.pipeline-stage-name{font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:8px}.pipe-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pipeline-stage-count{font-size:.72rem;color:var(--text3);margin-top:2px;display:block}.pipeline-bar-wrap{height:28px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;overflow:hidden}.pipeline-bar{height:100%;border-radius:6px;transition:width .4s}.pipeline-amount{font-family:Arial,Helvetica,sans-serif;font-size:.82rem;font-weight:700;text-align:right}.pipe-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:8px 18px;border:none;border-top:1px solid var(--border);background:var(--surface2);color:var(--text2);font-size:.75rem;font-weight:600;cursor:pointer;font-family:Arial,Helvetica,sans-serif;transition:background .12s}.pipe-toggle:hover{background:#0000000a;color:var(--text)}.pipe-items{border-top:1px solid var(--border)}.pipe-item{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid var(--surface2);transition:background .1s}.pipe-item:last-child{border-bottom:none}.pipe-item:hover{background:#00000005}.pipe-item-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.pipe-item-ref{font-family:Arial,Helvetica,sans-serif;font-size:.72rem;font-weight:700;color:var(--text3);flex-shrink:0;width:80px}.pipe-item-title{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.pipe-item-client{font-size:.75rem;color:var(--text2);flex-shrink:0}.pipe-item-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.pipe-item-amount{font-family:Arial,Helvetica,sans-serif;font-size:.78rem;font-weight:700;color:var(--text);min-width:100px;text-align:right}.pipe-recent-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px;position:sticky;top:24px}.pipe-recent-title{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.pipe-moves{display:flex;flex-direction:column;gap:0}.pipe-move{display:flex;gap:10px;padding:8px 0;position:relative}.pipe-move:not(:last-child):after{content:"";position:absolute;left:4px;top:22px;bottom:0;width:1px;background:var(--border)}.pipe-move-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:3px}.pipe-move-content{flex:1;min-width:0}.pipe-move-ref{font-size:.78rem;font-weight:600;color:var(--text)}.pipe-move-user{font-size:.72rem;color:var(--text2);margin-top:1px}.pipe-move-time{font-size:.65rem;color:var(--text3);margin-top:2px}.todo-list{display:flex;flex-direction:column;gap:6px}.todo-item{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;transition:all .12s}.todo-item.done{opacity:.5}.todo-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--border2);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--green);flex-shrink:0;font-family:Arial,Helvetica,sans-serif}.todo-check.checked{background:var(--green);color:#fff;border-color:var(--green)}.todo-content{flex:1;min-width:0}.todo-title{font-size:.85rem;font-weight:600}.todo-item.done .todo-title{text-decoration:line-through}.todo-desc{font-size:.78rem;color:var(--text2);margin-top:2px}.todo-priority{font-size:.72rem;font-weight:700;text-transform:uppercase;font-family:Arial,Helvetica,sans-serif}.todo-due{font-size:.72rem;color:var(--text3);font-family:Arial,Helvetica,sans-serif}.todo-delete{background:none;border:none;font-size:.85rem;color:var(--text3);cursor:pointer;padding:2px 6px}.todo-delete:hover{color:var(--red)}.agenda-header-row{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:10px}.agenda-period-tabs{display:flex;gap:4px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:3px}.agenda-period-tab{padding:5px 14px;font-size:.78rem;font-weight:600;border:none;border-radius:8px;background:transparent;color:var(--text2);cursor:pointer;transition:all .15s;font-family:Arial,Helvetica,sans-serif}.agenda-period-tab:hover{color:var(--text)}.agenda-period-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #0000001a}.agenda-cal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px}.agenda-cal-month-label{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:12px;text-transform:capitalize}.agenda-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.agenda-cal-day-header{font-size:.68rem;font-weight:700;color:var(--text3);text-align:center;padding:2px 0}.agenda-cal-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.78rem;border-radius:8px;color:var(--text2);position:relative}.agenda-cal-day{cursor:default;transition:background .1s}.agenda-cal-day:hover{background:var(--surface2)}.agenda-cal-day.today{background:var(--accent);color:#000;font-weight:700}.agenda-cal-day.has-events{color:var(--text);font-weight:600}.agenda-cal-dot{position:absolute;bottom:3px;width:4px;height:4px;border-radius:50%;background:var(--red)}.agenda-cal-day.today .agenda-cal-dot{background:#000}.agenda-list{display:flex;flex-direction:column;gap:20px}.agenda-day-events{display:flex;flex-direction:column;gap:8px}.agenda-date{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);text-transform:capitalize}.agenda-event-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:8px;padding:12px 14px;transition:box-shadow .12s}.agenda-event-card:hover{box-shadow:0 2px 8px #00000012}.agenda-event-card--clickable{cursor:pointer}.agenda-event-card[data-type=sla_due]{border-left-color:var(--red)}.agenda-event-card[data-type=proforma_due]{border-left-color:var(--green)}.agenda-event-card[data-type=meeting]{border-left-color:var(--blue)}.agenda-event-card[data-type=follow_up]{border-left-color:var(--accent)}.agenda-event-card[data-type=payment_due]{border-left-color:var(--purple)}.agenda-event-type-badge[data-type=sla_due]{background:#dc262617;color:var(--red);border:1px solid rgba(220,38,38,.25)}.agenda-event-type-badge[data-type=proforma_due]{background:#16a34a17;color:var(--green);border:1px solid rgba(22,163,74,.25)}.agenda-event-type-badge[data-type=meeting]{background:#2563eb17;color:var(--blue);border:1px solid rgba(37,99,235,.25)}.agenda-event-type-badge[data-type=follow_up]{background:#f0a50017;color:var(--accent);border:1px solid rgba(240,165,0,.25)}.agenda-event-type-badge[data-type=payment_due]{background:#7c3aed17;color:var(--purple);border:1px solid rgba(124,58,237,.25)}.agenda-event-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:5px}.agenda-event-type-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:20px}.agenda-event-time{font-size:.72rem;color:var(--text3);font-family:Arial,Helvetica,sans-serif}.agenda-event-title-main{font-size:.85rem;font-weight:600;color:var(--text);margin-bottom:6px}.agenda-event-meta-row{display:flex;flex-wrap:wrap;gap:6px}.agenda-meta-chip{font-size:.7rem;color:var(--text2);background:var(--surface2);border:1px solid var(--border);padding:1px 8px;border-radius:20px;display:inline-flex;align-items:center;gap:4px}.agenda-meta-chip--ref{font-family:Arial,Helvetica,sans-serif;font-weight:700;color:var(--blue);background:#2563eb0f;border-color:#2563eb33}.agenda-meta-chip--status{color:var(--text3);font-style:italic}.agenda-event{display:flex;align-items:flex-start;gap:10px;padding:8px 0}.agenda-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}.agenda-event-content{flex:1}.agenda-event-title{font-size:.85rem;font-weight:600}.agenda-event-meta{font-size:.75rem;color:var(--text3);margin-top:2px}.error-box{text-align:center;padding:40px 20px}.error-box-msg{color:var(--red);margin-bottom:12px;font-size:.9rem;font-weight:600}.notif-list{display:flex;flex-direction:column;gap:6px}.notif-item{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px;transition:background .12s}.notif-item:hover{background:var(--surface2)}.notif-item.unread{border-left:3px solid var(--accent)}.notif-item--info.unread{border-left-color:var(--blue)}.notif-item--warning.unread{border-left-color:var(--accent)}.notif-item--danger.unread{border-left-color:var(--red)}.notif-item--clickable{cursor:pointer}.notif-badge-type--info{background:#2563eb14;color:var(--blue);border:1px solid rgba(37,99,235,.25)}.notif-badge-type--warning{background:#f0a50014;color:var(--accent);border:1px solid rgba(240,165,0,.25)}.notif-badge-type--danger{background:#dc262614;color:var(--red);border:1px solid rgba(220,38,38,.25)}.notif-icon{font-size:1.2rem;flex-shrink:0;line-height:1}.notif-content{flex:1;min-width:0}.notif-title{font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.notif-body{font-size:.78rem;color:var(--text2);margin-top:3px}.notif-time{font-size:.7rem;color:var(--text3);margin-top:4px}.notif-dismiss-btn{background:none;border:none;cursor:pointer;color:var(--text3);font-size:.8rem;padding:2px 6px;border-radius:4px;transition:all .12s;flex-shrink:0;align-self:flex-start}.notif-dismiss-btn:hover{color:var(--red);background:#dc26260f}.notif-action-link{font-size:.72rem;color:var(--blue);text-decoration:underline;cursor:pointer;margin-top:6px;display:inline-block}.notif-header-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.notif-header-actions{display:flex;gap:8px}.notif-badge-type{font-size:.68rem;font-weight:700;padding:1px 7px;border-radius:20px}.notif-badge-count{font-size:.68rem;font-weight:800;padding:1px 7px;border-radius:20px;background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.notif-empty-icon{margin-bottom:10px;opacity:.4;display:block;margin-left:auto;margin-right:auto}.notif-stat-urgent{color:var(--red);font-weight:600;margin-right:10px}.notif-stat-warning{color:var(--accent);font-weight:600;margin-right:10px}.notif-stat-ok{color:var(--text3)}.notif-sub-row{margin-top:2px}.chat-layout{display:flex;gap:0;height:calc(100vh - 140px);background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.chat-threads{width:280px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overscroll-behavior:contain}.chat-threads-header{padding:14px 16px;font-weight:700;font-size:.85rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.chat-new-conv-btn{background:var(--surface2);border:1px solid var(--border);border-radius:6px;cursor:pointer;padding:3px 6px;color:var(--text2);display:flex;align-items:center;transition:all .12s}.chat-new-conv-btn:hover{background:var(--accent);color:#000;border-color:var(--accent)}.chat-new-conv-panel{border-bottom:1px solid var(--border);background:var(--surface2);padding-bottom:6px}.chat-new-conv-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 4px;font-size:.8rem;font-weight:600;color:var(--text2)}.chat-new-conv-close{background:none;border:none;cursor:pointer;color:var(--text3);font-size:.8rem;padding:2px 4px;border-radius:4px;transition:color .12s}.chat-new-conv-close:hover{color:var(--red)}.chat-thread-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--surface2);transition:background .12s}.chat-thread-item:hover{background:var(--surface2)}.chat-thread-item.active{background:#f0a5000f}.chat-thread-name{font-size:.82rem;font-weight:600;display:flex;align-items:center;justify-content:space-between}.chat-thread-name-text{display:flex;align-items:center;gap:6px}.chat-thread-preview{font-size:.75rem;color:var(--text3);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-online-dot{display:inline-block;width:8px;height:8px;background:var(--green);border-radius:50%;flex-shrink:0}.chat-messages{flex:1;display:flex;flex-direction:column}.chat-messages-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface2)}.chat-messages-header-name{font-weight:700;font-size:.88rem;display:flex;align-items:center;gap:8px}.chat-presence-label{font-size:.72rem;color:var(--text3)}.chat-presence-label.online{color:var(--green);font-weight:600}.chat-messages-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;overscroll-behavior:contain}.chat-bubble{max-width:70%;padding:10px 14px;border-radius:12px;font-size:.85rem}.chat-bubble.mine{align-self:flex-end;background:var(--accent);color:#000;border-bottom-right-radius:4px}.chat-bubble.theirs{align-self:flex-start;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-bubble-sender{font-size:.72rem;font-weight:700;color:var(--blue);margin-bottom:3px}.chat-bubble-text{line-height:1.4}.chat-bubble-time{font-size:.65rem;opacity:.6;margin-top:4px;text-align:right}.chat-typing-indicator{align-self:flex-start;display:flex;align-items:center;gap:4px;padding:8px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:12px 12px 12px 4px}.chat-typing-dot{width:6px;height:6px;background:var(--text3);border-radius:50%;animation:typingBounce 1.2s infinite ease-in-out}.chat-typing-dot:nth-child(2){animation-delay:.2s}.chat-typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.chat-typing-label{font-size:.72rem;color:var(--text3);margin-left:6px;font-style:italic}.chat-input-bar{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:10px}.chat-input{flex:1;height:38px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:0 12px;color:var(--text);font-family:Arial,Helvetica,sans-serif;font-size:.85rem;outline:none}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-new-conv-search{display:block;margin:6px 8px;width:calc(100% - 16px);height:32px;font-size:.8rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:0 10px;color:var(--text);font-family:Arial,Helvetica,sans-serif;outline:none}.chat-new-conv-hint{padding:8px 12px;color:var(--text3);font-size:.8rem}.chat-error-box{padding:16px}.chat-error-msg{color:var(--red);font-size:.82rem;margin-bottom:8px}.chat-empty-threads{padding:16px;color:var(--text3);font-size:.85rem}.chat-empty-messages{text-align:center;color:var(--text3);font-size:.82rem;padding:20px 0}.chat-selected-users{display:flex;flex-wrap:wrap;gap:4px;padding:6px 8px;border-bottom:1px solid var(--border)}.chat-user-pill{display:inline-flex;align-items:center;gap:4px;background:var(--accent);color:#000;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:20px}.chat-user-pill button{background:none;border:none;cursor:pointer;font-size:.7rem;padding:0;line-height:1;color:inherit}.chat-conv-user-list{overflow-y:auto;max-height:210px}.chat-conv-user-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;transition:background .12s}.chat-conv-user-item:hover{background:var(--surface)}.chat-conv-user-item.selected{background:#f0a50014}.chat-conv-user-info{display:flex;align-items:center;gap:6px}.chat-conv-user-name{font-size:.82rem;font-weight:600;display:block}.chat-conv-user-email{font-size:.72rem;color:var(--text3)}.chat-conv-start-wrap{padding:8px;border-top:1px solid var(--border)}.chat-conv-start-btn{width:100%}.chat-group-icon{color:var(--blue, #3b82f6);display:inline-flex;align-items:center;vertical-align:middle;margin-right:3px}.chat-group-icon--header{margin-right:6px}.chat-conv-check-icon{color:var(--accent);flex-shrink:0}.chat-header-participants{font-size:.72rem;color:var(--text3);margin-top:2px}.empty-state{text-align:center;padding:40px 20px;color:var(--text3);font-size:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:12px}.sb-logout{margin-left:auto;background:none;border:1px solid var(--border);border-radius:8px;padding:6px;cursor:pointer;color:var(--text3);display:flex;align-items:center;justify-content:center;transition:all .15s}.sb-logout:hover{color:var(--red);border-color:var(--red);background:#dc26260f}.hamburger-btn{display:none;background:none;border:none;cursor:pointer;color:var(--text);padding:4px;margin-right:8px;flex-shrink:0;border-radius:6px;transition:background .15s}.hamburger-btn:hover{background:#0000000f}.sidebar-backdrop{display:none}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast-item{pointer-events:auto;display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:10px;font-size:.85rem;font-weight:600;background:var(--surface);border:1px solid var(--border);box-shadow:0 4px 20px #0000001f;animation:toastSlide .3s ease-out;min-width:260px}.toast-icon{width:18px;height:18px;flex-shrink:0}.toast-success{border-color:#16a34a4d;background:#16a34a0f;color:var(--green)}.toast-error{border-color:#dc26264d;background:#dc26260f;color:var(--red)}.toast-info{border-color:#2563eb4d;background:#2563eb0f;color:var(--blue)}@keyframes toastSlide{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.viewer-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:6000;animation:modalFadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.viewer-container{background:var(--bg);border-radius:10px;width:92vw;max-width:1000px;height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 40px #00000080}.viewer-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--border);gap:10px;flex-shrink:0}.viewer-filename{display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;color:var(--text);min-width:0;overflow:hidden}.viewer-filename span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-meta{font-size:.68rem;font-weight:400;color:var(--text3);flex-shrink:0}.viewer-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.viewer-btn{height:28px;padding:0 10px;border-radius:5px;border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:.72rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:border-color .15s,color .15s}.viewer-btn:hover{border-color:var(--accent);color:var(--accent)}.viewer-close{width:28px;height:28px;padding:0;border-radius:5px;border:1px solid var(--border);background:var(--surface);color:var(--text3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}.viewer-close:hover{color:#ef4444;border-color:#ef4444}.viewer-content{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative}.viewer-image{max-width:100%;max-height:100%;object-fit:contain;display:block}.viewer-pdf{width:100%;height:100%;border:none}.viewer-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text3);font-size:.82rem;padding:40px;text-align:center}.viewer-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:5000;animation:modalFadeIn .2s ease-out}.modal-box{background:var(--surface);border-radius:14px;width:90%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px #0003;animation:modalScaleIn .2s ease-out}.modal-sm{max-width:380px}.modal-md{max-width:520px}.modal-lg{max-width:720px}.modal-xl{max-width:960px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border)}.modal-title{font-size:.95rem;font-weight:800}.modal-close{background:none;border:none;color:var(--text3);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:#0000000f;color:var(--text)}.modal-body{padding:20px}.modal-form{display:flex;flex-direction:column;gap:12px}.modal-label{font-size:.75rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}.modal-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:Arial,Helvetica,sans-serif;font-size:.85rem;padding:9px 12px;outline:none}.modal-input:focus{border-color:var(--accent)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalScaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-form-grid .span-2{grid-column:1 / -1}.modal-textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:Arial,Helvetica,sans-serif;font-size:.85rem;padding:9px 12px;outline:none;min-height:60px;resize:vertical}.modal-textarea:focus{border-color:var(--accent)}.preview-doc{background:#fff;border:1px solid var(--border);border-radius:10px;padding:28px 32px;font-size:.85rem;line-height:1.6}.preview-doc-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--accent)}.preview-doc-title{font-size:1.2rem;font-weight:800;color:var(--text)}.preview-doc-ref{font-size:.78rem;color:var(--text3);font-family:Arial,Helvetica,sans-serif}.preview-doc-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;margin-bottom:20px;font-size:.82rem}.preview-doc-meta dt{color:var(--text3);font-weight:600}.preview-doc-meta dd{color:var(--text);margin:0}.preview-section{margin-bottom:16px}.preview-section-title{font-size:.75rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.preview-section-body{color:var(--text);white-space:pre-wrap}.preview-amount-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-top:2px solid var(--border);margin-top:16px}.preview-amount-label{font-size:.85rem;font-weight:700;color:var(--text2)}.preview-amount-value{font-size:1.1rem;font-weight:800;color:var(--accent);font-family:Arial,Helvetica,sans-serif}.preview-footer{margin-top:20px;padding-top:14px;border-top:1px solid var(--border);font-size:.75rem;color:var(--text3);text-align:center}.preview-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.qv-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:14px}.qv-label{font-size:.72rem;font-weight:600;color:var(--text3);text-transform:uppercase}.qv-value{font-size:.85rem;color:var(--text);margin-bottom:4px}.qv-divider{grid-column:1 / -1;border:none;border-top:1px solid var(--border);margin:4px 0}.qv-section-title{grid-column:1 / -1;font-size:.75rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.qv-actions{display:flex;gap:8px;margin-top:8px;grid-column:1 / -1}.workflow-stepper{display:flex;gap:4px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px;overscroll-behavior-x:contain}.stepper-step{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:6px;white-space:nowrap;background:var(--surface2);border:1px solid var(--border);flex-shrink:0}.stepper-step.active{background:#f0a5001a;border-color:var(--accent)}.stepper-step.done{background:#16a34a14;border-color:#16a34a33}.stepper-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);flex-shrink:0}.stepper-step.active .stepper-dot{background:var(--accent)}.stepper-step.done .stepper-dot{background:var(--green)}.stepper-label{font-size:.65rem;font-weight:600;color:var(--text3)}.stepper-step.active .stepper-label{color:var(--accent);font-weight:700}.stepper-step.done .stepper-label{color:var(--green)}.notif-type-icon{flex-shrink:0}.row-actions{display:flex;align-items:center;gap:6px;justify-content:flex-end}.row-eye-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--accent);cursor:pointer;transition:all .15s;flex-shrink:0}.row-eye-btn:hover{background:#f0a5001a;border-color:var(--accent);color:var(--accent)}.row-arrow-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text2);cursor:pointer;transition:all .15s;flex-shrink:0}.row-arrow-btn:hover{background:#2563eb14;border-color:var(--blue);color:var(--blue)}@media(max-width:1024px){:root{--sidebar: 200px}.stats-row{grid-template-columns:repeat(3,1fr)}.analytics-row{flex-direction:column}.detail-grid,.form-grid{grid-template-columns:1fr}.pipeline-stage{grid-template-columns:150px 1fr 100px}.pipe-item-title{max-width:160px}.chat-threads{width:220px}}@media(max-width:768px){:root{--sidebar: 0px}#root{flex-direction:column}.sidebar{display:none;position:fixed;top:0;left:0;bottom:0;width:260px;z-index:1000;box-shadow:4px 0 24px #00000026}.sidebar.mobile-open{display:flex}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#0006;z-index:999}.hamburger-btn{display:flex;align-items:center;justify-content:center}.main{height:100vh}.content{padding:16px}.topbar{padding:0 16px}.stats-row{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:10px 12px}.stat-val{font-size:1.4rem}.toolbar{flex-wrap:wrap;gap:8px}.search-box{min-width:100%;max-width:100%}.filter-btn{padding:0 10px;font-size:.75rem;height:32px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:700px}.analytics-row{flex-direction:column}.detail-grid,.form-grid,.modal-form-grid{grid-template-columns:1fr}.kanban-board{min-height:auto}.kanban-col{min-width:260px;max-height:60vh}.pipeline-stage{grid-template-columns:1fr;gap:4px}.pipe-item-left{flex-direction:column;gap:2px;align-items:flex-start}.pipe-item-title{max-width:100%}.pipe-recent-card{position:static}.chat-layout{flex-direction:column;height:calc(100vh - 120px)}.chat-threads{width:100%;max-height:200px;border-right:none;border-bottom:1px solid var(--border)}.preview-doc{padding:18px}.preview-doc-meta,.qv-grid{grid-template-columns:1fr}}@media(max-width:480px){.content{padding:12px}.topbar{padding:0 12px;height:48px}.topbar-title{font-size:.9rem}.stats-row{grid-template-columns:1fr;gap:6px}.stat-val{font-size:1.2rem}.page-title{font-size:.95rem}table{min-width:600px}tbody td{padding:8px 10px;font-size:.8rem}thead th{padding:8px 10px;font-size:.68rem}.modal-box{width:96%;border-radius:10px}.modal-body{padding:14px}.kanban-col{min-width:220px}}
