.kpi-grid[data-v-6303a7f0]{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi-card[data-v-6303a7f0]{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000a}.kpi-icon[data-v-6303a7f0]{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.kpi-value[data-v-6303a7f0]{font-size:22px;font-weight:700;color:#1a1a2e}.kpi-label[data-v-6303a7f0]{font-size:12px;color:#6b7280;margin-top:2px}@media (max-width: 1200px){.kpi-grid[data-v-6303a7f0]{grid-template-columns:repeat(2,1fr)}}.pipeline-stats[data-v-be7f9023]{display:flex;gap:32px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f3f4f6}.stat[data-v-be7f9023]{display:flex;flex-direction:column}.stat-val[data-v-be7f9023]{font-size:24px;font-weight:700;color:#1a1a2e}.stat-lbl[data-v-be7f9023]{font-size:12px;color:#6b7280}.renewal-summary[data-v-5a8cc11a]{display:flex;gap:32px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f3f4f6}.stat[data-v-5a8cc11a]{display:flex;flex-direction:column}.stat-val[data-v-5a8cc11a]{font-size:24px;font-weight:700;color:#1a1a2e}.stat-lbl[data-v-5a8cc11a]{font-size:12px;color:#6b7280}.bucket-overdue[data-v-5a8cc11a]{border-color:#fca5a5;background:#fef2f2}.bucket-clients[data-v-5a8cc11a]{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.client-chip[data-v-5a8cc11a]{display:inline-block;padding:2px 10px;background:#e5e7eb;border-radius:12px;font-size:11px;color:#374151}.client-chip.more[data-v-5a8cc11a]{background:#dbeafe;color:#1d4ed8}.text-danger[data-v-8a9cd6a8]{color:#ef4444;font-weight:600}.text-muted[data-v-8a9cd6a8]{color:#9ca3af}.sub-text[data-v-8a9cd6a8]{font-size:11px;color:#9ca3af}.settings-page[data-v-8daf4d8a]{display:flex;flex-direction:column;gap:20px}.mock-toggle-card[data-v-8daf4d8a]{padding:20px 24px}.toggle-row[data-v-8daf4d8a]{display:flex;align-items:center;justify-content:space-between;gap:24px}.toggle-desc[data-v-8daf4d8a]{font-size:13px;color:#6b7280;margin-top:4px;max-width:500px}.toggle[data-v-8daf4d8a]{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0}.toggle input[data-v-8daf4d8a]{display:none}.toggle-slider[data-v-8daf4d8a]{width:44px;height:24px;background:#d1d5db;border-radius:12px;position:relative;transition:background .2s}.toggle-slider[data-v-8daf4d8a]:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s}.toggle input:checked+.toggle-slider[data-v-8daf4d8a]{background:#6366f1}.toggle input:checked+.toggle-slider[data-v-8daf4d8a]:after{transform:translate(20px)}.toggle-label[data-v-8daf4d8a]{font-size:13px;font-weight:600;color:#374151;min-width:80px}.source-section[data-v-8daf4d8a]{padding:24px}.section-header[data-v-8daf4d8a]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title[data-v-8daf4d8a]{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700}.source-icon[data-v-8daf4d8a]{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:#fff}.at-icon[data-v-8daf4d8a]{background:#fcb400}.pg-icon[data-v-8daf4d8a]{background:#336791}.crm-icon[data-v-8daf4d8a]{background:#6366f1}.source-tag[data-v-8daf4d8a]{font-size:11px;font-weight:500;color:#6b7280;background:#f3f4f6;padding:3px 10px;border-radius:12px}.test-btn[data-v-8daf4d8a]{display:flex;align-items:center;gap:6px;background:#f3f4f6;border:1px solid #d1d5db;color:#374151;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.test-btn[data-v-8daf4d8a]:hover:not(:disabled){background:#e5e7eb}.test-btn[data-v-8daf4d8a]:disabled{opacity:.6;cursor:not-allowed}.spinner-sm[data-v-8daf4d8a]{width:14px;height:14px;border:2px solid #d1d5db;border-top-color:#6366f1;border-radius:50%;animation:spin-8daf4d8a .6s linear infinite;display:inline-block}@keyframes spin-8daf4d8a{to{transform:rotate(360deg)}}.test-result[data-v-8daf4d8a]{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px}.result-ok[data-v-8daf4d8a]{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.result-err[data-v-8daf4d8a]{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.form-grid[data-v-8daf4d8a]{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.form-group[data-v-8daf4d8a]{display:flex;flex-direction:column;gap:4px}.form-group label[data-v-8daf4d8a]{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.3px}.form-group input[data-v-8daf4d8a]{padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;outline:none;transition:border-color .15s;font-family:inherit}.form-group input[data-v-8daf4d8a]:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group input[type=password][data-v-8daf4d8a]{font-family:monospace;letter-spacing:1px}.form-sm[data-v-8daf4d8a]{max-width:120px}.table-select-row[data-v-8daf4d8a]{display:flex;gap:8px}.table-select-row input[data-v-8daf4d8a],.table-select[data-v-8daf4d8a]{flex:1}.table-select[data-v-8daf4d8a]{padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;outline:none;transition:border-color .15s;font-family:inherit;background:#fff}.table-select[data-v-8daf4d8a]:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.fetch-tables-btn[data-v-8daf4d8a]{background:#f3f4f6;border:1px solid #d1d5db;color:#374151;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s}.fetch-tables-btn[data-v-8daf4d8a]:hover:not(:disabled){background:#e5e7eb}.fetch-tables-btn[data-v-8daf4d8a]:disabled{opacity:.5;cursor:not-allowed}.fetch-error[data-v-8daf4d8a]{font-size:12px;color:#dc2626;margin-top:4px}.qb-icon[data-v-8daf4d8a]{background:#2ca01c;font-size:10px}.tg-icon[data-v-8daf4d8a]{background:#08c}.tg-auth-row[data-v-8daf4d8a]{display:flex;gap:8px;margin-bottom:12px}.tg-auth-input[data-v-8daf4d8a]{flex:1;padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;outline:none}.tg-auth-input[data-v-8daf4d8a]:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.query-icon[data-v-8daf4d8a]{background:#059669}.query-controls[data-v-8daf4d8a]{display:flex;flex-direction:column;gap:10px}.query-source-toggle[data-v-8daf4d8a]{display:flex;gap:4px}.toggle-btn[data-v-8daf4d8a]{padding:6px 16px;border:1px solid #d1d5db;border-radius:6px;background:#f9fafb;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.toggle-btn.active[data-v-8daf4d8a]{background:#6366f1;color:#fff;border-color:#6366f1}.toggle-btn[data-v-8daf4d8a]:hover:not(.active){background:#e5e7eb}.query-input[data-v-8daf4d8a]{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-family:SF Mono,Fira Code,monospace;font-size:13px;resize:vertical;outline:none;transition:border-color .15s}.query-input[data-v-8daf4d8a]:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.query-actions[data-v-8daf4d8a]{display:flex;align-items:center;gap:12px}.run-btn[data-v-8daf4d8a]{background:#059669;color:#fff;border:none;padding:8px 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.run-btn[data-v-8daf4d8a]:hover:not(:disabled){background:#047857}.run-btn[data-v-8daf4d8a]:disabled{opacity:.5;cursor:not-allowed}.query-meta[data-v-8daf4d8a]{font-size:13px;color:#6b7280}.query-error[data-v-8daf4d8a]{padding:10px 14px;border-radius:8px;font-size:13px;background:#fef2f2;color:#991b1b;border:1px solid #fecaca;margin-top:10px}.query-results[data-v-8daf4d8a]{margin-top:12px}.query-table-wrap[data-v-8daf4d8a]{overflow-x:auto;max-height:400px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:8px}.query-table[data-v-8daf4d8a]{width:100%;border-collapse:collapse;font-size:12px}.query-table th[data-v-8daf4d8a]{text-align:left;padding:8px 10px;background:#f9fafb;font-weight:600;color:#6b7280;border-bottom:2px solid #e5e7eb;position:sticky;top:0;z-index:1}.query-table td[data-v-8daf4d8a]{padding:6px 10px;border-bottom:1px solid #f3f4f6;white-space:nowrap;max-width:300px;overflow:hidden;text-overflow:ellipsis}.query-table tr:hover td[data-v-8daf4d8a]{background:#f9fafb}.save-bar[data-v-8daf4d8a]{display:flex;align-items:center;justify-content:flex-end;gap:16px;padding:16px 0;position:sticky;bottom:0}.save-hint[data-v-8daf4d8a]{font-size:13px;color:#059669;font-weight:500}.save-err[data-v-8daf4d8a]{color:#dc2626}.save-btn[data-v-8daf4d8a]{background:#6366f1;color:#fff;border:none;padding:12px 28px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.save-btn[data-v-8daf4d8a]:hover:not(:disabled){background:#4f46e5}.save-btn[data-v-8daf4d8a]:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 800px){.form-grid[data-v-8daf4d8a]{grid-template-columns:1fr}}.qb-invoices[data-v-b1eed13f]{display:flex;flex-direction:column;gap:16px}.filter-bar[data-v-b1eed13f]{padding:16px 24px}.filter-row[data-v-b1eed13f]{display:flex;align-items:flex-end;gap:12px}.filter-group[data-v-b1eed13f]{display:flex;flex-direction:column;gap:4px}.filter-group label[data-v-b1eed13f]{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase}.filter-group select[data-v-b1eed13f],.filter-group input[data-v-b1eed13f]{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;outline:none}.filter-group select[data-v-b1eed13f]:focus,.filter-group input[data-v-b1eed13f]:focus{border-color:#6366f1}.search-group[data-v-b1eed13f]{flex:1}.search-group input[data-v-b1eed13f]{width:100%}.search-btn[data-v-b1eed13f]{background:#6366f1;color:#fff;border:none;padding:8px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}.search-btn[data-v-b1eed13f]:hover{background:#4f46e5}.filter-summary[data-v-b1eed13f]{font-size:12px;color:#6b7280;margin-top:8px}.loading-small[data-v-b1eed13f]{text-align:center;color:#6b7280;padding:24px}.error-msg[data-v-b1eed13f]{color:#dc2626;padding:12px;background:#fef2f2;border-radius:8px}.text-danger[data-v-b1eed13f]{color:#ef4444;font-weight:600}.badge-paid[data-v-b1eed13f]{background:#d1fae5;color:#065f46}.badge-unpaid[data-v-b1eed13f]{background:#fef3c7;color:#92400e}.badge-overdue[data-v-b1eed13f]{background:#fee2e2;color:#991b1b}.pagination[data-v-b1eed13f]{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 0}.pagination button[data-v-b1eed13f]{background:#f3f4f6;border:1px solid #d1d5db;color:#374151;padding:8px 16px;border-radius:8px;font-size:13px;cursor:pointer}.pagination button[data-v-b1eed13f]:hover:not(:disabled){background:#e5e7eb}.pagination button[data-v-b1eed13f]:disabled{opacity:.4;cursor:not-allowed}.pagination span[data-v-b1eed13f]{font-size:13px;color:#6b7280}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:#f0f2f5;color:#1a1a2e;line-height:1.5}.app{display:flex;min-height:100vh}.sidebar{width:240px;background:#1a1a2e;color:#e0e0e0;display:flex;flex-direction:column;padding:24px 16px;position:fixed;top:0;bottom:0}.logo{display:flex;align-items:center;gap:12px;margin-bottom:32px;font-weight:700;font-size:18px;color:#fff}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff}nav{flex:1;display:flex;flex-direction:column;gap:4px}.nav-btn{background:none;border:none;color:#a0a0b8;padding:10px 14px;border-radius:8px;font-size:14px;cursor:pointer;text-align:left;display:flex;align-items:center;gap:10px;transition:all .15s}.nav-btn:hover{background:#ffffff0f;color:#fff}.nav-btn.active{background:#6366f133;color:#818cf8;font-weight:600}.nav-icon{font-size:16px}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:8px}.mock-badge{display:flex;align-items:center;gap:6px;font-size:12px;color:#fbbf24;padding:6px 10px;background:#fbbf241a;border-radius:6px}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot-yellow{background:#fbbf24}.dot-green{background:#22c55e}.dot-red{background:#ef4444}.refresh-btn{background:#ffffff0f;border:none;color:#a0a0b8;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:13px;transition:all .15s}.refresh-btn:hover{background:#ffffff1f;color:#fff}.main{flex:1;margin-left:240px;display:flex;flex-direction:column}.topbar{background:#fff;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10}.topbar h1{font-size:20px;font-weight:700}.search-input{padding:8px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;width:280px;outline:none;transition:border-color .15s}.search-input:focus{border-color:#6366f1}.content{padding:24px 32px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f;border:1px solid #e5e7eb}.card-title{font-size:14px;color:#6b7280;font-weight:500;margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}.loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#6b7280}.spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.table-wrap{overflow-x:auto;margin-top:24px}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;padding:10px 14px;background:#f9fafb;color:#6b7280;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}td{padding:12px 14px;border-bottom:1px solid #f3f4f6}tr:hover td{background:#f9fafb}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize}.badge-new{background:#dbeafe;color:#1d4ed8}.badge-contacted{background:#e0e7ff;color:#4338ca}.badge-qualified{background:#fef3c7;color:#92400e}.badge-proposal{background:#fed7aa;color:#9a3412}.badge-negotiation{background:#fce7f3;color:#9d174d}.badge-closed_won{background:#d1fae5;color:#065f46}.badge-closed_lost{background:#fee2e2;color:#991b1b}.badge-active{background:#d1fae5;color:#065f46}.badge-at_risk{background:#fef3c7;color:#92400e}.badge-churned{background:#fee2e2;color:#991b1b}.badge-pending_renewal{background:#e0e7ff;color:#4338ca}.funnel{display:flex;flex-direction:column;gap:8px}.funnel-bar{display:flex;align-items:center;gap:12px}.funnel-label{width:110px;font-size:13px;font-weight:500;text-transform:capitalize;white-space:nowrap}.funnel-track{flex:1;height:32px;background:#f3f4f6;border-radius:6px;overflow:hidden;position:relative}.funnel-fill{height:100%;border-radius:6px;display:flex;align-items:center;padding-left:10px;font-size:12px;font-weight:600;color:#fff;transition:width .5s ease;min-width:40px}.funnel-value{font-size:13px;font-weight:600;min-width:90px;text-align:right}.health-bar{width:60px;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.health-fill{height:100%;border-radius:4px}.renewal-buckets{display:flex;flex-direction:column;gap:12px}.renewal-bucket{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.bucket-label{font-weight:600;font-size:14px}.bucket-meta{display:flex;gap:20px;font-size:13px;color:#6b7280}.bucket-meta strong{color:#1a1a2e}.source-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.source-card{background:#fff;border-radius:12px;padding:24px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000a}.source-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.source-name{font-weight:700;font-size:15px}.source-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500}.source-detail{font-size:13px;color:#6b7280;margin:4px 0}.source-error{font-size:12px;color:#f59e0b;margin-top:8px;padding:8px;background:#fffbeb;border-radius:6px}@media (max-width: 1024px){.grid-2,.source-cards{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{display:none}.main{margin-left:0}}
