.editor-page{background-color:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);min-height:calc(100vh - 120px);position:relative}.editor-container{position:relative;display:flex;flex-direction:column;min-height:calc(100vh - 180px)}.editor-loading{display:flex;justify-content:center;align-items:center;min-height:200px;padding:40px}.loading-spinner{font-size:1rem;color:var(--color-text-muted)}.editor-error{text-align:center;padding:2rem}.editor-error .error-message{color:var(--color-danger);margin-bottom:1rem}.expense-editor-error-popup{position:fixed;top:120px;left:50%;transform:translate(-50%);max-width:600px;width:90%;background:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border);padding:12px 40px 12px 16px;border-radius:var(--radius-md);box-shadow:0 4px 12px #00000040;z-index:var(--z-error);pointer-events:auto}.expense-editor-error-popup .error-dismiss-btn{position:absolute;top:8px;right:8px;background:none;border:none;font-size:20px;line-height:1;color:var(--color-danger-text);cursor:pointer;padding:4px 8px;opacity:.7}.expense-editor-error-popup .error-dismiss-btn:hover{opacity:1}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:6px 16px;background-color:var(--color-bg-white);border-bottom:1px solid var(--color-border);min-height:44px;max-height:64px;box-sizing:border-box;overflow:hidden}.editor-header-sticky{position:sticky;top:0;z-index:var(--z-sticky);background:var(--color-bg-white);border-bottom:1px solid var(--color-border);padding:6px 16px;min-height:44px;max-height:64px;box-sizing:border-box;box-shadow:var(--shadow-sm);border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow:hidden}.invoice-items-header-actions{display:inline-flex;gap:.5rem}.editor-header-left{display:flex;align-items:center;gap:8px;flex:1 1 0;min-width:0;overflow:hidden;flex-wrap:wrap;max-height:52px}.editor-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;align-self:center}.editor-title{margin:0;font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);white-space:nowrap;flex-shrink:0}.editor-title-separator{color:var(--color-text-light);font-weight:300}.editor-identifier{font-size:var(--font-size-md);font-weight:500;color:var(--color-text-secondary)}.editor-identifier-truncate{display:inline-block;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom}.editor-identifier-new{font-style:italic;color:var(--color-text-muted)}.editor-header-spacer{width:60px}.editor-header-metrics{display:inline-flex;align-items:center;gap:6px;margin-left:4px;white-space:nowrap;flex-shrink:0}.editor-header-metric{display:inline-flex;align-items:center;gap:3px}.editor-header-metric-label{font-size:.8rem;color:var(--color-text-muted);font-weight:400}.editor-header-metric-value{font-size:var(--font-size-sm);color:var(--color-text);font-weight:600}.editor-header-metric-sep{color:var(--color-border-dark);font-weight:300;margin:0 2px}.editor-confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:var(--z-session)}.editor-confirm-dialog{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:24px;max-width:400px;box-shadow:var(--shadow-xl)}.editor-confirm-dialog-back{min-width:320px}.editor-header-confirm-popup{position:absolute;top:100%;right:0;margin-top:4px;padding:var(--space-sm);background:var(--color-bg-white);border:1px solid var(--color-border-dark);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:var(--z-modal);white-space:nowrap}.editor-confirm-message{margin-bottom:20px;font-size:1rem;color:var(--color-text);line-height:1.5}.editor-confirm-buttons{display:flex;justify-content:center;gap:12px}.editor-confirm-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.editor-confirm-buttons-vertical{flex-direction:column;gap:10px}.editor-confirm-buttons-vertical .btn{width:100%;text-align:center}.expense-type-warning-dialog{max-width:520px}.expense-type-warning-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:12px}.expense-type-warning-dialog .editor-confirm-message{color:var(--color-text-secondary)}.editor-main{display:flex;flex-direction:column;gap:24px;padding:20px}.invoice-info-sections{display:flex;gap:20px;margin-bottom:20px}.invoice-info-section{flex:1;background:var(--color-bg-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:12px}.invoice-info-section-title{font-size:.875rem;font-weight:600;color:var(--color-text);margin-bottom:4px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.editor-header-fields{background:var(--color-bg-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:20px}.invoice-field-row{display:flex;gap:20px;margin-bottom:16px}.invoice-field-row:last-child{margin-bottom:0}.invoice-field{flex:1;display:flex;flex-direction:column;gap:6px}.invoice-field label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.invoice-field .input-error{border-color:var(--color-danger)}.invoice-field .field-error{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:4px}.invoice-items-table td.invoice-item-col-error{background-color:var(--color-danger-bg);box-shadow:inset 0 0 0 1px var(--color-danger)}.invoice-item-richtext-error{box-shadow:0 0 0 1px var(--color-danger);background-color:var(--color-danger-bg);border-radius:var(--radius-md)}.invoice-item-input-error{border-color:var(--color-danger)!important;box-shadow:0 0 0 1px #e74c3c59;background-color:var(--color-danger-bg)}.expense-line-cell-error{background-color:var(--color-danger-bg)}.expense-line-input-error{border-color:var(--color-danger);box-shadow:0 0 0 1px #dc35454d}.invoice-field textarea{resize:vertical;min-height:60px}.invoice-field .internal-only-label{color:var(--color-warning);font-style:italic;font-size:var(--font-size-xs);margin-left:4px}.invoice-customer-address{margin-top:8px;padding-top:8px;border-top:1px solid var(--color-border)}.invoice-customer-address .address-label{font-size:.875rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.invoice-customer-address .address-content{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6}.editor-form{display:flex;flex-direction:column;gap:24px}.editor-content{display:flex;gap:24px}.billable-sidebar{width:280px;min-width:240px;flex-shrink:0;display:flex;flex-direction:column;gap:16px;overflow:visible}.billable-sidebar-collapsed{width:auto;min-width:auto}.billable-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:8px;border-bottom:2px solid var(--color-primary)}.billable-sidebar-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-text)}.billable-count-badge{margin-left:6px;font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary)}.billable-collapse-toggle{font-size:var(--font-size-xs);color:var(--color-text-light);-webkit-user-select:none;user-select:none}.loading-indicator{font-size:var(--font-size-xs);color:var(--color-text-light)}.billable-section{background-color:var(--color-bg-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);position:relative;display:flex;flex-direction:column;overflow:visible}.billable-section-header{background:var(--color-bg-subtle);padding:10px 12px;font-weight:600;font-size:.875rem;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-shrink:0}.billable-list{padding:8px;max-height:200px;overflow-y:auto;overflow-x:visible;position:relative;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.billable-item{display:flex;flex-direction:column;padding:10px 12px;background-color:var(--color-bg-white);border:1px solid var(--color-border-medium);border-radius:var(--radius-md);margin-bottom:6px;transition:background-color .2s,border-color .2s;position:relative;overflow:visible}.billable-item:last-child{margin-bottom:0}.billable-item:hover:not(.billable-item-disabled){background-color:var(--color-info-bg);border-color:var(--color-primary)}.billable-item-disabled{background-color:var(--color-bg-page);color:var(--color-text-light);opacity:.6}.billable-item-warning{background-color:var(--color-warning-bg);border-color:var(--color-warning-border)}.billable-item-main{flex:1 1 auto;min-width:0}.billable-item-row-1{display:flex;align-items:center;gap:8px}.billable-item-row-2,.billable-item-row-3{margin-top:4px;padding-left:28px}.billable-item-name{flex:1;font-size:.875rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .1s,background-color .1s,border-color .1s}.billable-item-title-row{display:flex;align-items:center;gap:6px;min-width:0}.billable-item-amount,.billable-item-contractorName{font-size:.8125rem;color:var(--color-text-muted)}.billable-item-warning-icon{cursor:help;font-size:.875rem;position:relative;display:inline-flex;align-items:center;flex-shrink:0;--tt-left: 0px;--tt-top: 0px}.billable-item-warning-tooltip{position:fixed;left:var(--tt-left);top:var(--tt-top);transform:translateY(-50%);background:var(--color-text);color:#fff;padding:8px 12px;border-radius:var(--radius-md);font-size:var(--font-size-xs);white-space:nowrap;width:auto;max-width:90vw;line-height:1.4;opacity:0;visibility:hidden;transition:opacity .15s ease-out;z-index:var(--z-tooltip);pointer-events:none;box-shadow:0 4px 12px #0000004d}.billable-item-warning-icon:hover .billable-item-warning-tooltip,.billable-item-name:hover .billable-item-warning-tooltip{opacity:1;visibility:visible}.billable-expand-btn{flex-shrink:0;width:20px;height:20px;padding:0;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);transition:color .2s}.billable-expand-btn:hover{color:var(--color-text)}.billable-add-btn-container{position:relative;margin-left:auto;--tt-left: 0px;--tt-top: 0px}.billable-add-btn{width:24px;height:24px;padding:0;font-size:1rem;font-weight:700;line-height:1;border-radius:var(--radius-md)}.billable-add-btn-tooltip{position:fixed;left:var(--tt-left);top:var(--tt-top);transform:translate(-100%,-50%);background:var(--color-text);color:#fff;padding:6px 10px;border-radius:var(--radius-md);font-size:var(--font-size-xs);white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:var(--z-tooltip);pointer-events:none}.billable-add-btn-container:hover .billable-add-btn-tooltip{opacity:1;visibility:visible}.billable-item-details{margin-top:8px;padding:8px 12px;background:var(--color-bg-hover);border-radius:var(--radius-md);font-size:.8125rem}.billable-detail-row{display:flex;justify-content:space-between;margin-bottom:4px}.billable-detail-row:last-child{margin-bottom:0}.billable-detail-label{color:var(--color-text-muted);font-weight:500}.billable-detail-value{color:var(--color-text);font-weight:500}.billable-detail-block{margin-top:8px}.billable-detail-block .billable-detail-label{display:block;margin-bottom:4px;font-weight:500;color:var(--color-text-muted)}.billable-detail-block .billable-detail-value{display:block;color:var(--color-text);font-weight:400;padding-left:0;line-height:1.4}.billable-project-services{margin-top:8px;padding-top:8px;border-top:1px solid var(--color-border)}.billable-project-service-item{display:flex;justify-content:space-between;padding:4px 0;font-size:.8125rem}.billable-expense-items{margin-top:4px}.billable-expense-item{display:flex;justify-content:space-between;padding:2px 0}.billable-empty{padding:16px;text-align:center;color:var(--color-text-light);font-size:.875rem;font-style:italic}.invoice-items-section{flex:1;min-width:0;display:flex;flex-direction:column}.invoice-items-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-bg-page);border:1px solid var(--color-border);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.invoice-items-header span{font-weight:600;font-size:1rem;color:var(--color-text)}.invoice-items-table-container{border:1px solid var(--color-border);border-radius:0 0 var(--radius-lg) var(--radius-lg);overflow:hidden}.invoice-items-table{width:100%;border-collapse:collapse;table-layout:fixed}.invoice-items-table thead{background:var(--color-bg-hover)}.invoice-items-table th{padding:12px 8px;text-align:center;font-weight:600;font-size:.875rem;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border)}.invoice-items-table .col-date{width:145px}.invoice-items-table .col-activity{width:180px}.invoice-items-table .col-qty{width:62px}.invoice-item-col-qty input[type=number]::-webkit-outer-spin-button,.invoice-item-col-qty input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.invoice-item-col-qty input[type=number]{-moz-appearance:textfield}.invoice-items-table .col-rate{width:90px;border-right:3px solid var(--color-header-bg)}.invoice-items-table .col-amount{width:100px;border-right:3px solid var(--color-header-bg)}.invoice-items-table .col-tax{width:180px;border-right:3px solid var(--color-header-bg)}.invoice-items-table .col-1099{width:50px;text-align:center}.invoice-items-table .col-account{width:160px}.invoice-items-table .col-actions{width:50px}.invoice-items-table tbody tr{border-bottom:1px dotted var(--color-border-medium)}.invoice-items-table tbody tr:last-child{border-bottom:none}.invoice-items-table tbody tr:hover{background-color:var(--color-bg-hover)}.invoice-items-table td{padding:8px;vertical-align:top;font-size:.875rem}.invoice-items-table td.invoice-item-col-rate{border-right:3px solid var(--color-header-bg)}.invoice-items-table td.invoice-item-col-description-span{border-right:3px solid var(--color-header-bg);padding-top:6px;padding-bottom:10px}.invoice-item-description-row{display:flex;gap:10px;align-items:flex-start}.invoice-item-description-label{font-weight:600;padding-top:6px;white-space:nowrap}.invoice-item-row-description td{vertical-align:top}.invoice-item-col-description{vertical-align:top;padding:6px 8px;min-width:150px;max-width:250px}th.col-description{min-width:150px}.invoice-items-table tbody tr.invoice-item-row:not(.invoice-item-row-description):not(.invoice-item-row-project-header):not(.invoice-item-row-manual-title){border-bottom:none}.invoice-items-table td.invoice-item-col-amount{border-right:3px solid var(--color-header-bg);text-align:right;font-weight:500}.invoice-items-table td.invoice-item-col-tax{border-right:3px solid var(--color-header-bg)}.invoice-item-row-project-header{background:var(--color-info-bg)!important}.invoice-item-row-project-header:hover{background:var(--color-border-medium)!important}.invoice-item-row-project-header td.invoice-item-col-rate,.invoice-item-row-project-header td.invoice-item-col-amount,.invoice-item-row-project-header td.invoice-item-col-tax{border-right:3px solid var(--color-header-bg)!important}.invoice-item-col-project-header{text-align:center!important;padding:12px 16px!important;font-weight:600;color:var(--color-text);background:var(--color-info-bg)}.invoice-item-col-title-span{width:auto;border-right:3px solid var(--color-header-bg)}.invoice-item-project-header-text{width:100%}.invoice-item-project-header-text{font-weight:600;font-size:.9375rem;text-align:center}.invoice-item-row-project-service{background:var(--color-bg-hover)}.invoice-item-row-project-last{border-bottom:2px solid var(--color-border-medium)!important}.invoice-item-row-fee,.invoice-item-row-fee:hover{background-color:var(--color-warning-bg)!important}.invoice-items-table input[type=date],.invoice-items-table input[type=number],.invoice-items-table input[type=text],.invoice-items-table select,.invoice-items-table textarea{width:100%;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm)}.invoice-items-table input[type=number]{text-align:right}.invoice-items-table textarea{resize:none;min-height:32px;max-height:100px;overflow-y:auto;line-height:1.4;font-family:inherit}.invoice-item-amount-display{text-align:right;font-weight:500;padding:6px 8px}.invoice-item-remove-btn{width:24px;height:24px;padding:0;border:none;background:transparent;color:var(--color-danger);font-size:1.25rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:background-color .2s,color .2s;line-height:1}.invoice-item-remove-btn:hover{background-color:var(--color-danger);color:#fff}.item-subtext{font-size:var(--font-size-xs);margin-top:2px}.title-line-row{background-color:var(--color-bg-subtle)}.title-line-row td{font-weight:600;padding-top:10px;padding-bottom:6px}.item-input{width:100%;padding:6px 8px;border:1px solid var(--color-border-light);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:var(--color-bg-white);transition:border-color .15s}.item-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-ring)}.item-input:disabled{background:var(--color-bg-page);color:var(--color-text-muted);cursor:not-allowed}.item-input-sm{width:80px;text-align:right}.overpayment-credit-row{background-color:var(--color-bg-page);font-style:italic}.indicator-1099-eligible{color:var(--color-success-text);font-size:.85rem}.indicator-1099-not{color:var(--color-text-light);font-size:.85rem}.post-block-reasons{margin:0 0 .5rem}.post-block-reasons ul{margin:4px 0 0 16px;padding:0;list-style:disc}.post-block-reasons li{font-size:.85rem}.invoice-item-actions-container{display:flex;align-items:center;justify-content:center;gap:4px}.invoice-item-warning-container{position:relative;display:inline-block;--tt-left: 0px;--tt-top: 0px}.invoice-item-warning-icon{color:var(--color-warning);cursor:help;font-size:.875rem}.invoice-item-warning-tooltip{position:fixed;left:var(--tt-left);top:var(--tt-top);transform:translateY(-50%);background:var(--color-text);color:#fff;padding:8px 12px;border-radius:var(--radius-md);font-size:var(--font-size-xs);white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:var(--z-tooltip);max-width:250px;white-space:normal;pointer-events:none;box-shadow:0 2px 8px #00000040}.invoice-item-warning-tooltip-left{transform:translate(-100%,-50%)}.invoice-item-warning-container:hover .invoice-item-warning-tooltip{opacity:1;visibility:visible}.invoice-items-empty{text-align:center;padding:32px 16px;color:var(--color-text-light);font-style:italic}.invoice-totals{display:flex;flex-direction:column;align-items:flex-end;padding:16px;background:var(--color-bg-hover);border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.invoice-total-row{display:flex;justify-content:space-between;width:250px;padding:4px 0}.invoice-total-label{color:var(--color-text-muted)}.invoice-total-value{font-weight:500}.invoice-total-grand{border-top:1px solid var(--color-border-medium);padding-top:8px;margin-top:8px}.invoice-total-grand .invoice-total-label,.invoice-total-grand .invoice-total-value{font-weight:700;font-size:var(--font-size-lg);color:var(--color-text)}.invoice-total-category .invoice-total-label{color:var(--color-text-secondary);font-weight:400}.invoice-memo-section,.invoice-payment-link-section{display:flex;flex-direction:column;gap:6px}.invoice-memo-section label,.invoice-payment-link-section label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.invoice-memo-section textarea{resize:vertical;min-height:80px}.invoice-save-error{background:var(--color-danger-bg);color:var(--color-danger-text);padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--color-danger-border)}.invoice-payment-view{display:flex;flex-direction:column;gap:12px}.invoice-payment-view-modal{background:var(--color-bg-white);border-radius:var(--radius-lg);padding:20px;min-width:400px;max-width:500px;box-shadow:var(--shadow-lg)}.invoice-payment-header{display:flex;flex-direction:column;gap:4px}.invoice-payment-title{font-size:1rem;font-weight:600;color:var(--color-text);display:flex;justify-content:space-between;align-items:center}.invoice-payment-close-btn{width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--color-text-muted);font-size:1.5rem;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:background-color .2s,color .2s;line-height:1}.invoice-payment-close-btn:hover{background-color:var(--color-bg-subtle);color:var(--color-text)}.invoice-payment-subtitle{font-size:.8125rem;color:var(--color-text-muted);display:flex;align-items:center;gap:8px}.invoice-payment-invoice-number{font-weight:500;color:var(--color-text-secondary)}.invoice-payment-total{color:var(--color-text-muted)}.invoice-payment-content{display:flex;flex-direction:column;gap:16px;padding-top:8px;border-top:1px solid var(--color-border);flex:1 1 auto;overflow-y:auto}.invoice-payment-balance-section{display:flex;flex-direction:column;gap:8px}.invoice-payment-balance-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.invoice-payment-balance-due{font-weight:600;color:var(--color-primary-hover);font-size:1rem}.invoice-payment-placeholder{padding:16px;background:var(--color-bg-hover);border-radius:var(--radius-md);text-align:center;color:var(--color-text-light);font-style:italic;font-size:.875rem}body.payment-modal-open{overflow:hidden}@media(max-width:1200px){.billable-sidebar{width:240px;min-width:200px}.invoice-info-sections{gap:16px}.invoice-info-section{padding:12px}}@media(max-width:992px){.invoice-info-sections{flex-direction:column}.invoice-info-section{width:100%}.editor-content{flex-direction:column}.billable-sidebar{width:100%;flex-direction:row;flex-wrap:wrap;gap:16px}.billable-section{flex:1;min-width:250px}}@media(max-width:768px){.editor-header-sticky{flex-direction:column;gap:6px;align-items:flex-start;padding:8px 12px;height:auto}.editor-header-right{width:100%;justify-content:flex-end}.editor-header-spacer{display:none}.invoice-field-row{flex-direction:column;gap:12px}.invoice-items-table{font-size:.8125rem}.invoice-items-table th,.invoice-items-table td{padding:6px 4px}}.editor-form-payment-mode{display:flex;flex-direction:column;gap:16px}.editor-form-payment-mode .invoice-payment-layout-top{display:flex;gap:24px;align-items:flex-start}.invoice-payment-layout-left{flex:0 0 320px;display:flex;flex-direction:column;gap:16px}.invoice-payment-layout-right{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0}.invoice-details-payment-mode{padding:16px}.invoice-details-date-row{display:flex;gap:16px;margin-top:8px}.invoice-details-date-row .invoice-field{flex:1;min-width:0}.invoice-details-date-row .invoice-field input{width:100%}.invoice-payment-layout-payment{flex:1}.editor-form-payment-mode .editor-content-payment-mode{width:100%}.editor-content-payment-mode{min-width:0}.editor-content-payment-mode .invoice-items-section{width:100%}.invoice-payment-layout-info,.invoice-payment-layout-additional,.invoice-payment-layout-bottom{display:none}.invoice-payment-view{background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invoice-payment-view-modal{box-shadow:var(--shadow-lg);max-width:600px;margin:0 auto;display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.invoice-payment-header{background:var(--color-bg-hover);padding:16px;border-bottom:1px solid var(--color-border);flex:0 0 auto}.invoice-payment-modal-header{margin-bottom:16px}.invoice-payment-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text);display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.invoice-payment-close-btn{background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;padding:0;line-height:1}.invoice-payment-close-btn:hover{color:var(--color-text)}.invoice-payment-customer-line{font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:4px}.invoice-payment-customer-label{font-weight:500}.invoice-payment-customer-name{font-weight:600;color:var(--color-text)}.invoice-payment-subtitle{font-size:.875rem;color:var(--color-text-muted);display:flex;align-items:center;gap:8px}.invoice-payment-invoice-number{font-weight:600;color:var(--color-text)}.invoice-payment-separator{color:var(--color-border-dark)}.invoice-payment-total{color:var(--color-text)}.invoice-payment-balance-row-container{display:flex;gap:16px}.invoice-payment-balance-section{flex:0 0 calc(50% - 8px);background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:6px;padding:12px;box-sizing:border-box}.invoice-payment-section-title{font-size:.875rem;font-weight:600;color:var(--color-text);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--color-border-light)}.invoice-payment-balance-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.875rem}.invoice-payment-balance-label{color:var(--color-text-muted)}.invoice-payment-balance-value{font-weight:500;color:var(--color-text)}.invoice-payment-balance-row-highlight{background:var(--color-bg-hover);margin:4px -8px;padding:6px 8px;border-radius:var(--radius-md)}.invoice-payment-balance-due{font-size:1rem;font-weight:600;color:var(--color-danger)}.invoice-payment-linked-expenses-link{margin-top:8px;font-size:.8125rem}.invoice-payment-linked-expenses-link a{color:var(--color-primary);text-decoration:none}.invoice-payment-linked-expenses-link a:hover{text-decoration:underline}.fee-status-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.fee-status-none{background:var(--color-border-light);color:var(--color-text-muted)}.fee-status-unpaid{background:var(--color-danger-bg);color:var(--color-danger-text)}.fee-status-partial{background:var(--color-warning-bg);color:var(--color-warning-text)}.fee-status-paid{background:var(--color-success-bg);color:var(--color-success-text)}.invoice-payment-content{padding:16px}.invoice-payment-loading{text-align:center;padding:20px;color:var(--color-text-muted)}.invoice-payment-error{background:var(--color-danger-bg);color:var(--color-danger-text);padding:12px;border-radius:var(--radius-md);margin-bottom:16px}.invoice-payment-paid-notice{display:flex;align-items:center;gap:8px;background:var(--color-success-bg);color:var(--color-success-text);padding:16px;border-radius:6px;font-weight:500}.invoice-payment-paid-icon{font-size:1.25rem}.invoice-payment-form{margin-top:16px}.invoice-payment-credit-available{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--color-info-bg);border-radius:var(--radius-md);margin-bottom:16px;font-size:.875rem}.invoice-payment-credit-label{color:var(--color-info-text)}.invoice-payment-credit-value{font-weight:600;color:var(--color-info-text)}.invoice-payment-form-row{margin-bottom:16px}.invoice-payment-form-row-double{display:flex;gap:16px}.invoice-payment-form-column{flex:1;display:flex;flex-direction:column;gap:12px}.invoice-payment-form-field{display:flex;flex-direction:column;gap:6px}.invoice-payment-form-field label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.invoice-payment-input-wrapper{display:flex;align-items:stretch;border:1px solid var(--color-border-medium);border-radius:var(--radius-md);overflow:hidden;background:var(--color-bg-white)}.invoice-payment-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.invoice-payment-input-prefix{display:flex;align-items:center;padding:0 10px;background:var(--color-bg-page);border-right:1px solid var(--color-border-medium);color:var(--color-text-muted);font-weight:500}input.invoice-payment-amount-input{flex:1;border:none;outline:none;border-radius:0}.invoice-payment-amount-input:disabled{background:var(--color-bg-page);color:var(--color-text-light);cursor:not-allowed}.invoice-payment-account-select:disabled{background:var(--color-bg-page);color:var(--color-text-light);cursor:not-allowed}.invoice-payment-checkbox-label{display:flex;align-items:center;gap:8px;font-size:.9375rem;cursor:pointer}.invoice-payment-checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.invoice-payment-field-hint{font-size:var(--font-size-xs);color:var(--color-text-light);margin-top:2px}.invoice-payment-cleared-field{margin-top:4px}.invoice-payment-preview{background:var(--color-bg-hover);border:1px solid var(--color-border);border-radius:6px;padding:16px;margin-bottom:16px}.invoice-payment-preview-title{font-size:.875rem;font-weight:600;color:var(--color-text);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.invoice-payment-preview-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.9375rem}.invoice-payment-preview-total{font-weight:600;border-top:1px solid var(--color-border);margin-top:8px;padding-top:8px}.invoice-payment-preview-warning{background:var(--color-warning-bg);margin:8px -12px -12px;padding:10px 12px;border-radius:0 0 var(--radius-md) var(--radius-md);color:var(--color-warning-text)}.invoice-payment-balance-paid{color:var(--color-success);font-weight:600}.invoice-payment-warning{background:var(--color-warning-bg);color:var(--color-warning-text);padding:12px;border-radius:var(--radius-md);margin-bottom:16px;font-size:.875rem}.invoice-payment-success{background:var(--color-success-bg);color:var(--color-success-text);padding:12px;border-radius:var(--radius-md);margin-bottom:16px}.invoice-payment-submit-error{background:var(--color-danger-bg);color:var(--color-danger-text);padding:12px;border-radius:var(--radius-md);margin-bottom:16px}.invoice-payment-form-actions{margin-top:16px}.invoice-payment-submit-btn{width:100%;padding:12px 24px;font-size:1rem;font-weight:600;color:var(--color-bg-white);background:var(--color-success);border:none;border-radius:6px;cursor:pointer;transition:background-color .2s}.invoice-payment-submit-btn:hover:not(:disabled){background:var(--color-success-hover)}.invoice-payment-submit-btn:disabled{background:var(--color-secondary);cursor:not-allowed}.invoice-payment-cm-section{margin-top:12px;padding:12px;background:var(--color-info-bg);border:1px solid var(--color-border-medium);border-radius:6px}.invoice-payment-cm-section .invoice-payment-section-title{margin-bottom:8px}.invoice-payment-cm-list{display:flex;flex-direction:column;gap:6px}.invoice-payment-cm-row{display:flex;flex-direction:column;gap:4px;padding:8px 10px;background:var(--color-bg-white);border:1px solid var(--color-border-medium);border-radius:var(--radius-md);transition:border-color .15s,background .15s}.invoice-payment-cm-row-selected{border-color:var(--color-primary);background:var(--color-info-bg)}.invoice-payment-cm-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:var(--font-size-base)}.invoice-payment-cm-checkbox-label input[type=checkbox]{margin:0}.invoice-payment-cm-number{font-weight:600;color:var(--color-header-bg)}.invoice-payment-cm-date{color:var(--color-header-border);font-size:var(--font-size-sm)}.invoice-payment-cm-remaining{margin-left:auto;color:var(--color-success);font-weight:500;font-size:var(--font-size-base)}.invoice-payment-cm-amount-field{display:flex;align-items:center;gap:8px;padding-left:26px}.invoice-payment-cm-amount-field label{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.invoice-payment-cm-input-wrapper{max-width:140px}.invoice-payment-cm-amount-input{font-size:var(--font-size-sm)!important;padding:4px 6px!important}.invoice-payment-cm-total{display:flex;justify-content:space-between;padding:8px 10px;margin-top:6px;font-weight:600;color:var(--color-header-bg);border-top:1px solid var(--color-border-medium)}@media(max-width:1200px){.invoice-payment-layout-top{flex-direction:column}.invoice-payment-layout-info{flex:none;width:100%}.invoice-payment-layout-payment{min-width:auto;width:100%}.editor-form-payment-mode .invoice-payment-layout-top{flex-direction:column}.invoice-payment-layout-left{flex:none;width:100%}.invoice-payment-layout-right{width:100%}.invoice-details-date-row{flex-direction:column;gap:8px}}@media(max-width:768px){.invoice-payment-form-row-double,.invoice-payment-balance-row-container{flex-direction:column}}.list-section{margin-bottom:24px}.list-section-header{font-size:var(--font-size-lg);font-weight:600;margin:0 0 8px;padding:12px 16px;background-color:var(--color-bg-hover);border-radius:var(--radius-md) var(--radius-md) 0 0;border-bottom:1px solid var(--color-border-light)}.list-section-description{margin:0 0 12px;padding:0 16px;color:var(--color-text-muted);font-size:var(--font-size-base)}.list-section .list-table-container{margin-top:0}.list-section .list-empty{padding:24px 16px;text-align:center;color:var(--color-text-muted)}.col-basis,.invoice-item-col-basis{width:100px;max-width:100px}.invoice-items-table .col-status{width:100px;text-align:center}.invoice-item-col-activity,.invoice-item-col-status{white-space:nowrap;font-size:.8rem;text-align:center;vertical-align:middle}.invoice-items-table th.col-activity,.invoice-items-table th.col-status{text-align:center}.activity-badge{display:inline-block;padding:2px 6px;border-radius:var(--radius-sm);background:var(--color-info-bg);color:var(--color-text-secondary);font-size:.8rem}.activity-badge-project{background:var(--color-info-bg);color:var(--color-accent);font-weight:500}.activity-badge-manual{color:var(--color-text-light);background:transparent;cursor:help;position:relative}.activity-badge-manual .manual-warning-tooltip{display:none;position:fixed;left:var(--tt-left);top:var(--tt-top);transform:translateY(-50%);margin-top:0;padding:6px 10px;background:var(--color-text);color:var(--color-bg-white);font-size:.78rem;border-radius:4px;white-space:normal;width:240px;z-index:var(--z-tooltip);line-height:1.3;text-align:left;pointer-events:none}.activity-badge-manual:hover .manual-warning-tooltip{display:block}.activity-badge-empty{color:var(--color-border-dark)}.manual-warning-icon{color:var(--color-warning);font-size:.9rem;margin-left:2px}.status-recurring-active{background:#34a8531a;color:#34a853}.status-recurring-paused{background:#f9ab001a;color:#f9ab00}.status-recurring-completed{background:#9999991a;color:var(--color-text-light)}.status-recurring-cancelled{background:#ea43351a;color:#ea4335}.billable-item-draft-warning{font-size:.75rem;color:var(--color-warning);padding:2px 0 0 24px;font-style:italic}.google-btn{display:inline-flex;align-items:center;background-color:#fff;color:#1f1f1f;border:1px solid #747775;border-radius:4px;padding:0;font-family:Roboto,arial,sans-serif;font-weight:500;font-size:14px;cursor:pointer;height:40px;transition:background-color .2s,box-shadow .2s;overflow:hidden;vertical-align:middle}.google-btn:hover{background-color:#f8fafd;box-shadow:0 1px 2px #3c40434d,0 1px 3px 1px #3c404326}.google-btn:active{background-color:#eee}.google-btn:disabled{opacity:.6;cursor:not-allowed}.google-icon-wrapper{padding:10px;background-color:#fff;display:flex;align-items:center;justify-content:center;height:100%}.google-icon{width:18px;height:18px}.google-btn-text{padding:0 12px 0 4px;letter-spacing:.25px}.invoice-items-table td.invoice-item-col-description-full{padding-top:6px;padding-bottom:10px;border-right:none}.invoice-item-row-description td{border-right:none}.status-warning-icon{display:inline-flex;align-items:center;justify-content:center;position:relative;cursor:help}.status-warning-icon .manual-warning-icon{color:var(--color-warning);font-size:1.1rem}.status-warning-icon .manual-warning-tooltip{display:none;position:fixed;left:var(--tt-left);top:var(--tt-top);transform:translateY(-50%);background:var(--color-text);color:var(--color-bg-white);padding:8px 12px;border-radius:4px;font-size:.8rem;max-width:280px;z-index:var(--z-tooltip);white-space:normal;line-height:1.3;text-align:left;pointer-events:none;box-shadow:0 2px 8px #00000040}.status-warning-icon:hover .manual-warning-tooltip{display:block}.customer-table .col-customer-name{width:200px;min-width:150px}.customer-table .col-abbr{width:80px;min-width:60px}.customer-table .col-location{width:140px;min-width:120px}.customer-table .col-contacts{width:130px;min-width:100px}.customer-table .col-actions{width:70px;min-width:70px;text-align:center}.customer-table .col-date{width:120px;min-width:100px}.customer-table .col-status{width:80px;min-width:60px;text-align:center}.customer-table .col-balance,.customer-table .col-credit,.customer-table .col-amount{width:80px;min-width:60px;text-align:right}.vendor-table .col-customer-name{width:220px;min-width:160px}.vendor-table .col-abbr{width:80px;min-width:60px}.vendor-table .col-location{width:150px;min-width:120px}.vendor-table .col-contacts{width:160px;min-width:120px}.vendor-table .col-amount{width:90px;min-width:70px;text-align:right}.vendor-table .col-status{width:80px;min-width:60px;text-align:center}.vendor-table .col-actions{width:70px;min-width:70px;text-align:center}.contacts-vstack{display:flex;flex-direction:column;gap:2px}.contacts-vstack .contact-name{font-size:.85rem;line-height:1.3}.contacts-vstack .contact-name:first-child{font-weight:500}.overdue-amount{color:var(--color-danger);font-weight:500}.contractor-table .col-customer{width:220px;min-width:160px}.contractor-table .col-email{width:220px;min-width:150px}.contractor-table .col-phone{width:150px;min-width:120px}.contractor-table .col-location{width:155px;min-width:110px}.contractor-table .col-balance{width:100px;min-width:80px;text-align:right}.contractor-table .col-status{width:80px;min-width:60px;text-align:center}.contractor-table .col-actions{width:70px;min-width:70px;text-align:center}.contact-table .col-contact-name{width:210px;min-width:160px}.contact-table .col-contact-entity{width:180px;min-width:130px}.contact-table .col-contact-email{width:220px;min-width:160px}.contact-table .col-contact-phone{width:150px;min-width:120px}.contact-table .col-status{width:80px;min-width:60px;text-align:center}.contact-table .col-actions{width:70px;min-width:70px;text-align:center}.invoice-preview-pane{display:flex;flex-direction:column;height:calc(100vh - 88px);min-height:600px;background:var(--color-bg-page);border-radius:0 0 8px 8px;overflow:hidden}.invoice-preview-unsaved-notice{background:var(--color-warning-bg);color:var(--color-warning-text);border-bottom:1px solid var(--color-warning-border);padding:6px 16px;font-size:.8rem;text-align:center;flex-shrink:0}.invoice-preview-loading{display:flex;justify-content:center;align-items:center;flex:1}.invoice-preview-error{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;padding:2rem}.invoice-preview-error-message{color:var(--color-danger);font-size:.95rem}.invoice-preview-iframe{flex:1;width:100%;border:none;display:block}.charge-lock-warning{cursor:help;font-size:.85rem;position:relative;display:inline-flex;align-items:center;flex-shrink:0;color:var(--color-warning);--tt-left: 0px;--tt-top: 0px}.charge-lock-warning-popup{position:fixed;left:var(--tt-left);top:var(--tt-top);transform:translate(-50%,-100%);margin-top:-8px;background:var(--color-text);color:var(--color-bg-white);padding:10px 14px;border-radius:6px;font-size:.78rem;white-space:normal;width:260px;line-height:1.45;opacity:0;visibility:hidden;transition:opacity .15s ease-out .3s,visibility 0s linear .45s;z-index:var(--z-tooltip);pointer-events:none;box-shadow:0 4px 12px #0000004d}.charge-lock-warning-popup:after{content:"";position:absolute;left:0;right:0;bottom:-12px;height:12px}.charge-lock-warning:hover .charge-lock-warning-popup{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .15s ease-out 0s}.charge-lock-warning-popup-text{margin-bottom:8px}.charge-lock-warning-popup-extra{margin-top:6px;font-style:italic;opacity:.85;font-size:.72rem}.charge-lock-warning-popup .btn-unlock{display:inline-block;font-size:.72rem;padding:3px 10px;cursor:pointer;background:var(--color-bg-white);color:var(--color-text);border:1px solid var(--color-border-dark);border-radius:3px;white-space:nowrap;font-weight:500}.charge-lock-warning-popup .btn-unlock:hover{background:var(--color-bg-subtle);border-color:var(--color-text-light)}.invoice-item-drag-handle{cursor:grab;color:var(--color-text-light);font-size:1rem;line-height:1;padding:2px 4px;border:none;background:transparent;display:flex;align-items:center;touch-action:none;border-radius:var(--radius-sm)}.invoice-item-drag-handle:hover{color:var(--color-text-muted);background-color:var(--color-bg-hover)}.invoice-item-drag-handle:active{cursor:grabbing}.sortable-row--dragging{opacity:.4;background:var(--color-bg-hover)}.sortable-row--dragging tr{background:var(--color-bg-hover)!important}.drag-overlay-table{width:100%;border-collapse:collapse;background:var(--color-bg-white);box-shadow:0 4px 12px #00000026;border-radius:var(--radius-sm);opacity:.9}.drag-overlay-table td{padding:6px 8px;font-size:.85rem}.report-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin:0 1rem;padding:0}.report-tab{padding:.5rem 1rem;border:none;background:none;cursor:pointer;font-size:var(--font-size-base);color:var(--color-text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.report-tab:hover{color:var(--color-text)}.report-tab-active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:500}.editor-subsection{margin:0 24px 24px;padding:16px;background:var(--color-bg-hover);border-radius:var(--radius-md)}.editor-subsection-title{margin:0 0 12px;font-size:.95rem;font-weight:600}.contact-editor-row{display:flex;gap:var(--space-lg);flex-wrap:wrap;align-items:flex-start}.contact-editor-section-wide{flex:1 1 380px;min-width:300px}.contact-editor-section-narrow{flex:1 1 280px;min-width:220px}.contact-editor-hint{font-size:var(--font-size-xs);opacity:.75;margin-top:var(--space-sm)}.contact-editor-hint--dim{font-size:var(--font-size-sm);opacity:.8;margin-top:var(--space-sm)}.contact-editor-notes-group{flex:0 1 50%;max-width:50%;min-width:320px}.contact-editor-notes-group textarea{min-height:220px}.retainer-header{display:flex;align-items:center;gap:var(--space-sm)}.retainer-badge{font-size:.65rem;padding:1px 6px}.retainer-balance-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-purple-dark)}.retainer-total-deposits{font-size:var(--font-size-base);color:var(--color-success)}.retainer-total-recognized{font-size:var(--font-size-base)}.retainer-actions{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.retainer-message{border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);font-size:var(--font-size-sm)}.retainer-message--success{background-color:var(--color-success-bg);border:1px solid var(--color-success-border);color:var(--color-success-text)}.retainer-message--error{background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);color:var(--color-danger-text)}.retainer-form{background-color:var(--color-bg-hover);border:1px solid var(--color-border-light);border-radius:6px;padding:var(--space-md) 14px;margin-bottom:var(--space-md)}.retainer-form-title{font-weight:600;margin-bottom:var(--space-sm);font-size:var(--font-size-base)}.retainer-form-description{font-size:.8rem;margin-bottom:10px}.retainer-history-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.retainer-history-table th{text-align:left;padding:6px 8px;font-weight:600}.retainer-history-table th.text-right,.retainer-history-table td.text-right{text-align:right}.retainer-history-table thead tr{border-bottom:2px solid var(--color-border-light)}.retainer-history-table tbody tr{border-bottom:1px solid var(--color-bg-hover)}.retainer-history-table td{padding:6px 8px}.retainer-history-type-badge{font-size:.7rem;padding:1px 6px;border-radius:var(--radius-sm)}.retainer-history-type-badge--deposit{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.retainer-history-type-badge--recognition{background-color:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border)}.retainer-history-amount--deposit{color:var(--color-success)}.retainer-history-amount--recognition{color:var(--color-danger)}.retainer-history-balance{font-weight:500}.mt-half{margin-top:.5rem}.mt-1{margin-top:8px}.mt-quarter{margin-top:4px}.mb-12{margin-bottom:12px}.ml-auto{margin-left:auto}.overflow-x-auto{overflow-x:auto}.text-underline{text-decoration:underline}.text-muted-light{opacity:.85}.fw-600{font-weight:600}.fw-500{font-weight:500}.d-block{display:block}.form-row-end{display:flex;gap:16px;align-items:flex-end}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-secondary)}.empty-state p{margin-bottom:1rem;font-size:1.05rem}.empty-state .btn{margin-top:.5rem}.skeleton-table{padding:0}.skeleton-row td{padding:.75rem .5rem}.skeleton-cell{height:1rem;background:var(--color-bg-hover);border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-header-cell{height:.85rem;width:60%;opacity:.6}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}@media(prefers-reduced-motion:reduce){.skeleton-cell{animation:none;opacity:.6}}.status-popover{position:fixed;background:var(--color-bg-white);border-radius:var(--radius-md, 8px);padding:16px;box-shadow:0 4px 20px #0003;z-index:var(--z-menu);min-width:220px;max-width:320px}.status-popover-backdrop{position:fixed;inset:0;z-index:9999}.status-popover-title{margin:0 0 .25rem;font-size:1rem}.status-popover-entity{margin:.25rem 0 .75rem}.status-popover-current{margin:0 0 .25rem;font-size:.8rem}.status-popover-error{margin-bottom:.75rem}.status-popover-options{display:flex;flex-direction:column;gap:6px;margin:.75rem 0}.status-popover-option{text-align:left;justify-content:flex-start}.status-popover-footer{display:flex;justify-content:flex-end;margin-top:8px}.status-popover-cancel{font-size:.85rem}.service-progress-wrapper{margin-bottom:8px}.service-progress-labels{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px}.service-status-actions{margin-top:8px;display:flex;gap:.5rem;position:relative;flex-wrap:wrap}.service-status-override-inline{position:absolute;top:100%;left:0;margin-top:4px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.section-description{color:var(--color-text-muted);font-size:var(--font-size-base);margin:0 0 1.25rem}.data-table th.admin-th{padding:.75rem;border-bottom:2px solid var(--color-border-medium)}.data-table th.admin-th--center{text-align:center}.data-table td.admin-td{padding:.75rem}.data-table td.admin-td--center{text-align:center}.data-table td.admin-td--edit{padding:.5rem}.data-table tr.admin-row--inactive{opacity:.6;background-color:var(--color-bg-hover)}.admin-status-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.85rem}.admin-status-badge--active{background-color:var(--color-success-bg);color:var(--color-success-text)}.admin-status-badge--inactive{background-color:var(--color-bg-hover);color:var(--color-text-muted)}.admin-system-badge{display:inline-block;margin-top:.25rem;padding:.1rem .4rem;border-radius:3px;background-color:var(--color-info-bg);color:var(--color-info-text);font-size:.7rem;font-weight:600;letter-spacing:.03em}.admin-add-form{margin-bottom:1.5rem;padding:1rem;background-color:var(--color-bg-hover);border-radius:4px}.admin-add-form h4{margin:0 0 1rem;font-size:1rem}.admin-form-row{display:flex;gap:1rem;flex-wrap:wrap}.admin-form-field{flex:1 1 180px}.admin-form-field--narrow{flex:1 1 130px}.admin-form-field--fixed{flex:0 0 120px}.admin-form-field--btn{flex:0 0 auto;display:flex;align-items:flex-end}.admin-table-actions{display:flex;gap:.25rem;justify-content:center}.admin-inline-pair{display:flex;gap:.5rem;flex-wrap:wrap}.admin-inline-pair select{width:90px}.admin-inline-pair input{width:80px}.admin-edit-input{width:100%}.admin-checkbox-field--spaced{margin-top:.75rem}.form-help--block{margin-top:.5rem;display:block}.je-preview-box{background:var(--color-bg-subtle);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md)}.je-preview-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.je-preview-table th{font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:var(--font-size-xs, 11px);padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-border-light)}.je-preview-table td{padding:var(--space-xs) var(--space-sm)}.notification-bell-container{position:relative;display:inline-flex;align-items:center}.notification-bell-button{position:relative;background:none;border:none;cursor:pointer;padding:.4rem;color:var(--color-header-text);display:flex;align-items:center;justify-content:center;transition:color .2s}.notification-bell-button:hover{color:var(--color-bg-white)}.notification-bell-icon{width:22px;height:22px}.notification-badge{position:absolute;top:0;right:-2px;background-color:var(--color-danger);color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;line-height:16px;text-align:center;border-radius:10px;padding:0 4px;pointer-events:none}.notification-panel{position:absolute;top:100%;right:0;margin-top:8px;width:420px;max-height:520px;background:var(--color-bg-white);border:1px solid var(--color-border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-notification);z-index:var(--z-dropdown);display:flex;flex-direction:column;overflow:hidden}.notification-panel-header{padding:12px 16px;border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;align-items:center}.notification-panel-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-header-bg)}.notification-panel-body{flex:1;overflow-y:auto;max-height:400px}.notification-panel-footer{padding:10px 16px;border-top:1px solid var(--color-border-light);display:flex;flex-direction:column;gap:8px;align-items:center}.notification-footer-hint{font-size:.75rem;color:var(--color-text-light);text-align:center;padding:10px 16px;border-top:1px solid var(--color-bg-subtle)}.notification-footer-actions{display:flex;gap:12px;align-items:center}.notification-btn-view-all{font-size:.8rem;padding:5px 14px;background:var(--color-primary);color:#fff;font-weight:500;text-decoration:none;text-align:center;border-radius:var(--radius-md)}.notification-btn-view-all:hover{background:var(--color-primary-hover);color:#fff}.notification-empty{padding:32px 16px;text-align:center;color:var(--color-text-light);font-size:var(--font-size-base)}.notification-item{padding:12px 16px;border-bottom:1px solid var(--color-bg-subtle);cursor:pointer;transition:background-color .15s}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:var(--color-bg-hover)}.notification-unread{background-color:var(--color-info-bg);border-left:3px solid var(--color-primary)}.notification-unread:hover{background-color:var(--color-info-bg)}.notification-read{border-left:3px solid transparent}.notification-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}.notification-title{font-weight:600;font-size:.88rem;color:var(--color-header-bg);flex:1;line-height:1.3}.notification-unread .notification-title{font-weight:700}.notification-title-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.notification-body-row{display:flex;gap:12px}.notification-body-left{flex:1;min-width:0}.notification-body{margin:0 0 4px;font-size:.82rem;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.notification-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.notification-time{font-size:.75rem;color:var(--color-text-light)}.notification-sender{font-size:.75rem;color:var(--color-header-border);font-style:italic}.notification-reminder-badge{font-size:.7rem;color:var(--color-warning);background:var(--color-warning-bg);padding:1px 6px;border-radius:3px;font-weight:500}.notification-body-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0;align-items:flex-end}.notification-btn{border:none;cursor:pointer;font-size:.75rem;border-radius:var(--radius-md);padding:4px 8px;transition:background-color .15s,color .15s;white-space:nowrap}.notification-btn-mark-unread{background:none;color:var(--color-primary);padding:2px 6px;font-size:.72rem}.notification-btn-mark-unread:hover{background:var(--color-info-bg);color:var(--color-primary-hover)}.notification-btn-clear{background:none;color:var(--color-text-light);padding:2px 6px;font-size:var(--font-size-sm);font-weight:500}.notification-btn-clear:hover{color:var(--color-danger);background:var(--color-danger-bg)}.notification-btn-action{background:var(--color-primary);color:#fff;font-weight:500;padding:5px 10px}.notification-btn-action:hover{background:var(--color-primary-hover)}.notification-btn-remind{background:var(--color-bg-subtle);color:var(--color-text-secondary)}.notification-btn-remind:hover{background:var(--color-border);color:var(--color-text)}.notification-btn-test{background:var(--color-header-bg);color:#fff;font-size:.8rem;padding:6px 14px}.notification-btn-test:hover{background:var(--color-header-bg-dark)}.notification-reminder-input{font-size:var(--font-size-xs);padding:3px 6px;max-width:180px}.notification-high-priority{border-left-color:var(--color-danger)!important;border-left-width:3px!important}.notification-high-priority.notification-unread{background-color:var(--color-danger-bg)}.notification-header-actions{display:flex;gap:8px;align-items:center}.notification-btn-bulk{font-size:11px;padding:2px 8px;background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap}.notification-btn-bulk:hover{background-color:var(--color-bg-hover);color:var(--color-text)}.notification-read[data-notif-type=INVOICE],.notification-read[data-notif-type=EXPENSE],.notification-read[data-notif-type=CREDIT_MEMO],.notification-read[data-notif-type=AP_CREDIT],.notification-read[data-notif-type=REFUND],.notification-read[data-notif-type=PAYMENT]{border-left-color:var(--color-notif-financial)}.notification-read[data-notif-type=ASSIGNMENT],.notification-read[data-notif-type=SERVICE],.notification-read[data-notif-type=PROJECT]{border-left-color:var(--color-notif-workflow)}.notification-read[data-notif-type=USER_SECURITY],.notification-read[data-notif-type=GOOGLE]{border-left-color:var(--color-notif-security)}.notification-read[data-notif-type=SYSTEM],.notification-read[data-notif-type=REPORT]{border-left-color:var(--color-notif-system)}.notification-read[data-notif-type=RETAINER]{border-left-color:var(--color-notif-retainer)}.notification-read[data-notif-type=FISCAL_PERIOD],.notification-read[data-notif-type=RECONCILIATION],.notification-read[data-notif-type=FORM_1099]{border-left-color:var(--color-notif-accounting)}.notification-read[data-notif-type=RECURRING_INVOICE],.notification-read[data-notif-type=RECURRING_EXPENSE]{border-left-color:var(--color-notif-recurring)}.session-timeout-warning{position:fixed;top:0;left:0;right:0;z-index:var(--z-session);background:linear-gradient(135deg,var(--color-warning) 0%,var(--color-danger) 100%);color:#fff;box-shadow:var(--shadow-md);animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.session-timeout-content{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 20px;max-width:1200px;margin:0 auto;flex-wrap:wrap}.session-timeout-icon{flex-shrink:0}.session-timeout-icon svg{width:28px;height:28px;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.session-timeout-message{display:flex;flex-direction:column;gap:2px;flex:1;min-width:200px}.session-timeout-message strong{font-size:1rem;font-weight:600}.session-timeout-message span{font-size:.9rem;opacity:.95}.session-timeout-message .countdown{font-weight:700;font-size:1.1em;background:#fff3;padding:2px 8px;border-radius:var(--radius-md);font-family:monospace}.session-timeout-error{color:var(--color-danger-bg);font-size:.85rem;margin-top:4px}.session-timeout-actions{display:flex;gap:10px;flex-shrink:0}.session-extend-btn{background:#fff;color:var(--color-danger);border:none;padding:8px 16px;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .15s ease}.session-extend-btn:hover:not(:disabled){background:var(--color-bg-hover);transform:scale(1.02)}.session-extend-btn:disabled{opacity:.7;cursor:not-allowed}.session-logout-btn{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6);padding:8px 16px;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .15s ease}.session-logout-btn:hover:not(:disabled){background:#ffffff1a;border-color:#fff}.session-logout-btn:disabled{opacity:.7;cursor:not-allowed}@media(max-width:600px){.session-timeout-content{flex-direction:column;text-align:center;padding:16px 12px}.session-timeout-message{align-items:center}.session-timeout-actions{width:100%;justify-content:center}}.dashboard-widget-grid{--dashboard-row-height: 110px;display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:var(--dashboard-row-height);gap:var(--space-lg)}.dashboard-widget-cell{min-width:0;overflow:hidden;position:relative}.dashboard-widget-grid--editing .dashboard-widget-cell{overflow:visible}@media(max-width:1023px){.dashboard-widget-grid{grid-template-columns:repeat(6,1fr)}}@media(max-width:767px){.dashboard-widget-grid{grid-template-columns:1fr;grid-auto-rows:auto}.dashboard-widget-cell{grid-column:1 / -1!important;grid-row:auto!important}}.dashboard-widget-cell .kpi-card{height:100%;box-sizing:border-box;overflow:hidden}.kpi-card--compact{padding:var(--space-sm) var(--space-md);gap:2px}.kpi-card--compact .kpi-card-title{font-size:var(--font-size-xs, 11px)}.kpi-card--compact .kpi-card-value{font-size:var(--font-size-lg);font-weight:700}.kpi-card--narrow{padding:var(--space-sm);gap:var(--space-xs);text-align:center;justify-content:center}.kpi-card--narrow .kpi-card-title{font-size:var(--font-size-xs, 11px)}.kpi-card--narrow .kpi-card-value{font-size:var(--font-size-lg);font-weight:700;word-break:break-all}.kpi-card--narrow .kpi-card-subtitle{font-size:var(--font-size-xs, 11px)}.kpi-card--small{gap:var(--space-xs)}.kpi-card--small .kpi-card-title{font-size:var(--font-size-xs, 11px)}.kpi-card--standard{padding:var(--space-lg) var(--space-xl)}.kpi-card--large{gap:var(--space-sm)}.kpi-card--large .kpi-card-value{font-size:var(--font-size-3xl, 2rem)}.kpi-card-detail{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-widget-grid--editing{min-height:500px;padding:var(--space-md);border-radius:var(--radius-lg);background:var(--color-bg-subtle, #f8f9fa);border:1px dashed var(--color-border-medium)}.dashboard-grid-cell{border:1px dashed var(--color-border-medium, #ccc);border-radius:var(--radius-sm);background:color-mix(in srgb,var(--color-bg-white) 50%,transparent);pointer-events:none;min-height:var(--dashboard-row-height)}.dashboard-widget-grid--editing .dashboard-widget-cell{cursor:grab}.dashboard-widget-grid--editing .dashboard-widget-cell:active{cursor:grabbing}.dashboard-widget-grid--editing .dashboard-widget-cell .kpi-card{border-style:dashed;border-color:var(--color-primary-light, var(--color-primary));background:color-mix(in srgb,var(--color-primary) 3%,var(--color-bg-white));position:relative}.dashboard-widget-grid--editing .dashboard-widget-cell .kpi-card:hover{transform:none;box-shadow:var(--shadow-sm)}.widget-drag-handle{position:absolute;top:var(--space-xs);left:var(--space-xs);display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-white);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:grab;z-index:2}.widget-drag-handle:active{cursor:grabbing}.widget-edit-toolbar{position:absolute;top:var(--space-xs);right:var(--space-xs);display:flex;align-items:center;gap:var(--space-xs);z-index:2}.widget-edit-toolbar button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-white);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);padding:0;transition:background .15s ease,color .15s ease}.widget-edit-toolbar button:hover{background:var(--color-bg-hover);color:var(--color-text)}.widget-edit-toolbar button.widget-remove-btn:hover{background:var(--color-danger-bg);color:var(--color-danger-text);border-color:var(--color-danger-border)}.widget-size-select{height:28px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-white);color:var(--color-text-secondary);font-size:var(--font-size-xs, 11px);padding:0 var(--space-xs);cursor:pointer}.widget-size-select:hover{background:var(--color-bg-hover);color:var(--color-text)}.dashboard-widget-cell--drag-over{outline:2px dashed var(--color-primary);outline-offset:-2px;background:color-mix(in srgb,var(--color-primary) 5%,transparent);border-radius:var(--radius-lg)}.dashboard-widget-cell--drag-invalid{outline-color:var(--color-danger);background:color-mix(in srgb,var(--color-danger) 5%,transparent)}.dashboard-widget-cell--dragging{opacity:.4}.dashboard-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-lg);margin-bottom:var(--space-xl)}.dashboard-header-row .dashboard-header{margin-bottom:0}.dashboard-header-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0;padding-top:var(--space-xs)}.dashboard-add-widget-row{display:flex;justify-content:center;padding:var(--space-lg) 0}.dashboard-add-widget-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-xl);border:2px dashed var(--color-border-medium);border-radius:var(--radius-lg);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-base);cursor:pointer;transition:border-color .15s ease,color .15s ease}.dashboard-add-widget-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.widget-picker-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:400px;overflow-y:auto;padding:var(--space-sm) 0}.widget-picker-category{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-sm) 0 var(--space-xs) 0;border-bottom:1px solid var(--color-border-light)}.widget-picker-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.widget-picker-item:hover:not(.widget-picker-item--disabled){background:var(--color-bg-hover)}.widget-picker-item--disabled{opacity:.5;cursor:not-allowed}.widget-picker-item-info{display:flex;flex-direction:column;gap:2px}.widget-picker-item-label{font-weight:500;color:var(--color-text)}.widget-picker-item-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.widget-picker-item-sizes{display:flex;gap:var(--space-xs)}.widget-picker-size-tag{font-size:var(--font-size-xs, 11px);padding:2px var(--space-xs);border-radius:var(--radius-sm);background:var(--color-bg-subtle);color:var(--color-text-muted)}.kpi-card-skeleton{background:linear-gradient(90deg,var(--color-bg-subtle) 25%,var(--color-bg-hover) 50%,var(--color-bg-subtle) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm);max-width:60%;min-height:1.2em}.kpi-card-subtitle.kpi-card-skeleton{max-width:40%;min-height:.9em}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.quick-actions-content{display:flex;flex-direction:column;gap:var(--space-sm);justify-content:center;align-items:stretch}.quick-actions-buttons{display:flex;gap:var(--space-xs);flex-wrap:wrap}.quick-actions-buttons--row{flex-direction:row}.quick-actions-buttons--column{flex-direction:column}.quick-actions-buttons .btn{font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);flex:1 1 auto}@media(prefers-reduced-motion:reduce){.dashboard-widget-grid--editing .dashboard-widget-cell .kpi-card:hover{transform:none}.kpi-card-skeleton{animation:none}}.reset-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-header-bg-dark);padding:1rem}.reset-password-card{background:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden}.reset-password-header{background:var(--color-header-bg);color:var(--color-bg-white);padding:1.5rem;text-align:center}.reset-password-header h1{margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.reset-password-header h2{margin:0;font-size:1.1rem;font-weight:400;opacity:.9}.reset-password-body{padding:2rem}.validating-message{text-align:center;color:var(--color-text-muted);padding:1rem 0}.reset-info{text-align:center;color:var(--color-text);margin-bottom:.5rem}.reset-info strong{color:var(--color-header-bg)}.reset-expiry{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border-light)}.error-banner{background:var(--color-danger-bg);border:1px solid var(--color-danger-border);color:var(--color-danger-hover);padding:.75rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:var(--font-size-base)}.error-message{text-align:center;padding:1rem;background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);margin-bottom:1.5rem}.error-message p{margin:.5rem 0;color:var(--color-danger-hover)}.success-message{text-align:center;padding:1rem;background:var(--color-success-bg);border:1px solid var(--color-success-border);border-radius:var(--radius-md);margin-bottom:1.5rem}.success-message p{margin:.5rem 0;color:var(--color-success-text)}.reset-password-body .form-group{width:80%;margin:0 auto 1rem}.reset-password-body .form-group label{display:block;margin-bottom:.4rem;font-size:var(--font-size-base);font-weight:500;color:var(--color-text);text-align:center}.reset-password-body .form-group input{width:100%;min-width:0}.password-requirements{background:var(--color-bg-hover);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.5rem}.password-requirements p{margin:0 0 .5rem;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text)}.password-requirements ul{list-style:none;padding:0;margin:0}.password-requirements li{font-size:var(--font-size-sm);color:var(--color-text-light);padding:.25rem 0 .25rem 1.5rem;position:relative}.password-requirements li:before{content:"○";position:absolute;left:0;color:var(--color-border-dark)}.password-requirements li.met{color:var(--color-success)}.password-requirements li.met:before{content:"●";color:var(--color-success)}.btn-block{display:block;width:100%}.reset-password-body .btn{display:block;width:80%;margin:0 auto;padding:.75rem 1.5rem;font-size:1rem;border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s ease}.reset-password-body .btn-primary{background-color:var(--color-primary);border:none;color:var(--color-bg-white)}.reset-password-body .btn-primary:hover{background-color:var(--color-primary-hover)}.reset-password-body .btn-primary:disabled{background-color:#7fb3d8;cursor:not-allowed}.admin-layout{display:flex;height:100%;margin:-1.5rem;min-height:calc(100vh - 60px)}.admin-sidebar{width:200px;min-width:200px;background-color:var(--color-bg-hover);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0}.admin-sidebar-header{padding:1rem;border-bottom:1px solid var(--color-border);background-color:var(--color-bg-white)}.admin-sidebar-header h3{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--color-header-bg)}.admin-badge{display:inline-block;padding:.2rem .5rem;font-size:.7rem;font-weight:500;border-radius:var(--radius-sm);text-transform:uppercase}.admin-badge.super-admin{background-color:var(--color-purple);color:var(--color-bg-white)}.admin-badge.company-admin{background-color:var(--color-primary);color:var(--color-bg-white)}.admin-nav-sections{flex:1;overflow-y:auto}.admin-nav-section{margin-bottom:.5rem}.admin-nav-section-title{padding:.75rem 1rem .25rem;font-size:.7rem;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);letter-spacing:.5px}.admin-nav-list{list-style:none;padding:0;margin:0}.admin-nav-item{margin:0}.admin-nav-link{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;color:var(--color-text-secondary);text-decoration:none;border-left:3px solid transparent;transition:background-color .15s ease,border-color .15s ease}.admin-nav-link:hover{background-color:var(--color-bg-hover);border-left-color:var(--color-text-muted);color:var(--color-text)}.admin-nav-link.active{background-color:var(--color-primary-light);border-left-color:var(--color-accent);color:var(--color-info-text);font-weight:500}.super-admin-only-indicator{color:var(--color-purple);font-weight:700;margin-left:.25rem}.admin-content{flex:1;padding:0;overflow-y:auto;background-color:var(--color-bg-white);display:flex;flex-direction:column}.admin-content .view-header{position:sticky;top:0;z-index:var(--z-sticky);background-color:var(--color-bg-white);border-bottom:1px solid var(--color-border);padding:1rem 1.5rem;flex-shrink:0}.admin-content .admin-page-body{flex:1;padding:1.5rem;overflow-y:auto}.admin-content .view-header-title-section{display:flex;align-items:baseline;gap:.5rem}.admin-content .view-header-subtitle{color:var(--color-text-muted);font-size:var(--font-size-base);font-weight:400}.admin-page-placeholder{padding:2rem;text-align:center;color:var(--color-text-muted)}.admin-page-placeholder h2{margin-bottom:1rem;color:var(--color-text-secondary)}.admin-page-placeholder p{margin:0}.admin-settings-page{max-width:900px}.settings-form{display:flex;flex-direction:column;gap:1.5rem}.settings-section{background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem}.settings-section h3{margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border-light);font-size:1rem;font-weight:600;color:var(--color-header-bg)}.settings-section h4{margin:0 0 .5rem;font-size:var(--font-size-md);font-weight:600;color:var(--color-header-bg-dark)}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.form-row:last-child{margin-bottom:0}.settings-form .form-group{flex:1;min-width:0}.settings-form .form-group.full-width{flex:1 1 100%}.settings-form .form-group label{display:block;margin-bottom:.4rem;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.company-logo-section{display:flex;flex-direction:column;gap:1rem}.company-logo-preview{display:inline-block;padding:1rem;background:var(--color-bg-hover);border:1px solid var(--color-bg-hover);border-radius:var(--radius-md);max-width:300px}.company-logo-preview img{max-width:100%;max-height:150px;object-fit:contain;display:block}.company-logo-upload{display:flex;align-items:center;gap:1rem}.company-logo-upload input[type=file]{display:none}.settings-form .form-group input[type=text],.settings-form .form-group input[type=email],.settings-form .form-group input[type=url],.settings-form .form-group input[type=number],.settings-form .form-group select,.settings-form .form-group textarea{width:100%;min-width:0}.admin-settings-page .settings-form input[type=checkbox]{width:auto;min-width:0;padding:0;margin:0;line-height:normal}.form-help{display:block;margin-top:.35rem;font-size:.8rem;color:var(--color-text-muted);line-height:1.4}.form-group.checkbox-group{display:flex;flex-direction:column;justify-content:flex-end}.form-group.checkbox-group label,.checkbox-inline{display:flex;align-items:flex-start;gap:.2rem;font-weight:400;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.3;margin:0;flex:1 1 320px;min-width:240px;max-width:none}.admin-settings-page .form-group.checkbox-group label{display:inline-flex;flex:0 0 auto;min-width:0;max-width:100%;width:auto;gap:.15rem;padding:0;margin:0}.admin-settings-page .form-group.checkbox-group{flex:0 0 auto;width:auto;min-width:0;max-width:100%;padding:0;margin:0}.admin-checkbox-stack{display:flex;flex-direction:column;gap:.5rem}.admin-checkbox-field{display:flex;flex-direction:column;align-items:flex-start;margin:0;text-align:left;width:fit-content}.admin-setting-block{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}.settings-form .form-group label.admin-override-label{display:inline-flex!important;align-items:center;gap:6px;width:max-content;margin:0;padding:0;text-align:left}.settings-form .form-group label.admin-override-label input[type=checkbox]{width:auto;min-width:0;padding:0;margin:0;display:inline-block}.settings-form .form-group label.admin-override-label span{display:inline-block;margin:0;text-align:left}.admin-checkbox-item{display:inline-flex;align-items:flex-start;gap:.2rem;padding:0;margin:0;cursor:pointer;line-height:1.3;width:fit-content;max-width:100%}.settings-form .form-group label.admin-checkbox-item{display:inline-flex;align-items:center;justify-content:flex-start;gap:.25rem;width:auto;margin-bottom:0}.admin-checkbox-item input[type=checkbox]{margin:0}.settings-form .form-group label.admin-checkbox-item span{display:inline;margin:0}.checkbox-label--wide,.checkbox-inline--wide{align-items:flex-start;gap:.2rem}.checkbox-label--tight,.checkbox-inline--tight{gap:.1rem}.checkbox-label--full,.checkbox-inline--full{width:100%;flex:1 1 100%;min-width:0;padding:0;margin:0}.checkbox-label--compact,.checkbox-inline--compact{width:auto;flex:0 0 auto;min-width:0}.checkbox-label--wide span,.checkbox-inline--wide span{flex:1 1 auto;min-width:0}.form-group.checkbox-group input[type=checkbox],.checkbox-inline input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary);margin:0}.view-header-actions{display:flex;align-items:center;gap:1rem}.unsaved-indicator{color:var(--color-warning);font-size:var(--font-size-sm);font-weight:500}.success-text{color:var(--color-success);font-size:var(--font-size-sm);font-weight:500}.error-text{color:var(--color-danger);font-size:var(--font-size-sm);font-weight:500}.admin-content .loading{padding:2rem;text-align:center;color:var(--color-text-muted)}.admin-content .error{padding:1rem;background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);color:var(--color-danger-hover)}.error-message{color:var(--color-danger-hover);font-size:var(--font-size-sm)}.success-message{color:var(--color-success);font-size:var(--font-size-sm);padding:.75rem;background-color:var(--color-success-bg);border:1px solid var(--color-success-border);border-radius:var(--radius-md);margin-bottom:1rem}.reset-password-section{margin-top:1rem}.reset-password-section hr{border:none;border-top:1px solid var(--color-border-light);margin:1rem 0}.reset-password-form{background-color:var(--color-warning-bg);border:1px solid var(--color-warning-border);border-radius:var(--radius-lg);padding:1rem}.reset-password-form h4{margin:0 0 .5rem;color:var(--color-warning);font-size:var(--font-size-md)}.reset-password-form .help-text{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:1rem}.reset-password-form .form-group{margin-bottom:1rem}.reset-password-form .form-group label{display:block;margin-bottom:.4rem;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.reset-password-form .form-group input{width:100%}.reset-password-form small.help-text{display:block;margin-top:.35rem;font-size:.75rem;color:var(--color-text-muted)}.reset-password-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn-warning{background-color:var(--color-warning);border-color:var(--color-warning-border);color:var(--color-bg-white)}.btn-warning:hover{background-color:var(--color-warning-hover);border-color:var(--color-warning-border);filter:brightness(.9)}.btn-warning:disabled{opacity:.65;cursor:not-allowed}.reset-email-option{margin-bottom:1rem}.reset-email-option .help-text{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:.5rem}.reset-temp-option{margin-bottom:.5rem}.reset-temp-option .help-text,.reset-unavailable .help-text{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:.5rem}.reset-temp-option .warning-text,.reset-unavailable .warning-text{color:var(--color-warning-text);background-color:var(--color-warning-bg);padding:.5rem;border-radius:var(--radius-md);border:1px solid var(--color-warning-border)}.reset-temp-secondary{margin-top:1rem;padding-top:.75rem;border-top:1px dashed var(--color-border-medium)}.reset-temp-secondary .btn-link{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:0;cursor:pointer;text-decoration:underline}.reset-temp-secondary .btn-link:hover{color:var(--color-text-secondary)}.admin-backup-page .backup-category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.admin-backup-page .backup-toggle-buttons{display:flex;gap:.5rem}.admin-backup-page .backup-link-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:.85rem;padding:.25rem .5rem;border-radius:4px;transition:background-color .15s}.admin-backup-page .backup-link-btn:hover{background-color:var(--color-info-bg);text-decoration:underline}.admin-backup-page .backup-link-btn:disabled{color:var(--color-text-light);cursor:not-allowed}.admin-backup-page .backup-category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.5rem}.admin-backup-page .backup-category-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border:1px solid var(--color-border-light);border-radius:6px;cursor:pointer;transition:border-color .15s,background-color .15s}.admin-backup-page .backup-category-item:hover{border-color:var(--color-border-dark);background-color:var(--color-bg-hover)}.admin-backup-page .backup-category-item.selected{border-color:var(--color-primary);background-color:var(--color-info-bg)}.admin-backup-page .backup-category-item input[type=checkbox]{margin-top:2px;flex-shrink:0}.admin-backup-page .backup-category-info{display:flex;flex-direction:column;gap:.15rem}.admin-backup-page .backup-category-label{font-weight:500;font-size:.9rem;color:var(--color-text)}.admin-backup-page .backup-category-description{font-size:.8rem;color:var(--color-text-light);line-height:1.3}.super-admin-table th.super-admin-expand-col{width:30px}.super-admin-expand-cell{text-align:center;cursor:pointer}.super-admin-membership-row{background-color:var(--color-bg-hover)}.super-admin-membership-row td.super-admin-membership-detail{padding-left:2rem}.super-admin-membership-name{display:flex;align-items:center;gap:8px}.super-admin-membership-name .company-name{font-weight:500}.super-admin-membership-name .company-abbrev,.super-admin-membership-alias{font-size:13px}.super-admin-default-badge{font-size:11px}.super-admin-menu-label{padding:4px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.super-admin-menu-divider{border-top:1px solid var(--color-border-light);margin:4px 0}.super-admin-role-active{font-weight:600}.vendor-detail-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-bottom:1px solid var(--color-border)}.vendor-detail-item-label{flex:1}.vendor-detail-item-actions{display:flex;gap:.25rem}.vendor-detail-item-actions .btn{padding:.25rem .5rem}@media(max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;min-width:100%;border-right:none;border-bottom:1px solid var(--color-border)}.admin-nav-list{display:flex;flex-wrap:wrap;padding:.5rem}.admin-nav-item{flex:1 1 auto}.admin-nav-link{padding:.5rem .75rem;border-left:none;border-bottom:2px solid transparent;text-align:center;justify-content:center}.admin-nav-link.active{border-left:none;border-bottom-color:var(--color-accent)}}:root{--color-primary: #3498db;--color-primary-hover: #2980b9;--color-primary-dark: #1565c0;--color-primary-light: #e3f2fd;--color-primary-ring: rgba(52, 152, 219, .2);--color-text: #333;--color-text-secondary: #555;--color-text-muted: #666;--color-text-light: #767676;--color-border: #e0e0e0;--color-border-light: #eee;--color-border-medium: #ddd;--color-border-dark: #ccc;--color-bg-page: #f5f5f5;--color-bg-hover: #f8f9fa;--color-bg-subtle: #f0f0f0;--color-bg-white: #fff;--color-danger: #e74c3c;--color-danger-hover: #c0392b;--color-danger-text: #721c24;--color-danger-bg: #f8d7da;--color-danger-border: #f5c6cb;--color-success: #27ae60;--color-success-hover: #229954;--color-success-text: #2e7d32;--color-success-bg: #e8f5e9;--color-success-border: #a5d6a7;--color-warning: #e67e22;--color-warning-text: #856404;--color-warning-bg: #fff3cd;--color-warning-border: #ffc107;--color-info-text: #1565c0;--color-info-bg: #e3f2fd;--color-purple: #7c3aed;--color-purple-dark: #5b21b6;--color-purple-bg: #f0ebff;--color-purple-border: #c4b5fd;--color-teal: #2c7a7b;--color-teal-bg: #e6fffa;--color-teal-border: #38b2ac;--color-indigo: #4f46e5;--color-indigo-dark: #3730a3;--color-indigo-bg: #eef2ff;--color-rose: #e11d48;--color-rose-bg: #fff1f2;--color-accent: #1a73e8;--color-account-asset: #1565C0;--color-account-asset-bg: #1565C020;--color-account-liability: #9C27B0;--color-account-liability-bg: #9C27B020;--color-account-equity: #2E7D32;--color-account-equity-bg: #2E7D3220;--color-account-income: #00838F;--color-account-income-bg: #00838F20;--color-account-expense: #E65100;--color-account-expense-bg: #E6510020;--color-header-bg: #2c3e50;--color-header-bg-dark: #34495e;--color-header-text: #ecf0f1;--color-header-muted: #bdc3c7;--color-header-border: #7f8c8d;--color-secondary: #95a5a6;--color-secondary-hover:#7f8c8d;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 2px 10px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .15);--shadow-xl: 0 4px 20px rgba(0, 0, 0, .2);--shadow-modal: 0 4px 20px rgba(0, 0, 0, .25);--shadow-focus: 0 0 0 2px rgba(52, 152, 219, .2);--shadow-notification: 0 8px 24px rgba(0, 0, 0, .15);--radius-sm: 3px;--radius-md: 4px;--radius-lg: 8px;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 3rem;--font-size-xs: .75rem;--font-size-sm: .85rem;--font-size-base: .9rem;--font-size-md: .95rem;--font-size-lg: 1.1rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--z-dropdown: 1000;--z-sticky: 1050;--z-header: 1100;--z-modal: 5000;--z-tooltip: 6000;--z-popover: 7000;--z-session: 9999;--z-menu: 10000;--z-error: 10050;--color-notif-financial: #7b8fa8;--color-notif-workflow: #7a9e7e;--color-notif-security: #c4a35a;--color-notif-system: #9e9e9e;--color-notif-retainer: var(--color-purple);--color-notif-accounting: #5f9ea0;--color-notif-recurring: #7b8fa8}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.skip-to-content{position:absolute;top:-100%;left:0;z-index:var(--z-menu);padding:.75rem 1.5rem;background:var(--color-primary);color:#fff;font-weight:600;font-size:.875rem;text-decoration:none;border-radius:0 0 4px}.skip-to-content:focus{top:0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--color-bg-page);min-height:100vh}.form-input,input[type=text],input[type=number],input[type=email],input[type=password],input[type=date],input[type=datetime-local],input[type=search],input[type=tel],input[type=url],select,textarea{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);border:1px solid var(--color-border-medium);border-radius:var(--radius-md);color:var(--color-text);background-color:var(--color-bg-white);line-height:1.5;font-family:inherit;transition:border-color .15s,box-shadow .15s}.form-input:focus,input[type=text]:focus,input[type=number]:focus,input[type=email]:focus,input[type=password]:focus,input[type=date]:focus,input[type=datetime-local]:focus,input[type=search]:focus,input[type=tel]:focus,input[type=url]:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}.form-input:disabled,input[type=text]:disabled,input[type=number]:disabled,input[type=email]:disabled,input[type=password]:disabled,input[type=date]:disabled,input[type=datetime-local]:disabled,input[type=search]:disabled,input[type=tel]:disabled,input[type=url]:disabled,select:disabled,textarea:disabled{background-color:var(--color-bg-page);color:var(--color-text-muted);cursor:not-allowed}.form-input-sm,.form-input-sm input,.form-input-sm select,.form-input-sm textarea{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm)}.header{background-color:var(--color-header-bg);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:var(--z-header);height:60px}.header h1{font-size:1.8rem;font-weight:600}.header-right{display:flex;align-items:center;gap:1rem}.header-company{font-size:.9rem;color:var(--color-header-muted);padding-right:.75rem;border-right:1px solid var(--color-header-border)}.header-username{font-size:.9rem;color:var(--color-header-text)}.logout-button-header{padding:.5rem 1rem;background-color:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-base);transition:background-color .2s}.logout-button-header:hover{background-color:var(--color-danger-hover)}.header-company-section{position:relative;padding-right:.75rem;border-right:1px solid var(--color-header-border)}.header-company-button{background:none;border:1px solid transparent;color:var(--color-header-muted);font-size:var(--font-size-base);cursor:pointer;padding:.35rem .5rem;border-radius:var(--radius-md);display:flex;align-items:center;gap:.5rem;transition:all .2s}.header-company-button:hover{background-color:#ffffff1a;border-color:var(--color-header-border)}.header-company-button .company-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-company-button .company-name.no-company{color:var(--color-warning);font-style:italic}.header-company-button .dropdown-arrow{font-size:.6rem;opacity:.7}.header-company-logo{width:22px;height:22px;object-fit:contain;border-radius:var(--radius-sm);vertical-align:middle;margin-right:6px}.company-selector-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background-color:#fff;border-radius:8px;box-shadow:var(--shadow-modal);min-width:280px;max-height:400px;overflow:hidden;z-index:var(--z-dropdown)}.company-selector-header{padding:.75rem 1rem;background-color:var(--color-bg-hover);border-bottom:1px solid var(--color-border);font-weight:600;color:var(--color-header-bg);font-size:var(--font-size-sm)}.company-selector-list{max-height:320px;overflow-y:auto}.company-selector-loading,.company-selector-empty{padding:1rem;text-align:center;color:var(--color-text-muted);font-size:var(--font-size-base)}.company-selector-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border:none;background:none;text-align:left;cursor:pointer;font-size:var(--font-size-base);color:var(--color-text);transition:background-color .15s}.company-selector-item:hover{background-color:var(--color-bg-subtle)}.company-selector-item.active{background-color:var(--color-primary-light)}.company-selector-item:disabled{opacity:.6;cursor:not-allowed}.company-item-name{flex:1;font-weight:500}.company-item-abbr{color:var(--color-text-muted);font-size:var(--font-size-sm)}.company-item-check{color:var(--color-success);font-weight:700}.invitation-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .35rem;border-radius:.625rem;background-color:var(--color-warning);color:#fff;font-size:.7rem;font-weight:700;line-height:1;margin-left:.35rem}.company-selector-invitations-header{border-top:1px solid var(--color-border);background-color:#fff8f0;color:var(--color-warning)}.company-selector-invitation{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.6rem 1rem;border-bottom:1px solid var(--color-bg-subtle)}.company-selector-invitation:last-child{border-bottom:none}.invitation-info{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}.invitation-role{font-size:.75rem;color:var(--color-text-light);text-transform:capitalize}.invitation-accept-btn{padding:.3rem .7rem;border:none;border-radius:var(--radius-md);background-color:var(--color-success);color:#fff;font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background-color .15s}.invitation-accept-btn:hover{background-color:var(--color-success-hover)}.invitation-accept-btn:disabled{opacity:.6;cursor:not-allowed}.main-layout{min-height:100vh;display:flex;flex-direction:column}.main-content-wrapper{display:flex;flex:1;min-height:calc(100vh - 60px);overflow:hidden}.main-content{flex:1;padding:1.5rem;overflow-y:auto;background-color:var(--color-bg-page);height:calc(100vh - 60px)}.navbar{width:200px;min-width:200px;background-color:var(--color-header-bg-dark);padding:1rem 0;display:flex;flex-direction:column;position:sticky;top:60px;height:calc(100vh - 60px);overflow-y:auto;flex-shrink:0}.navbar-list{list-style:none;padding:0;margin:0}.navbar-item{margin:0}.navbar-link{display:block;padding:.75rem 1.5rem;color:var(--color-header-text);text-decoration:none;font-size:var(--font-size-md);transition:background-color .2s,border-left .2s;border-left:3px solid transparent}.navbar-link:hover{background-color:#3d566e;border-left-color:var(--color-primary)}.navbar-link.active{background-color:var(--color-header-bg);border-left-color:var(--color-primary);font-weight:500}.navbar-divider{height:1px;background-color:#4a6278;margin:1rem}.navbar-section-title{padding:.5rem 1.5rem;font-size:.75rem;text-transform:uppercase;color:var(--color-secondary);letter-spacing:.05em;font-weight:600}.navbar-sub-list{list-style:none;padding:0;margin:0}.navbar-sub-item{margin:0}.navbar-sub-link{display:block;padding:.5rem 1.5rem .5rem 2.5rem;color:var(--color-header-muted);text-decoration:none;font-size:.875rem;transition:background-color .2s,border-left .2s;border-left:3px solid transparent}.navbar-sub-link:hover{background-color:#3d566e;border-left-color:var(--color-primary);color:var(--color-header-text)}.navbar-sub-link.active{background-color:var(--color-header-bg);border-left-color:var(--color-primary);font-weight:500;color:var(--color-header-text)}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 80px);padding:2rem}.login-box{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:400px;justify-items:center}.login-box h2{text-align:center;margin-bottom:1.5rem;color:var(--color-header-bg)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--color-text);font-weight:500}.form-group input{width:100%;min-width:250px}.form-row{display:flex;gap:16px;margin-bottom:1rem}.form-row .form-group{flex:1;margin-bottom:0}.modal-summary{padding:12px;background:var(--color-bg-page);border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.9rem}.modal-summary-row{display:flex;justify-content:space-between;margin-bottom:4px}.modal-summary-row:last-child{margin-bottom:0}.login-button{width:100%;padding:.75rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;cursor:pointer;margin-top:1rem}.login-button:hover{background-color:var(--color-primary-hover)}.login-button:disabled{background-color:var(--color-header-muted);cursor:not-allowed}.home-content{max-width:800px}.welcome-box{background:#fff;padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.welcome-box h2{color:var(--color-header-bg);margin-bottom:1rem}.dashboard-container{padding:var(--space-xl);max-width:1400px}.dashboard-header{margin-bottom:var(--space-xl)}.dashboard-header h2{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text);margin:0 0 var(--space-xs) 0}.dashboard-header p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}@media(max-width:992px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.dashboard-grid{grid-template-columns:1fr}.dashboard-container{padding:var(--space-lg)}}.kpi-card{background:var(--color-bg-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);transition:box-shadow .2s ease,transform .15s ease;display:flex;flex-direction:column;gap:var(--space-xs)}.kpi-card[role=button]{cursor:pointer}.kpi-card[role=button]:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.kpi-card--warning{border-left:4px solid var(--color-warning)}.kpi-card--danger{border-left:4px solid var(--color-danger)}.kpi-card--success{border-left:4px solid var(--color-success)}.kpi-card--info{border-left:4px solid var(--color-primary)}.kpi-card-title{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0;font-weight:500}.kpi-card-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);margin:0;line-height:1.2}.kpi-card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.kpi-trend{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);font-weight:500}.kpi-trend--up{color:var(--color-success-text)}.kpi-trend--down{color:var(--color-danger-text)}.kpi-trend--neutral{color:var(--color-text-muted)}.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-3xl) var(--space-xl);text-align:center}.dashboard-error p{color:var(--color-text-secondary);font-size:var(--font-size-base);margin:0}@media(prefers-reduced-motion:reduce){.kpi-card{transition:none}.kpi-card[role=button]:hover{transform:none}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-base);font-weight:500;transition:background-color .2s,opacity .2s,box-shadow .15s}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--color-secondary-hover)}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--color-success-hover)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--color-danger-hover)}.btn-outline{background-color:var(--color-bg-white);border:1px solid var(--color-border-medium);color:var(--color-text)}.btn-outline:hover:not(:disabled){background-color:var(--color-bg-page);border-color:var(--color-border-dark)}.btn-sm{padding:.4rem .75rem;font-size:var(--font-size-sm)}.btn-disabled,.btn:disabled{background-color:var(--color-header-muted)!important;color:var(--color-secondary-hover)!important;cursor:not-allowed;opacity:.7}.view-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:#fff;border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-bottom:1px solid var(--color-border);margin-bottom:0}.view-header h2{color:var(--color-header-bg);font-size:var(--font-size-2xl);margin:0}.view-header-actions{display:flex;align-items:center;gap:.5rem}.view-header-title-section{display:flex;align-items:baseline;gap:1rem}.view-header-subtitle{font-size:1rem;color:var(--color-header-border);font-weight:400}.view-header-warning{font-size:var(--font-size-base);color:var(--color-danger-hover);font-weight:600;background-color:var(--color-danger-bg);padding:.25rem .75rem;border-radius:var(--radius-md);border:1px solid var(--color-danger)}.back-button-container{position:relative}.spacer-sm{width:1rem}.settings-page-container{display:flex;flex-direction:column;height:100%;margin:-1.5rem;min-height:calc(100vh - 60px)}.settings-page-container .view-header{position:sticky;top:0;z-index:var(--z-sticky);background-color:var(--color-bg-white);border-radius:0;flex-shrink:0}.settings-page-container .settings-page-body{flex:1;padding:1.5rem;overflow-y:auto;background-color:var(--color-bg-page)}.access-denied{text-align:center;padding:2rem}.access-denied h2{color:var(--color-danger);margin-bottom:1rem}.access-denied-box{background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-lg);padding:2rem;text-align:center}.access-denied-box h3{color:var(--color-danger);margin-bottom:.5rem}.access-denied-box p{color:var(--color-danger-text)}.loading{text-align:center;padding:2rem;color:var(--color-text-muted)}.loading-message{text-align:center;padding:2rem;color:var(--color-text-muted);background-color:#fff;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.error-message{color:var(--color-danger);text-align:center;margin-top:1rem;font-size:var(--font-size-base);padding:1rem;background-color:var(--color-danger-bg);border-radius:var(--radius-md)}.empty-message{text-align:center;padding:2rem;color:var(--color-text-muted);background-color:#fff;border-radius:0 0 8px 8px;font-style:italic}.invoice-list-view,.accounts-list-view{background-color:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.list-table-container{display:flex;flex-direction:column;max-height:calc(100vh - 220px)}.list-table-body{flex:1;overflow-y:auto;overflow-x:auto}.invoice-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.invoice-table th,.invoice-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.invoice-table th.col-status,.invoice-table td.col-status{text-align:center}.invoice-table thead{position:sticky;top:0;z-index:2}.invoice-table th{font-weight:600;color:var(--color-header-bg);background-color:var(--color-bg-hover);white-space:nowrap;border-bottom:2px solid var(--color-border)}.invoice-table tbody tr:hover{background-color:var(--color-bg-hover)}.clickable-row{cursor:pointer}.clickable-row:hover{background-color:var(--color-bg-hover)}.list-view-table-container{overflow-x:auto}.list-view-table{width:100%;border-collapse:separate;border-spacing:0}.list-view-table th,.list-view-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.list-view-table th{font-weight:600;color:var(--color-header-bg);background-color:var(--color-bg-hover);white-space:nowrap;border-bottom:2px solid var(--color-border)}.list-view-table tbody tr:hover{background-color:var(--color-bg-hover)}.table-empty{padding:2rem;text-align:center;color:var(--color-text-muted);font-size:var(--font-size-base)}.table-error{padding:1rem;color:var(--color-danger);background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);margin-bottom:1rem}.col-date{width:88px}.col-customer{width:130px}.col-invoice-num{width:100px}.col-total{width:90px;text-align:right}.col-fee-revenue{width:85px;text-align:right}.col-due-terms{width:80px}.col-due-date{width:88px}.col-status{width:110px}.col-balance{width:90px;text-align:right}.col-fee-total{width:85px;text-align:right}.col-billable-to{width:120px}.col-file{width:60px;text-align:center}.col-actions{width:70px;text-align:center}.col-assigned-to{width:115px}.invoice-table th.col-total,.invoice-table td.col-total,.invoice-table th.col-fee-revenue,.invoice-table td.col-fee-revenue,.invoice-table th.col-balance,.invoice-table td.col-balance,.invoice-table th.col-fee-total,.invoice-table td.col-fee-total{text-align:right}.invoice-cell-wrap{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.2;font-size:.875rem;word-break:break-word;overflow-wrap:anywhere;position:relative}.invoice-cell-tooltip{position:fixed;left:var(--tt-left);top:var(--tt-top);transform:translateY(-50%);z-index:var(--z-tooltip);max-width:400px;background-color:#333;color:#fff;padding:.35rem .5rem;border-radius:var(--radius-md);font-size:.75rem;line-height:1.2;white-space:normal;word-break:break-word;overflow-wrap:anywhere;box-shadow:0 2px 8px #00000026;opacity:0;visibility:hidden;pointer-events:none}.invoice-fee-cost-cell{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.invoice-fee-cost-status{display:flex;justify-content:flex-end;width:100%}.invoice-fee-cost-status .status-badge{font-size:.75rem;padding:2px 8px;white-space:normal;text-align:center}.invoice-cell-wrap.tooltip-visible .invoice-cell-tooltip,.editor-identifier-truncate.tooltip-visible .invoice-cell-tooltip{opacity:1;visibility:visible}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.sortable-header:hover{background-color:var(--color-bg-hover)}.header-content{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sort-indicator{font-size:.8rem;flex-shrink:0}.sort-inactive{color:var(--color-text-light)}.sort-active{color:var(--color-primary);font-weight:700}.status-badge{display:inline-block;padding:2px 10px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;text-transform:capitalize;white-space:nowrap}.status-badge-sm{font-size:.65rem;padding:2px 6px;text-transform:uppercase;letter-spacing:.5px}.invoice-table td.col-status .status-badge{max-width:100%;white-space:normal}.status-draft{background-color:var(--color-bg-subtle);color:var(--color-text-muted)}.status-posted,.status-sent{background-color:var(--color-info-bg);color:var(--color-info-text)}.status-partial,.status-partially_paid,.status-partially_applied{background-color:var(--color-warning-bg);color:var(--color-warning)}.status-paid,.status-applied,.status-refunded{background-color:var(--color-success-bg);color:var(--color-success-text)}.status-void{background-color:var(--color-danger-bg);color:var(--color-danger-hover)}.status-partially-credited{background:var(--color-indigo-bg);color:var(--color-indigo)}.status-credited{background:var(--color-indigo-bg);color:var(--color-indigo-dark)}.status-partially-refunded,.status-refunded-full{background:var(--color-rose-bg);color:var(--color-rose)}.status-open{background-color:var(--color-success-bg);color:var(--color-success-text)}.status-soft-closed{background-color:var(--color-warning-bg);color:var(--color-warning)}.status-closed{background-color:var(--color-purple-bg);color:var(--color-purple-dark)}.status-warning{background-color:var(--color-danger-bg);color:var(--color-danger-hover)}.payee-badge{color:var(--color-danger-text);font-size:.7rem;padding-right:2px}.status-none{background-color:var(--color-bg-page);color:var(--color-text-light)}.status-assigned{background-color:var(--color-info-bg);color:var(--color-accent)}.status-pending{background-color:var(--color-info-bg);color:var(--color-info-text)}.status-warn{background-color:var(--color-warning-bg);color:var(--color-warning-text)}.file-link{color:var(--color-primary);text-decoration:none}.file-link:hover{text-decoration:underline}.account-name,.account-name-sub{display:inline-block}.subaccount-cell{position:relative}.subaccount-cell-name .account-subaccount-arrow{position:absolute;left:.25rem;top:50%;transform:translateY(-50%);color:var(--color-text-light)}.subaccount-cell-amount .account-subaccount-arrow{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:var(--color-text-light)}.account-subaccount-arrow{color:var(--color-text-light)}.actions-cell{position:relative;display:flex;justify-content:center}.menu-button{background:none;border:1px solid var(--color-border-medium);border-radius:var(--radius-md);padding:.25rem .5rem;cursor:pointer;font-size:1.2rem;line-height:1;color:var(--color-text-muted);transition:background-color .2s}.menu-button:hover{background-color:var(--color-bg-subtle)}.menu-popup{position:absolute;right:100%;top:0;background-color:#fff;border:1px solid var(--color-border-medium);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:var(--z-menu);min-width:120px;margin-right:.5rem;padding:.25rem 0}.menu-popup-content{padding:.75rem 1rem;color:var(--color-text);font-size:var(--font-size-base);white-space:nowrap}.menu-popup-item{display:block;width:100%;padding:.5rem 1rem;border:none;background:none;text-align:left;font-size:var(--font-size-base);color:var(--color-text);cursor:pointer;transition:background-color .2s}.menu-popup-item:hover{background-color:var(--color-bg-subtle)}.filter-container{position:relative}.filter-button-container{position:relative;display:inline-block}.btn-filter-active{background-color:var(--color-primary-hover)!important;color:#fff!important}.filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;background-color:var(--color-danger);color:#fff;border-radius:10px;font-size:.7rem;font-weight:600}.filter-popup{position:absolute;top:100%;right:0;margin-top:.5rem;background-color:#fff;border:1px solid var(--color-border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-menu);min-width:320px;max-width:400px}.filter-popup-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);background-color:var(--color-bg-hover);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.filter-popup-title{font-weight:600;color:var(--color-header-bg);font-size:var(--font-size-md)}.filter-clear-btn{background:none;border:none;color:var(--color-danger);font-size:.8rem;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius-md);transition:background-color .2s}.filter-clear-btn:hover{background-color:var(--color-danger-bg)}.filter-popup-body,.filter-popup-content{padding:.5rem 0;max-height:450px;overflow-y:auto}.filter-section{padding:.5rem 1rem;border-bottom:1px solid var(--color-bg-subtle)}.filter-section:last-child{border-bottom:none}.filter-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;color:var(--color-text);padding:.25rem 0}.filter-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.filter-submenu{margin-top:.5rem;padding:.5rem;background-color:var(--color-bg-hover);border-radius:var(--radius-md);border:1px solid var(--color-border)}.filter-submenu-scrollable{max-height:200px;overflow-y:auto}.filter-option{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;cursor:pointer;border-radius:var(--radius-md);transition:background-color .15s}.filter-option:hover{background-color:var(--color-border)}.filter-option input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--color-primary)}.filter-option span{font-size:var(--font-size-base);color:var(--color-text)}.filter-input-row,.filter-date-row,.filter-amount-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.filter-input-row:last-child,.filter-date-row:last-child,.filter-amount-row:last-child{margin-bottom:0}.filter-input-row label,.filter-date-row label,.filter-amount-row label{font-size:var(--font-size-sm);color:var(--color-text-muted);min-width:90px}.filter-input-row input,.filter-date-row input[type=date],.filter-amount-row input[type=number]{flex:1;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm)}.filter-input-row input.filter-number-3digit{flex:0 0 64px;width:64px;text-align:right}.filter-date-range,.filter-amount-range{display:flex;flex-direction:column;gap:.5rem}.filter-multi-select,.filter-customer-select{display:flex;flex-direction:column;gap:.25rem}.filter-checkbox-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.25rem 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.filter-checkbox-item:hover{background-color:var(--color-bg-hover)}.filter-checkbox-item input[type=checkbox]{width:14px;height:14px;cursor:pointer}.filter-loading,.filter-empty{padding:.5rem;text-align:center;color:var(--color-text-light);font-size:var(--font-size-sm);font-style:italic}.filter-popup-content::-webkit-scrollbar,.filter-popup-body::-webkit-scrollbar,.filter-submenu-scrollable::-webkit-scrollbar{width:6px}.filter-popup-content::-webkit-scrollbar-track,.filter-popup-body::-webkit-scrollbar-track,.filter-submenu-scrollable::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.filter-popup-content::-webkit-scrollbar-thumb,.filter-popup-body::-webkit-scrollbar-thumb,.filter-submenu-scrollable::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.filter-popup-content::-webkit-scrollbar-thumb:hover,.filter-popup-body::-webkit-scrollbar-thumb:hover,.filter-submenu-scrollable::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.list-table-body::-webkit-scrollbar{width:8px;height:8px}.list-table-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.list-table-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.list-table-body::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.placeholder-text{font-style:italic;color:var(--color-text-light);padding:1rem;background-color:var(--color-bg-hover);border-radius:var(--radius-md);text-align:center}.admin-users-page{background-color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.users-table th{font-weight:600;color:var(--color-header-bg);background-color:var(--color-bg-hover);white-space:nowrap}.users-table tbody tr:hover{background-color:var(--color-bg-hover)}.users-table .inactive-row,.inactive-row{background-color:var(--color-bg-hover);color:var(--color-text-muted)}.users-table .actions-cell{vertical-align:middle}.users-table .companies-cell{max-width:200px}.users-table .companies-list{font-size:.85rem;color:var(--color-text-secondary)}.users-table .no-data{color:var(--color-text-light)}.delete-confirm{display:flex;gap:.25rem}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--space-xl) var(--space-lg);overflow-y:auto;z-index:var(--z-modal)}.modal-overlay.modal-top{align-items:flex-start;padding-top:40px}.modal-content{background:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);max-width:600px;width:100%;max-height:calc(100vh - 3rem);display:flex;flex-direction:column;overflow:hidden}.modal-content.modal-sm{max-width:400px}.modal-content.modal-md{max-width:600px}.modal-content.modal-lg{max-width:900px}.modal-content.modal-xl{max-width:1100px}.modal-content.modal-xxl{max-width:1280px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-border);background-color:var(--color-bg-hover);border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-shrink:0}.modal-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.modal-header h2,.modal-header h3{margin:0;color:var(--color-header-bg);font-size:1.2rem;font-weight:600;display:flex;align-items:center;gap:var(--space-sm)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-muted);padding:0;line-height:1}.modal-close:hover{color:var(--color-text)}.modal-body{padding:var(--space-xl);overflow-y:auto;flex:1;min-height:0}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--color-border);background-color:var(--color-bg-hover);border-radius:0 0 var(--radius-lg) var(--radius-lg);flex-shrink:0}.modal-error{padding:var(--space-md) var(--space-xl);background:var(--color-danger-bg);color:var(--color-danger-text);border-bottom:1px solid var(--color-danger-border);flex-shrink:0}.modal-body.modal-body-flush{padding:0}.modal-body-flush .customer-editor-section{padding:var(--space-lg) var(--space-xl)}.modal-body-flush .editor-loading,.modal-body-flush .editor-error{padding:40px var(--space-xl)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-content.modal-animate{animation:modalSlideIn .2s ease-out}.user-edit-modal .form-group{margin-bottom:1rem}.user-edit-modal .user-edit-form{display:flex;flex-direction:column;flex:1;min-height:0}.user-edit-modal .modal-body{flex:1 1 auto;min-height:0}.user-edit-modal .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text)}.user-edit-modal .form-group input[type=text],.user-edit-modal .form-group input[type=email],.user-edit-modal .form-group input[type=password]{width:100%}.user-edit-modal .form-row.checkboxes{display:grid;grid-auto-rows:min-content;row-gap:.15rem;margin:0;padding:0;background-color:transparent;border-radius:0}.user-edit-modal .checkbox-label{display:grid;grid-template-columns:16px 1fr;align-items:center;column-gap:.4rem;cursor:pointer;font-size:var(--font-size-md);line-height:1.1;margin:0;padding:0;flex:0 0 auto;max-width:none}.user-edit-modal .checkbox-label+.checkbox-label{margin-top:0}.user-edit-modal .checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;margin:0}.input-with-suffix{display:flex;align-items:stretch}.input-with-suffix input{flex:1;border-top-right-radius:0;border-bottom-right-radius:0}.input-with-suffix .input-suffix{display:inline-flex;align-items:center;padding:0 .75rem;border:1px solid var(--color-border-dark);border-left:0;border-radius:0 var(--radius-md) var(--radius-md) 0;background-color:var(--color-bg-page);color:var(--color-text-muted);font-size:var(--font-size-base);white-space:nowrap}.settings-form .checkbox-row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:.75rem 1.5rem}.settings-form .checkbox-label{display:inline-flex;align-items:flex-start;gap:.25rem;padding:0;margin:0;cursor:pointer;line-height:1.3;flex:1 1 320px;max-width:none;min-width:240px}.settings-form .checkbox-label input[type=checkbox]{margin:0;flex:0 0 auto}.user-name-cell{display:flex;flex-direction:column;gap:.25rem}.user-reset-badge{align-self:flex-start;display:inline-block;font-size:.75rem;line-height:1.2}.user-edit-modal .company-memberships{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border)}.user-edit-modal .company-memberships h4{margin:0 0 .75rem;color:var(--color-header-bg);font-size:1rem}.user-edit-modal .company-list{list-style:none;padding:0;margin:0 0 1rem}.user-edit-modal .company-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background-color:var(--color-bg-hover);border-radius:var(--radius-md);margin-bottom:.5rem}.user-edit-modal .company-name{flex:1;font-weight:500}.user-edit-modal .company-abbr{font-weight:400;color:var(--color-text-muted);margin-left:.25rem}.user-edit-modal .default-badge{background-color:var(--color-primary);color:#fff;font-size:.7rem;padding:.15rem .4rem;border-radius:var(--radius-sm);margin-left:.5rem;text-transform:uppercase}.user-edit-modal .company-role{font-size:var(--font-size-sm);color:var(--color-text-muted);padding:.2rem .5rem;background-color:var(--color-border);border-radius:var(--radius-sm)}.user-edit-modal .no-companies{color:var(--color-text-light);font-style:italic;font-size:var(--font-size-base);margin:.5rem 0 1rem}.user-edit-modal .add-company-row{display:flex;gap:.5rem;align-items:center}.user-edit-modal .add-company-row select{flex:1}.col-service-type{width:150px}.col-service-name{width:200px}.col-service-project{width:180px}.col-service-assigned{width:160px}.status-unassigned{background-color:var(--color-bg-subtle);color:var(--color-text-muted)}.status-inprogress,.status-in_progress{background-color:var(--color-warning-bg);color:var(--color-warning)}.status-completed,.status-approved{background-color:var(--color-success-bg);color:var(--color-success-text)}.status-cancelled{background-color:var(--color-danger-bg);color:var(--color-danger-hover)}.status-pending_approval{background-color:var(--color-info-bg);color:var(--color-info-text)}.col-project-name{width:260px}.col-project-services{width:90px;text-align:right}.col-project-assigned{width:220px}.view-body{padding:1rem 0}.data-table-wrapper{overflow-x:auto;margin-top:.5rem}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-border-light)}.data-table th{font-weight:600;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background-color:var(--color-bg-page)}.error-boundary-card{background-color:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem;max-width:480px;width:100%;text-align:center}.error-boundary-icon{color:var(--color-danger);margin-bottom:1rem}.error-boundary-title{color:var(--color-text);font-size:var(--font-size-xl);font-weight:600;margin:0 0 .75rem}.error-boundary-message{color:var(--color-text-muted);font-size:var(--font-size-base);line-height:1.5;margin:0 0 1.25rem}.error-boundary-details{text-align:left;margin-bottom:1.25rem;background-color:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);padding:.75rem}.error-boundary-details summary{cursor:pointer;color:var(--color-danger-text);font-size:var(--font-size-sm);font-weight:500}.error-boundary-details pre{margin-top:.5rem;font-size:var(--font-size-xs);color:var(--color-danger-text);white-space:pre-wrap;word-break:break-word}.error-boundary-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.text-muted{color:var(--color-text-muted)}.text-light{color:var(--color-text-light)}.text-secondary{color:var(--color-text-secondary)}.text-error{color:var(--color-danger)}.text-success{color:var(--color-success-text)}.text-warning{color:var(--color-warning-text)}.text-lighter{color:var(--color-text-light)}.text-sm{font-size:var(--font-size-sm)}.recon-cleared-row{background-color:var(--color-success-bg)!important}.text-xs{font-size:var(--font-size-xs)}.font-mono{font-family:monospace}.btn-unstyled{background:none;border:none;padding:0;font:inherit;cursor:pointer;text-align:left;color:inherit}.table-footer{padding:1rem;font-size:var(--font-size-sm);border-top:1px solid var(--color-border-light)}.alert-banner{padding:.5rem .75rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);line-height:1.4}.alert-warning-banner{background-color:var(--color-warning-bg);color:var(--color-warning-text);border:1px solid var(--color-warning-border)}.alert-danger-banner{background-color:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border)}.alert-success-banner{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.alert-info-banner{background-color:var(--color-info-bg);color:var(--color-info-text)}.badge-retainer{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;background-color:var(--color-purple-bg);color:var(--color-purple);border:1px solid var(--color-purple-border)}.badge-connected{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--radius-md);background-color:var(--color-teal-bg);color:var(--color-teal);border:1px solid var(--color-teal-border);font-weight:500}.badge-category{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;background-color:var(--color-info-bg);color:var(--color-info-text)}.badge-system{display:inline-block;padding:2px 10px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;background-color:var(--color-info-bg);color:var(--color-info-text)}.status-active{background-color:var(--color-success-bg);color:var(--color-success-text)}.status-inactive{background-color:var(--color-bg-subtle);color:var(--color-text-muted)}.badge-account-type{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.badge-account-asset{color:var(--color-account-asset);background-color:var(--color-account-asset-bg)}.badge-account-liability{color:var(--color-account-liability);background-color:var(--color-account-liability-bg)}.badge-account-equity{color:var(--color-account-equity);background-color:var(--color-account-equity-bg)}.badge-account-income{color:var(--color-account-income);background-color:var(--color-account-income-bg)}.badge-account-expense{color:var(--color-account-expense);background-color:var(--color-account-expense-bg)}.progress-track{height:8px;background:var(--color-border);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--color-primary-dark);border-radius:999px;transition:width .3s ease}.progress-fill--mixed{background:repeating-linear-gradient(45deg,var(--color-info-text),var(--color-info-text) 10px,var(--color-border-light) 10px,var(--color-border-light) 20px)}.table-row-border{border-bottom:1px solid var(--color-border-light)}.table-header-bg{background-color:var(--color-bg-page)}.table-row-border-medium{border-bottom:1px solid var(--color-border-medium)}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table th{padding:.5rem .75rem;font-weight:600;border-bottom:2px solid var(--color-border-medium);color:var(--color-text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.data-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border-light)}.data-table tbody tr:hover{background-color:var(--color-bg-hover)}.text-link{color:var(--color-primary);cursor:pointer;text-decoration:none}.text-link:hover{text-decoration:underline}.editor-inline-link{padding:6px 0;display:inline-block}.stack-tight{display:flex;flex-direction:column;gap:0}.privacy-heading{color:var(--color-header-bg);border-bottom:2px solid var(--color-bg-hover);padding-bottom:.5rem;margin-bottom:1rem}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xl)}.loading-spinner-container.full-page{position:fixed;inset:0;z-index:var(--z-modal);background:#fffc}.loading-spinner-container.inline{display:inline-flex;padding:0;gap:var(--space-xs)}.loading-spinner-animated{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-animated.spinner-sm{width:16px;height:16px;border-width:2px}.loading-spinner-animated.spinner-md{width:32px;height:32px;border-width:3px}.loading-spinner-animated.spinner-lg{width:48px;height:48px;border-width:4px}.loading-spinner-message{color:var(--color-text-muted);font-size:var(--font-size-sm)}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;bottom:var(--space-xl);right:var(--space-xl);z-index:var(--z-popover);display:flex;flex-direction:column;gap:var(--space-sm);max-width:400px}.toast{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:toast-slide-in .3s ease-out;font-size:var(--font-size-sm);color:var(--color-bg-white)}.toast-success{background-color:var(--color-success)}.toast-error{background-color:var(--color-danger)}.toast-warning{background-color:var(--color-warning)}.toast-info{background-color:var(--color-primary)}.toast-message{flex:1}.toast-close{background:none;border:none;color:inherit;opacity:.8;cursor:pointer;font-size:1.2rem;padding:0 2px;line-height:1}.toast-close:hover{opacity:1}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.command-palette-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-popover);display:flex;align-items:flex-start;justify-content:center;padding-top:15vh}.command-palette{background:var(--color-bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:560px;overflow:hidden;animation:command-palette-in .15s ease-out}@keyframes command-palette-in{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.command-palette-input{width:100%;padding:var(--space-lg);border:none;border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-lg);outline:none;background:transparent;color:var(--color-text)}.command-palette-input::placeholder{color:var(--color-text-light)}.command-palette-results{max-height:400px;overflow-y:auto}.command-palette-results::-webkit-scrollbar{width:6px}.command-palette-results::-webkit-scrollbar-track{background:transparent}.command-palette-results::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:3px}.command-palette-group-label{padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-xs);color:var(--color-text-light);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.command-palette-item{padding:var(--space-sm) var(--space-lg);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-base);color:var(--color-text)}.command-palette-item:hover,.command-palette-item.selected{background:var(--color-bg-hover)}.command-palette-item.selected{background:var(--color-primary-light)}.command-palette-item-icon{flex-shrink:0;width:20px;text-align:center;color:var(--color-text-light);font-size:var(--font-size-sm)}.command-palette-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.command-palette-shortcut{margin-left:auto;font-size:var(--font-size-xs);color:var(--color-text-light)}.command-palette-empty{padding:var(--space-xl);text-align:center;color:var(--color-text-muted)}.command-palette-footer{display:flex;gap:var(--space-lg);padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--color-border-light);background:var(--color-bg-hover);font-size:var(--font-size-xs);color:var(--color-text-light)}.command-palette-hint{display:flex;align-items:center;gap:var(--space-xs)}.command-palette-hint kbd{display:inline-block;padding:1px 5px;font-size:.7rem;font-family:inherit;line-height:1.4;color:var(--color-text-muted);background:var(--color-bg-white);border:1px solid var(--color-border-dark);border-radius:var(--radius-sm)}.text-right{text-align:right}.btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);text-decoration:none}.btn-link:hover{color:var(--color-primary-hover);text-decoration:underline}.btn-link:disabled{color:var(--color-text-light);cursor:not-allowed;text-decoration:none}.cm-apply-actions{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.cm-apply-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.cm-apply-table th{text-align:left;font-weight:600;padding:var(--space-sm) var(--space-sm);border-bottom:2px solid var(--color-border);color:var(--color-text-secondary);white-space:nowrap}.cm-apply-table td{padding:var(--space-sm) var(--space-sm);border-bottom:1px solid var(--color-border-light);vertical-align:middle}.cm-apply-table tbody tr:hover{background-color:var(--color-bg-hover)}.cm-apply-amount-col{width:140px}.cm-apply-amount-input{width:120px;text-align:right}.cm-apply-over{border-color:var(--color-danger)!important;background-color:var(--color-danger-bg)}.modal-filter-bar{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border-light);background-color:var(--color-bg-hover)}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-column{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mb-0{margin-bottom:0}.mb-xs{margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mt-0{margin-top:0}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-left{text-align:left}.nowrap{white-space:nowrap}
