.table-container{overflow-x:auto;box-shadow:0 0 10px #0000000d;border-radius:8px;background:#fff}.generic-table{width:100%;border-collapse:collapse;font-family:sans-serif;font-size:.95rem}.generic-table thead tr{background-color:#f8f9fa;text-align:left}.generic-table th,.generic-table td{padding:15px;border-bottom:1px solid #eee}.generic-table th{color:#666;font-weight:600;text-transform:uppercase;font-size:.9rem;letter-spacing:.5px}.generic-table tbody tr:hover{background-color:#f1f7ff}.font-bold{font-weight:600;color:#333}.status-badge{padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:capitalize}.status-open{background:#e6fffa;color:#008a66}.status-pending{background:#fffaf0;color:#c05621}.status-closed{background:#edf2f7;color:#4a5568}.view-btn{padding:6px 12px;border:1px solid #3182ce;background:#fff;color:#3182ce;border-radius:4px;cursor:pointer;font-size:.8rem}.view-btn:hover{background:#3182ce;color:#fff}.no-data{padding:20px;text-align:center;color:#888}.table-link{color:#333;text-decoration:none}.table-link:hover{text-decoration:underline}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.sortable-header:hover{background-color:#e9ecef!important}.header-content{display:flex;align-items:center;justify-content:space-between;gap:8px}.sort-icon{font-size:.85rem;color:#999;opacity:.6;transition:opacity .2s}.sortable-header:hover .sort-icon{opacity:1}.filter-row th{padding:8px 15px;background-color:#fff;border-bottom:2px solid #dee2e6}.filter-input{width:100%;padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:.85rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.filter-input:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 2px #3182ce1a}.filter-input::placeholder{color:#999;font-size:.8rem}.no-data-cell{padding:30px 20px;text-align:center;color:#888;font-style:italic}[data-theme=dark] .table-container{background:#1a1a1a}[data-theme=dark] .generic-table thead tr{background-color:#2d2d2d}[data-theme=dark] .generic-table th{color:#ccc}[data-theme=dark] .generic-table tbody tr:hover{background-color:#2a2a2a}[data-theme=dark] .sortable-header:hover{background-color:#3a3a3a!important}[data-theme=dark] .filter-row th{background-color:#1a1a1a;border-bottom-color:#444}[data-theme=dark] .filter-input{background-color:#2d2d2d;border-color:#444;color:#fff}[data-theme=dark] .filter-input:focus{border-color:#5a9fd4;box-shadow:0 0 0 2px #5a9fd433}[data-theme=dark] .filter-input::placeholder{color:#666}[data-theme=dark] .table-link{color:#ccc}[data-theme=dark] .no-data-cell{color:#666}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:modalFadeIn var(--transition-fast) ease-out}.modal-container{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;animation:modalSlideIn var(--transition-base) ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0}.modal-close{background:none;border:none;padding:var(--spacing-sm);cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--color-surface-hover);color:var(--color-text)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:768px){.modal-container{max-width:100%;margin:var(--spacing-md)}}.toast-container{position:fixed;top:var(--spacing-lg);right:var(--spacing-lg);z-index:1100;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:300px;max-width:400px;pointer-events:auto;animation:toastSlideIn var(--transition-base) ease-out}.toast-exiting{animation:toastSlideOut var(--transition-base) ease-in forwards}.toast-success{background-color:#e9fbf0;border:1px solid var(--color-success);color:#126d34}.toast-error{background-color:#fde8e8;border:1px solid var(--color-error);color:#8d0c0c}.toast-info{background-color:#e7f6fe;border:1px solid var(--color-info);color:#075578}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast-content{flex:1}.toast-message{font-size:.875rem;font-weight:500;line-height:1.4}.toast-close{background:none;border:none;padding:0;cursor:pointer;color:inherit;opacity:.6;transition:opacity var(--transition-fast);flex-shrink:0}.toast-close:hover{opacity:1}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@media(max-width:768px){.toast-container{top:var(--spacing-md);right:var(--spacing-md);left:var(--spacing-md)}.toast{min-width:auto;max-width:none}}.matter-detail{max-width:1200px;margin:0 auto;padding:20px;font-family:sans-serif}.matter-header{margin-bottom:30px}.matter-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.matter-header h1{margin:0 0 8px;font-size:1.75rem;color:#333}.matter-meta{color:#666;font-size:.9rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:30px}.info-card{background:#fff;border-radius:8px;box-shadow:0 0 10px #0000000d;overflow:hidden}.info-card-header{background:#f8f9fa;padding:12px 15px;border-bottom:1px solid #eee}.info-card-header h3{margin:0;font-size:.9rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.info-card-body{padding:15px}.info-card-value{font-size:1.1rem;color:#333;font-weight:500}.info-card-empty{color:#999;font-style:italic}.detail-row{display:flex;padding:8px 0;border-bottom:1px solid #f0f0f0}.detail-row:last-child{border-bottom:none}.detail-label{flex:0 0 140px;color:#666;font-size:.85rem;font-weight:500}.detail-value{flex:1;color:#333;font-size:.9rem}.section-title{font-size:1.1rem;font-weight:600;color:#333;margin:0 0 15px;display:flex;align-items:center;gap:8px}.section-count{background:#3182ce;color:#fff;font-size:.75rem;padding:2px 8px;border-radius:10px}.merchants-section{margin-top:10px}.merchants-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:15px}.merchant-card{background:#fff;border-radius:8px;box-shadow:0 0 10px #0000000d;padding:15px}.merchant-card-header{margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #eee}.merchant-name{font-size:1rem;font-weight:600;color:#333;margin:0}.merchant-dba{font-size:.85rem;color:#666;margin:4px 0 0}.loading-state,.error-state,.empty-state{text-align:center;padding:60px 20px;color:#666}.error-state{color:#e53e3e}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #3182ce;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.settlements-dashboard{padding:var(--spacing-xl);max-width:1200px;margin:0 auto}.settlements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.settlement-card{display:block;background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);text-decoration:none;color:var(--color-text);transition:all var(--transition-base);overflow:hidden}.settlement-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--color-border-hover)}.settlement-id{font-weight:600;font-size:.875rem;color:var(--color-text-secondary)}.settlement-card .card-body{padding:var(--spacing-lg)}.settlement-info{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.payment-tracker-section{margin:0}.stat{display:flex;flex-direction:column;gap:var(--spacing-xs)}.stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-weight:600;font-size:.875rem}.capitalize{text-transform:capitalize}.settlement-card .card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-bg)}.created-date{font-size:.75rem;color:var(--color-text-muted)}.settlements-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.settlement-item{display:flex;flex-direction:column}.settlement-card .card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.payment-tracker-loading,.payment-tracker-empty{padding:var(--spacing-lg);text-align:center;color:var(--color-text-muted)}.payment-stats{display:flex;gap:var(--spacing-xl);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.payment-stats .stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase}.payment-stats .stat-value{font-weight:600;font-size:.875rem}.payments-table th{text-align:left;padding:var(--spacing-sm) var(--spacing-md);font-weight:600;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);font-size:.75rem;text-transform:uppercase}.payments-table .payment-type{text-transform:capitalize;color:var(--color-text-muted)}.payment-overdue{background:#fef4e7}.payments-table .status-badge{text-transform:capitalize}@media(max-width:768px){.header-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.settlements-grid{grid-template-columns:1fr}.payment-stats{flex-direction:column;gap:var(--spacing-sm)}.payments-table{font-size:.75rem}.payments-table th,.payments-table td{padding:var(--spacing-xs) var(--spacing-sm)}}.settlement-detail{padding:var(--spacing-xl);max-width:1400px;margin:0 auto}.page-header h1{font-size:2rem;margin-bottom:0}.settlement-layout{display:grid;grid-template-columns:1fr 360px;gap:var(--spacing-xl);align-items:start}.settlement-main{display:flex;flex-direction:column;gap:var(--spacing-xl)}.settlement-sidebar{position:sticky;top:var(--spacing-xl)}.section-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-text)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-header .section-title{margin-bottom:0}.settlement-form{background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.input-with-prefix{position:relative;display:flex;align-items:center}.input-prefix{position:absolute;left:1rem;color:var(--color-text-muted);font-weight:500}.input-with-prefix .form-input{padding-left:2rem}.form-hint{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.tier-builder{background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.tiers-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.tier-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.tier-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.tier-number{font-weight:600;color:var(--color-text-secondary)}.tier-actions{display:flex;gap:var(--spacing-xs)}.btn-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;color:var(--color-text-secondary);transition:all var(--transition-fast)}.btn-icon:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-hover)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-icon.btn-danger:hover:not(:disabled){background:#fde8e8;border-color:var(--color-error);color:var(--color-error)}.tier-fields{display:grid;grid-template-columns:1fr 1fr auto;gap:var(--spacing-md);align-items:end}.tier-fields .form-group{margin-bottom:0}.tier-subtotal{padding:.75rem;background:var(--color-surface);border-radius:var(--radius-sm);text-align:right;min-width:120px}.tier-subtotal .label{display:block;font-size:.75rem;color:var(--color-text-muted)}.tier-subtotal .value{font-weight:600;color:var(--color-text)}.tier-summary{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.summary-row{display:flex;justify-content:space-between;padding:var(--spacing-xs) 0;font-size:.875rem}.summary-row.difference{font-weight:600}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.one-time-payments{background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.payments-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.payment-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md)}.payment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.payment-label{font-weight:600;color:var(--color-text-secondary);font-size:.875rem}.payment-fields{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.payment-fields .form-group{margin-bottom:0}.form-group-full{grid-column:1 / -1}.one-time-summary{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;justify-content:space-between;font-size:.875rem;font-weight:500}.payment-schedule-preview{background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.schedule-table-container{overflow-x:auto;margin-bottom:var(--spacing-md)}.schedule-table{width:100%;border-collapse:collapse;font-size:.875rem}.schedule-table th,.schedule-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}.schedule-table th{font-weight:600;color:var(--color-text-secondary);background:var(--color-bg)}.schedule-table tbody tr:hover{background:var(--color-surface-hover)}.schedule-table tbody tr.selected{background:var(--color-primary-light)}.schedule-table tbody tr.edited .date-display{color:var(--color-primary)}.col-checkbox{width:40px;text-align:center}.col-number{width:50px}.col-date{min-width:180px}.col-amount{width:120px;text-align:right}.col-type,.col-status{width:100px}.date-display{cursor:pointer}.edited-badge{color:var(--color-primary);margin-left:var(--spacing-xs)}.remainder-badge{color:var(--color-text-muted);margin-left:var(--spacing-xs);font-size:.75rem}.inline-date-input{padding:var(--spacing-xs);border:1px solid var(--color-primary);border-radius:var(--radius-sm);font-size:.875rem;width:100%}.type-badge{display:inline-block;padding:.125rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.type-scheduled{background:var(--color-primary-light);color:var(--color-primary)}.type-onetime{background:#fdecce;color:var(--color-warning)}.status-badge{display:inline-block;padding:.125rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.status-pending{background:var(--color-bg);color:var(--color-text-secondary)}.status-drafting{background:#e2e4e9;color:var(--color-text-secondary)}.status-active{background:#d3f8e1;color:var(--color-success)}.status-completed{background:#cfeefc;color:var(--color-info)}.status-breached{background:#fbd0d0;color:var(--color-error)}.total-row{font-weight:600;background:var(--color-bg)}.total-label{text-align:right}.table-hint{font-size:.75rem;color:var(--color-text-muted);margin:0}.bulk-edit-content{padding:var(--spacing-md) 0}.bulk-edit-info{margin-bottom:var(--spacing-lg);color:var(--color-text-secondary)}.radio-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.radio-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.875rem}.radio-label input{accent-color:var(--color-primary)}.bulk-edit-preview{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md);font-size:.875rem;text-align:center}.settlement-summary{background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.summary-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.summary-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.summary-value{font-weight:600;font-size:1rem}.validation-warning,.validation-success{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.875rem}.validation-warning{background:#fef5e7;color:#ab6f07}.validation-success{background:#e9fbf0;color:#16833e}.warning-icon,.success-icon{font-size:1rem}.summary-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.summary-actions .btn{width:100%}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover{background:#1eae53}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{background:#eb1414}.status-message{text-align:center;padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem}.actual-payments-section{background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.payment-stats-mini{display:flex;gap:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.payment-stats-mini .stat{display:flex;gap:var(--spacing-sm);align-items:baseline}.payment-stats-mini .label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.payment-stats-mini .value{font-weight:600;font-size:.875rem}.payment-stats-mini .value.paid{color:var(--color-success)}.payment-stats-mini .value.pending{color:var(--color-text-secondary)}.payment-stats-mini .value.overdue{color:var(--color-error)}.payments-table-wrapper{overflow-x:auto}.payments-table th{text-align:left;padding:var(--spacing-sm) var(--spacing-md);font-weight:600;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);font-size:.75rem;text-transform:uppercase;background:var(--color-bg)}.payments-table .amount{font-weight:600;font-family:var(--font-mono);text-align:right}.payment-partial,.payment-due-today{background:#fef9f0}.payments-table .actions{white-space:nowrap}.btn-action{width:28px;height:28px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;font-size:.875rem;transition:all var(--transition-base)}@media(max-width:1024px){.settlement-layout{grid-template-columns:1fr}.settlement-sidebar{position:static}.form-row,.tier-fields,.payment-fields,.summary-grid{grid-template-columns:1fr}.payment-stats-mini{flex-direction:column;gap:var(--spacing-sm)}}.payments-dashboard{padding:var(--spacing-xl);margin:0 auto}.page-header{margin-bottom:var(--spacing-xl)}.breadcrumb{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.breadcrumb a{color:var(--color-text-secondary)}.breadcrumb a:hover{color:var(--color-primary)}.breadcrumb .separator{margin:0 var(--spacing-sm);color:var(--color-text-muted)}.header-row{display:flex;justify-content:space-between;align-items:center}.header-row h1{font-size:2rem;margin-bottom:0}.empty-state{text-align:center;padding:var(--spacing-3xl) var(--spacing-xl);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.empty-state h3{margin-bottom:var(--spacing-sm);color:var(--color-text)}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.filter-buttons{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.filter-buttons button{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;color:var(--color-text);transition:all .2s ease}.filter-buttons button:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.filter-buttons button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.filter-buttons button.active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.payment-stats{display:flex;gap:var(--spacing-xl);padding:var(--spacing-lg);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);margin-bottom:var(--spacing-xl)}.payment-stats .stat-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.payment-stats .stat-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.payment-stats .stat-value{font-weight:600;font-size:1rem}.payment-stats .stat-value.paid{color:var(--color-success)}.payment-stats .stat-value.pending{color:var(--color-text-secondary)}.payment-stats .stat-value.overdue{color:var(--color-error)}.payments-list{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.payments-list .table-container{box-shadow:none;border-radius:0;background:transparent}.payments-list .generic-table{font-size:.875rem}.payments-list .generic-table th{background:var(--color-bg);color:var(--color-text-secondary)}.payments-list .generic-table td{padding:var(--spacing-sm) var(--spacing-md)}.payments-list .generic-table .matter-name{font-weight:500}.payments-table{width:100%;border-collapse:collapse;font-size:.875rem}.payments-table th{text-align:left;padding:var(--spacing-md);font-weight:600;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);font-size:.75rem;text-transform:uppercase;background:var(--color-bg)}.payments-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border)}.payments-table tbody tr:hover{background:var(--color-surface-hover)}.payments-table .matter-name a{color:var(--color-primary);text-decoration:none;font-weight:500}.payments-table .matter-name a:hover{text-decoration:underline}.payments-table .amount{font-weight:600;font-family:var(--font-mono)}.payments-table .payment-method{color:var(--color-text-muted)}.payments-table .due-date{display:flex;align-items:center;gap:var(--spacing-sm)}.overdue-badge{font-size:.625rem;padding:.125rem .375rem;background:#fbd0d0;color:var(--color-error);border-radius:var(--radius-sm);font-weight:600}.payment-paid{background:#f2fdf6}.payment-paid td{color:var(--color-text-muted)}.payment-missed{background:#fef1f1}.payment-due-today{background:#fef9f0}.payment-due-tomorrow{background:#fefbf0}.payment-due-this-week{background:#f1fafe}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.status-pending{background:#e2e4e9;color:var(--color-text-secondary)}.status-paid{background:#d3f8e1;color:var(--color-success)}.status-partial{background:#fde9ce;color:#a26107}.status-missed{background:#fbd0d0;color:var(--color-error)}.status-due_today{background:#fde9ce;color:#a26107}.status-due_tomorrow{background:#fdf1ce;color:#937006}.status-due_this_week{background:#cfeefc;color:var(--color-info)}.status-fully_paid{background:#d3f8e1;color:var(--color-success)}.status-partially_paid{background:#fde9ce;color:#a26107}.status-overdue{background:#fbd0d0;color:var(--color-error)}.payments-table .actions,.payments-list .actions{white-space:nowrap}.btn-action{width:28px;height:28px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;font-size:.875rem;transition:all var(--transition-base);margin-right:var(--spacing-xs)}.btn-action:last-child{margin-right:0}.btn-action:hover{transform:scale(1.05)}.btn-paid{color:var(--color-success)}.btn-paid:hover{background:#d3f8e1;border-color:var(--color-success)}.btn-missed{color:var(--color-error)}.btn-missed:hover{background:#fbd0d0;border-color:var(--color-error)}.btn-undo{color:var(--color-text-secondary)}.btn-undo:hover{background:var(--color-surface-hover)}.updating{color:var(--color-text-muted);font-style:italic}.payment-locked{display:inline-block;width:28px;height:28px;text-align:center;line-height:28px;color:var(--color-text-muted);font-size:.875rem;cursor:help}@media(max-width:1024px){.payments-table .matter-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}@media(max-width:768px){.header-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.payment-stats{flex-direction:column;gap:var(--spacing-sm)}.filter-buttons{flex-wrap:wrap}.filter-buttons button{font-size:.8rem;padding:var(--spacing-xs) var(--spacing-sm)}.payments-table{font-size:.75rem}.payments-table th,.payments-table td{padding:var(--spacing-xs) var(--spacing-sm)}.payments-list{overflow-x:auto}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: hsl(250, 84%, 54%);--color-primary-hover: hsl(250, 84%, 48%);--color-primary-light: hsl(250, 84%, 94%);--color-secondary: hsl(280, 70%, 60%);--color-accent: hsl(320, 85%, 60%);--color-success: hsl(142, 71%, 45%);--color-warning: hsl(38, 92%, 50%);--color-error: hsl(0, 84%, 60%);--color-info: hsl(199, 89%, 48%);--color-bg: hsl(0, 0%, 98%);--color-surface: hsl(0, 0%, 100%);--color-surface-hover: hsl(0, 0%, 96%);--color-text: hsl(220, 13%, 18%);--color-text-secondary: hsl(220, 9%, 46%);--color-text-muted: hsl(220, 9%, 66%);--color-border: hsl(220, 13%, 91%);--color-border-hover: hsl(220, 13%, 80%);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "Fira Code", "Courier New", monospace;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-bg: hsl(220, 13%, 10%);--color-surface: hsl(220, 13%, 14%);--color-surface-hover: hsl(220, 13%, 18%);--color-text: hsl(0, 0%, 95%);--color-text-secondary: hsl(220, 9%, 75%);--color-text-muted: hsl(220, 9%, 55%);--color-border: hsl(220, 13%, 25%);--color-border-hover: hsl(220, 13%, 35%);--color-primary-light: hsl(250, 84%, 20%)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-weight:400;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--transition-base),color var(--transition-base)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;margin-bottom:var(--spacing-md);color:var(--color-text)}h1{font-size:3rem}h2{font-size:2.25rem}h3{font-size:1.875rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.container-narrow{max-width:800px}.container-wide{max-width:1400px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background-color:var(--color-surface);color:var(--color-text);border:2px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-surface-hover);border-color:var(--color-border-hover)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background-color:var(--color-surface-hover);color:var(--color-text)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:1rem 2rem;font-size:1.125rem}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.card-title{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-xs)}.card-description{color:var(--color-text-secondary);font-size:.875rem}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:600;color:var(--color-text)}.form-input,.form-textarea,.form-select{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:var(--font-sans);color:var(--color-text);background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input::placeholder{color:var(--color-text-muted)}.form-error{color:var(--color-error);font-size:.875rem;margin-top:var(--spacing-xs)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.dropdown{position:relative}.dropdown-trigger{display:flex;align-items:center;gap:var(--spacing-sm)}.dropdown-arrow{font-size:.7rem;color:var(--color-text-muted);transition:transform var(--transition-fast)}.dropdown-menu{position:absolute;top:calc(100% + var(--spacing-xs));right:0;min-width:140px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;animation:fadeIn var(--transition-fast) ease-out}.dropdown-item{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;background:none;border:none;font-size:.9rem;font-family:var(--font-sans);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast)}.dropdown-item:hover{background:var(--color-surface-hover)}.dropdown-item:not(:last-child){border-bottom:1px solid var(--color-border)}.toast-container{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);z-index:1000;display:flex;flex-direction:column;gap:var(--spacing-sm)}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.875rem;font-weight:600;border-radius:var(--radius-full)}.badge-primary{background-color:var(--color-primary-light);color:var(--color-primary)}.badge-success{background-color:#d3f8e1;color:var(--color-success)}.badge-warning{background-color:#fdecce;color:var(--color-warning)}.badge-error{background-color:#fbd0d0;color:var(--color-error)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease-out}.animate-slide-in{animation:slideIn var(--transition-slow) ease-out}@media(max-width:768px){h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.container{padding:0 var(--spacing-md)}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}
