:root{--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease-in-out}:root{--bg-primary: #171717;--bg-secondary: #212121;--bg-tertiary: #2f2f2f;--bg-input: #3a3a3a;--bg-hover: #404040;--text-primary: #ececec;--text-secondary: #9a9a9a;--text-tertiary: #6b6b6b;--accent-primary: #10a37f;--accent-hover: #0e8c6b;--accent-text: #ffffff;--brand-primary: #10a37f;--brand-text: #ffffff;--border-color: #3a3a3a;--border-hover: #4a4a4a;--success-bg: #1a3d2a;--success-text: #4ade80;--error-bg: #4a2020;--error-text: #ff6b6b;--warning-bg: #4a3d20;--warning-text: #fbbf24;--color-danger: #dc3545;--info-bg: #1a2d4a;--info-text: #60a5fa;--color-action-blue: #2563eb;--color-action-blue-hover: #1d4ed8;--stated-bg: #2d2650;--stated-text: #a78bfa;--color-status-scheduled: #2563eb;--color-status-scheduled-bg: #1a2d4a;--color-status-in-progress: #0a7a54;--color-status-in-progress-bg: #1a3d2a;--color-status-completed: #0e8037;--color-status-completed-bg: #1a3d2a;--color-status-on-hold: #b35a0a;--color-status-on-hold-bg: #4a3d20;--color-status-cancelled: #dc2626;--color-status-cancelled-bg: #4a2020;--color-neutral-400: #525252;--entity-contact-accent: #60a5fa;--entity-project-accent: #a78bfa;--entity-calendar-accent: #60a5fa;--entity-estimate-accent: #9a9a9a;--entity-invoice-accent: #f59e0b;--accent-primary-rgb: 16, 163, 127;--overlay-backdrop: rgba(0, 0, 0, .5);--shadow-overlay: rgba(0, 0, 0, .3);--shadow-light: rgba(0, 0, 0, .2);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-pill: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .3);--sidebar-width: 260px;--chat-max-width: 768px;--header-height: 56px;--touch-target-min: 44px;--inline-edit-hover-bg: var(--bg-hover);--inline-edit-focus-border: var(--accent-primary);--inline-edit-focus-shadow: 0 0 0 2px rgba(var(--accent-primary-rgb), .2);--inline-edit-success-color: var(--success-text);--inline-edit-error-color: var(--error-text);--inline-edit-saving-opacity: .6;--inline-edit-success-duration: 2s}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body{height:100%}html{overflow-y:scroll}body{font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary)}#root{min-height:100%}input,select,textarea,button{font-family:inherit;font-size:100%}input,select,textarea{background-color:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:var(--space-xl);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%239a9a9a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-sm) center}.filter-search{flex:1;min-width:200px}.filter-select{min-width:150px}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.2)}textarea:focus{border-color:var(--border-color);box-shadow:none}.filter-search:focus,.filter-select:focus{border-color:var(--border-color);box-shadow:none}input:disabled,select:disabled,textarea:disabled{opacity:.6;cursor:not-allowed}button{cursor:pointer;background-color:transparent;color:var(--text-primary);border:none;border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-weight:500;transition:background-color var(--transition-fast),opacity var(--transition-fast)}button:disabled{opacity:.5;cursor:not-allowed}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover);text-decoration:underline}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-lg)}.page-container{flex:1;background-color:var(--bg-secondary);padding:var(--space-xl);display:flex;flex-direction:column;min-height:0;overflow-y:auto;scrollbar-gutter:stable}.page-inner{width:100%;max-width:1000px;margin:0 auto}.page-inner--narrow{max-width:800px}.page-inner--full-height{display:flex;flex-direction:column;height:100%}.page-container--pipeline{padding-left:0;padding-right:0}.pipeline-header-area{width:100%;max-width:calc(1000px + 2 * var(--space-xl));margin:0 auto;padding:0 var(--space-xl)}.page-inner--full-width{max-width:none}.page-header-centered{max-width:1000px;margin:0 auto;padding:0 var(--space-xl)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.page-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--text-primary);margin:0}.page-title--spaced{margin-bottom:var(--space-xl)}.page-header-actions{display:flex;align-items:center;gap:var(--space-md)}.page-header-actions .btn{min-width:140px}.layout-container{display:flex;height:100vh;overflow:hidden}.layout-main{flex:1;display:flex;flex-direction:column;min-width:0}.layout-content{flex:1;display:flex;flex-direction:column;overflow-y:auto}.mobile-header{display:none;padding:var(--space-md);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.mobile-menu-btn{padding:var(--space-sm);background-color:transparent;border:none;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background-color:var(--bg-primary);display:flex;flex-direction:column;z-index:50;transform:translate(-100%);transition:transform var(--transition-normal)}.sidebar--open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--overlay-backdrop);z-index:40}.sidebar-header{padding:var(--space-md);border-bottom:1px solid var(--border-color)}.sidebar-logo-link{display:flex;text-decoration:none;cursor:pointer}.sidebar-logo-link:hover,.sidebar-logo-link:focus,.sidebar-logo-link:active{opacity:1;text-decoration:none}.sidebar-logo{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);margin:0}.sidebar-new-chat-btn{width:100%;padding:var(--space-md);margin-top:var(--space-md);display:flex;align-items:center;justify-content:center;gap:var(--space-sm);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:background-color var(--transition-fast)}.sidebar-new-chat-btn:hover:not(:disabled){background-color:var(--bg-hover)}.sidebar-conversations{flex:1;overflow-y:auto;padding:var(--space-md)}.sidebar-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-xs);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);color:var(--text-secondary);font-size:var(--font-size-sm);background-color:transparent;border:none;font-family:inherit;text-align:left;width:100%}button.sidebar-item:hover{background-color:var(--bg-hover)}button.sidebar-item.active{background-color:var(--bg-tertiary);color:var(--text-primary)}.sidebar-item-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.sidebar-item-delete{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;margin-left:var(--space-sm);background-color:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast);flex-shrink:0;opacity:0;pointer-events:none}.sidebar-item:hover .sidebar-item-delete,.sidebar-item.active .sidebar-item-delete{opacity:1;pointer-events:auto}button.sidebar-item-delete:hover:not(:disabled){color:var(--error-text)}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-color)}.sidebar-nav-link{display:block;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:var(--font-size-sm);transition:background-color var(--transition-fast),color var(--transition-fast)}.sidebar-nav-link:hover{background-color:var(--bg-hover);color:var(--text-primary);text-decoration:none}.sidebar-nav-link.active{background-color:var(--bg-tertiary);color:var(--text-primary)}.sidebar-nav-content{display:flex;align-items:center;gap:var(--space-sm)}.sidebar-logout-btn{width:100%;padding:var(--space-sm) var(--space-md);margin-top:var(--space-sm);background-color:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;text-align:left;font-size:var(--font-size-sm);transition:background-color var(--transition-fast),color var(--transition-fast)}.sidebar-logout-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.sidebar-loading,.sidebar-empty{color:var(--text-tertiary);font-size:var(--font-size-sm);padding:var(--space-md);text-align:center}.sidebar-item-animate{will-change:transform}@media (prefers-reduced-motion: reduce){.sidebar-item-animate{transition:none!important;transform:none!important}}@media (max-width: 767px){.page-container{padding:var(--space-md)}.page-header{flex-direction:column;align-items:stretch;gap:var(--space-md)}.page-header-actions{flex-direction:column;gap:var(--space-sm)}.layout-content:has(.chat-container){overflow:hidden}.sidebar-item{min-height:var(--touch-target-min);touch-action:manipulation}.sidebar-nav-link{min-height:var(--touch-target-min)}.sidebar-item-delete{min-width:var(--touch-target-min);min-height:var(--touch-target-min);touch-action:manipulation}.mobile-menu-btn{min-width:var(--touch-target-min);min-height:var(--touch-target-min)}}@media print{.sidebar,.sidebar-overlay,.mobile-header,.page-header-actions{display:none!important}.page-container{padding:0}.page-inner{max-width:none;padding:0}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--accent-primary);color:var(--accent-text);border:none}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--border-hover)}.btn-danger{background-color:#dc2626;color:#fff;border:1px solid #dc2626}.btn-danger:hover:not(:disabled){background-color:#b91c1c;border-color:#b91c1c}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-danger--sent{background-color:#dc262680;color:#fff;border:1px solid #dc262680}.btn-blue{background-color:var(--color-action-blue);color:#fff;border:none}.btn-blue:hover:not(:disabled){background-color:var(--color-action-blue-hover)}.btn-blue--sent{background-color:var(--success-bg);color:var(--success-text);border:none}.btn-blue--sent:disabled{opacity:1;cursor:default}.btn-google{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-lg);background-color:#f2f2f2;color:#3c4043;border:none;border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:background-color var(--transition-fast)}.btn-google:hover{background-color:#dfe1e3}.btn-google:focus-visible{outline:none;background-color:#dfe1e3}.btn-dismiss{padding:var(--space-sm) var(--space-lg);background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.btn-dismiss:hover{background-color:var(--bg-hover);border-color:var(--border-hover)}.btn-dismiss:focus-visible{outline:none;background-color:var(--bg-hover);border-color:var(--border-hover)}.btn-dismiss:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background-color:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-hover)}.btn-icon{display:flex;align-items:center;justify-content:center;padding:var(--space-xs);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:color var(--transition-fast),background-color var(--transition-fast)}.btn-icon:hover{background:var(--bg-hover)}.btn-icon--danger:hover{color:var(--color-error);background:rgba(var(--color-error-rgb),.1)}.btn.btn-icon:hover{background-color:transparent;border-color:var(--border-hover);color:var(--text-primary)}.context-menu-btn{display:flex;align-items:center;justify-content:center;padding:var(--space-xs);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-tertiary);transition:color var(--transition-fast),background-color var(--transition-fast);flex-shrink:0}.context-menu-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.btn-link{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-size:var(--font-size-sm);padding:0}.btn-link:hover{text-decoration:underline}.btn-link:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.btn-delete{padding:var(--space-xs) var(--space-sm);background-color:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;font-size:var(--font-size-xs);margin-left:var(--space-sm);flex-shrink:0;white-space:nowrap}.btn-delete:hover:not(:disabled){border-color:var(--error-text);color:var(--error-text)}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.btn-row{display:flex;gap:var(--space-sm);margin-top:var(--space-lg)}.btn-row--end{justify-content:flex-end}.btn-group{display:flex;gap:var(--space-sm)}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;margin-bottom:var(--space-xs);color:var(--text-secondary);font-size:var(--font-size-sm)}.form-input{width:100%;padding:var(--space-sm) var(--space-md);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-md)}.form-input--full{width:100%;padding:var(--space-md)}.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-md);min-height:80px;resize:vertical}.form-select{width:100%;padding:var(--space-sm) var(--space-md);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-md)}.form-hint{margin-top:var(--space-xs);font-size:var(--font-size-xs);color:var(--text-tertiary)}.form-input--error{border-color:var(--error-text)!important}.form-input--error:focus{border-color:var(--error-text)!important;box-shadow:0 0 0 2px #ff6b6b33}.form-error-message{margin-top:var(--space-xs);font-size:var(--font-size-sm);color:var(--error-text)}.places-autocomplete-container{width:100%}.pac-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 12px var(--shadow-overlay);font-family:var(--font-family);margin-top:var(--space-xs)}.pac-item{padding:var(--space-sm) var(--space-md);color:var(--text-primary);border-top:1px solid var(--border-color);cursor:pointer}.pac-item:first-child{border-top:none}.pac-item:hover,.pac-item-selected{background-color:var(--bg-hover)}.pac-item-query{color:var(--text-primary);font-weight:500}.pac-matched{font-weight:600;color:var(--accent-primary)}.pac-icon{display:none}.pac-logo:after{display:none}.field{margin-bottom:var(--space-md)}.field-label{display:block;font-weight:500;margin-bottom:var(--space-xs);color:var(--text-secondary);font-size:var(--font-size-sm)}.field-value{font-size:var(--font-size-md);color:var(--text-primary)}.field-hint{margin-left:var(--space-sm);font-size:var(--font-size-xs);color:var(--text-tertiary);font-style:italic}.input-with-prefix{display:flex;align-items:center;position:relative}.input-prefix{position:absolute;left:var(--space-sm);color:var(--text-secondary);pointer-events:none}.input-with-prefix .form-input{padding-left:var(--space-lg)}.form-input--number{text-align:right;font-variant-numeric:tabular-nums;-moz-appearance:textfield}.form-input--number::-webkit-outer-spin-button,.form-input--number::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.form-subtitle{font-size:var(--font-size-md);margin-bottom:var(--space-md)}.form-select--padded{padding:var(--space-md)}.card{background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--space-lg);cursor:pointer;transition:border-color var(--transition-fast);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.card:hover{border-color:var(--border-hover)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0}.card-meta{display:flex;gap:var(--space-lg);color:var(--text-secondary);font-size:var(--font-size-sm);flex-wrap:wrap}.card-meta-item{display:flex;align-items:center;gap:var(--space-xs)}.section{margin-bottom:var(--space-xl);padding:var(--space-lg);background-color:var(--bg-primary);border-radius:var(--radius-lg)}.section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-top:0;margin-bottom:var(--space-lg)}.section-description{color:var(--text-secondary);font-size:var(--font-size-sm);margin-top:0;margin-bottom:var(--space-md)}.section--danger{border-color:var(--error-text);background-color:#ef44440d}.section--danger .section-title{color:var(--error-text)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.section-header .section-title{margin-bottom:0}.section-header-row{display:flex;justify-content:space-between;align-items:center}.section-title--no-margin{margin-bottom:0}.section-description--spaced{margin-top:var(--space-sm)}.section-description--compact{margin-bottom:var(--space-sm)}.action-card{margin-top:var(--space-md);padding:var(--space-lg);border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-secondary);max-width:450px}.action-card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.action-card-title{font-weight:600;font-size:var(--font-size-md);color:var(--text-primary)}.action-card-title--truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.action-card-title--danger{color:var(--error-text)}.action-card-description{font-size:var(--font-size-md);color:var(--text-primary);margin-bottom:var(--space-sm)}.action-card-reason{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-lg)}.action-card-hint{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--space-sm);text-align:center}.action-card-footer{margin-top:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.action-card-checkbox-label{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer}.action-card-checkbox{width:16px;height:16px;cursor:pointer}.action-card-field{margin-bottom:var(--space-md)}.action-card-field--inline{display:flex;align-items:baseline;gap:var(--space-xs)}.action-card-field--inline .action-card-field-value{color:var(--text-secondary);font-size:var(--font-size-sm)}.action-card-email-link{color:var(--text-secondary);font-size:var(--font-size-sm);text-decoration:underline;transition:color var(--transition-fast)}.action-card-email-link:hover{color:var(--text-primary)}.action-card-field-label{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:2px}.action-card-field-value{font-size:var(--font-size-md);color:var(--text-primary)}.action-card-field-value--muted{color:var(--text-tertiary);font-style:italic}.action-card-field-value--bold{font-weight:500}.action-card-content{max-height:200px;overflow-y:auto}.action-card-preview{font-size:var(--font-size-sm);color:var(--text-secondary);background-color:var(--bg-primary);padding:var(--space-sm) var(--space-sm) var(--space-sm) 0;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);border-left:none;white-space:pre-wrap}.action-card-buttons{display:flex;margin-top:var(--space-md)}.action-card-buttons .btn{flex:1}.action-card-close{position:absolute;top:var(--space-sm);right:var(--space-sm);display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease,opacity .25s ease-out}.action-card-close:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.action-card-close:disabled{opacity:.3;cursor:not-allowed}.action-card-collapsible{display:grid;grid-template-rows:1fr}.action-card-collapsible-inner{overflow:hidden}.list-container{display:flex;flex-direction:column;gap:var(--space-md)}.list-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.list-item-clickable{cursor:pointer;transition:border-color var(--transition-fast)}.list-item-clickable:hover{border-color:var(--border-hover)}.list-item-info{display:flex;flex-direction:column}.list-item-title{color:var(--text-primary);font-weight:500}.list-item-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm)}.list-item-meta{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-xs)}.editable-field{margin-bottom:var(--space-md)}.editable-field-input{flex:1}.editable-field-success{color:var(--success-text);display:flex;align-items:center;padding:var(--space-xs) var(--space-sm)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:100}.modal-dialog{background-color:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px var(--shadow-overlay);margin:var(--space-md)}.modal-dialog--sm{max-width:400px}.modal-title{margin:0;margin-bottom:var(--space-sm);font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.modal-body{margin:0;margin-bottom:var(--space-lg);font-size:var(--font-size-md);color:var(--text-secondary);line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.modal-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg)}.preview-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:100}.preview-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px var(--shadow-overlay)}.preview-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.preview-modal-header-content{flex:1;display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-sm)}.preview-modal-title{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.preview-modal-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500}.preview-modal-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.preview-modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.preview-modal-body{padding:var(--space-lg)}.preview-modal-field{margin-bottom:var(--space-md)}.preview-modal-field:last-child{margin-bottom:0}.preview-modal-field-label{display:block;font-weight:500;margin-bottom:var(--space-xs);color:var(--text-secondary);font-size:var(--font-size-sm)}.preview-modal-field-value{font-size:var(--font-size-md);color:var(--text-primary)}.preview-modal-field-value--editable{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);margin:calc(-1 * var(--space-xs)) calc(-1 * var(--space-sm));border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast)}.preview-modal-field-value--editable:hover{background-color:var(--bg-hover)}.preview-modal-edit-icon{opacity:0;color:var(--text-tertiary);transition:opacity var(--transition-fast);flex-shrink:0}.preview-modal-field-value--editable:hover .preview-modal-edit-icon{opacity:1}.preview-modal-edit-row{display:flex;align-items:center;gap:var(--space-xs)}.preview-modal-edit-input{flex:1;min-width:0;padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-md)}.preview-modal-edit-input:focus{outline:none;border-color:var(--accent-primary)}.preview-modal-edit-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.preview-modal-edit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.preview-modal-edit-btn:disabled{opacity:.5;cursor:not-allowed}.preview-modal-edit-btn--save{background-color:var(--accent-primary);color:var(--accent-text)}.preview-modal-edit-btn--save:hover:not(:disabled){background-color:var(--accent-hover)}.preview-modal-edit-btn--cancel{background-color:var(--bg-tertiary);color:var(--text-secondary)}.preview-modal-edit-btn--cancel:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.preview-modal-footer{padding:var(--space-lg);border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.preview-modal-actions{display:flex;gap:var(--space-sm)}.preview-modal-loading,.preview-modal-error{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.preview-modal-error{color:var(--error-text)}.badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.badge--sm{font-size:var(--font-size-sm)}.badge[data-status=scheduled]{background-color:var(--info-bg);color:var(--info-text)}.badge[data-status=in_progress],.badge[data-status=completed]{background-color:var(--success-bg);color:var(--success-text)}.badge[data-status=on_hold]{background-color:var(--warning-bg);color:var(--warning-text)}.badge[data-status=cancelled]{background-color:var(--error-bg);color:var(--error-text)}.badge[data-type=client]{background-color:var(--success-bg);color:var(--success-text)}.badge[data-type=supplier]{background-color:var(--info-bg);color:var(--info-text)}.badge[data-type=sub]{background-color:var(--warning-bg);color:var(--warning-text)}.badge[data-type=other]{background-color:var(--bg-tertiary);color:var(--text-secondary)}.badge-role{font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border-radius:var(--radius-sm);text-transform:capitalize;color:var(--text-primary)}.aging-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);margin-left:var(--space-sm);font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.02em;background-color:var(--bg-tertiary);color:var(--text-secondary)}.aging-badge--current{background-color:var(--color-status-completed);color:#fff}.aging-badge--30{background-color:var(--color-status-on-hold);color:#fff}.aging-badge--60{background-color:var(--color-status-cancelled);color:#fff}.aging-badge--90{background-color:var(--color-danger);color:#fff}.aging-badge--90-plus{background-color:#7f1d1d;color:#fff}.aging-badge--neutral{background-color:var(--bg-tertiary);color:var(--text-secondary)}.relationship-badge{font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border-radius:var(--radius-sm);color:var(--text-primary)}.relationship-desc{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-left:var(--space-sm)}.tags-list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.tag{padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border-radius:var(--radius-pill);font-size:var(--font-size-sm);color:var(--text-secondary)}.alert{padding:var(--space-md);margin-bottom:var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.alert-success{background-color:var(--success-bg);color:var(--success-text)}.alert-error{background-color:var(--error-bg);color:var(--error-text)}.loading-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-secondary)}.loading-state--full{height:100vh}.global-loading-bar{position:fixed;top:0;left:0;right:0;height:4px;z-index:9999;opacity:0;pointer-events:none;transition:opacity .15s ease-in-out;overflow:hidden}.global-loading-bar--visible{opacity:1}.global-loading-bar__indicator{position:absolute;top:0;left:0;background:linear-gradient(90deg,transparent 0%,var(--accent-primary) 25%,var(--accent-primary) 75%,transparent 100%);width:100%;height:100%}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--text-secondary)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:var(--space-md)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.editable-title{display:inline-block;padding:var(--space-xs) var(--space-sm);margin:calc(-1 * var(--space-xs)) calc(-1 * var(--space-sm));border-radius:var(--radius-sm);cursor:text;transition:background-color var(--transition-fast);max-width:100%}.editable-title:hover{background-color:var(--bg-hover)}.editable-title-input{font-size:var(--font-size-lg);font-weight:500;color:var(--text-primary);background-color:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);margin:calc(-1 * var(--space-xs)) calc(-1 * var(--space-sm));width:calc(100% + var(--space-md));min-width:200px;outline:none}.editable-title-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.2)}.editable-title--saving{opacity:.6;pointer-events:none}.contact-name-link{color:var(--text-primary);font-weight:500;cursor:pointer;text-decoration:none}.contact-item-clickable{cursor:pointer;transition:background-color var(--transition-fast)}.contact-item-clickable:hover{background-color:var(--bg-hover)}.notes-text{display:block;color:var(--text-secondary);font-size:var(--font-size-sm);white-space:pre-wrap;cursor:pointer;padding:var(--space-sm);margin:calc(-1 * var(--space-sm));border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.notes-text:hover{background-color:var(--bg-hover);border:1px dashed var(--text-tertiary);margin:calc(-1 * var(--space-sm) - 1px)}.notes-placeholder{color:var(--text-tertiary);font-style:italic}.notes-textarea{color:var(--text-secondary);font-size:var(--font-size-sm);border:none;padding:var(--space-sm);margin:calc(-1 * var(--space-sm));border-radius:var(--radius-md);resize:vertical;min-height:auto;line-height:1.5;width:calc(100% + 2 * var(--space-sm));field-sizing:content}.notes-textarea:focus{outline:none;box-shadow:none}.action-bar{max-width:var(--chat-max-width);margin:0 auto var(--space-md);overflow:visible}.action-stack{display:grid}.action-stack-card{margin-bottom:var(--space-xs)}.action-stack-card:last-child{margin-bottom:0}.action-stack-card--collapsed{cursor:pointer}.action-stack-card--collapsed .action-card-collapsible{grid-template-rows:0fr}.action-stack-card--collapsed .action-card-close{display:none}.action-stack-card--collapsed:hover .action-bar-card{border-color:var(--border-hover)}.action-bar-card{position:relative;padding:var(--space-lg);border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-primary)}.action-bar-card .action-card-header{color:var(--text-primary)}.action-bar-card--danger{background-color:var(--bg-primary)}.action-bar-card--danger .action-card-header,.action-bar-card--danger .action-card-title{color:#dc2626}.action-bar-error{position:absolute;top:0;left:0;right:0;z-index:1;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md) var(--radius-md) 0 0;background-color:var(--error-bg);color:var(--error-text);font-size:var(--font-size-sm);text-align:center}.edit-row{display:flex;gap:var(--space-sm);align-items:center}.relationship-form{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-md);margin-bottom:var(--space-md)}.filter-bar{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.filter-toggle{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.filter-toggle:hover{background-color:var(--bg-hover)}.filter-toggle--active{background-color:var(--bg-tertiary);border-color:var(--text-secondary);color:var(--text-primary)}.filter-toggle--active:hover{background-color:var(--bg-hover);border-color:var(--text-secondary)}.back-link{display:inline-flex;align-items:center;gap:var(--space-xs);color:var(--text-secondary);text-decoration:none;margin-bottom:var(--space-lg);cursor:pointer;background-color:transparent;border:none;padding:0;font-family:inherit;font-size:var(--font-size-sm);line-height:1}.back-link:hover{color:var(--text-primary);text-decoration:none}.flex-row{display:flex;flex-direction:row}.flex-col{display:flex;flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.user-menu{position:relative;margin-top:var(--space-sm)}.user-menu-trigger{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background-color:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;text-align:left;font-size:var(--font-size-sm);transition:background-color var(--transition-fast),color var(--transition-fast)}button.user-menu-trigger:hover{background-color:var(--bg-hover);color:var(--text-primary)}.user-menu-trigger:focus-visible{outline:none}.user-menu-avatar{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background-color:var(--accent-primary);color:#fff;font-size:10px;font-weight:600;flex-shrink:0}.user-menu-email{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-chevron{flex-shrink:0;transition:transform var(--transition-fast)}.user-menu-chevron--open{transform:rotate(180deg)}.user-menu-popover{position:absolute;bottom:100%;left:0;right:0;margin-bottom:var(--space-xs);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 12px var(--shadow-light);z-index:100;overflow:hidden}.user-menu-header{padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary)}.user-menu-header-account{display:block;color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-divider{height:1px;background-color:var(--border-color)}.user-menu-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background-color:transparent;border:none;border-radius:0;color:var(--text-secondary);cursor:pointer;text-align:left;font-size:var(--font-size-sm);transition:background-color var(--transition-fast),color var(--transition-fast)}button.user-menu-item:hover{background-color:var(--bg-hover);color:var(--text-primary)}.user-menu-item--active{background-color:var(--bg-active);color:var(--text-primary)}.google-connect-card{padding:var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);max-width:400px}.google-connect-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.google-connect-title{font-weight:700;color:var(--text-primary)}.google-connect-status{margin-left:auto;padding:2px var(--space-sm);border-radius:var(--radius-pill);font-size:var(--font-size-xs)}.google-connect-status--connected{background-color:var(--success-bg);color:var(--success-text)}.google-connect-status--disconnected{background-color:var(--error-bg);color:var(--error-text)}.google-connect-error{color:var(--error-text);font-size:var(--font-size-sm);margin-bottom:var(--space-sm)}.google-connect-info{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--space-sm)}.google-connect-btn{width:100%;padding:var(--space-sm);background-color:#4285f4;color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm)}.google-connect-btn:hover:not(:disabled){opacity:.9}.google-connect-btn:disabled{opacity:.7;cursor:not-allowed}.google-disconnect-btn{width:100%;padding:var(--space-sm);background-color:var(--error-text);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm)}.google-disconnect-btn:hover:not(:disabled){opacity:.9}.google-disconnect-btn:disabled{opacity:.7;cursor:not-allowed}.add-contact-form{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md);margin-top:var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md)}.add-contact-row{display:flex;gap:var(--space-sm)}.add-contact-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);margin-top:var(--space-md);padding:var(--space-md);background-color:transparent;border:1px dashed var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;width:100%;font-size:var(--font-size-sm);transition:background-color var(--transition-fast),border-color var(--transition-fast)}.add-contact-btn:hover{background-color:var(--bg-hover);border-color:var(--border-hover)}.empty-contacts{color:var(--text-tertiary);font-size:var(--font-size-sm);text-align:center;padding:var(--space-md)}.project-preview-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:100}.project-preview-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px var(--shadow-overlay)}.project-preview-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.project-preview-modal-header-content{flex:1}.project-preview-modal-title{margin:0;margin-bottom:var(--space-xs);font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.project-preview-modal-status-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500}.project-preview-modal-status-badge[data-status=lead]{background-color:var(--bg-tertiary);color:var(--text-secondary)}.project-preview-modal-status-badge[data-status=quoted]{background-color:var(--warning-bg);color:var(--warning-text)}.project-preview-modal-status-badge[data-status=scheduled]{background-color:var(--info-bg);color:var(--info-text)}.project-preview-modal-status-badge[data-status=in_progress]{background-color:#2a3a1a;color:#f59e0b}.project-preview-modal-status-badge[data-status=completed]{background-color:var(--success-bg);color:var(--success-text)}.project-preview-modal-status-badge[data-status=lost]{background-color:var(--error-bg);color:var(--error-text)}.project-preview-modal-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.project-preview-modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.project-preview-modal-body{padding:var(--space-lg)}.project-preview-modal-field{margin-bottom:var(--space-md)}.project-preview-modal-field:last-child{margin-bottom:0}.project-preview-modal-field-label{display:block;font-weight:500;margin-bottom:var(--space-xs);color:var(--text-secondary);font-size:var(--font-size-sm)}.project-preview-modal-field-value{font-size:var(--font-size-md);color:var(--text-primary)}.project-preview-modal-contacts{display:flex;flex-direction:column;gap:var(--space-xs)}.project-preview-modal-contact{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background-color:var(--bg-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.project-preview-modal-contact-name{color:var(--text-primary)}.project-preview-modal-contact-role{color:var(--text-tertiary);font-size:var(--font-size-xs)}.project-preview-modal-footer{padding:var(--space-lg);border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.project-preview-modal-actions{display:flex;gap:var(--space-sm)}.project-preview-modal-loading,.project-preview-modal-error{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.project-preview-modal-error{color:var(--error-text)}.estimate-preview-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:100}.estimate-preview-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px var(--shadow-overlay)}.estimate-preview-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.estimate-preview-modal-header-content{flex:1;display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.estimate-preview-modal-title{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.estimate-preview-modal-type-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500}.estimate-preview-modal-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.estimate-preview-modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.estimate-preview-modal-body{padding:var(--space-lg)}.estimate-preview-modal-field{margin-bottom:var(--space-md)}.estimate-preview-modal-field:last-child{margin-bottom:0}.estimate-preview-modal-field-label{display:block;font-weight:500;margin-bottom:var(--space-xs);color:var(--text-secondary);font-size:var(--font-size-sm)}.estimate-preview-modal-field-value{font-size:var(--font-size-md);color:var(--text-primary)}.estimate-preview-modal-total{font-weight:600;font-size:var(--font-size-lg);color:var(--text-primary)}.estimate-preview-modal-notes{white-space:pre-wrap;color:var(--text-secondary)}.estimate-preview-modal-footer{padding:var(--space-lg);border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.estimate-preview-modal-actions{display:flex;gap:var(--space-sm)}.estimate-preview-modal-loading,.estimate-preview-modal-error{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.estimate-preview-modal-error{color:var(--error-text)}.invoice-preview-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:100}.invoice-preview-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px var(--shadow-overlay)}.invoice-preview-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.invoice-preview-modal-header-content{flex:1;display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.invoice-preview-modal-title{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.invoice-preview-modal-type-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500}.invoice-preview-modal-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.invoice-preview-modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.invoice-preview-modal-body{padding:var(--space-lg)}.invoice-preview-modal-field{margin-bottom:var(--space-md)}.invoice-preview-modal-field:last-child{margin-bottom:0}.invoice-preview-modal-field-label{display:block;font-weight:500;margin-bottom:var(--space-xs);color:var(--text-secondary);font-size:var(--font-size-sm)}.invoice-preview-modal-field-value{font-size:var(--font-size-md);color:var(--text-primary)}.invoice-preview-modal-total{font-weight:600;font-size:var(--font-size-lg);color:var(--text-primary)}.invoice-preview-modal-amount-due{font-weight:600;color:var(--warning-text)}.invoice-preview-modal-notes{white-space:pre-wrap;color:var(--text-secondary)}.invoice-preview-modal-overdue{display:flex;align-items:center;gap:var(--space-sm);color:var(--error-text)}.invoice-preview-modal-overdue-badge{display:inline-block;padding:2px var(--space-sm);background-color:var(--error-bg);color:var(--error-text);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.invoice-preview-modal-footer{padding:var(--space-lg);border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.invoice-preview-modal-actions{display:flex;gap:var(--space-sm)}.invoice-preview-modal-loading,.invoice-preview-modal-error{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.invoice-preview-modal-error{color:var(--error-text)}.insight-list{display:flex;flex-direction:column;gap:var(--space-sm)}.insight-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);gap:var(--space-md)}.insight-item-content{flex:1;min-width:0}.insight-item-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.insight-item-label{font-weight:500;color:var(--text-primary);font-size:var(--font-size-md)}.insight-item-source{font-size:var(--font-size-xs);padding:2px var(--space-sm);border-radius:var(--radius-pill);background-color:var(--bg-tertiary);color:var(--text-tertiary)}.insight-item-source--explicit{background-color:var(--success-bg);color:var(--success-text)}.insight-item-source--inferred{background-color:var(--warning-bg);color:var(--warning-text)}.insight-item-source--stated{background-color:var(--stated-bg);color:var(--stated-text)}.insight-item-value{font-size:var(--font-size-sm);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.insight-item-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.insight-empty{text-align:center;padding:var(--space-xl);color:var(--text-secondary);font-size:var(--font-size-sm)}.insight-editor-form{display:flex;flex-direction:column;gap:var(--space-md)}.insight-editor-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-sm)}.insight-editor-checkbox-row{display:flex;align-items:center;gap:var(--space-sm)}.insight-editor-checkbox{width:18px;height:18px;cursor:pointer}.insight-editor-checkbox-label{font-size:var(--font-size-md);color:var(--text-primary);cursor:pointer}.pending-insights-list{display:flex;flex-direction:column;gap:var(--space-md)}.pending-insight-card{padding:var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid var(--primary)}.pending-insight-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.pending-insight-card-label{font-weight:500;color:var(--text-primary);font-size:var(--font-size-md)}.pending-insight-card-confidence{font-size:var(--font-size-xs);color:var(--text-tertiary);padding:2px var(--space-sm);border-radius:var(--radius-pill);background-color:var(--bg-tertiary)}.pending-insight-card-value{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-sm)}.pending-insight-card-value strong{color:var(--text-primary)}.pending-insight-card-evidence{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-bottom:var(--space-md);font-style:italic}.pending-insight-card-actions{display:flex;gap:var(--space-sm)}.pending-insight-card--stated{border-left-color:var(--stated-text)}.pending-insight-card--inferred{border-left-color:var(--warning-text)}.pending-insight-card-source{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);padding:2px var(--space-sm);border-radius:var(--radius-pill)}.pending-insight-card-source--stated{background-color:var(--stated-bg);color:var(--stated-text)}.pending-insight-card-source--inferred{background-color:var(--warning-bg);color:var(--warning-text)}.insight-help-toggle{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);margin-bottom:var(--space-sm);background:none;border:none;border-radius:var(--radius-sm)}button.insight-help-toggle:hover{background:transparent;color:var(--text-primary)}.insight-help-chevron{transition:transform var(--transition-fast)}.insight-help-chevron--expanded{transform:rotate(90deg)}.insight-help-content{font-size:var(--font-size-xs);color:var(--text-secondary);background-color:var(--bg-tertiary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin-top:var(--space-sm);margin-bottom:var(--space-md)}.insight-help-content ul{margin:var(--space-xs) 0 0 0;padding-left:var(--space-md)}.insight-help-content li{margin-bottom:var(--space-xs)}.insight-source-badge{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);padding:2px var(--space-sm);border-radius:var(--radius-pill)}.insight-source-badge--explicit{background-color:var(--success-bg);color:var(--success-text)}.insight-source-badge--inferred{background-color:var(--warning-bg);color:var(--warning-text)}.insight-source-badge--stated{background-color:var(--stated-bg);color:var(--stated-text)}.insight-source-badge__icon{width:12px;height:12px;flex-shrink:0}.searchable-selector{position:relative;width:100%}.searchable-selector-input-wrapper{position:relative;width:100%;display:flex;align-items:center}.searchable-selector-input{width:100%;padding:var(--space-sm) var(--space-md);padding-right:var(--space-xl);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-md);transition:border-color var(--transition-fast)}.searchable-selector-input::placeholder{color:var(--text-tertiary)}.searchable-selector-input:hover{border-color:var(--border-hover)}.searchable-selector-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.2)}.searchable-selector-clear{position:absolute;right:var(--space-sm);display:flex;align-items:center;justify-content:center;padding:4px;background:none;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.searchable-selector-clear:hover{color:var(--text-primary);background-color:var(--bg-hover)}.searchable-selector-popover{position:absolute;top:100%;left:0;right:0;margin-top:0;background-color:var(--bg-primary);border:1px solid var(--border-color);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:0 4px 12px var(--shadow-light);z-index:50;max-height:300px;overflow:hidden}.searchable-selector-results{overflow-y:auto;max-height:300px}.searchable-selector-item{padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background-color var(--transition-fast)}.searchable-selector-item:hover,.searchable-selector-item--highlighted{background-color:var(--bg-hover)}.searchable-selector-item-main{display:flex;align-items:center;gap:var(--space-sm)}.searchable-selector-item-name{font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.searchable-selector-item-badge{flex-shrink:0;padding:2px var(--space-xs);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.searchable-selector-item-badge[data-type=client]{background-color:var(--success-bg);color:var(--success-text)}.searchable-selector-item-badge[data-type=supplier]{background-color:var(--info-bg);color:var(--info-text)}.searchable-selector-item-badge[data-type=sub]{background-color:var(--warning-bg);color:var(--warning-text)}.searchable-selector-item-badge[data-type=other],.searchable-selector-item-badge[data-status=lead]{background-color:var(--bg-tertiary);color:var(--text-secondary)}.searchable-selector-item-badge[data-status=quoted]{background-color:var(--warning-bg);color:var(--warning-text)}.searchable-selector-item-badge[data-status=scheduled]{background-color:var(--info-bg);color:var(--info-text)}.searchable-selector-item-badge[data-status=in_progress],.searchable-selector-item-badge[data-status=completed]{background-color:var(--success-bg);color:var(--success-text)}.searchable-selector-item-badge[data-status=lost]{background-color:var(--error-bg);color:var(--error-text)}.searchable-selector-item-meta{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.searchable-selector-loading,.searchable-selector-empty{padding:var(--space-lg);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm)}.searchable-selector-create{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border-color);color:var(--accent-primary);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;transition:background-color var(--transition-fast);background-color:var(--bg-primary)}.searchable-selector-create:hover{background-color:var(--bg-hover)}.searchable-selector-results:empty~.searchable-selector-create{border-top:none}.quick-contact-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-md)}.quick-contact-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 8px 32px var(--shadow-medium);width:100%;max-width:400px;max-height:90vh;overflow-y:auto}.quick-contact-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.quick-contact-modal-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0}.quick-contact-modal-close{display:flex;align-items:center;justify-content:center;padding:var(--space-xs);background:none;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.quick-contact-modal-close:hover{color:var(--text-primary);background-color:var(--bg-hover)}.quick-contact-modal-close:disabled{opacity:.5;cursor:not-allowed}.quick-contact-modal-error{margin:var(--space-md) var(--space-lg) 0;padding:var(--space-sm) var(--space-md);background-color:var(--error-bg);color:var(--error-text);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.quick-contact-modal-form{padding:var(--space-lg)}.quick-contact-modal-form .form-group{margin-bottom:var(--space-md)}.quick-contact-modal-form .form-group:last-of-type{margin-bottom:var(--space-lg)}.quick-contact-modal-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.contact-preview-modal-edit-btn:disabled,.project-preview-modal-edit-btn:disabled{opacity:.5;cursor:not-allowed}.contact-preview-modal-edit-btn--save,.project-preview-modal-edit-btn--save{background-color:var(--accent-primary);color:var(--accent-text)}.contact-preview-modal-edit-btn--save:hover:not(:disabled),.project-preview-modal-edit-btn--save:hover:not(:disabled){background-color:var(--accent-hover)}.contact-preview-modal-edit-btn--cancel,.project-preview-modal-edit-btn--cancel{background-color:var(--bg-tertiary);color:var(--text-secondary)}.contact-preview-modal-edit-btn--cancel:hover:not(:disabled),.project-preview-modal-edit-btn--cancel:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.project-preview-modal-edit-textarea{resize:vertical;min-height:60px}.project-preview-modal-status-badge--editable{cursor:pointer;transition:transform var(--transition-fast),opacity var(--transition-fast)}.project-preview-modal-status-badge--editable:hover{transform:scale(1.05);opacity:.9}.project-preview-modal-status-select{padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500}.project-preview-modal-status-select:focus{outline:none;border-color:var(--accent-primary)}.relationship-cards-section{margin-top:var(--space-xl)}.relationship-cards-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-md) 0}.relationship-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-md)}.relationship-cards-empty{color:var(--text-tertiary);font-size:var(--font-size-sm);padding:var(--space-md);text-align:center;border:1px dashed var(--border-color);border-radius:var(--radius-md)}.relationship-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md)}.relationship-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.relationship-card-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);margin:0}.relationship-card-count{font-size:var(--font-size-xs);font-weight:500;color:var(--text-tertiary);background:var(--bg-secondary);padding:2px var(--space-sm);border-radius:var(--radius-pill)}.relationship-card-list{display:flex;flex-direction:column;gap:var(--space-xs)}.relationship-card-item{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-sm);background-color:var(--bg-secondary);border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border-color);transition:border-color var(--transition-fast);font:inherit;text-align:left;width:100%;color:inherit}button.relationship-card-item:hover{border-color:var(--border-hover);background-color:var(--bg-secondary)}button.relationship-card-item:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.relationship-card-item-info{flex:1;min-width:0}.relationship-card-item-main{display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap}.relationship-card-item-name{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary)}.relationship-card-item-meta{margin-top:var(--space-xs);display:flex;flex-direction:column;gap:2px;font-size:var(--font-size-xs);color:var(--text-tertiary)}.relationship-card-item-label{color:var(--text-secondary)}.relationship-card-item-detail{color:var(--text-tertiary)}.relationship-card-item-actions{display:flex;gap:var(--space-xs);flex-shrink:0;margin-left:var(--space-sm)}.relationship-card-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);color:var(--text-tertiary);background:transparent;border:none;padding:0;transition:background-color var(--transition-fast),color var(--transition-fast)}.relationship-card-action-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.relationship-card-expand{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);width:100%;padding:var(--space-sm);margin-top:var(--space-sm);font-size:var(--font-size-xs);font-weight:500;color:var(--text-tertiary);background:none;border:none;border-top:1px solid var(--border-color);cursor:pointer;transition:color var(--transition-fast)}.relationship-card-expand:hover{color:var(--accent-primary)}.metadata-section{background-color:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-md)}.metadata-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md)}.metadata-field{display:flex;flex-direction:column;gap:var(--space-xs)}.metadata-field-label{font-size:var(--font-size-sm);color:var(--text-muted);font-weight:500}.metadata-field-value{font-size:var(--font-size-md);color:var(--text-primary)}.metadata-field-value--currency{font-weight:600;color:var(--success-text)}.metadata-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-sm);background-color:var(--bg-tertiary);color:var(--text-secondary)}.metadata-badge--emergency{background-color:var(--error-bg);color:var(--error-text)}.metadata-badge--permits{background-color:var(--warning-bg);color:var(--warning-text)}.metadata-badge--success{background-color:var(--success-bg);color:var(--success-text)}.metadata-summary{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-sm)}.metadata-cost-indicator{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--success-text);font-weight:500}.metadata-cost-indicator svg{flex-shrink:0}.metadata-flag{display:inline-flex;align-items:center;padding:2px 6px;font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-sm);background-color:var(--error-bg);color:var(--error-text)}.metadata-field--editable{cursor:pointer;padding:var(--space-xs);margin:calc(-1 * var(--space-xs));border-radius:var(--radius-sm);transition:background-color .15s ease}.metadata-field--editable:hover{background-color:var(--bg-tertiary)}.metadata-empty{color:var(--text-muted);font-size:var(--font-size-sm);font-style:italic}@media (max-width: 767px){.filter-bar{flex-direction:column;gap:var(--space-sm)}.filter-search,.filter-select{width:100%;min-width:unset}.card{padding:var(--space-md);position:relative}.card-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.card .context-menu-btn{position:absolute;top:var(--space-md);right:var(--space-md)}.insight-item-header{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.modal-overlay{align-items:flex-end}.modal-dialog{width:100%;max-width:100%;max-height:90vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin:0}.modal-footer{flex-direction:column-reverse;gap:var(--space-sm)}.modal-footer button{width:100%}}.entity-pill{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px var(--space-sm);border-radius:var(--radius-pill);font-size:var(--font-size-sm);line-height:1.4;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast),opacity var(--transition-fast);max-width:200px}.entity-pill:hover{opacity:.85}.entity-pill:active{opacity:.7}.entity-pill:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.entity-pill-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.entity-pill-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entity-pill--contact{background-color:#60a5fa33;color:var(--entity-contact-accent);border:1px solid rgba(96,165,250,.4)}.entity-pill--project{background-color:#a78bfa33;color:var(--entity-project-accent);border:1px solid rgba(167,139,250,.4)}.entity-pill--calendar{background-color:#60a5fa33;color:var(--entity-calendar-accent);border:1px solid rgba(96,165,250,.4)}.entity-pill--estimate{background-color:#9a9a9a33;color:var(--entity-estimate-accent);border:1px solid rgba(154,154,154,.4)}.entity-pill--invoice{background-color:#f59e0b33;color:var(--entity-invoice-accent);border:1px solid rgba(245,158,11,.4)}.entity-row{display:flex;flex-wrap:nowrap;gap:var(--space-xs);padding:var(--space-xs) 0;margin:0 auto var(--space-sm);max-width:var(--chat-max-width);overflow-x:auto;min-height:36px;max-height:40px;align-items:center;justify-content:flex-start}.entity-row::-webkit-scrollbar{height:4px}.entity-row::-webkit-scrollbar-track{background:transparent}.entity-row::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-pill)}.entity-row::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.entity-row--expanded{max-height:none}.entity-pill--overflow{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);flex-shrink:0}.entity-pill--overflow:hover{background-color:var(--bg-hover);color:var(--text-primary)}.inline-edit{position:relative;display:inline-flex;align-items:center;gap:var(--space-xs);min-height:var(--touch-target-min)}.inline-edit-value{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);margin:calc(-1 * var(--space-xs)) calc(-1 * var(--space-sm));border-radius:var(--radius-sm);color:var(--text-primary);cursor:default;transition:background-color var(--transition-fast)}.inline-edit-value:hover{background-color:var(--inline-edit-hover-bg)}.inline-edit-value:focus{outline:none;background-color:var(--inline-edit-hover-bg)}.inline-edit-value:focus-visible{box-shadow:var(--inline-edit-focus-shadow)}.inline-edit-icon{display:none}.inline-edit-input{flex:1;min-width:0;padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border:1px solid var(--inline-edit-focus-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:inherit;font-family:inherit;line-height:inherit;box-shadow:var(--inline-edit-focus-shadow)}.inline-edit-input:focus{outline:none}.inline-edit-input::placeholder{color:var(--text-tertiary)}.inline-edit-textarea{resize:vertical;min-height:60px;field-sizing:content}.inline-edit-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.inline-edit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.inline-edit-btn:disabled{opacity:.5;cursor:not-allowed}.inline-edit-btn--save{background-color:var(--accent-primary);color:var(--accent-text)}.inline-edit-btn--save:hover:not(:disabled){background-color:var(--accent-hover)}.inline-edit-btn--cancel{background-color:var(--bg-tertiary);color:var(--text-secondary)}.inline-edit-btn--cancel:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.inline-edit-row{display:flex;align-items:center;gap:var(--space-xs);width:100%}.inline-edit--editing .inline-edit-value{display:none}.inline-edit--saving{opacity:var(--inline-edit-saving-opacity);pointer-events:none}.inline-edit-spinner{display:none;width:14px;height:14px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:inline-edit-spin .8s linear infinite}.inline-edit--saving .inline-edit-spinner{display:inline-block}@keyframes inline-edit-spin{to{transform:rotate(360deg)}}.inline-edit-success-icon{display:none;color:var(--inline-edit-success-color)}.inline-edit--success .inline-edit-success-icon{display:inline-flex;animation:inline-edit-success-fade var(--inline-edit-success-duration) ease-out forwards}@keyframes inline-edit-success-fade{0%{opacity:1}70%{opacity:1}to{opacity:0}}.inline-edit--error .inline-edit-input{border-color:var(--inline-edit-error-color)}.inline-edit-error{display:none;color:var(--inline-edit-error-color);font-size:var(--font-size-sm);margin-top:var(--space-xs)}.inline-edit--error .inline-edit-error{display:block}.inline-edit--full-width{display:flex;width:100%}.inline-edit--full-width .inline-edit-input{width:100%}.inline-edit--compact{min-height:auto}.inline-edit--compact .inline-edit-value{padding:2px var(--space-xs);margin:-2px calc(-1 * var(--space-xs))}.inline-edit--compact .inline-edit-input{padding:2px var(--space-xs)}select.inline-edit-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:var(--space-lg);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-sm) center;background-size:14px}.inline-edit-tags{flex-wrap:wrap}.inline-edit-tags-display{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.inline-edit-tags-editor{display:flex;flex-wrap:wrap;gap:var(--space-xs);padding:var(--space-xs);background-color:var(--bg-input);border:1px solid var(--inline-edit-focus-border);border-radius:var(--radius-sm);box-shadow:var(--inline-edit-focus-shadow);min-height:36px;align-items:center}.inline-edit-tag{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px var(--space-sm);background-color:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--text-primary)}.inline-edit-tag--readonly{cursor:default}.inline-edit-tag-remove{display:flex;align-items:center;justify-content:center;padding:0;border:none;background:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-xs);transition:color var(--transition-fast),background-color var(--transition-fast)}.inline-edit-tag-remove:hover{color:var(--text-primary);background-color:var(--bg-hover)}.inline-edit-tags-input{flex:1;min-width:80px;padding:2px var(--space-xs);border:none;background:none;font-size:inherit;font-family:inherit;color:var(--text-primary)}.inline-edit-tags-input:focus{outline:none}.inline-edit-tags-input::placeholder{color:var(--text-tertiary)}.inline-edit-tags-suggestions{position:absolute;top:100%;left:0;right:0;z-index:10;margin-top:var(--space-xs);padding:var(--space-xs);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.inline-edit-tags-suggestion{display:block;width:100%;padding:var(--space-xs) var(--space-sm);border:none;background:none;text-align:left;font-size:var(--font-size-sm);color:var(--text-primary);cursor:pointer;border-radius:var(--radius-xs);transition:background-color var(--transition-fast)}.inline-edit-tags-suggestion:hover{background-color:var(--bg-hover)}.inline-edit-cell{display:flex;align-items:center;width:100%;min-height:36px;padding:var(--space-xs) var(--space-sm)}.inline-edit-cell .inline-edit{width:100%}.inline-edit-cell .inline-edit-value{width:100%;justify-content:flex-start}.inline-edit-cell .inline-edit-input{width:100%}.inline-edit-cell--numeric .inline-edit-value{justify-content:flex-end}.inline-edit-cell--numeric .inline-edit-input{text-align:right}.line-item-cell--editable{cursor:default;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);overflow:visible}.line-item-cell--editable:hover{background-color:var(--inline-edit-hover-bg)}.line-item-row--editing{background-color:var(--bg-secondary)}.line-item-delete-btn{opacity:0;transition:opacity var(--transition-fast)}.line-item-row:hover .line-item-delete-btn,.line-item-row:focus-within .line-item-delete-btn{opacity:1}.line-item-row--clickable{cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.line-item-row--clickable:hover{background-color:var(--inline-edit-hover-bg)}.line-item-row--clickable:focus{outline:none;background-color:var(--inline-edit-hover-bg)}.line-item-row--clickable:focus-visible{box-shadow:var(--inline-edit-focus-shadow)}.line-item-display-value{display:block;width:100%}.line-item-placeholder{color:var(--text-tertiary)}.line-item-row-input{width:100%;padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border:1px solid var(--inline-edit-focus-border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:inherit;font-family:inherit;line-height:inherit;box-shadow:var(--inline-edit-focus-shadow)}.line-item-row-input:focus{outline:none;border-color:var(--accent-primary)}.line-item-row-input::placeholder{color:var(--text-tertiary)}.line-item-row-input--numeric{text-align:right}.line-item-row--editing .inline-edit-cell{padding:0}.line-item-row--editing .line-item-cell--editable:hover{background-color:transparent}@media (max-width: 767px){.inline-edit{min-height:var(--touch-target-min)}.inline-edit-value{min-height:var(--touch-target-min);padding:var(--space-sm);margin:calc(-1 * var(--space-sm))}.inline-edit-btn{width:36px;height:36px}.line-item-delete-btn{opacity:1}}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding-right:calc(var(--space-md) + 32px)}.password-toggle-btn{position:absolute;right:var(--space-sm);display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.password-toggle-btn:hover:not(:disabled){color:var(--text-secondary);background-color:var(--bg-hover)}.password-toggle-btn:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.password-toggle-btn:disabled{cursor:not-allowed;opacity:.5}.password-input-container{position:relative}.password-strength-popover{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:var(--space-xs);animation:password-popover-fade-in .15s ease-out}@keyframes password-popover-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.password-strength-indicator{padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);box-shadow:0 4px 12px #00000026;border:1px solid var(--border-color)}.password-strength-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.password-strength-label{color:var(--text-secondary)}.password-strength-level{font-weight:500}.password-strength-level--weak{color:var(--color-danger)}.password-strength-level--medium{color:var(--color-warning)}.password-strength-level--strong{color:var(--color-success)}.password-requirements-list{list-style:none;margin:0;padding:0}.password-requirement{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) 0}.password-requirement-icon{flex-shrink:0;width:16px;text-align:center;font-weight:600}.password-requirement--met .password-requirement-icon{color:var(--color-success)}.password-requirement--unmet .password-requirement-icon{color:var(--color-danger)}.password-requirement--met .password-requirement-label{color:var(--text-secondary)}.password-requirement--unmet .password-requirement-label{color:var(--text-primary)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);padding:var(--space-lg)}.auth-card{width:100%;max-width:400px;padding:var(--space-xl);background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.auth-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-lg);text-align:center}.auth-divider{display:flex;align-items:center;margin:var(--space-lg) 0;color:var(--text-tertiary)}.auth-divider-line{flex:1;height:1px;background-color:var(--border-color)}.auth-divider-text{padding:0 var(--space-md);font-size:var(--font-size-sm)}.auth-footer{margin-top:var(--space-lg);text-align:center;color:var(--text-secondary);font-size:var(--font-size-sm)}.auth-logo{display:flex;justify-content:center;margin-bottom:var(--space-lg)}.contact-info-link{text-decoration:underline dotted;text-decoration-skip-ink:none;text-underline-offset:2px}.contact-info-link:hover{text-decoration:underline dotted}.message-content{line-height:1.6;word-wrap:break-word;overflow-wrap:anywhere;max-width:100%;min-width:0}.message-content h1,.message-content h2,.message-content h3,.message-content h4,.message-content h5,.message-content h6{margin-top:1em;margin-bottom:.5em;font-weight:600;line-height:1.25;color:var(--text-primary)}.message-content h1:first-child,.message-content h2:first-child,.message-content h3:first-child,.message-content h4:first-child,.message-content h5:first-child,.message-content h6:first-child{margin-top:0}.message-content h1{font-size:1.5em}.message-content h2{font-size:1.3em}.message-content h3{font-size:1.15em}.message-content h4,.message-content h5,.message-content h6{font-size:1em}.message-content p{margin-top:0;margin-bottom:.75em}.message-content p:last-child{margin-bottom:0}.message-content ul,.message-content ol{margin-top:0;margin-bottom:.75em;padding-left:1.5em}.message-content li{margin-bottom:.25em}.message-content li:last-child{margin-bottom:0}.message-content code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace;font-size:.9em;background-color:var(--bg-tertiary);color:var(--text-primary);padding:.15em .35em;border-radius:var(--radius-sm)}.message-content pre{margin-top:0;margin-bottom:.75em;padding:.75em 1em;background-color:var(--bg-primary);border-radius:var(--radius-md);overflow-x:auto;border:1px solid var(--border-color)}.message-content pre code{background-color:transparent;padding:0;font-size:.85em;line-height:1.45}.message-content blockquote{margin:0 0 .75em;padding:.5em 1em;border-left:4px solid var(--accent-primary);background-color:var(--bg-tertiary);color:var(--text-secondary)}.message-content blockquote p:last-child{margin-bottom:0}.message-content a{color:var(--accent-primary);text-decoration:underline}.message-content a:hover{color:var(--accent-hover)}.message-content table{border-collapse:collapse;margin-bottom:.75em;width:100%}.message-content th,.message-content td{border:1px solid var(--border-color);padding:.4em .6em;text-align:left}.message-content th{background-color:var(--bg-tertiary);font-weight:600}.message-content hr{border:none;border-top:1px solid var(--border-color);margin:1em 0}.message-content img{max-width:100%;height:auto;border-radius:var(--radius-md)}@keyframes thinking-dot-pulse{0%,60%,to{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}.thinking-indicator{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) 0;animation:thinking-fade-in var(--transition-normal) ease-out}.thinking-indicator-inline{padding-left:var(--space-md);margin-top:var(--space-xs)}@keyframes thinking-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.thinking-indicator-dot{width:8px;height:8px;background-color:var(--text-tertiary);border-radius:50%;animation:thinking-dot-pulse 1.4s infinite ease-in-out}.thinking-indicator-dot:nth-child(1){animation-delay:0s}.thinking-indicator-dot:nth-child(2){animation-delay:.2s}.thinking-indicator-dot:nth-child(3){animation-delay:.4s}@keyframes thinking-shimmer{0%{background-position:-100% 0}to{background-position:100% 0}}.thinking-indicator-text{font-size:var(--font-size-sm);font-style:italic;background:linear-gradient(90deg,var(--text-secondary) 25%,var(--text-primary) 50%,var(--text-secondary) 75%);background-size:200% 100%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:thinking-shimmer 2s linear infinite;opacity:1;transition:opacity var(--transition-slow)}.thinking-indicator-text--fading{opacity:0}.streaming-message{display:block;width:100%;animation:streaming-fade-in .15s ease-out}@keyframes streaming-fade-in{0%{opacity:.7}to{opacity:1}}.chat-container{display:flex;flex-direction:column;height:100vh;background-color:var(--bg-secondary)}.chat-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary)}.chat-title{margin:0;font-size:var(--font-size-lg);font-weight:500;color:var(--text-primary)}.chat-messages-area{position:relative;flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column-reverse}.chat-messages--loading{visibility:hidden}.chat-messages-inner{max-width:var(--chat-max-width);margin:0 auto;width:100%}.chat-loading-older,.chat-beginning{text-align:center;padding:var(--space-md);color:var(--text-tertiary);font-size:var(--font-size-sm)}.chat-empty{color:var(--text-tertiary);text-align:center;padding:var(--space-2xl)}.chat-message{margin-bottom:var(--space-lg)}.chat-message--user{display:flex;justify-content:flex-end}.chat-message-user-bubble{max-width:80%;padding:var(--space-sm) var(--space-md);background-color:var(--accent-primary);color:var(--accent-text);border-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-sm);white-space:pre-wrap}.chat-message--assistant{position:relative;display:flex;flex-direction:column;align-items:flex-start;max-width:100%;overflow:hidden}.chat-message-assistant-bubble{width:100%;padding:var(--space-md) 0;color:var(--text-primary);overflow:hidden}.chat-message-system-bubble{text-align:center;padding:var(--space-md);color:var(--text-secondary);font-size:var(--font-size-sm)}.chat-message-system-bubble a{color:inherit;text-decoration:underline}.chat-message-system-bubble a:hover{color:var(--text-primary)}.chat-time-header{text-align:center;color:var(--text-tertiary);font-size:var(--font-size-xs);margin:var(--space-lg) 0;padding:var(--space-xs) 0}.chat-scroll-btn{position:absolute;bottom:var(--space-lg);left:50%;transform:translate(-50%);width:48px;height:48px;border-radius:50%;background-color:var(--bg-tertiary);border:1px solid var(--border-color);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity var(--transition-fast),background-color var(--transition-fast);z-index:10;padding:0}.chat-scroll-btn:hover{background-color:var(--bg-hover)}.chat-scroll-btn--hidden{opacity:0;pointer-events:none}.chat-scroll-btn-icon{font-size:24px;line-height:1;color:var(--text-secondary)}.chat-input-area{padding:var(--space-lg);background-color:var(--bg-secondary);border-top:1px solid var(--border-color)}.chat-input-container{max-width:var(--chat-max-width);margin:0 auto;position:relative}.chat-entity-selector{max-width:var(--chat-max-width);margin:0 auto var(--space-md);padding:var(--space-md);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg)}.chat-entity-selector-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);font-weight:500;color:var(--text-primary)}.chat-entity-selector-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--space-xs);line-height:1;font-size:1.2rem}.chat-entity-selector-close:hover{color:var(--text-primary)}.chat-entity-selector-fields{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.chat-entity-selector-field{display:flex;flex-direction:column;gap:var(--space-xs)}.chat-entity-selector-field label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.chat-entity-selector-info{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);color:var(--text-secondary)}.chat-entity-link-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;flex-shrink:0;transition:color var(--transition-fast),background-color var(--transition-fast)}button.chat-entity-link-btn:hover:not(:disabled){color:var(--accent-primary)}.chat-entity-link-btn:disabled{opacity:.5;cursor:not-allowed}.chat-input-wrapper{display:flex;align-items:center;gap:var(--space-sm);background-color:var(--bg-input);border-radius:var(--radius-xl);padding:var(--space-sm) var(--space-md);border:1px solid var(--border-color);transition:border-color var(--transition-fast)}.chat-textarea{flex:1;border:none;background-color:transparent;color:var(--text-primary);font-size:var(--font-size-md);resize:none;outline:none;padding:var(--space-sm) 0;min-height:24px;max-height:200px;overflow-y:auto}.chat-send-btn{padding:var(--space-sm) var(--space-md);background-color:var(--accent-primary);color:var(--accent-text);border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.chat-send-btn:hover:not(:disabled){background-color:var(--accent-hover)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-mic-btn{padding:var(--space-sm) var(--space-md);background-color:transparent;color:var(--text-secondary);border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast)}.chat-mic-btn:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.chat-mic-btn:disabled{opacity:.5;cursor:not-allowed}.chat-mic-btn--recording{color:var(--status-error);animation:mic-pulse 1.5s ease-in-out infinite}.chat-mic-btn--recording:hover:not(:disabled){color:var(--status-error)}.chat-mic-btn--transcribing{color:var(--accent-primary);opacity:.7}@keyframes mic-pulse{0%,to{opacity:1}50%{opacity:.5}}.chat-auto-speak-btn{padding:var(--space-sm) var(--space-md);background-color:transparent;color:var(--text-secondary);border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast)}.chat-auto-speak-btn:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.chat-auto-speak-btn:disabled{opacity:.5;cursor:not-allowed}.chat-auto-speak-btn--enabled{color:var(--accent-primary);background-color:rgba(var(--accent-primary-rgb),.1)}.chat-auto-speak-btn--enabled:hover:not(:disabled){background-color:rgba(var(--accent-primary-rgb),.2);color:var(--accent-primary)}.chat-hint{margin-top:var(--space-sm);text-align:center;font-size:var(--font-size-xs);color:var(--text-tertiary)}@media (max-width: 768px){.chat-hint{display:none}}.chat-container--transitioning .chat-messages-inner{opacity:.6;transition:opacity var(--transition-fast)}.chat-transition-indicator{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary) 0%,var(--accent-primary) 30%,transparent 30%);background-size:200% 100%;animation:chat-transition-slide 1s linear infinite;z-index:100}@keyframes chat-transition-slide{0%{background-position:100% 0}to{background-position:-100% 0}}.chat-transition-error{display:flex;align-items:center;justify-content:space-between;border-radius:0;margin:0}.chat-transition-error-dismiss{background:transparent;border:none;color:inherit;font-size:var(--font-size-lg);cursor:pointer;padding:0 var(--space-sm);opacity:.7;transition:opacity var(--transition-fast)}.chat-transition-error-dismiss:hover{opacity:1}.welcome-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:var(--bg-secondary);padding:var(--space-lg)}.welcome-content{text-align:center;max-width:400px}.welcome-icon{margin-bottom:var(--space-lg);color:var(--text-tertiary)}.welcome-title{font-size:var(--font-size-2xl);font-weight:500;color:var(--text-primary);margin-bottom:var(--space-sm)}.welcome-subtitle{font-size:var(--font-size-md);color:var(--text-secondary);margin-bottom:var(--space-xl)}.welcome-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);font-size:var(--font-size-md)}.message-actions-container{display:flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-sm);transition:opacity var(--transition-fast)}.message-action-btn{display:flex;align-items:center;justify-content:center;padding:var(--space-xs);background-color:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-tertiary);transition:background-color var(--transition-fast),color var(--transition-fast)}button.message-action-btn:hover:not(:disabled){color:var(--accent-primary)}.message-action-btn.active{color:var(--accent-primary)}.message-action-copy{position:relative}.copied-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--space-xs) var(--space-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:var(--font-size-xs);border-radius:var(--radius-sm);white-space:nowrap;margin-bottom:var(--space-xs)}.message-action-speak{position:relative}.message-action-speak.loading{cursor:wait}.message-action-speak.loading .tts-loading-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mention-autocomplete{position:absolute;bottom:100%;left:0;right:0;margin-bottom:var(--space-xs);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 -4px 12px var(--shadow-light);z-index:50;max-height:280px;display:flex;flex-direction:column;overflow:hidden;animation:mention-autocomplete-appear .15s ease-out}@keyframes mention-autocomplete-appear{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.mention-autocomplete-list{overflow-y:auto;max-height:220px}.mention-autocomplete-item{padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background-color var(--transition-fast)}.mention-autocomplete-item:hover,.mention-autocomplete-item--highlighted{background-color:var(--bg-hover)}.mention-autocomplete-item-main{display:flex;align-items:center;gap:var(--space-sm)}.mention-autocomplete-item-name{font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mention-autocomplete-item-badge{flex-shrink:0;padding:2px var(--space-xs);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.mention-autocomplete-item-badge[data-type=client]{background-color:var(--success-bg);color:var(--success-text)}.mention-autocomplete-item-badge[data-type=supplier]{background-color:var(--info-bg);color:var(--info-text)}.mention-autocomplete-item-badge[data-type=sub]{background-color:var(--warning-bg);color:var(--warning-text)}.mention-autocomplete-item-badge[data-type=other],.mention-autocomplete-item-badge[data-status=lead]{background-color:var(--bg-tertiary);color:var(--text-secondary)}.mention-autocomplete-item-badge[data-status=quoted]{background-color:var(--warning-bg);color:var(--warning-text)}.mention-autocomplete-item-badge[data-status=scheduled]{background-color:var(--info-bg);color:var(--info-text)}.mention-autocomplete-item-badge[data-status=in_progress],.mention-autocomplete-item-badge[data-status=completed]{background-color:var(--success-bg);color:var(--success-text)}.mention-autocomplete-item-badge[data-status=lost]{background-color:var(--error-bg);color:var(--error-text)}.mention-autocomplete-item-meta{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mention-autocomplete-loading{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-lg);color:var(--text-tertiary);font-size:var(--font-size-sm)}.mention-autocomplete-loading-spinner{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:mention-spinner .8s linear infinite}@keyframes mention-spinner{to{transform:rotate(360deg)}}.mention-autocomplete-empty{padding:var(--space-lg);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm)}.mention-autocomplete-hint{padding:var(--space-xs) var(--space-md);border-top:1px solid var(--border-color);font-size:var(--font-size-xs);color:var(--text-tertiary);background-color:var(--bg-secondary)}.mention-input-wrapper{position:relative;flex:1;display:flex;align-items:flex-start}.mention-input{flex:1;border:none;background-color:transparent;color:var(--text-primary);font-size:var(--font-size-md);cursor:text;line-height:1.5;resize:none;outline:none;padding:var(--space-sm) 0;min-height:24px;max-height:200px;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}.mention-input:empty:before{content:""}.mention-input--disabled{opacity:.5;cursor:not-allowed}.mention-input-placeholder{position:absolute;top:var(--space-sm);left:0;color:var(--text-tertiary);pointer-events:none;font-size:var(--font-size-md);line-height:1.5;opacity:1;transition:opacity var(--transition-slow)}.mention-input-placeholder--fade-out{opacity:0}.mention-input-chip{display:inline-flex;align-items:center;padding:3px var(--space-sm);margin:0 1px;border-radius:var(--radius-pill);font-size:var(--font-size-sm);line-height:1.4;vertical-align:baseline;cursor:default;-webkit-user-select:none;user-select:none;opacity:.9}.mention-input-chip--contact{background-color:#6366f140;color:#fff;border:1px solid rgba(129,140,248,.6)}.mention-input-chip--project{background-color:#06b6d440;color:#fff;border:1px solid rgba(34,211,238,.6)}.mention-input-chip--message{-webkit-user-select:text;user-select:text;cursor:text}.mention-input-chip--message.mention-input-chip--contact{background-color:#e0e7ffd9;color:#3730a3;border:1px solid rgba(165,180,252,.9)}.mention-input-chip--message.mention-input-chip--project{background-color:#cffafed9;color:#0a5d72;border:1px solid rgba(103,232,249,.9)}.mention-input-chip-icon{flex-shrink:0;width:13px;height:13px}.chat-content-dropzone{position:relative;display:flex;flex-direction:column;flex:1;min-height:0;outline:none}.chat-content-dropzone-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:rgba(var(--accent-primary-rgb),.08);border:2px dashed var(--accent-primary);border-radius:var(--radius-md);z-index:100;font-weight:500;font-size:var(--font-size-lg);color:var(--accent-primary);pointer-events:none;animation:dropzone-fade-in .15s ease-out}@keyframes dropzone-fade-in{0%{opacity:0}to{opacity:1}}.chat-upload-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;flex-shrink:0;transition:color var(--transition-fast),background-color var(--transition-fast)}button.chat-upload-btn:hover:not(:disabled){color:var(--accent-primary)}.chat-upload-btn:disabled{opacity:.5;cursor:not-allowed}.chat-attachments{display:flex;flex-wrap:wrap;gap:var(--space-xs);padding:0 0 var(--space-sm) 0;max-width:100%;overflow:hidden}.message-attachments{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.chat-file-actions{display:flex;gap:var(--space-xs);margin-top:var(--space-xs)}.chat-file-link-btn{padding:var(--space-xs) var(--space-sm);background:none;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;cursor:pointer;display:flex;align-items:center;gap:var(--space-xs);transition:all var(--transition-fast)}.chat-file-link-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.chat-file-link-btn svg{width:12px;height:12px}@media (max-width: 767px){.chat-container{height:100%;overflow:hidden}.chat-messages-area{flex:1;overflow:hidden}.chat-messages{-webkit-overflow-scrolling:touch}.chat-input-area{padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom))}.chat-entity-selector-fields{grid-template-columns:1fr}}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}.dashboard-card{background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--space-lg);cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.dashboard-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.dashboard-card:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.dashboard-card--warning{border-color:var(--warning-border)}.dashboard-card--warning:hover{border-color:var(--warning-text)}.dashboard-card--success{border-color:var(--success-border)}.dashboard-card--success:hover{border-color:var(--success-text)}.dashboard-card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.dashboard-card-icon{display:flex;align-items:center;justify-content:center;color:var(--accent-primary)}.dashboard-card-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:0;flex:1}.dashboard-card-attention{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-xs);background-color:var(--error-bg);color:var(--error-text);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-pill)}.dashboard-card-primary{margin-bottom:var(--space-md)}.dashboard-card-primary-value{display:block;font-size:var(--font-size-3xl);font-weight:700;color:var(--text-primary);line-height:1.2}.dashboard-card-primary-label{display:block;font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.dashboard-card-secondary{display:flex;gap:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.dashboard-card-metric{flex:1;min-width:0}.dashboard-card-metric--clickable{cursor:pointer;padding:var(--space-xs);margin:calc(-1 * var(--space-xs));border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.dashboard-card-metric--clickable:hover{background-color:var(--bg-hover)}.dashboard-card-metric--clickable:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.dashboard-card-metric-value{display:block;font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.dashboard-card-metric-label{display:block;font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:2px}@media (max-width: 767px){.dashboard-grid{grid-template-columns:1fr}.dashboard-card-secondary{flex-wrap:wrap;gap:var(--space-md)}.dashboard-card-metric{flex:0 0 calc(50% - var(--space-sm))}}.dashboard-summary-bar{display:flex;gap:var(--space-lg);padding:var(--space-md) var(--space-lg);background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);margin-bottom:var(--space-lg)}.dashboard-summary-stat{display:flex;flex-direction:column;gap:2px;padding:0;margin:0;background:none;border:none;text-align:left;color:inherit;font-family:inherit}.dashboard-summary-stat--clickable{cursor:pointer;padding:var(--space-xs) var(--space-sm);margin:calc(-1 * var(--space-xs)) calc(-1 * var(--space-sm));border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.dashboard-summary-stat--clickable:hover{background-color:var(--bg-hover)}.dashboard-summary-stat--clickable:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.dashboard-summary-stat-value{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.dashboard-summary-stat-label{font-size:var(--font-size-xs);color:var(--text-tertiary)}.dashboard-section{background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.dashboard-section-header{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-lg);background:none;border:none;cursor:pointer;text-align:left;color:inherit;font-family:inherit}.dashboard-section-header:focus{outline:none}.dashboard-section-header:focus-visible{outline:2px solid var(--accent-primary);outline-offset:-2px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.dashboard-section--collapsed .dashboard-section-header:focus-visible{border-radius:var(--radius-lg)}.dashboard-section-header:disabled{cursor:default}.dashboard-section-header:disabled:hover{background-color:transparent}.dashboard-section-icon{display:flex;align-items:center;justify-content:center;color:var(--accent-primary)}.dashboard-section-title{flex:1;font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:0}.dashboard-section-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-xs);background-color:var(--accent-primary);color:#fff;font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-pill)}.dashboard-section-chevron{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:transform var(--transition-fast),color var(--transition-fast)}.dashboard-section-header:hover .dashboard-section-chevron{color:var(--text-primary)}.dashboard-section--collapsed .dashboard-section-chevron{transform:rotate(-90deg)}.dashboard-section-body{padding:0 var(--space-lg) var(--space-lg)}.dashboard-section-empty{padding:var(--space-lg);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm);margin:0}.action-item-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background-color:var(--bg-secondary);border:1px solid var(--border-color);margin-bottom:var(--space-sm);transition:border-color var(--transition-fast),background-color var(--transition-fast);width:100%;text-align:left;font-family:inherit;font-size:inherit;color:inherit}.action-item-card:last-child{margin-bottom:0}.action-item-card--clickable{cursor:pointer}.action-item-card--clickable:hover{border-color:var(--border-hover);background-color:var(--bg-hover)}.action-item-card--clickable:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.action-item-card--attention{border-color:var(--warning-border);background-color:var(--warning-bg)}.action-item-card--attention:hover{border-color:var(--warning-text)}.action-item-card-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.action-item-card--attention .action-item-card-icon{color:var(--warning-text)}.action-item-card-content{flex:1;min-width:0}.action-item-card-title{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.action-item-card-subtitle{font-size:var(--font-size-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.action-item-card-metadata{flex-shrink:0;font-size:var(--font-size-xs);color:var(--text-tertiary);white-space:nowrap}.action-item-card--attention .action-item-card-metadata{color:var(--warning-text);font-weight:500}.action-item-card-badge{flex-shrink:0;width:8px;height:8px;border-radius:50%;background-color:var(--warning-text)}.dashboard-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:var(--space-xl)}.dashboard-welcome-content{text-align:center;max-width:480px}.dashboard-welcome-icon{margin-bottom:var(--space-lg);color:var(--text-tertiary)}.dashboard-welcome-title{font-size:var(--font-size-2xl);font-weight:500;color:var(--text-primary);margin:0 0 var(--space-sm)}.dashboard-welcome-subtitle{font-size:var(--font-size-md);color:var(--text-secondary);margin:0 0 var(--space-xl);line-height:1.5}.dashboard-welcome-actions{display:flex;flex-direction:column;gap:var(--space-sm);align-items:center}.dashboard-welcome-actions .btn{display:inline-flex;align-items:center;gap:var(--space-sm);min-width:200px;justify-content:center}.dashboard-sections{display:flex;flex-direction:column;gap:0}.dashboard-main{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,2fr);gap:var(--space-lg)}.dashboard-left-column,.dashboard-right-column{display:flex;flex-direction:column}.activity-feed-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-lg);background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);text-align:center;min-height:300px}.activity-feed-placeholder-icon{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);margin-bottom:var(--space-md)}.activity-feed-placeholder-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-xs)}.activity-feed-placeholder-description{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0}.activity-feed-section{display:flex;flex-direction:column;gap:var(--space-lg)}.weekly-summary-card{background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.weekly-summary-card-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.weekly-summary-card-icon{display:flex;align-items:center;justify-content:center;color:var(--accent-primary)}.weekly-summary-card-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:0}.weekly-summary-card-body{padding:var(--space-lg)}.weekly-summary-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.weekly-summary-loading-text{color:var(--text-secondary);font-size:var(--font-size-sm);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.weekly-summary-error{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);text-align:center}.weekly-summary-error-text{color:var(--text-tertiary);font-size:var(--font-size-sm);margin:0}.weekly-summary-empty{color:var(--text-tertiary);font-size:var(--font-size-sm);margin:0;font-style:italic}.weekly-summary-content{color:var(--text-primary);font-size:var(--font-size-sm);line-height:1.6;margin:0}.this-week-section{background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.this-week-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.this-week-icon{display:flex;align-items:center;justify-content:center;color:var(--accent-primary)}.this-week-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);margin:0}.this-week-body{padding:var(--space-lg)}.this-week-loading,.this-week-error{color:var(--text-tertiary);font-size:var(--font-size-sm);text-align:center;padding:var(--space-md)}.daily-activity-list{display:flex;flex-direction:column;gap:var(--space-md)}.daily-activity-group{display:flex;flex-direction:column;gap:var(--space-sm)}.daily-activity-header{display:flex;align-items:center;gap:var(--space-sm)}.daily-activity-day-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.daily-activity-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-xs);background-color:var(--bg-secondary);color:var(--text-secondary);font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-pill)}.daily-activity-highlights{display:flex;flex-direction:column;gap:var(--space-xs)}.activity-highlight{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast);width:100%;text-align:left;font-family:inherit;font-size:inherit;color:inherit}.activity-highlight:hover{border-color:var(--border-hover);background-color:var(--bg-hover)}.activity-highlight:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.activity-highlight--deleted{cursor:default;opacity:.7}.activity-highlight--deleted:hover{border-color:var(--border-color);background-color:var(--bg-secondary)}.activity-highlight-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-tertiary)}.activity-highlight-summary{flex:1;font-size:var(--font-size-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-highlight-count{flex-shrink:0;font-size:var(--font-size-xs);color:var(--text-tertiary)}.activity-feed-empty{color:var(--text-tertiary);font-size:var(--font-size-sm);margin:0;text-align:center;padding:var(--space-md)}.activity-feed-empty--onboarding{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-lg)}.activity-feed-empty-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);margin:0}.activity-feed-empty-description{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0;line-height:1.5}.tasks-section{display:flex;flex-direction:column;gap:var(--space-lg)}.task-card{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background-color:var(--bg-secondary);border:1px solid var(--border-color);margin-bottom:var(--space-sm);width:100%;animation:task-card-enter .2s ease-out}@keyframes task-card-enter{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.task-card:last-child{margin-bottom:0}.task-card-content{flex:1;min-width:0}.task-card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:2px}.task-card-title{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-card-badge{flex-shrink:0;font-size:var(--font-size-xs);font-weight:500;padding:2px var(--space-xs);border-radius:var(--radius-sm);background-color:var(--bg-tertiary);color:var(--text-tertiary)}.task-card-badge--inferred{background-color:var(--accent-primary-bg);color:var(--accent-primary)}.task-card-description{font-size:var(--font-size-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-card-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.task-card-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);background-color:transparent;color:var(--text-tertiary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.task-card-action-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.task-card-action-btn:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.task-card-action-btn:disabled{opacity:.5;cursor:not-allowed}.task-card-action-btn--complete:hover{background-color:var(--success-bg);color:var(--success-text)}.task-card-action-btn--dismiss:hover{background-color:var(--error-bg);color:var(--error-text)}.tasks-section-error{background-color:var(--error-bg);color:var(--error-text);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:var(--font-size-sm);animation:tasks-error-fade-in .2s ease-out}@keyframes tasks-error-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.task-card--loading{opacity:.7;pointer-events:none}.task-card-loading-indicator{display:flex;align-items:center;justify-content:center;width:28px;height:28px}.task-card-spinner{animation:task-card-spin 1s linear infinite;color:var(--text-tertiary)}@keyframes task-card-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.task-card-content{cursor:pointer;padding:var(--space-xs);margin:calc(-1 * var(--space-xs));border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.task-card-content:hover{background-color:var(--bg-hover)}.task-card-content:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.task-card-content--expanded .task-card-title,.task-card-content--expanded .task-card-description{white-space:normal;overflow:visible;text-overflow:unset}@media (max-width: 767px){.dashboard-summary-bar{flex-wrap:wrap;gap:var(--space-md)}.dashboard-summary-stat{flex:0 0 calc(50% - var(--space-sm))}.dashboard-section-header{padding:var(--space-sm) var(--space-md)}.dashboard-section-body{padding:0 var(--space-md) var(--space-md)}.action-item-card{padding:var(--space-sm)}.dashboard-welcome-actions,.dashboard-welcome-actions .btn{width:100%}.dashboard-main{grid-template-columns:1fr}.activity-feed-placeholder{min-height:200px;padding:var(--space-lg)}.task-card{padding:var(--space-sm)}.weekly-summary-card-header,.this-week-header{padding:var(--space-sm) var(--space-md)}.weekly-summary-card-body,.this-week-body{padding:var(--space-md)}.activity-highlight{padding:var(--space-xs) var(--space-sm)}}.pipeline-wrapper{display:flex;flex-direction:column;flex:1;min-height:0}.pipeline-container{display:flex;align-items:flex-start;gap:var(--space-md);overflow-x:auto;padding-left:calc(max(0px,(100% - 1000px - 2 * var(--space-xl)) / 2) + var(--space-xl));padding-right:var(--space-md);padding-bottom:var(--space-md);flex:1;height:100%;scroll-snap-type:x mandatory;scroll-padding-left:var(--space-xl);-webkit-overflow-scrolling:touch}.pipeline-column{flex:0 0 280px;min-width:280px;max-width:280px;max-height:100%;background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:1px solid var(--border-color);display:flex;flex-direction:column;scroll-snap-align:start;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.pipeline-column--drag-over{border-color:var(--accent-primary);background-color:rgba(var(--accent-primary-rgb),.05)}.pipeline-column-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);border-bottom:1px solid var(--border-color);position:sticky;top:0;background-color:var(--bg-tertiary);border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:1}.pipeline-column-title{font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary);margin:0}.pipeline-column-count{font-size:var(--font-size-xs);color:var(--text-tertiary);background-color:var(--bg-secondary);padding:2px var(--space-sm);border-radius:var(--radius-pill);min-width:24px;text-align:center}.pipeline-column-body{flex:1;overflow-y:auto;padding:var(--space-sm);padding-bottom:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.pipeline-column-empty{color:var(--text-tertiary);font-size:var(--font-size-sm);text-align:center;padding:var(--space-xl) var(--space-md)}.pipeline-add-button{width:100%;padding:var(--space-sm);background-color:transparent;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.pipeline-add-button:hover{background-color:var(--bg-secondary);color:var(--text-secondary)}.pipeline-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);cursor:grab;transition:transform var(--transition-fast),box-shadow var(--transition-fast),opacity var(--transition-fast),border-color var(--transition-fast);-webkit-user-select:none;user-select:none;color:var(--text-primary);font:inherit;text-align:left}button.pipeline-card:hover{border-color:var(--border-hover);box-shadow:0 2px 8px var(--shadow-light);background-color:var(--bg-secondary)}button.pipeline-card:active{cursor:grabbing}.pipeline-card--dragging{opacity:.5;transform:rotate(2deg);box-shadow:0 8px 20px var(--shadow-overlay)}.pipeline-card-title{font-weight:500;font-size:var(--font-size-sm);color:var(--text-primary);margin:0 0 var(--space-xs) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pipeline-card-meta{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--text-secondary)}.pipeline-card-meta-item{display:flex;align-items:center;gap:var(--space-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pipeline-card-meta-item svg{flex-shrink:0;color:var(--text-tertiary)}.view-toggle{display:flex;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.view-toggle-btn{padding:var(--space-xs) var(--space-md);background-color:transparent;border:none;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast);display:flex;align-items:center;gap:var(--space-xs)}.view-toggle-btn:hover:not(.view-toggle-btn--active){background-color:var(--bg-hover)}.view-toggle-btn--active{background-color:var(--accent-primary);color:var(--accent-text)}@media (max-width: 768px){.pipeline-column{flex:0 0 260px;min-width:260px;max-width:260px}.pipeline-card{padding:var(--space-sm)}.view-toggle-btn{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs)}}.pipeline-column--collapsed{flex:0 0 48px;min-width:48px;max-width:48px;transition:flex var(--transition-normal),min-width var(--transition-normal),max-width var(--transition-normal),border-color var(--transition-fast),background-color var(--transition-fast)}.pipeline-column-collapsed-content{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:var(--space-sm);padding:var(--space-md) var(--space-xs);height:100%;width:100%;background:transparent;border:none;cursor:pointer;color:var(--text-secondary);transition:color var(--transition-fast)}.pipeline-column-collapsed-content:hover{color:var(--text-primary)}.pipeline-column-collapsed-label{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);font-weight:600;font-size:var(--font-size-sm);white-space:nowrap}.pipeline-column-collapse-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;margin-left:auto;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.pipeline-column-collapse-btn:hover{color:var(--text-secondary);background-color:var(--bg-hover)}.pipeline-column-collapse-btn svg{transition:transform var(--transition-fast)}.pipeline-column--collapsed.pipeline-column--drag-over{background-color:rgba(var(--accent-primary-rgb),.1)}.pipeline-column--collapsed.pipeline-column--drag-over .pipeline-column-collapsed-content{color:var(--accent-primary)}@media (max-width: 768px){.pipeline-column--collapsed{flex:0 0 40px;min-width:40px;max-width:40px}.pipeline-column-collapsed-label{font-size:var(--font-size-xs)}}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-xl)}.detail-header-content{flex:1}.detail-header-actions{display:flex;gap:var(--space-sm);align-items:center}.detail-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--text-primary);margin:0;margin-bottom:var(--space-sm)}.attribution-info{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg);font-size:var(--font-size-sm);color:var(--text-muted)}.attribution-item{display:inline-flex;align-items:center}.attribution-item:not(:last-child):after{content:"•";margin-left:var(--space-md);color:var(--text-muted)}@media (max-width: 767px){.detail-header{flex-direction:column;gap:var(--space-md)}}.contact-preview-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:100}.contact-preview-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px var(--shadow-overlay)}.contact-preview-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.contact-preview-modal-header-content{flex:1}.contact-preview-modal-title{margin:0;margin-bottom:var(--space-xs);font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.contact-preview-modal-type-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500}.contact-preview-modal-close{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.contact-preview-modal-close:hover{background-color:var(--bg-hover);color:var(--text-primary)}.contact-preview-modal-body{padding:var(--space-lg)}.contact-preview-modal-field{margin-bottom:var(--space-md)}.contact-preview-modal-field:last-child{margin-bottom:0}.contact-preview-modal-field-label{display:block;font-weight:500;margin-bottom:var(--space-xs);color:var(--text-secondary);font-size:var(--font-size-sm)}.contact-preview-modal-field-value{font-size:var(--font-size-md);color:var(--text-primary)}.contact-preview-modal-footer{padding:var(--space-lg);border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.contact-preview-modal-actions{display:flex;gap:var(--space-sm)}.contact-preview-modal-loading,.contact-preview-modal-error{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.contact-preview-modal-error{color:var(--error-text)}.contact-preview-modal-relationship-section{margin-top:var(--space-md)}.contact-preview-modal-relationship-divider{height:1px;background-color:var(--border-color);margin-bottom:var(--space-md)}.contact-preview-modal-relationship-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.contact-preview-modal-relationship-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0}.contact-preview-modal-relationship-delete-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:50%;background-color:var(--error-bg);color:var(--error-text);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.contact-preview-modal-relationship-delete-btn:hover{background-color:var(--error-text);color:#fff}.contact-preview-modal-edit-select{flex:1;min-width:0;padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-md)}.contact-preview-modal-edit-select:focus{outline:none;border-color:var(--accent-primary)}.contact-preview-modal-delete-btn{background-color:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.contact-preview-modal-field-value--editable,.project-preview-modal-field-value--editable{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);margin:calc(-1 * var(--space-xs)) calc(-1 * var(--space-sm));border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast)}.contact-preview-modal-field-value--editable:hover,.project-preview-modal-field-value--editable:hover{background-color:var(--bg-hover)}.contact-preview-modal-edit-icon,.project-preview-modal-edit-icon{opacity:0;color:var(--text-tertiary);transition:opacity var(--transition-fast);flex-shrink:0}.contact-preview-modal-field-value--editable:hover .contact-preview-modal-edit-icon,.project-preview-modal-field-value--editable:hover .project-preview-modal-edit-icon{opacity:1}.contact-preview-modal-edit-row,.project-preview-modal-edit-row{display:flex;align-items:center;gap:var(--space-xs)}.contact-preview-modal-edit-input,.project-preview-modal-edit-input{flex:1;min-width:0;padding:var(--space-xs) var(--space-sm);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-md)}.contact-preview-modal-edit-input:focus,.project-preview-modal-edit-input:focus{outline:none;border-color:var(--accent-primary)}.contact-preview-modal-edit-actions,.project-preview-modal-edit-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.contact-preview-modal-edit-btn,.project-preview-modal-edit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.activity-timeline{display:flex;flex-direction:column;gap:var(--space-sm)}.activity-timeline-loading,.activity-timeline-error,.activity-timeline-empty{padding:var(--space-md);text-align:center;color:var(--text-secondary);font-size:var(--font-size-sm)}.activity-timeline-error{color:var(--error-text)}.activity-timeline-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:400px;overflow-y:auto}.activity-timeline-day-group{display:flex;flex-direction:column;gap:var(--space-xs)}.activity-timeline-day-group:not(:first-child){margin-top:var(--space-md)}.activity-timeline-day-header{font-size:var(--font-size-xs);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.activity-timeline-entry{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-xs) 0;padding-left:var(--space-md);background-color:transparent}.activity-timeline-separator{color:var(--text-tertiary)}.activity-timeline-description{font-size:var(--font-size-sm);line-height:1.5}.activity-timeline-actor{font-weight:600;color:var(--text-primary)}.activity-timeline-message{color:var(--text-secondary);margin-left:var(--space-xs)}.activity-timeline-timestamp{font-size:var(--font-size-xs);color:var(--text-tertiary)}.activity-change-details{display:flex;flex-direction:column;gap:var(--space-xs);margin-top:var(--space-xs)}.activity-change-toggle-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:0;background:none;border:none;color:var(--text-tertiary);font-size:var(--font-size-xs);cursor:pointer;transition:color var(--transition-fast)}.activity-change-toggle-btn:hover{color:var(--text-secondary)}.activity-change-toggle-btn:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:var(--radius-sm)}.activity-change-content{display:flex;flex-direction:column;gap:var(--space-xs);padding-left:var(--space-md)}.activity-change-item{font-size:var(--font-size-sm);line-height:1.5;color:var(--text-secondary)}.activity-change-field{font-weight:600;color:var(--text-tertiary)}.activity-change-old{text-decoration:line-through;color:var(--text-tertiary)}.activity-change-arrow{color:var(--text-tertiary)}.activity-change-new{color:var(--text-primary)}@media (max-width: 767px){.activity-timeline-entry{padding:var(--space-sm)}.activity-change-details{padding:var(--space-xs)}.activity-change-item{font-size:var(--font-size-xs)}}.file-upload-dropzone{position:relative;display:flex;flex-direction:column;gap:var(--space-sm)}.file-upload-dropzone--disabled{pointer-events:none;opacity:.6}.file-upload-input-external{display:contents}.file-upload-input-external--disabled{pointer-events:none;opacity:.6}.file-upload-dropzone-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:rgba(var(--accent-primary-rgb),.1);border:2px dashed var(--accent-primary);border-radius:var(--radius-md);z-index:10;font-weight:500;color:var(--accent-primary)}.file-attachment-wrapper{display:inline-flex;align-items:center;gap:var(--space-xs);position:relative}.file-attachment-wrapper--linkable .file-attachment-link-btn{opacity:0;pointer-events:none;transition:opacity var(--transition-fast)}.file-attachment-wrapper--linkable:hover .file-attachment-link-btn{opacity:1;pointer-events:auto}.file-attachment-link-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.file-attachment-link-btn:hover{background-color:var(--bg-hover);border-color:var(--accent-primary);color:var(--accent-primary)}.file-attachment{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background-color:#00000040;border:none;border-radius:var(--radius-sm);font-size:.75rem;max-width:180px;position:relative;transition:background-color var(--transition-fast)}.file-attachment--completed{cursor:pointer}.file-attachment--completed:hover{background-color:#00000059}.file-attachment--uploading{background-color:#0000001a}.file-attachment--failed{background-color:#dc354533}.file-attachment-icon{flex-shrink:0;font-size:.875rem}.file-attachment-info{display:flex;flex-direction:column;min-width:0;flex:1}.file-attachment-name{font-weight:500;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.9}.file-attachment-size{font-size:.6875rem;color:inherit;opacity:.7}.file-attachment-error{color:var(--color-danger)}.file-attachment-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background-color:var(--bg-secondary);border-radius:0 0 var(--radius-sm) var(--radius-sm);overflow:hidden}.file-attachment-progress-bar{height:100%;background-color:var(--accent-primary);transition:width .2s ease-out}.file-attachment-remove{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:16px;height:16px;margin-left:auto;padding:0;background-color:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.file-attachment-remove:hover{background-color:#ffffff1a;color:var(--text-primary)}.file-attachment-remove:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.file-attachment-vision-badge{font-size:.75rem;margin-right:var(--space-2xs);cursor:help}.entity-files-list{position:relative;padding:var(--space-sm);border:1px dashed var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-secondary);transition:border-color var(--transition-fast),background-color var(--transition-fast)}.entity-files-list--drag-active{border-color:var(--accent-primary);background-color:rgba(var(--accent-primary-rgb),.05)}.entity-files-dropzone-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:rgba(var(--accent-primary-rgb),.1);border-radius:var(--radius-md);z-index:10;font-weight:500;color:var(--accent-primary)}.entity-files-pending,.entity-files-grid{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-sm)}.entity-file-item{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background-color:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.entity-file-main{flex:1;display:flex;align-items:center;gap:var(--space-sm);background:none;border:none;padding:0;cursor:pointer;text-align:left;min-width:0}.entity-file-main:disabled{cursor:default}.entity-file-main:not(:disabled):hover .entity-file-name{color:var(--accent-primary)}.entity-file-icon{font-size:1.25rem;flex-shrink:0}.entity-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.entity-file-name{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition-fast)}.entity-file-meta{font-size:.75rem;color:var(--text-secondary)}.entity-file-remove{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.entity-file-remove:hover{color:var(--color-danger);background-color:#dc35451a}.entity-file-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.entity-file-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background-color:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.entity-file-action-btn:hover{color:var(--text-primary)}.entity-file-action-btn:disabled{opacity:.5;cursor:not-allowed}.entity-file-action-btn--danger:hover{background-color:#dc35451a;color:var(--color-danger)}.entity-file-rename-input{flex:1;padding:2px var(--space-xs);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;width:100%}.entity-file-error{color:var(--color-danger);font-size:.75rem}.entity-files-empty{color:var(--text-secondary);font-size:.875rem;text-align:center;padding:var(--space-md) 0}.entity-files-upload-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);width:100%;padding:var(--space-sm);background:none;border:none;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:color var(--transition-fast)}.entity-files-upload-btn:hover:not(:disabled){color:var(--accent-primary)}.entity-files-upload-btn:disabled{opacity:.5;cursor:not-allowed}.file-association-modal{display:flex;flex-direction:column;gap:var(--space-md)}.file-association-filename{font-size:.875rem;color:var(--text-secondary);margin:0}.file-association-filename strong{color:var(--text-primary)}.file-association-type-selector{display:flex;gap:var(--space-xs)}.file-association-type-btn{flex:1;padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.file-association-type-btn:hover{background-color:var(--bg-tertiary)}.file-association-type-btn--active{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.file-association-type-btn--active:hover{background-color:var(--accent-hover)}.file-association-selector{min-height:48px}.file-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.file-preview-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:90vw;max-height:90vh;width:100%;display:flex;flex-direction:column;overflow:hidden}.file-preview-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-bottom:1px solid var(--border-color);gap:var(--space-md)}.file-preview-info{flex:1;min-width:0}.file-preview-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-preview-meta{font-size:.75rem;color:var(--text-secondary)}.file-preview-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.file-preview-download-btn{display:flex;align-items:center;gap:var(--space-xs)}button.file-preview-close-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast)}button.file-preview-close-btn svg{width:24px;height:24px}button.file-preview-close-btn:hover,button.file-preview-close-btn:hover:not(:disabled){color:var(--text-primary)}.file-preview-content{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;padding:var(--space-md);background-color:var(--bg-secondary)}.file-preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-sm)}.file-preview-pdf{width:100%;height:70vh;border:none;border-radius:var(--radius-sm)}.file-preview-unsupported{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);text-align:center}.file-preview-unsupported-icon{color:var(--text-secondary)}.file-preview-unsupported-text{color:var(--text-secondary);font-size:.875rem;margin:0}.file-preview-analysis{border-top:1px solid var(--border-color);background-color:var(--bg-secondary)}.file-preview-analysis-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-sm) var(--space-md);background:none;border:none;cursor:pointer;color:var(--text-primary);font-size:.875rem;font-weight:500;transition:background-color var(--transition-fast)}.file-preview-analysis-header:hover{background-color:var(--bg-tertiary)}.file-preview-analysis-title{display:flex;align-items:center;gap:var(--space-xs)}.file-preview-analysis-icon{font-size:.875rem}.file-preview-analysis-chevron{transition:transform var(--transition-fast)}.file-preview-analysis--collapsed .file-preview-analysis-chevron{transform:rotate(-90deg)}.file-preview-analysis-content{padding:var(--space-sm) var(--space-md);padding-top:0;max-height:200px;overflow-y:auto}.file-preview-analysis-text{margin:0;padding:var(--space-sm);background-color:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.8125rem;font-family:inherit;white-space:pre-wrap;word-wrap:break-word;color:var(--text-secondary);line-height:1.5}.file-list{display:flex;flex-direction:column;gap:var(--space-sm)}.file-list-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-sm) 0}.file-list-search{flex:1;max-width:300px}.file-list-search input{width:100%;padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.file-list-search input::placeholder{color:var(--text-secondary)}.file-list-filters{display:flex;gap:var(--space-sm)}.file-list-sort-btn{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:none;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all var(--transition-fast)}button.file-list-sort-btn:hover,button.file-list-sort-btn--active{border-color:var(--accent-primary);color:var(--accent-primary)}.file-list-table{display:flex;flex-direction:column;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.file-list-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);transition:background-color var(--transition-fast);cursor:pointer}.file-list-row:last-child{border-bottom:none}.file-list-row:hover{background-color:var(--bg-secondary)}.file-list-icon{font-size:1.25rem;flex-shrink:0;width:32px;text-align:center}.file-list-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.file-list-name{display:flex;align-items:center;gap:var(--space-xs)}.file-list-name-text{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:color var(--transition-fast)}.file-list-name-text:hover{color:var(--accent-primary)}.file-list-name-input{flex:1;padding:var(--space-xs);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:500}.file-list-meta{font-size:.75rem;color:var(--text-secondary);display:flex;gap:var(--space-sm)}.file-list-entity-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px var(--space-xs);background-color:var(--bg-tertiary);border-radius:var(--radius-xs);font-size:.675rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.file-list-entity-badge:hover{color:var(--accent-primary);background-color:rgba(var(--accent-primary-rgb),.1)}.file-list-actions{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.file-list-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background-color:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}button.file-list-action-btn:hover{color:var(--text-primary)}button.file-list-action-btn--danger:hover{color:var(--color-danger)}.file-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);text-align:center;color:var(--text-secondary);border:1px dashed var(--border-color);border-radius:var(--radius-md)}.file-list-empty-icon{font-size:3rem;margin-bottom:var(--space-md)}.file-list-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-xl);color:var(--text-secondary)}.file-list-bulk-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.file-list-bulk-count{font-size:.875rem;color:var(--text-primary);font-weight:500}.file-list-bulk-actions{display:flex;align-items:center;gap:var(--space-sm)}.file-list-bulk-btn{padding:var(--space-xs) var(--space-sm);border:none;border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:background-color .2s}.file-list-bulk-btn--danger{background-color:transparent;color:var(--text-secondary)}.file-list-bulk-btn--danger:hover{background-color:transparent;color:var(--color-danger)}.file-list-bulk-btn--secondary{background-color:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.file-list-bulk-btn--secondary:hover{background-color:var(--bg-hover);color:var(--text-primary)}.file-list-select-all{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--border-color)}.file-list-checkbox-label{display:flex;align-items:center;cursor:pointer;flex-shrink:0}.file-list-row .file-list-checkbox-label{margin-right:var(--space-sm)}.file-list-checkbox{width:16px;height:16px;margin:0;cursor:pointer;accent-color:var(--color-primary)}.file-list-select-all-text{margin-left:var(--space-sm);font-size:.875rem;color:var(--text-secondary)}.files-page-filters{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.files-page-filter-select{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;cursor:pointer}.files-page-upload-zone{margin-bottom:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs)}.files-page--drag-active{position:relative}.files-page-dropzone-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:rgba(var(--accent-primary-rgb),.1);border:3px dashed var(--accent-primary);z-index:100;font-weight:500;font-size:1.25rem;color:var(--accent-primary)}@media (max-width: 767px){.file-list-checkbox-label{min-height:var(--touch-target-min);min-width:var(--touch-target-min);padding:var(--space-xs)}}.import-modal{max-width:700px}.import-modal .modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.import-modal .modal-close{background:none;border:none;cursor:pointer;padding:var(--space-xs);color:var(--text-tertiary);border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.import-modal .modal-close:hover{color:var(--text-primary);background-color:var(--bg-hover)}.import-upload-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.import-dropzone{width:100%;padding:var(--space-xl);border:2px dashed var(--border-color);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.import-dropzone:hover,.import-dropzone--active{border-color:var(--accent-primary);background-color:var(--bg-hover)}.import-dropzone-icon{color:var(--text-tertiary);margin-bottom:var(--space-md)}.import-dropzone-text{color:var(--text-primary);font-weight:500;margin-bottom:var(--space-xs)}.import-dropzone-hint{color:var(--text-tertiary);font-size:var(--font-size-sm)}.import-template-link{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--accent-primary);background:none;border:none;font-size:var(--font-size-sm);cursor:pointer;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.import-template-link:hover{background-color:var(--bg-hover)}.import-preview-step{display:flex;flex-direction:column;gap:var(--space-md)}.import-preview-summary{display:flex;gap:var(--space-lg);flex-wrap:wrap}.import-preview-stat{color:var(--text-secondary);font-size:var(--font-size-sm)}.import-preview-stat strong{color:var(--text-primary)}.import-preview-stat--warning,.import-preview-stat--warning strong{color:var(--status-warning)}.import-preview-stat--info,.import-preview-stat--info strong{color:var(--accent-primary)}.import-preview-errors{background-color:var(--bg-error);border:1px solid var(--status-error);border-radius:var(--radius-md);padding:var(--space-md)}.import-preview-error{color:var(--status-error);font-size:var(--font-size-sm)}.import-preview-options{display:flex;gap:var(--space-md)}.import-preview-option{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer}.import-preview-option input[type=checkbox]{accent-color:var(--accent-primary)}.import-preview-table-container{max-height:300px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-md)}.import-preview-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.import-preview-table th,.import-preview-table td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--border-color)}.import-preview-table th{background-color:var(--bg-secondary);color:var(--text-secondary);font-weight:500;position:sticky;top:0;z-index:1}.import-preview-table td{color:var(--text-primary)}.import-preview-checkbox-col{width:40px;text-align:center!important}.import-preview-row--invalid{opacity:.5}.import-preview-row--duplicate td{background-color:#ffc1071a}.import-status{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.import-status--success{background-color:#34d39933;color:var(--status-success)}.import-status--warning{background-color:#fbbf2433;color:var(--status-warning)}.import-status--error{background-color:#f8717133;color:var(--status-error)}.import-status--info{background-color:rgba(var(--accent-primary-rgb),.2);color:var(--accent-primary)}.import-complete-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-align:center;padding:var(--space-xl) 0}.import-complete-icon{margin-bottom:var(--space-md)}.import-complete-title{color:var(--text-primary);font-size:var(--font-size-lg);margin:0}.import-complete-stats{color:var(--text-secondary);margin:0}.import-dropdown{display:flex;gap:var(--space-sm)}.billing-type-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-md);padding:var(--space-xs);background-color:var(--bg-tertiary);border-radius:var(--radius-md);width:fit-content}.billing-type-tab{padding:var(--space-sm) var(--space-md);background-color:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.billing-type-tab:hover{background-color:var(--bg-hover);color:var(--text-primary)}.billing-type-tab--active{background-color:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.billing-type-tab--active:hover{background-color:var(--bg-primary)}.billing-card-type-indicator{display:inline-flex;align-items:center;padding:2px 8px;font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-sm);background-color:var(--bg-tertiary);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.billing-card-badges{display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap}.billing-card-totals{display:flex;flex-direction:column;gap:var(--space-xs);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border-color)}.billing-card-total{display:flex;justify-content:space-between;align-items:center}.billing-card-total-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.billing-card-total-amount{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.billing-card-total--secondary .billing-card-total-label{font-size:var(--font-size-xs)}.billing-card-total--secondary .billing-card-total-amount{font-size:var(--font-size-base);font-weight:500}.account-deletion-card{background-color:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-md);padding:var(--space-lg)}.account-deletion-title{color:var(--color-error);margin-bottom:var(--space-sm);font-size:var(--font-size-md)}.account-deletion-description{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:var(--font-size-sm)}.document-form{display:flex;flex-direction:column}.document-form .form-row{display:flex;gap:var(--space-lg);flex-wrap:wrap}.document-form .form-group--narrow{flex:0 0 auto;min-width:150px}.document-totals,.document-form-totals{display:flex;flex-direction:column;gap:var(--space-sm);align-items:flex-end;padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.document-total-row{display:flex;justify-content:space-between;gap:var(--space-xl);width:200px}.document-total-label{font-size:var(--font-size-base);color:var(--text-secondary)}.document-total-value{font-size:var(--font-size-base);font-weight:500;color:var(--text-primary)}.document-total-row--grand{padding-top:var(--space-sm);border-top:1px solid var(--border-color)}.document-total-row--grand .document-total-label,.document-total-row--grand .document-total-value{font-size:var(--font-size-lg);font-weight:600}.document-total-row--paid .document-total-value{color:var(--color-status-completed)}.document-total-row--due{padding-top:var(--space-sm);border-top:1px solid var(--border-color)}.document-total-row--due .document-total-label,.document-total-row--due .document-total-value{font-weight:600}.document-detail{display:flex;flex-direction:column;gap:var(--space-lg);margin-bottom:var(--space-xl)}.document-detail-section{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-lg)}.document-detail-section-title{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md)}.document-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md)}.document-detail-field{display:flex;flex-direction:column;gap:var(--space-xs)}.document-detail-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.document-detail-value{font-size:var(--font-size-base);color:var(--text-primary)}.document-detail-info{font-size:var(--font-size-sm);color:var(--text-secondary);font-style:italic}.document-detail-notes{white-space:pre-wrap;color:var(--text-primary)}.document-status-actions,.estimate-status-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.line-item-editor{display:flex;flex-direction:column;gap:var(--space-md)}.line-item-table{display:flex;flex-direction:column;gap:var(--space-xs)}.line-item-header{display:none}.line-item-row{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.line-item-col{width:100%}.line-item-col--description{flex:1}.line-item-col--total{font-weight:500;text-align:right;padding:var(--space-sm);background:var(--bg-primary);border-radius:var(--radius-sm)}.line-item-col--actions{display:flex;justify-content:flex-end}.line-item-subtotal{display:flex;justify-content:space-between;padding:var(--space-sm) var(--space-md);font-weight:500}.line-item-editor--readonly .line-item-row{flex-direction:row;align-items:center;padding:var(--space-sm) var(--space-md);gap:var(--space-md)}.line-item-editor--readonly .line-item-col{width:auto}.line-item-editor--readonly .line-item-col--description{flex:1;min-width:0}.line-item-editor--readonly .line-item-col--quantity,.line-item-editor--readonly .line-item-col--unit,.line-item-editor--readonly .line-item-col--price,.line-item-editor--readonly .line-item-col--total{flex-shrink:0;text-align:right}.line-item-editor--readonly .line-item-col--total{padding:0;background:transparent;font-weight:600}@media (min-width: 768px){.line-item-header{display:flex;gap:var(--space-md);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.line-item-row{flex-direction:row;align-items:center;gap:var(--space-md)}.line-item-col{width:auto}.line-item-col--description{flex:1}.line-item-col--quantity,.line-item-col--unit{width:100px}.line-item-col--price{width:140px}.line-item-col--total{width:100px;background:transparent;padding:0}.line-item-col--actions{width:40px}.line-item-editor--readonly .line-item-col--quantity,.line-item-editor--readonly .line-item-col--unit{width:100px}.line-item-editor--readonly .line-item-col--price{width:140px}.line-item-editor--readonly .line-item-col--total{width:100px}}@media print{.document-detail-section{break-inside:avoid;background:#fff;border:1px solid #ccc;margin-bottom:1rem}.line-item-row,.document-totals{background:#fff;border:1px solid #ccc}}.financials-list{display:flex;flex-direction:column;gap:var(--space-sm)}.financials-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);cursor:pointer;transition:border-color var(--transition-fast)}.financials-item:hover{border-color:var(--border-hover)}.financials-item-type{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;white-space:nowrap}.financials-item-type--estimate{background-color:var(--info-bg);color:var(--info-text)}.financials-item-type--invoice{background-color:var(--success-bg);color:var(--success-text)}.financials-item-info{display:flex;flex-direction:column;flex:1;min-width:0}.financials-item-number{color:var(--text-primary);font-weight:500}.financials-item-contact{color:var(--text-secondary);font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.financials-item-status{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;color:#fff;white-space:nowrap}.financials-item-amount{font-weight:600;color:var(--text-primary);white-space:nowrap}.sent-emails-search{flex:1;max-width:300px}.sent-emails-search input{width:100%;padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.sent-emails-search input::placeholder{color:var(--text-secondary)}.sent-emails-search input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.2)}.sent-emails-filters{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md);align-items:center}.sent-emails-filter-select{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;cursor:pointer;min-width:140px}.sent-emails-filter-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.2)}.sent-emails-date-filter{display:flex;align-items:center;gap:var(--space-xs)}.sent-emails-date-label{font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap}.sent-emails-date-input{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.sent-emails-date-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.2)}.sent-emails-list{display:flex;flex-direction:column;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.sent-emails-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-xl);color:var(--text-secondary)}.sent-emails-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);text-align:center;color:var(--text-secondary);border:1px dashed var(--border-color);border-radius:var(--radius-md)}.sent-emails-empty-icon{font-size:3rem;margin-bottom:var(--space-md)}.sent-emails-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.sent-emails-header .sent-emails-col--recipient{flex:1;min-width:120px}.sent-emails-header .sent-emails-col--subject{flex:2;min-width:150px}.sent-emails-header .sent-emails-col--type{width:100px;flex-shrink:0}.sent-emails-header .sent-emails-col--date{width:140px;flex-shrink:0}.sent-emails-header .sent-emails-col--actions{width:48px;flex-shrink:0}.sent-emails-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:var(--bg-primary);border:none;border-bottom:1px solid var(--border-color);text-align:left;font:inherit;cursor:pointer;width:100%;transition:background-color var(--transition-fast)}.sent-emails-row:last-child{border-bottom:none}.sent-emails-row:hover{background-color:var(--bg-secondary)}.sent-emails-row:focus{outline:none;background-color:var(--bg-secondary)}.sent-emails-col{display:flex;align-items:center;min-width:0}.sent-emails-col--recipient{flex:1;min-width:120px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sent-emails-col--subject{flex:2;min-width:150px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sent-emails-col--type{width:100px;flex-shrink:0;justify-content:flex-start}.sent-emails-col--date{width:140px;flex-shrink:0;font-size:var(--font-size-sm);color:var(--text-tertiary);white-space:nowrap}.sent-emails-col--actions{width:48px;flex-shrink:0;justify-content:center}.sent-emails-view-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background-color:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.sent-emails-view-btn:hover{color:var(--accent-primary);background-color:rgba(var(--accent-primary-rgb),.1)}.sent-emails-view-btn:focus{outline:none;color:var(--accent-primary);background-color:rgba(var(--accent-primary-rgb),.1)}.sent-emails-type-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;text-transform:capitalize}.sent-emails-type-badge--freeform{background-color:var(--info-bg);color:var(--info-text)}.sent-emails-type-badge--estimate{background-color:var(--warning-bg);color:var(--warning-text)}.sent-emails-type-badge--invoice{background-color:var(--success-bg);color:var(--success-text)}.sent-emails-type-badge--project-update{background-color:var(--stated-bg);color:var(--stated-text)}.sent-email-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-lg)}.sent-email-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);max-width:700px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.sent-email-modal-loading{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.sent-email-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.sent-email-modal-header-content{flex:1;min-width:0}.sent-email-modal-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0;word-wrap:break-word}.sent-email-modal-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.sent-email-modal-close:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.sent-email-modal-close:focus{outline:none;background-color:var(--bg-secondary)}.sent-email-modal-meta{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary)}.sent-email-modal-meta-row{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm)}.sent-email-modal-meta-row+.sent-email-modal-meta-row{margin-top:var(--space-xs)}.sent-email-modal-meta-label{font-weight:500;color:var(--text-secondary);min-width:50px}.sent-email-modal-meta-value{color:var(--text-primary)}.sent-email-type-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;text-transform:capitalize}.sent-email-type-badge--freeform{background-color:var(--info-bg);color:var(--info-text)}.sent-email-type-badge--estimate{background-color:var(--warning-bg);color:var(--warning-text)}.sent-email-type-badge--invoice{background-color:var(--success-bg);color:var(--success-text)}.sent-email-type-badge--project-update{background-color:var(--stated-bg);color:var(--stated-text)}.sent-email-modal-body{flex:1;overflow-y:auto;padding:var(--space-lg);min-height:200px}.sent-email-modal-iframe{width:100%;height:400px;border:none;background-color:var(--bg-primary)}.sent-email-modal-text{margin:0;white-space:pre-wrap;font-family:inherit;font-size:var(--font-size-sm);line-height:1.6;color:var(--text-primary)}@media (max-width: 768px){.sent-emails-filters{flex-direction:column;align-items:stretch}.sent-emails-search{max-width:none}.sent-emails-filter-select,.sent-emails-date-filter{width:100%}.sent-emails-date-input{flex:1}.sent-emails-header{display:none}.sent-emails-row{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.sent-emails-col--recipient,.sent-emails-col--subject,.sent-emails-col--type,.sent-emails-col--date{width:100%;flex:none}.sent-emails-col--subject{white-space:normal}.sent-emails-col--actions{position:absolute;top:var(--space-sm);right:var(--space-sm);width:auto}.sent-emails-row{position:relative;padding-right:56px}.sent-email-modal{max-height:90vh;margin:var(--space-md)}.sent-email-modal-iframe{height:300px}}
