:root{--bg-primary: #0c0d0f;--bg-secondary: #141518;--bg-tertiary: #1a1c20;--bg-elevated: #22242a;--border: #2a2d35;--border-hover: #3a3d45;--text-primary: #f0f0ee;--text-secondary: #a0a3ab;--text-muted: #6a6d75;--accent: #e8ff47;--accent-dim: rgba(232, 255, 71, .15);--success: #4ade80;--warning: #fbbf24;--error: #f87171;--blue: #60a5fa;--font-sans: "DM Sans", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius: 8px;--radius-lg: 12px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;line-height:1.5}.hub{display:grid;grid-template-columns:200px 1fr 360px;grid-template-rows:100vh;height:100vh;overflow:hidden}.hub-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.hub-logo{padding:18px 16px 14px;display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--border);margin-bottom:8px}.hub-logo-cr{font-size:16px;font-weight:800;color:var(--accent);letter-spacing:-.02em}.hub-logo-text{font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.hub-nav-section{flex:1;padding:4px 8px;display:flex;flex-direction:column;gap:2px}.hub-nav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all .12s;cursor:pointer;position:relative}.hub-nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.hub-nav-item.active{background:var(--accent-dim);color:var(--accent)}.hub-nav-item.disabled{opacity:.4;cursor:default;pointer-events:none}.hub-nav-badge{margin-left:auto;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg-tertiary);padding:2px 5px;border-radius:4px}.hub-sidebar-footer{padding:8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2px}.hub-sync-result{font-size:11px;color:var(--success);text-align:center;padding:2px 0}.hub-main{overflow-y:auto;background:var(--bg-primary)}.module-layout{padding:20px 24px}.module-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.hub-ai{border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary)}.hub-ai-header{display:flex;align-items:center;gap:6px;padding:11px 14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);border-bottom:1px solid var(--border);background:var(--bg-tertiary)}.app{display:grid;grid-template-rows:auto 1fr;grid-template-columns:1fr 380px;height:100vh}.app-header{grid-column:1 / -1;display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.app-header h1{font-size:15px;font-weight:600;letter-spacing:-.02em;color:var(--accent);white-space:nowrap}.app-header .divider{width:1px;height:20px;background:var(--border)}.phase-picker{display:flex;align-items:center;gap:6px}.phase-select{min-width:160px;font-size:12px;padding:6px 28px 6px 10px}.login-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.login-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;width:360px;text-align:center}.login-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:var(--accent-dim);color:var(--accent);margin-bottom:20px}.login-card h1{font-size:18px;font-weight:700;color:var(--accent);margin-bottom:6px}.login-card p{font-size:13px;color:var(--text-muted);margin-bottom:20px}.login-input{width:100%;padding:12px 16px;font-size:14px;text-align:center;letter-spacing:.1em;margin-bottom:12px}.login-error{padding:8px 12px;border-radius:var(--radius);background:#f871711a;border:1px solid rgba(248,113,113,.25);color:var(--error);font-size:12px;margin-bottom:12px}.login-btn{width:100%;padding:12px;font-size:14px;justify-content:center}.main-content{overflow-y:auto;padding:24px}.sidebar{border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.tab{flex:1;padding:10px 16px;font-size:12px;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg)}.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-header h2{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.card-body{padding:18px}.data-table{width:100%;border-collapse:collapse}.data-table th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);text-align:left;padding:8px 12px;border-bottom:1px solid var(--border)}.data-table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:13px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-tertiary)}.data-table .amount{text-align:right;font-family:var(--font-mono);font-size:13px;font-weight:500}.data-table .account{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}select,input[type=text],input[type=number]{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-sans);font-size:13px;padding:8px 12px;outline:none;transition:border-color .15s}select:hover,input:hover{border-color:var(--border-hover)}select:focus,input:focus{border-color:var(--accent)}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236a6d75' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;font-weight:500;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .15s}.btn:hover{border-color:var(--border-hover);background:var(--bg-elevated)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-accent{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.btn-accent:hover{filter:brightness(.9)}.btn-sm{padding:5px 10px;font-size:12px}.stats-row{display:flex;gap:12px;margin-bottom:20px}.stat{flex:1;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.stat-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:4px}.stat-value{font-family:var(--font-mono);font-size:18px;font-weight:600;color:var(--text-primary)}.stat-value.accent{color:var(--accent)}.bar-row{display:flex;align-items:center;gap:12px;padding:8px 0}.bar-label{width:160px;font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{flex:1;height:22px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.bar-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .4s ease;min-width:2px}.bar-fill.production{background:var(--accent)}.bar-fill.post{background:var(--blue)}.bar-fill.fees{background:var(--warning)}.bar-fill.cr-owned{background:var(--success)}.bar-fill.consulting{background:#c084fc}.bar-fill.other{background:var(--text-muted)}.bar-amount{width:90px;text-align:right;font-family:var(--font-mono);font-size:13px;font-weight:500}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-message{max-width:95%;padding:10px 14px;border-radius:var(--radius);font-size:13px;line-height:1.6;white-space:pre-wrap}.chat-message.user{align-self:flex-end;background:var(--accent-dim);border:1px solid rgba(232,255,71,.25);color:var(--text-primary)}.chat-message.assistant{align-self:flex-start;background:var(--bg-tertiary);border:1px solid var(--border)}.chat-input-row{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--bg-secondary)}.chat-input-row input{flex:1}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:500}.status-badge.draft{background:#60a5fa26;color:var(--blue)}.status-badge.pushed{background:#4ade8026;color:var(--success)}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-muted);font-size:13px}.spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;color:var(--text-muted);text-align:center}.empty-state svg{margin-bottom:12px;opacity:.4}.empty-state p{font-size:13px;max-width:260px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.json-preview{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);padding:16px;overflow:auto;max-height:400px;font-family:var(--font-mono);font-size:12px;line-height:1.6;color:var(--text-secondary);white-space:pre}.history-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.history-item:hover{background:var(--bg-tertiary)}.history-item-info h3{font-size:13px;font-weight:500;margin-bottom:2px}.history-item-info p{font-size:11px;color:var(--text-muted)}.history-item-amount{font-family:var(--font-mono);font-size:14px;font-weight:600}.field-label{display:block;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.customer-picker{position:relative}.customer-search-row{position:relative;display:flex;align-items:center}.customer-search-icon{position:absolute;left:10px;color:var(--text-muted);pointer-events:none}.customer-search-input{width:100%;padding-left:32px!important}.customer-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:4px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0006;max-height:280px;overflow-y:auto}.customer-dropdown-loading,.customer-dropdown-empty{padding:12px 14px;font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.customer-dropdown-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border:none;background:none;color:var(--text-primary);font-family:var(--font-sans);font-size:13px;cursor:pointer;text-align:left;border-bottom:1px solid var(--border);transition:background .1s}.customer-dropdown-item:hover{background:var(--bg-tertiary)}.customer-dropdown-item-main{display:flex;flex-direction:column;gap:1px}.customer-dropdown-item-name{font-weight:500}.customer-dropdown-item-company{font-size:11px;color:var(--text-muted)}.customer-dropdown-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.customer-dropdown-item-id{font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.customer-dropdown-item-loc{font-size:11px;color:var(--text-muted)}.customer-dropdown-create{width:100%;display:flex;align-items:center;gap:6px;padding:10px 14px;border:none;background:var(--accent-dim);color:var(--accent);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;transition:background .1s}.customer-dropdown-create:hover{background:#e8ff4738}.customer-dropdown-section{display:flex;align-items:center;gap:5px;padding:6px 14px 4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);border-top:1px solid var(--border)}.customer-dropdown-section:first-child{border-top:none}.customer-dropdown-show-more{width:100%;padding:7px 14px;border:none;background:transparent;color:var(--text-muted);font-family:var(--font-sans);font-size:11px;cursor:pointer;text-align:left;transition:color .1s}.customer-dropdown-show-more:hover{color:var(--text-primary)}.customer-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);font-size:13px}.customer-chip-name{font-weight:500}.customer-chip-id{font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.customer-chip-clear{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:var(--bg-elevated);border-radius:50%;color:var(--text-muted);cursor:pointer;margin-left:2px;transition:all .1s}.customer-chip-clear:hover{background:var(--error);color:#fff}.project-picker-loading,.project-picker-error{font-size:12px;color:var(--text-muted);padding:8px 0;display:flex;align-items:center;gap:6px}.project-picker-error{color:var(--error)}.project-picker-empty{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted)}.project-picker-row{display:flex;align-items:center;gap:6px}.project-picker-selected{display:flex;align-items:center;gap:5px;margin-top:6px;font-size:11px;color:var(--text-muted)}.project-picker-selected strong{color:var(--text-secondary)}.project-form-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);overflow:hidden}.project-form-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-primary)}.project-form-body{padding:14px}.project-form-two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}.project-form-field{margin-bottom:12px}.project-form-field label{display:block;margin-bottom:5px}.project-form-field input{width:100%}.project-form-suggestion{margin-top:5px;background:none;border:none;padding:0;font-size:11px;color:var(--accent);cursor:pointer;text-decoration:underline;text-align:left}.project-form-suggestion:hover{color:var(--text-primary)}.project-form-error{font-size:12px;color:var(--error);margin-bottom:8px}.project-confirm-row{display:flex;gap:12px;padding:6px 0;border-bottom:1px solid var(--border);font-size:12px}.project-confirm-label{color:var(--text-muted);width:110px;flex-shrink:0}.project-confirm-value{color:var(--text-primary)}.customer-form-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.customer-ai-assist{margin-bottom:12px}.customer-form-divider{height:1px;background:var(--border);margin:16px 0}.customer-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.customer-field{display:flex;flex-direction:column;gap:4px}.customer-field.span-2{grid-column:1 / -1}.customer-field.short input{max-width:120px}.customer-form-error{padding:8px 12px;margin-top:12px;border-radius:var(--radius);background:#f871711a;border:1px solid rgba(248,113,113,.25);color:var(--error);font-size:12px}.customer-confirm-grid{display:flex;flex-direction:column;gap:6px}.customer-confirm-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border)}.customer-confirm-label{font-size:12px;color:var(--text-muted);font-weight:500}.customer-confirm-value{font-size:13px;font-weight:500}.invoice-config-grid{display:flex;gap:12px;align-items:flex-start}.invoice-config-field{flex:1;min-width:0;position:relative}.expandable-row:hover td{background:var(--bg-tertiary)}.detail-section-header td{background:var(--bg-primary)!important;padding:0!important}.detail-section{margin:0 0 0 28px;padding:8px 16px 10px;border-left:2px solid var(--border)}.detail-section-title{display:flex;align-items:center;gap:8px;padding:4px 0 6px;font-size:12px;font-weight:600;color:var(--text-secondary)}.detail-section-letter{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;background:var(--accent-dim);color:var(--accent);font-family:var(--font-mono);font-size:11px;font-weight:700;flex-shrink:0}.detail-section-total{margin-left:auto;font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-secondary)}.detail-item{display:flex;align-items:center;justify-content:space-between;padding:3px 0 3px 30px;font-size:12px;color:var(--text-muted);border-bottom:1px solid rgba(42,45,53,.5)}.detail-item:last-child{border-bottom:none}.detail-item-desc{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:12px}.detail-item-amt{font-family:var(--font-mono);font-size:12px;font-weight:500;white-space:nowrap}.inv{background:#fff;color:#1a1a1a;border-radius:0 0 var(--radius-lg) var(--radius-lg);overflow:hidden;font-family:var(--font-sans)}.inv-header{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 32px;background:#e8611a;color:#fff}.inv-company-name{font-size:20px;font-weight:700;margin-bottom:4px}.inv-company-detail{font-size:12px;opacity:.85;line-height:1.5}.inv-meta{text-align:right}.inv-title{font-size:26px;font-weight:800;letter-spacing:.04em;margin-bottom:8px}.inv-meta-row{display:flex;gap:12px;justify-content:flex-end;align-items:center;font-size:12px;margin-bottom:2px}.inv-meta-label{font-weight:700;font-size:10px;letter-spacing:.06em;opacity:.8}.inv-addresses{display:flex;gap:48px;padding:20px 32px;background:#fafafa;border-bottom:1px solid #e5e5e5}.inv-address-block{flex:1}.inv-address-label{font-size:10px;font-weight:700;letter-spacing:.06em;color:#e8611a;margin-bottom:4px}.inv-address-name{font-size:14px;font-weight:600}.inv-table{width:100%;border-collapse:collapse}.inv-table thead tr{background:#e8611a}.inv-table thead th{color:#fff;font-size:10px;font-weight:700;letter-spacing:.06em;padding:10px 16px;text-align:left}.inv-table tbody tr{border-bottom:1px solid #eee;transition:background .1s}.inv-table tbody tr:hover{background:#fef9f5}.inv-table tbody td{padding:10px 16px;font-size:13px;vertical-align:middle}.inv-td-activity{font-weight:600;min-width:150px}.inv-td-desc{color:#666;font-size:12px}.inv-td-rate,.inv-td-qty,.inv-td-amount{text-align:right;font-family:var(--font-mono);font-size:13px}.inv-td-qty{text-align:center;width:60px}.inv-totals{padding:16px 32px 20px;display:flex;flex-direction:column;align-items:flex-end;gap:6px;background:#fafafa;border-top:1px solid #e5e5e5}.inv-totals-row{display:flex;gap:32px;font-size:13px;font-weight:500;color:#555}.inv-totals-row span:last-child{font-family:var(--font-mono);min-width:100px;text-align:right}.inv-totals-grand{margin-top:6px;padding-top:10px;border-top:2px solid #e8611a}.inv-totals-grand span{font-size:15px;font-weight:700;color:#1a1a1a}.inv-totals-grand-amount{font-size:18px!important;font-weight:800!important;color:#e8611a!important;font-family:var(--font-mono);min-width:100px;text-align:right}.inv-footer{padding:16px 32px 24px;font-size:12px;color:#888;border-top:1px solid #eee}.inv-footer p{margin-bottom:2px}.copy-cell{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:4px;cursor:pointer;transition:all .15s;position:relative}.copy-cell:hover{background:#e8611a14}.copy-cell.copied{background:#4ade801f}.copy-cell.mono{font-family:var(--font-mono)}.copy-cell-icon{display:inline-flex;opacity:0;color:#999;transition:opacity .15s}.copy-cell:hover .copy-cell-icon{opacity:1}.copy-cell.copied .copy-cell-icon{opacity:1;color:#4ade80}.inv-split{display:flex;gap:16px;border-radius:0 0 var(--radius-lg) var(--radius-lg);overflow:hidden}.inv-split-main{flex:2;min-width:0}.inv-split-main .inv{border-radius:0 0 0 var(--radius-lg)}.inv-split-notes{flex:1;min-width:280px;max-width:380px}.push-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.push-confirm-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(92vw,56rem);max-width:56rem;overflow:hidden;box-shadow:0 20px 60px #00000080}.push-confirm-header{display:flex;align-items:center;gap:8px;padding:16px 20px;border-bottom:1px solid var(--border);font-size:14px;font-weight:600;color:var(--text-primary)}.push-confirm-body{padding:20px;display:flex;flex-direction:column;gap:16px}.push-confirm-row{display:flex;gap:16px;align-items:flex-start}.push-confirm-label{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;width:70px;flex-shrink:0;padding-top:2px}.push-confirm-value{font-size:13px;color:var(--text-primary)}.push-confirm-total{font-size:18px;font-weight:700;color:var(--accent);font-family:var(--font-mono)}.push-confirm-note{display:flex;align-items:center;gap:4px;margin-top:4px;font-size:11px;color:var(--text-muted)}.push-confirm-edit-row{display:flex;gap:16px;align-items:flex-start}.push-confirm-input{flex:1;width:100%;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-sans);font-size:12px;padding:6px 10px}.push-confirm-actions{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border);background:var(--bg-tertiary)}.bid-notes-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:0 0 var(--radius-lg) 0;display:flex;flex-direction:column;height:100%;min-height:500px}.bid-notes-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--bg-tertiary)}.bid-notes-header h3{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.bid-notes-actions{display:flex;gap:4px}.bid-notes-body{flex:1;overflow-y:auto;padding:0}.bid-notes-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:var(--text-muted);font-size:12px;text-align:center;padding:20px}.bid-notes-textarea{width:100%;height:100%;min-height:400px;padding:14px;background:var(--bg-primary);border:none;color:var(--text-primary);font-family:var(--font-sans);font-size:12px;line-height:1.7;resize:none;outline:none}.bid-notes-textarea::placeholder{color:var(--text-muted)}.bid-notes-content{padding:14px;font-size:12px;line-height:1.7;color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word}.projects-toolbar{display:flex;align-items:center;gap:16px;margin-bottom:12px;flex-wrap:wrap}.projects-toolbar-left{display:flex;align-items:center;gap:8px}.projects-title{font-size:16px;font-weight:700;letter-spacing:-.02em}.projects-count{font-size:11px;font-weight:600;color:var(--text-muted);background:var(--bg-tertiary);padding:2px 7px;border-radius:99px}.projects-toolbar-center{display:flex;align-items:center;gap:8px;flex:1}.projects-search{position:relative;flex:1;max-width:320px}.projects-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.projects-search-input{width:100%;padding-left:32px!important;font-size:12px}.projects-toolbar-right{display:flex;align-items:center;gap:6px}.projects-view-toggle{display:flex;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.projects-view-btn{display:flex;align-items:center;justify-content:center;padding:6px 10px;background:none;border:none;color:var(--text-muted);cursor:pointer;transition:all .12s}.projects-view-btn:hover{color:var(--text-primary)}.projects-view-btn.active{background:var(--accent-dim);color:var(--accent)}.projects-filter-wrap{position:relative}.btn-filter-active{border-color:var(--accent)!important;color:var(--accent)!important}.projects-filter-count{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--accent);color:var(--bg-primary);font-size:10px;font-weight:700}.projects-filter-menu{position:absolute;top:calc(100% + 4px);left:0;z-index:100;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0006;min-width:180px;max-height:min(320px,70vh);overflow-x:hidden;overflow-y:auto}.projects-filter-menu-wide{min-width:240px}.projects-filter-tag-label{flex:1;min-width:0;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.projects-filter-dot-tag{background:var(--accent);opacity:.75}.projects-filter-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;cursor:pointer;transition:background .1s}.projects-filter-option:hover{background:var(--bg-tertiary)}.projects-filter-option.active{background:var(--accent-dim);color:var(--text-primary)}.projects-filter-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.projects-filter-option-count{margin-left:auto;font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.projects-filter-clear{display:block;width:100%;padding:8px 12px;border:none;border-top:1px solid var(--border);background:none;color:var(--error);font-family:var(--font-sans);font-size:11px;cursor:pointer;text-align:left}.projects-filter-clear:hover{background:var(--bg-tertiary)}.projects-status-bar{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.projects-status-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:99px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s}.projects-status-pill:hover{border-color:var(--border-hover);background:var(--bg-tertiary)}.projects-status-pill.dimmed{opacity:.35}.projects-status-pill-dot{width:7px;height:7px;border-radius:50%;background:var(--pill-color)}.projects-status-pill-count{font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.projects-tags-bar{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:16px}.projects-tags-bar-label{flex:0 0 auto;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-right:4px}.projects-tag-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:99px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s;max-width:100%}.projects-tag-pill:hover{border-color:var(--accent);background:var(--accent-dim);color:var(--text-primary)}.projects-tag-pill.dimmed{opacity:.35}.projects-tag-pill-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.projects-tag-pill-count{font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.projects-error{padding:8px 12px;border-radius:var(--radius);background:#f871711a;border:1px solid rgba(248,113,113,.25);color:var(--error);font-size:12px;margin-bottom:12px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.projects-grid--large{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px}.projects-list{display:flex;flex-direction:column;gap:8px}.project-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:8px}.project-card:hover{border-color:var(--border-hover);background:var(--bg-tertiary);transform:translateY(-1px);box-shadow:0 4px 12px #0003}.project-card--list{flex-direction:row;align-items:flex-start;flex-wrap:wrap;gap:10px 20px;padding:12px 16px;transform:none}.project-card--list:hover{transform:none}.project-card--list .project-card-name--list{flex:1 1 200px;min-width:0;margin:0;font-size:13px}.project-card-list-mid{display:flex;flex-wrap:wrap;align-items:center;gap:12px 20px;flex:1 1 180px}.project-card-list-end{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;justify-content:flex-end;margin-left:auto}.project-card-list-end .project-card-labels{margin-top:0;justify-content:flex-end}.project-card-list-end .project-card-time{flex-shrink:0}.project-card-header{display:flex;align-items:center;justify-content:flex-end}.project-card-status{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--status-color);background:color-mix(in srgb,var(--status-color) 12%,transparent)}.project-card-time{font-size:11px;color:var(--text-muted)}.project-card-name{font-size:14px;font-weight:600;letter-spacing:-.01em;line-height:1.3;color:var(--text-primary)}.project-card-meta{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted)}.project-card-budget{color:var(--accent);font-family:var(--font-mono);font-weight:500}.project-card-labels{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px}.project-card-label{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:4px;background:var(--bg-tertiary);font-size:10px;color:var(--text-muted)}.projects-grouped{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;align-items:start}.projects-lane{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.projects-lane-header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg-tertiary)}.projects-lane-dot{width:8px;height:8px;border-radius:50%;background:var(--lane-color)}.projects-lane-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.projects-lane-count{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.projects-lane-body{padding:8px;display:flex;flex-direction:column;gap:8px;max-height:70vh;overflow-y:auto}.projects-lane-body--list{flex-direction:column;gap:8px}.projects-lane-body--grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.projects-lane-body--grid.projects-lane-body--grid-large{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}.projects-lane-empty{padding:20px;text-align:center;font-size:12px;color:var(--text-muted)}.pd-header{margin-bottom:16px}.pd-header-main{display:flex;flex-direction:column;gap:8px}.pd-name{font-size:22px;font-weight:700;letter-spacing:-.02em}.pd-header-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pd-status-wrap{position:relative}.pd-status-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;border:1px solid var(--border);background:color-mix(in srgb,var(--status-color) 10%,var(--bg-secondary));color:var(--status-color);font-family:var(--font-sans);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}.pd-status-btn:hover{border-color:var(--status-color)}.pd-status-dot{width:7px;height:7px;border-radius:50%;background:var(--status-color)}.pd-status-menu{position:absolute;top:calc(100% + 4px);left:0;z-index:100;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0006;min-width:160px;overflow:hidden}.pd-status-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;cursor:pointer;transition:background .1s}.pd-status-option:hover{background:var(--bg-tertiary)}.pd-status-option.active{background:var(--accent-dim);color:var(--accent)}.pd-status-option-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.pd-company-badge,.pd-label-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;background:var(--bg-tertiary);border:1px solid var(--border);font-size:11px;font-weight:500;color:var(--text-secondary)}.pd-grid{display:grid;grid-template-columns:1fr 340px;gap:16px;align-items:start}.pd-grid-main,.pd-grid-side{min-width:0}.pd-budget-summary{display:flex;flex-direction:column;gap:6px}.pd-budget-total{display:flex;flex-direction:column;gap:2px;padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:4px}.pd-budget-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.pd-budget-value{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--accent)}.pd-budget-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted)}.pd-budget-row span:last-child{font-family:var(--font-mono);font-weight:500;color:var(--text-secondary)}.pd-budget-date{display:flex;align-items:center;gap:4px;margin-top:6px;padding-top:6px;border-top:1px solid var(--border);font-size:11px;color:var(--text-muted)}.pd-details-list{display:flex;flex-direction:column;gap:0}.pd-detail-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border)}.pd-detail-row:last-child{border-bottom:none}.pd-detail-label{font-size:11px;font-weight:500;color:var(--text-muted)}.pd-detail-value{font-size:12px;color:var(--text-secondary);text-align:right}.pd-labels-wrap{display:flex;gap:6px;flex-wrap:wrap}.pd-label-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;background:var(--bg-tertiary);font-size:11px;color:var(--text-secondary)}.pd-editable{position:relative}.pd-editable-textarea{width:100%;min-height:80px;padding:10px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-sans);font-size:12px;line-height:1.7;resize:vertical;outline:none;transition:border-color .15s}.pd-editable-textarea:focus{border-color:var(--accent)}.pd-editable-textarea::placeholder{color:var(--text-muted)}.pd-editable-hint{display:flex;align-items:center;gap:4px;margin-top:4px;font-size:10px;color:var(--text-muted)}.pd-summary-content{font-family:var(--font-sans);font-size:11px;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word;background:none;border:none;margin:0;padding:0}.pd-kb-entry{padding:10px 14px;border-bottom:1px solid var(--border)}.pd-kb-entry:last-child{border-bottom:none}.pd-kb-entry-header{display:flex;justify-content:space-between;margin-bottom:2px}.pd-kb-entry-category{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.pd-kb-entry-date{font-size:10px;color:var(--text-muted)}.pd-kb-entry-title{font-size:12px;font-weight:500;color:var(--text-secondary)}.pd-links-list{display:flex;flex-direction:column;gap:12px}.pd-link-row{display:flex;flex-direction:column;gap:4px}.pd-link-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.pd-link-input-wrap{display:flex;align-items:center;gap:6px}.pd-link-input{flex:1;font-size:12px}.pd-link-open{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);font-family:var(--font-sans);font-size:11px;text-decoration:none;white-space:nowrap;transition:all .12s}.pd-link-open:hover{border-color:var(--accent);color:var(--accent)}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.client-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:10px}.client-card:hover{border-color:var(--border-hover);background:var(--bg-tertiary);transform:translateY(-1px);box-shadow:0 4px 12px #0003}.client-card-top{display:flex;align-items:center;gap:12px}.client-avatar{width:40px;height:40px;border-radius:var(--radius);background:var(--avatar-bg);color:var(--avatar-color);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;letter-spacing:-.02em;flex-shrink:0;border:1px solid color-mix(in srgb,var(--avatar-color) 20%,transparent)}.client-card-info{flex:1;min-width:0}.client-card-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-card-company{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.client-card-details{display:flex;flex-direction:column;gap:4px}.client-card-detail{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted)}.client-card-balance{color:var(--warning);font-family:var(--font-mono);font-weight:500}.cd-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.cd-avatar-lg{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--avatar-bg);color:var(--avatar-color);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;letter-spacing:-.02em;flex-shrink:0;border:1px solid color-mix(in srgb,var(--avatar-color) 20%,transparent)}.cd-header-info{flex:1;display:flex;flex-direction:column;gap:8px}.cd-name{font-size:22px;font-weight:700;letter-spacing:-.02em}.cd-name-input{font-size:20px;font-weight:700;padding:4px 8px;width:100%}.cd-header-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cd-fields{display:flex;flex-direction:column;gap:0}.cd-field{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);gap:16px}.cd-field:last-child{border-bottom:none}.cd-field .pd-detail-label{min-width:100px;flex-shrink:0}.cd-field input{flex:1;font-size:12px;padding:4px 8px}.cd-field .pd-detail-value{text-align:right}
