*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f2f5;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.login-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-container{background:#fff;border-radius:8px;width:100%;max-width:450px;overflow:hidden;box-shadow:0 10px 40px #0003}.login-header{color:#fff;text-align:center;background-color:#2c3e50;padding:40px 30px}.login-header h1{margin-bottom:10px;font-size:32px}.login-header p{color:#bdc3c7;font-size:14px}.login-content{padding:40px 30px}.login-content h2{color:#2c3e50;margin-bottom:10px}.login-subtitle{color:#7f8c8d;margin-bottom:30px;font-size:14px;line-height:1.5}.login-input{box-sizing:border-box;border:1px solid #dcdcdc;border-radius:4px;width:100%;padding:12px;font-size:16px;transition:border-color .2s}.login-input:focus{border-color:#0078d4;outline:none}.login-btn{color:#fff;cursor:pointer;background-color:#0078d4;border:none;border-radius:4px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:background-color .2s;display:flex}.login-btn:hover{background-color:#006cbd}.login-btn:active{background-color:#005a9e}.login-btn:disabled{cursor:not-allowed;background-color:#a0c2e0}.login-error{color:#c53030;text-align:center;background-color:#fde8e8;border-radius:4px;margin-bottom:20px;padding:10px;font-size:14px}.user-banner{color:#4a5568;justify-content:space-between;align-items:center;margin-bottom:20px;font-size:14px;display:flex}.link-btn{color:#0078d4;cursor:pointer;background:0 0;border:none;padding:0;font-size:14px}.link-btn:hover{text-decoration:underline}.login-info{text-align:center;border-top:1px solid #ecf0f1;margin-top:30px;padding-top:20px}.login-info p{color:#95a5a6;font-size:12px}.login-register{text-align:center;margin-top:20px}.login-register p{color:#7f8c8d;font-size:14px}.login-register a{color:#667eea;font-weight:600;text-decoration:none}.login-register a:hover{text-decoration:underline}.loading-container{justify-content:center;align-items:center;height:100vh;display:flex}.spinner{border:4px solid #0000001a;border-left-color:#09f;border-radius:50%;width:36px;height:36px;animation:1s infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-logo{width:auto;height:64px;margin-bottom:20px}.register-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.register-container{background:#fff;border-radius:8px;width:100%;max-width:500px;overflow:hidden;box-shadow:0 10px 40px #0003}.register-header{color:#fff;text-align:center;background-color:#2c3e50;padding:40px 30px}.register-header h1{margin-bottom:10px;font-size:32px}.register-header p{color:#bdc3c7;font-size:14px}.register-content{padding:40px 30px}.register-content h2{color:#2c3e50;margin-bottom:10px}.register-subtitle{color:#7f8c8d;margin-bottom:30px;font-size:14px;line-height:1.5}.register-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#2c3e50;font-size:14px;font-weight:600}.form-group input{border:1px solid #ddd;border-radius:4px;padding:12px 14px;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{cursor:not-allowed;background-color:#f5f5f5}.form-group small{color:#95a5a6;font-size:12px}.register-btn{color:#fff;cursor:pointer;text-align:center;background-color:#667eea;border:none;border-radius:4px;width:100%;padding:14px;font-size:16px;font-weight:600;text-decoration:none;transition:background-color .2s;display:inline-block}.register-btn:hover{background-color:#5a6fd6}.register-btn:active{background-color:#4e5fc9}.register-btn:disabled{cursor:not-allowed;background-color:#bdc3c7}.register-btn.secondary{background-color:#95a5a6;margin-top:15px}.register-btn.secondary:hover{background-color:#7f8c8d}.error-message{color:#c0392b;background-color:#fee;border:1px solid #fcc;border-radius:4px;padding:12px 15px;font-size:14px;line-height:1.5}.register-footer{text-align:center;border-top:1px solid #ecf0f1;margin-top:25px;padding-top:20px}.register-footer p{color:#7f8c8d;font-size:14px}.register-footer a{color:#667eea;font-weight:600;text-decoration:none}.register-footer a:hover{text-decoration:underline}.register-success{text-align:center}.success-icon{color:#fff;background-color:#27ae60;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 20px;font-size:32px;display:flex}.info-icon{color:#fff;background-color:#3498db;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 20px;font-size:32px;display:flex}.register-success h2{color:#2c3e50;margin-bottom:15px}.register-success p{color:#7f8c8d;margin-bottom:10px;line-height:1.6}.next-steps{text-align:left;background-color:#f8f9fa;border-radius:6px;margin:25px 0;padding:20px}.next-steps h3{color:#2c3e50;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:14px}.next-steps ol{color:#555;margin:0;padding-left:20px}.next-steps li{margin-bottom:8px;line-height:1.5}.members-page{max-width:1400px;margin:0 auto;padding:2rem}.members-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.members-header h1{color:#2c3e50;margin:0;font-size:2rem}.members-actions{align-items:center;gap:1rem;display:flex}.members-stats{color:#7f8c8d;margin-bottom:1rem;font-size:.9rem}.members-table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.members-table{border-collapse:collapse;width:100%}.members-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.members-table th{text-align:left;color:#495057;text-transform:uppercase;letter-spacing:.5px;padding:1rem;font-size:.875rem;font-weight:600}.members-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.members-table th.sortable:hover{background-color:#e9ecef}.members-table tbody tr{border-bottom:1px solid #dee2e6;transition:background-color .2s}.members-table tbody tr:hover{background-color:#f8f9fa}.members-table td{color:#212529;padding:1rem}.code-cell{color:#3498db;font-family:Courier New,monospace;font-weight:600}.name-cell{font-weight:500}.email-cell{color:#7f8c8d;font-size:.9rem}.tier-cell{white-space:nowrap}.tier-none{color:#adb5bd}.tier-badge{border-radius:4px;padding:.2rem .6rem;font-size:.8rem;font-weight:600;display:inline-block}.tier-group-header td{text-transform:uppercase;letter-spacing:.5px;color:#495057;background:#f0f4f8;border-top:2px solid #dee2e6;padding:.5rem 1rem;font-size:.8rem;font-weight:700}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.actions-cell{text-align:right}.view-btn{color:#fff;cursor:pointer;background-color:#6c757d;border:none;border-radius:4px;padding:.375rem 1rem;font-size:.875rem;transition:background-color .2s}.view-btn:hover{background-color:#5a6268}.no-results{text-align:center;color:#7f8c8d;font-style:italic;padding:3rem!important}.loading,.error{text-align:center;padding:3rem}.loading{color:#7f8c8d;font-size:1.2rem}.error{color:#e74c3c}.error h2{color:#c0392b;margin-top:0}.retry-btn{color:#fff;cursor:pointer;background-color:#e74c3c;border:none;border-radius:4px;margin-top:1rem;padding:.5rem 1.5rem;font-size:1rem;transition:background-color .2s}@media (width<=768px){.members-page{padding:1rem}.members-header{flex-direction:column;align-items:flex-start;gap:1rem}.members-actions{flex-direction:column;width:100%}.search-input{width:100%}.members-table-container{overflow-x:auto}.members-table{min-width:600px}}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:8px;flex-direction:column;width:560px;max-height:90vh;display:flex;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-content.modal-wide{width:760px;max-width:96vw}.modal-close{cursor:pointer;color:#666;background:0 0;border:none;padding:0 .25rem;font-size:1.1rem}.wizard-steps{background:#f8f9fa;border-bottom:1px solid #e8e8e8;flex-wrap:wrap;gap:.5rem;padding:.75rem 1.25rem;font-size:.85rem;display:flex}.wizard-step{color:#999}.wizard-step.active{color:#1677ff;font-weight:600}.wizard-step.done{color:#52c41a}.wizard-body{flex:1;padding:1.25rem}.wizard-footer{border-top:1px solid #e8e8e8;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:1rem;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#1677ff;border:none;border-radius:4px;padding:.5rem 1.25rem;font-size:.9rem;font-weight:500}.btn-primary:hover:not(:disabled){background:#0958d9}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{color:#333;cursor:pointer;background:#f5f5f5;border:1px solid #d9d9d9;border-radius:4px;padding:.5rem 1.25rem;font-size:.9rem}.btn-secondary:hover:not(:disabled){background:#e8e8e8}.form-control{box-sizing:border-box;border:1px solid #d9d9d9;border-radius:4px;width:100%;padding:.4rem .6rem;font-size:.9rem}.invoice-view-container{background:#fff;border-radius:8px;max-width:1200px;margin:0 auto;padding:24px;box-shadow:0 2px 8px #0000001a}.invoice-period-selector{background:#f8f9fa;border-radius:6px;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;display:flex}.invoice-period-selector label{color:#374151;white-space:nowrap;font-weight:600}.invoice-period-selector .period-select{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:4px;min-width:180px;padding:8px 12px;font-size:.95rem}.invoice-period-selector .period-select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f633}.invoice-period-selector .btn-close-header{color:#6b7280;cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0 8px;font-size:24px;line-height:1}.invoice-period-selector .btn-close-header:hover{color:#1f2937}.invoice-period-selector .btn-generate-pdf,.invoice-period-selector .btn-view-pdf{cursor:pointer;white-space:nowrap;border-radius:4px;padding:6px 14px;font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.invoice-period-selector .btn-generate-pdf{color:#fff;background:#1d4ed8;border:1px solid #1d4ed8}.invoice-period-selector .btn-generate-pdf:hover:not(:disabled){background:#1e40af}.invoice-period-selector .btn-view-pdf{color:#1d4ed8;background:#fff;border:1px solid #1d4ed8}.invoice-period-selector .btn-view-pdf:hover:not(:disabled){background:#eff6ff}.invoice-period-selector .btn-generate-pdf:disabled,.invoice-period-selector .btn-view-pdf:disabled{opacity:.5;cursor:not-allowed}.invoice-period-selector .btn-view-pdf.active{color:#1d4ed8;background:#eff6ff;border-color:#1d4ed8;font-weight:600}.pdf-iframe{border:none;border-radius:4px;width:100%;height:calc(100vh - 180px);min-height:700px}.pdf-skeleton-container{background:#fff;border:1px solid #f0f0f0;border-radius:4px;width:100%;min-height:700px;padding:32px}.invoice-loading,.invoice-error,.invoice-empty{text-align:center;padding:48px 24px}.invoice-loading .spinner{border:4px solid #e1e1e1;border-top-color:#1890ff;border-radius:50%;width:40px;height:40px;margin:0 auto 16px;animation:1s linear infinite spin}.invoice-error{color:#ff4d4f}.invoice-error h3{margin-bottom:8px}.invoice-header{border-bottom:2px solid #1a1a1a;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;display:flex}.invoice-header-left h1{color:#1a1a1a;margin:0 0 8px;font-size:1.5rem;font-weight:600}.invoice-member{align-items:center;gap:8px;display:flex}.invoice-member .label{color:#666;font-weight:500}.invoice-member .value{font-weight:600}.invoice-member .barrister-code{background:#f5f5f5;border-radius:4px;padding:2px 8px;font-size:.85rem}.invoice-header-right{align-items:flex-start;gap:24px;display:flex}.invoice-meta{text-align:right;font-size:.9rem}.invoice-meta p{margin:4px 0}.btn-close{color:#999;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1.5rem;transition:all .2s;display:flex}.btn-close:hover{color:#333;background:#f5f5f5}.status-badge{border-radius:4px;padding:2px 8px;font-size:.8rem;font-weight:500;display:inline-block}.status-badge.preview{color:#1890ff;background:#e6f7ff}.status-badge.draft{color:#fa8c16;background:#fff7e6}.status-badge.published{color:#52c41a;background:#f6ffed}.status-badge.paid{color:#666;background:#f0f0f0}.page-tabs{border-bottom:2px solid #e1e1e1;gap:4px;margin-bottom:24px;display:flex}.page-tab{color:#666;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:12px 20px;font-size:.95rem;transition:all .2s}.page-tab:hover{color:#1890ff}.page-tab.active{color:#1890ff;border-bottom-color:#1890ff;font-weight:500}.invoice-page{min-height:400px}.invoice-section{margin-bottom:24px}.invoice-section h2{color:#1a1a1a;margin:0 0 12px;font-size:1.1rem;font-weight:600}.invoice-section h3{color:#333;margin:0 0 8px;font-size:1rem;font-weight:500}.section-header-with-filter{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-header-with-filter h2{margin:0}.filter-toggle{align-items:center;font-size:.9rem;display:flex}.filter-toggle label{cursor:pointer;color:#555;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;display:flex}.filter-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px}.section-header{margin-bottom:8px;padding:8px 12px;font-weight:600}.section-header.shaded{background:#f5f5f5;border-radius:4px}.two-column-section{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;display:grid}.half-width{margin-bottom:0}@media (width<=768px){.two-column-section{grid-template-columns:1fr}}.invoice-table{border-collapse:collapse;table-layout:auto;width:100%;font-size:.9rem}.invoice-table th,.invoice-table td{text-align:left;border-bottom:1px solid #e1e1e1;padding:8px 12px}.invoice-table th{color:#666;background:#fafafa;font-weight:600}.invoice-table tbody tr:hover{background:#fafafa}.invoice-table .amount-col{text-align:right;white-space:nowrap;width:1%;font-family:SF Mono,Consolas,monospace}.invoice-table .amount-zero{color:#9ca3af;opacity:.6}.invoice-table th.amount-col{text-align:right}.invoice-table .pct-col{text-align:right;white-space:nowrap;width:1%}.invoice-table th.pct-col{text-align:right}.invoice-table .solicitor-col{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.invoice-table tfoot .totals-row{background:#fafafa;border-top:2px solid #1a1a1a}.invoice-table tfoot .totals-row td{font-weight:600}.fee-details-table th,.fee-details-table td,.aged-debt-table th,.aged-debt-table td{padding:6px 8px;font-size:.85rem}.aged-debt-table.ant-table-wrapper,.aged-debt-table .ant-table{font-size:.85rem}.aged-debt-table .ant-table-thead>tr>th{background:#f5f5f5;border-bottom:2px solid #e0e0e0;padding:8px;font-size:.85rem;font-weight:600}.aged-debt-table .ant-table-tbody>tr>td{padding:6px 8px;font-size:.85rem}.aged-debt-table .ant-table-summary .totals-row{background:#fafafa;border-top:2px solid #1a1a1a}.aged-debt-table .ant-table-summary .totals-row>td{padding:8px;font-weight:600}.aged-debt-table .ant-table-filter-dropdown{min-width:200px}.aged-debt-table .ant-input{font-size:.85rem}@media print{.aged-debt-table .ant-table-filter-column,.aged-debt-table .ant-table-column-sorter{display:none}}.empty-section{color:#999;padding:12px;font-style:italic}.balances-section{background:#fafafa;border-radius:8px;padding:16px}.balance-row{border-bottom:1px solid #e1e1e1;justify-content:space-between;padding:8px 0;display:flex}.balance-row:last-of-type{border-bottom:none}.balance-row.total-due{border-top:2px solid #1a1a1a;border-bottom:none;margin-top:12px;padding-top:12px}.balance-row .total-label{font-size:1.1rem;font-weight:600}.balance-row .total-amount{color:#1890ff;font-size:1.3rem;font-weight:700}.direct-debit-note{color:#666;margin-top:16px;font-size:.9rem}.fees-analysis-section{max-width:500px}.fees-analysis-table{font-size:.9rem}.invoice-footer{border-top:1px solid #e1e1e1;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-top:32px;padding-top:16px;display:flex}.invoice-footer-downloads{flex-shrink:0;gap:8px;display:flex}.btn-xero-download{cursor:pointer;color:#555;background:#fff;border:1px solid #d9d9d9;border-radius:4px;padding:4px 12px;font-size:.8rem;transition:all .2s}.btn-xero-download:hover:not(:disabled){color:#1677ff;border-color:#1677ff}.btn-xero-download:disabled{opacity:.5;cursor:not-allowed}.section-visibility{flex-wrap:wrap;gap:12px;display:flex}.section-visibility span{border-radius:4px;padding:4px 10px;font-size:.8rem}.section-visibility .has-data{color:#52c41a;background:#f6ffed}.section-visibility .no-data{color:#999;background:#f5f5f5}.empty-sections-note{color:#666;margin-top:12px;font-size:.85rem}.btn-secondary{cursor:pointer;background:#f5f5f5;border:1px solid #d9d9d9;border-radius:4px;padding:8px 16px;font-size:.9rem;transition:all .2s}.btn-secondary:hover{background:#e6e6e6;border-color:#bfbfbf}.provenance-annotated{cursor:help;border-bottom:1px dotted #1677ff;display:inline}.provenance-controls{align-items:center;gap:6px;margin-left:10px;display:inline-flex}.provenance-label{color:#555;-webkit-user-select:none;user-select:none;font-size:12px}@media print{.invoice-view-container{box-shadow:none;padding:0}.page-tabs,.btn-close,.invoice-footer,.screen-only{display:none}.invoice-page{page-break-after:always}}.member-profile{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.profile-header{align-items:flex-start;gap:2rem;margin-bottom:2rem;display:flex}.profile-avatar-container{flex-shrink:0}.profile-avatar{object-fit:cover;border-radius:50%;width:60px;height:60px;box-shadow:0 2px 4px #0000001a}.profile-info{flex:1;min-width:0}.profile-name{color:#1a1a1a;margin:0 0 .5rem;font-size:1.75rem;font-weight:600}.profile-code{color:#1976d2;background:#e3f2fd;border-radius:4px;margin-bottom:.5rem;padding:.25rem .75rem;font-size:.875rem;font-weight:500;display:inline-block}.profile-email{margin-top:.5rem}.profile-email a{color:#666;font-size:.95rem;text-decoration:none}.profile-email a:hover{color:#1976d2;text-decoration:underline}.profile-intro-text{color:#666;max-width:600px;margin:.75rem 0 .5rem;font-size:.95rem;font-style:italic;line-height:1.5}.practice-areas-section{margin-bottom:2rem}.section-heading{color:#333;margin:0 0 1rem;font-size:1.1rem;font-weight:600}.practice-areas-list{margin:0;padding-left:1.5rem;list-style:outside}.practice-areas-list li{color:#333;margin-bottom:.5rem;font-size:.95rem;line-height:1.5}.member-stats{color:#1976d2;background:#fff;border:2px solid #1976d2;border-radius:6px;align-items:center;padding:.75rem 1.5rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.external-profile-link:hover{color:#fff;background:#1976d2;transform:translate(4px)}.member-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:2rem;display:grid}.stat-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:1.25rem}.stat-label{color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.875rem}.stat-value{color:#1976d2;font-size:1.5rem;font-weight:600}.tier-badge{text-transform:capitalize;border-radius:4px;padding:.5rem .75rem;font-size:.875rem;font-weight:600;display:inline-block}.tier-badge span{border-radius:4px;padding:.25rem .625rem;font-size:.875rem;font-weight:600;display:inline-block}.tier-badge-pupil{color:#1b5e20;background:#c8e6c9}.tier-badge-fixed-term-tenant{color:#856404;background:#fff3cd}.tier-badge-standard,.tier-badge-tenant{color:#0d47a1;background:#bbdefb}.tier-badge-door-tenant{color:#880e4f;background:#f8bbd0}.tier-badge-split-rent{color:#4a148c;background:#e1bee7}.tier-badge-special{color:#e65100;background:#ffe0b2}@media (width<=768px){.profile-header{flex-direction:column;gap:1rem}.profile-avatar{width:50px;height:50px}.profile-name{font-size:1.5rem}.member-stats{grid-template-columns:1fr}}.financial-matrix-container{background:#fff;border-radius:8px;margin-top:20px;padding:20px;box-shadow:0 1px 3px #0000001a}.financial-matrix-table{border-collapse:collapse;width:100%;font-size:.85rem}.financial-matrix-table th,.financial-matrix-table td{text-align:right;white-space:nowrap;border:1px solid #e0e0e0;padding:6px 8px}.financial-matrix-table th.category-col{text-align:left;z-index:10;background-color:#f8f9fa;min-width:250px;position:sticky;left:0}.financial-matrix-table td.category-cell{text-align:left}.financial-matrix-table .section-header td{text-align:left;color:#495057;text-transform:uppercase;letter-spacing:.5px;background-color:#f1f3f5;padding-top:15px;font-size:.8rem;font-weight:600}.financial-matrix-table .grand-total-row td{color:#212529;background-color:#e9ecef;border-top:2px solid #ced4da;font-weight:700}.amount-cell.negative{color:#c62828}.amount-cell.positive{color:#2e7d32}.table-responsive{max-width:100%;overflow-x:auto}.loading-spinner{text-align:center;color:#666;padding:40px}.error-message{color:#d32f2f;background-color:#ffebee;border-radius:4px;padding:20px}.member-fees-tab{padding:0}.fees-error{color:#dc2626;margin-bottom:1rem}.fy-period-label{color:#6b7280;margin:-.5rem 0 1rem;font-size:.875rem}.fees-filter-bar{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:.75rem 1rem;display:flex}.case-filter{align-items:center;gap:.5rem;display:flex}.case-filter-input{color:#111827;border:1px solid #d1d5db;border-radius:.375rem;width:200px;padding:.375rem .625rem;font-size:.875rem}.case-filter-input:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 2px #6366f133}.status-filter{align-items:center;gap:.5rem;display:flex}.status-filter-select{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:.375rem;padding:.375rem .625rem;font-size:.875rem}.month-filter{align-items:center;gap:.5rem;display:flex}.adjust-btn{white-space:nowrap}.fees-result-count{color:#6b7280;white-space:nowrap;margin-left:auto;font-size:.875rem}.fy-group{margin-bottom:2rem}.fy-header{color:#374151;background:#f3f4f6;border-left:4px solid #d1d5db;border-radius:0 .25rem .25rem 0;margin:0 0 1rem;padding:.5rem .75rem;font-size:1.1rem;font-weight:700}.fy-header.current-fy{color:#1e40af;background:#eff6ff;border-left-color:#3b82f6}.month-group{margin-bottom:1.5rem}.month-header{color:#374151;border-bottom:1px solid #e5e7eb;align-items:baseline;gap:.75rem;margin:0 0 .5rem;padding-bottom:.375rem;font-size:.95rem;font-weight:600;display:flex}.month-name{flex-shrink:0}.month-meta{color:#6b7280;font-size:.8125rem;font-weight:400}.member-fees-tab .fees-table{table-layout:fixed;width:100%}.member-fees-tab .fees-table .checkbox-col,.member-fees-tab .fees-table .checkbox-cell{width:40px}.member-fees-tab .fees-table .date-col{width:90px}.member-fees-tab .fees-table .client-col{width:100px}.member-fees-tab .fees-table .amount-col{width:105px}.member-fees-tab .fees-table .rate-col{width:75px}.member-fees-tab .fees-table .status-col{width:100px}.member-fees-tab .fees-table .invoice-col{width:105px}.chambers-fee-cell{color:#059669;font-weight:600}@media (width<=768px){.fees-filter-bar{flex-direction:column;align-items:flex-start}.fees-result-count{margin-left:0}.case-filter-input{width:100%}.month-header{flex-direction:column;gap:.25rem}}.fee-drawer-overlay{z-index:1100;background:#00000059;position:fixed;inset:0}.fee-drawer{z-index:1101;background:#fff;flex-direction:column;width:380px;max-width:95vw;animation:.22s fee-drawer-in;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-4px 0 24px #0000001f}@keyframes fee-drawer-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.fee-drawer-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.fee-drawer-header h2{color:#111827;margin:0;font-size:1.125rem}.fee-drawer-body{flex:1;padding:1.25rem 1.5rem;overflow-y:auto}.fee-drawer-fields{grid-template-columns:130px 1fr;gap:.625rem 1rem;margin:0;display:grid}.fee-drawer-fields dt{color:#6b7280;text-transform:uppercase;letter-spacing:.04em;word-break:keep-all;padding-top:.125rem;font-size:.8125rem;font-weight:600}.fee-drawer-fields dd{color:#111827;word-break:break-word;margin:0;font-size:.9375rem}.fee-drawer-amount{font-family:monospace;font-size:1rem!important}.fee-drawer-override-badge{color:#92400e;text-transform:uppercase;vertical-align:middle;background:#fef3c7;border-radius:.25rem;margin-left:.375rem;padding:.1rem .4rem;font-size:.7rem;font-weight:600;display:inline-block}.invoice-history-tab{padding:1.5rem 0}.invoice-history-header{align-items:baseline;gap:1rem;margin-bottom:1.25rem;display:flex}.invoice-history-header h2{margin:0;font-size:1.25rem;font-weight:600}.invoice-history-count{color:#6b7280;font-size:.875rem}.invoice-history-loading,.invoice-history-empty{text-align:center;color:#6b7280;padding:2rem}.invoice-history-error{color:#b91c1c;background:#fef2f2;border:1px solid #fca5a5;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.invoice-history-table-wrapper{overflow-x:auto}.invoice-history-table{border-collapse:collapse;width:100%;font-size:.875rem}.invoice-history-table th{text-align:left;color:#374151;white-space:nowrap;background:#f8fafc;border-bottom:2px solid #e2e8f0;padding:.6rem .75rem;font-weight:600}.invoice-history-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.55rem .75rem}.invoice-history-table tr:hover td{background:#f8fafc}.invoice-history-table th.currency,.invoice-history-table td.currency{text-align:right}.invoice-history-table td.strong{font-weight:600}.invoice-history-table td.invoice-number{color:#4b5563;font-family:monospace;font-size:.8rem}.status-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.status-published{color:#15803d;background:#dcfce7}.status-paid{color:#1d4ed8;background:#dbeafe}.status-draft{color:#854d0e;background:#fef9c3}.status-preview{color:#475569;background:#f1f5f9}.pdf-btn{white-space:nowrap;cursor:pointer;border-radius:4px;align-items:center;gap:.3rem;padding:.25rem .6rem;font-size:.8rem;font-weight:500;text-decoration:none;display:inline-flex}.pdf-btn--available{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.pdf-btn--available:hover{background:#dbeafe}.pdf-btn--restoring{color:#a16207;background:#fefce8;border:1px solid #fde68a}.pdf-btn--unavailable{color:#94a3b8;cursor:default;background:#f1f5f9;border:1px solid #e2e8f0}.restore-spinner{border:2px solid #fde68a;border-top-color:#a16207;border-radius:50%;width:10px;height:10px;animation:.8s linear infinite spin;display:inline-block}.invoice-history-pagination{justify-content:center;align-items:center;gap:1rem;padding:1.25rem 0 .5rem;display:flex}.page-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.4rem .9rem;font-size:.875rem;transition:background .15s}.page-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.page-btn:disabled{color:#94a3b8;cursor:default}.page-indicator{color:#6b7280;text-align:center;min-width:100px;font-size:.875rem}.member-detail-page{margin:0 auto;padding:2rem}.page-header{border-bottom:2px solid #e5e7eb;margin-bottom:2rem;padding-bottom:1rem;position:relative}.header-actions{position:absolute;top:0;right:0}.back-link{color:#2563eb;align-items:center;gap:.25rem;font-size:.95rem;text-decoration:none;transition:color .2s;display:inline-flex}.back-link:hover{color:#1d4ed8;text-decoration:underline}.page-header h1{color:#111827;margin:0 0 .5rem;font-size:2rem}.member-code-badge{color:#1e40af;background-color:#dbeafe;border-radius:.375rem;padding:.25rem .75rem;font-family:monospace;font-size:.875rem;font-weight:600;display:inline-block}.member-dept-badge{color:#5b21b6;background-color:#ede9fe;border-radius:.375rem;margin-left:.5rem;padding:.25rem .75rem;font-family:monospace;font-size:.875rem;font-weight:600;display:inline-block}.form-control-badge-row{align-items:center;gap:.75rem;display:flex}.form-control-badge-row .form-control-disabled{flex:1}.form-control-badge-row .member-dept-badge{white-space:nowrap;margin-left:0}.reference-section{background-color:#f8fafc}.reference-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.reference-item{margin-bottom:0}@media (width<=720px){.reference-grid{grid-template-columns:1fr}}.loading-spinner{text-align:center;color:#6b7280;padding:3rem;font-size:1.1rem}.success-message{color:#065f46;background-color:#d1fae5;border:1px solid #6ee7b7;border-radius:.375rem;margin-bottom:1.5rem;padding:.75rem 1rem;font-weight:500}.error-message{color:#991b1b;background-color:#fee2e2;border:1px solid #fca5a5;border-radius:.375rem;margin-bottom:1.5rem;padding:.75rem 1rem}.member-form{background-color:#fff;border-radius:.5rem;padding:2rem;box-shadow:0 1px 3px #0000001a}.form-section{border-bottom:1px solid #e5e7eb;margin-bottom:2.5rem;padding-bottom:2rem}.form-section:last-of-type{border-bottom:none;margin-bottom:2rem}.form-section h2{color:#374151;margin-bottom:1.5rem;font-size:1.25rem;font-weight:600}.form-group{margin-bottom:1.5rem}.form-group label{color:#374151;margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.form-control{border:1px solid #d1d5db;border-radius:.375rem;width:100%;padding:.625rem .75rem;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-control:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-control-disabled{color:#6b7280;cursor:not-allowed;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;width:100%;padding:.625rem .75rem;font-size:1rem}.form-help{color:#6b7280;margin-top:.375rem;font-size:.875rem;font-style:italic;display:block}.checkbox-group{flex-direction:column;display:flex}.checkbox-label{cursor:pointer;color:#374151;align-items:center;gap:.5rem;font-weight:500;display:flex}.form-checkbox{cursor:pointer;accent-color:#2563eb;width:1.25rem;height:1.25rem}.form-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.btn-primary{color:#fff;cursor:pointer;background-color:#2563eb;border:none;border-radius:.375rem;padding:.625rem 1.5rem;font-size:1rem;font-weight:500;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-primary:disabled{cursor:not-allowed;background-color:#9ca3af}.btn-secondary{color:#374151;cursor:pointer;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;padding:.625rem 1.5rem;font-size:1rem;font-weight:500;transition:background-color .2s,border-color .2s}.btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.metadata-section{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;margin-top:3rem;padding:1.5rem}.metadata-section h3{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem;font-size:1rem;font-weight:600}.metadata-list{grid-template-columns:auto 1fr;gap:.5rem 1.5rem;font-size:.95rem;display:grid}.metadata-list dt{color:#6b7280;font-weight:500}.metadata-list dd{color:#374151;margin:0;font-family:monospace}@media (width<=640px){.member-detail-page{padding:1rem}.member-form{padding:1.5rem}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.tabs{border-bottom:2px solid #e5e7eb;gap:.5rem;margin-bottom:2rem;display:flex}.tab{cursor:pointer;color:#6b7280;background:0 0;border:none;border-bottom:3px solid #0000;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s}.tab:hover{color:#111827;background-color:#f9fafb}.tab.active{color:#2563eb;border-bottom-color:#2563eb}.fees-section{margin-top:2rem}.fees-summary{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:2rem;padding:1.5rem}.fees-summary h2{color:#111827;margin-top:0;margin-bottom:1rem;font-size:1.25rem}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.summary-item{flex-direction:column;gap:.25rem;display:flex}.summary-item label{color:#6b7280;font-size:.875rem;font-weight:500}.summary-value.chambers-fee{color:#059669}.fees-list h2{color:#111827;margin-bottom:1rem;font-size:1.25rem}.fees-table{border-collapse:collapse;table-layout:auto;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;overflow:hidden}.fees-table thead{background-color:#f9fafb}.fees-table th{text-align:left;color:#374151;border-bottom:1px solid #e5e7eb;padding:.75rem 1rem;font-size:.875rem;font-weight:600}.fees-table td{color:#111827;border-bottom:1px solid #f3f4f6;padding:.75rem 1rem;font-size:.875rem}.fees-table tbody tr:last-child td{border-bottom:none}.fees-table .case-title{text-overflow:ellipsis;white-space:nowrap;max-width:300px;overflow:hidden}.fees-table .solicitor-code{text-overflow:ellipsis;white-space:nowrap;max-width:100px;overflow:hidden}.fees-table .case-ref{color:#6c757d;font-size:.85em}.fees-table .currency{text-align:right;white-space:nowrap;width:1%;font-family:monospace}.fees-table th.currency{text-align:right}.fees-table .percentage{text-align:center;white-space:nowrap;width:1%}.fees-table th.percentage{text-align:center}.fees-table .chambers-fee{color:#059669;font-weight:600}.no-data{text-align:center;color:#6b7280;padding:3rem;font-style:italic}.fees-list-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.fees-list-header h2{margin:0}.bulk-actions{align-items:center;gap:.5rem;display:flex}.checkbox-col{text-align:center;width:40px}.fees-table tbody tr.selected{background-color:#eff6ff}.fees-table tbody tr.selected:hover{background-color:#dbeafe}.modal-content{background-color:#fff;border-radius:.5rem;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;font-size:1.5rem;transition:background-color .2s;display:flex}.modal-close:hover{color:#111827;background-color:#f3f4f6}.modal-body p{color:#374151;margin-bottom:1rem}.modal-body .help-text{color:#6b7280;font-size:.875rem;font-style:italic}.modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:.5rem;padding:1.5rem;display:flex}@media (width<=768px){.fees-list-header{flex-direction:column;align-items:flex-start;gap:1rem}.bulk-actions{flex-direction:column;width:100%}.bulk-actions button{width:100%}.summary-grid{grid-template-columns:1fr}.fees-table{font-size:.8125rem}.fees-table th,.fees-table td{padding:.5rem}.fees-table .case-title{max-width:150px}.modal-content{width:95%}}.invoices-tab{background:#fff;border-radius:8px;min-height:400px;box-shadow:0 1px 3px #0000001a}.parental-leave-tab{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.parental-leave-tab h2{color:#111827;margin-top:0;margin-bottom:1.5rem;font-size:1.5rem}.parental-leave-list{flex-direction:column;gap:1.5rem;display:flex}.parental-leave-period{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem}.period-header{border-bottom:2px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.period-header h3{color:#374151;margin:0;font-size:1.125rem}.status-badge{text-transform:uppercase;border-radius:.375rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.status-active{color:#1e40af;background-color:#dbeafe}.status-completed{color:#065f46;background-color:#d1fae5}.status-calculated{color:#4338ca;background-color:#e0e7ff}.status-posted{color:#065f46;background-color:#d1fae5}.status-reversed{color:#991b1b;background-color:#fee2e2}.status-imported{color:#374151;background-color:#f3f4f6}.status-pending{color:#92400e;background-color:#fef3c7}.status-approved{color:#1e40af;background-color:#dbeafe}.status-invoiced{color:#065f46;background-color:#d1fae5}.status-excluded{color:#991b1b;background-color:#fee2e2}.period-details{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.detail-row{border-bottom:1px solid #e5e7eb;justify-content:space-between;padding:.5rem 0;display:flex}.detail-row:last-child{border-bottom:none}.detail-row .label{color:#6b7280;font-weight:600}.detail-row .value{color:#111827}.detail-row .value.currency{font-family:monospace;font-weight:500}.detail-row .value.currency.negative{color:#dc2626}.detail-row .value.currency.strong{font-size:1.05rem;font-weight:700}.detail-row.notes{flex-direction:column;gap:.25rem}.detail-row.notes .value{color:#6b7280;font-style:italic}.credits-section{border-top:2px solid #e5e7eb;margin-top:1.5rem;padding-top:1.5rem}.credits-section h4{color:#374151;margin-top:0;margin-bottom:1rem;font-size:1rem}.credits-table{border-collapse:collapse;background:#fff;border-radius:6px;width:100%;overflow:hidden;box-shadow:0 1px 3px #0000001a}.credits-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.credits-table th{text-align:left;color:#374151;text-transform:uppercase;letter-spacing:.025em;padding:.75rem;font-size:.875rem;font-weight:600}.credits-table tbody tr{border-bottom:1px solid #f3f4f6}.credits-table tbody tr:last-child{border-bottom:none}.credits-table tbody tr:hover{background-color:#f9fafb}.credits-table td{color:#111827;padding:.75rem}.credits-table td.currency{text-align:right;white-space:nowrap;width:1%;font-family:monospace;font-weight:500}.credits-table th.currency{text-align:right}.credits-table td.currency.negative{color:#dc2626}.credits-table td.currency.strong{font-weight:700}.tier-history-table{border-collapse:collapse;width:100%;font-size:.875rem}.tier-history-table th,.tier-history-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:.5rem .75rem}.tier-history-table th{color:#6b7280;text-transform:uppercase;letter-spacing:.4px;font-size:.75rem;font-weight:600}.tier-history-table tr.tier-current td{color:#111827;font-weight:600}.tier-open{color:#059669;font-style:italic}.fees-page{--app-sticky-header-height:64px;--fees-selection-bar-height:0px;max-width:1600px;margin:0 auto;padding:2rem}.fees-page.selection-active{--fees-selection-bar-height:72px}.fees-header{gap:1rem;margin-bottom:1.5rem}.fees-header-top{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.fees-title-block{align-items:center;min-height:44px;display:flex}.fees-header h1{color:#2c3e50;margin:0;font-size:2rem}.fees-primary-controls,.fees-period-controls,.fees-secondary-actions,.fees-filter-strip,.fees-filter-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.fees-primary-controls,.fees-period-controls,.fees-secondary-actions{justify-content:flex-end}.fees-filter-strip{margin-top:.25rem}.fees-filter-trigger{display:none}.rate-filter{background:#f9fbfd;border:1px solid #e1e5ea;border-radius:6px;align-items:center;gap:.5rem;padding:.4rem .6rem;display:flex}.filter-label{color:#6c757d;text-transform:uppercase;letter-spacing:.3px;font-size:.8rem}.rate-filter-options{flex-wrap:wrap;gap:.5rem;display:flex}.rate-filter-option{color:#495057;align-items:center;gap:.3rem;font-size:.85rem;display:inline-flex}.rate-filter-option input{margin:0}.clear-rate-btn{color:#6c757d;cursor:pointer;background:#fff;border:1px solid #d1d8e0;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:1rem;line-height:1;transition:all .15s;display:inline-flex}.clear-rate-btn:hover:not(:disabled){color:#3498db;background:#f4f8fb;border-color:#3498db}.clear-rate-btn:disabled{opacity:.45;cursor:not-allowed;background:#f8f9fa}.muted-text{color:#adb5bd;font-size:.85rem}.period-select,.status-select{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;min-width:150px;padding:.5rem 1rem;font-size:.9rem}.period-select:focus,.status-select:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 2px #3498db1a}.search-input{border:1px solid #ddd;border-radius:4px;width:280px;padding:.5rem 1rem;font-size:.9rem}.search-input:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 2px #3498db1a}.filter-inputs{gap:.5rem;display:flex}.filter-input-group{align-items:center;display:flex;position:relative}.filter-input{border:1px solid #ddd;border-radius:4px;width:185px;padding:.5rem 1.75rem .5rem .75rem;font-size:.9rem}.filter-input:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 2px #3498db1a}.filter-clear-btn{cursor:pointer;color:#999;background:0 0;border:none;padding:0 .2rem;font-size:1rem;line-height:1;position:absolute;right:.4rem}.filter-clear-btn:hover{color:#333}.col-filter-wrap{vertical-align:middle;align-items:center;margin-left:.3rem;display:inline-flex;position:relative}.col-filter-btn{cursor:pointer;color:#888;background:0 0;border:1px solid #0000;border-radius:3px;padding:0 .2rem;font-size:.75rem;line-height:1}.col-filter-btn:hover,.col-filter-btn.active{color:#3498db;border-color:#3498db}.col-filter-btn.active{background-color:#3498db1a}.col-filter-dropdown{z-index:90;background:#fff;border:1px solid #ddd;border-radius:4px;min-width:200px;max-height:280px;padding:.35rem 0;position:absolute;top:100%;left:0;overflow-y:auto;box-shadow:0 4px 12px #0000001f}.col-filter-search{box-sizing:border-box;border:1px solid #ddd;border-radius:3px;outline:none;width:calc(100% - 1rem);margin:.35rem .5rem .25rem;padding:.25rem .5rem;font-size:.8rem;display:block}.col-filter-search:focus{border-color:#3498db}.col-filter-clear{cursor:pointer;text-align:left;color:#e74c3c;background:0 0;border:1px solid #ddd;border-radius:3px;width:calc(100% - 1rem);margin:.25rem .5rem;padding:.2rem .5rem;font-size:.8rem;display:block}.col-filter-clear:hover{background-color:#fef0f0}.col-filter-item{cursor:pointer;white-space:nowrap;align-items:center;gap:.4rem;padding:.3rem .75rem;font-size:.85rem;font-weight:400;display:flex}.col-filter-item:hover{background-color:#f5f5f5}.col-filter-item input[type=checkbox]{cursor:pointer;margin:0}.col-filter-code{color:#999;margin-left:auto;font-size:.75rem}.refresh-btn{color:#fff;cursor:pointer;background-color:#3498db;border:none;border-radius:4px;padding:.5rem 1.5rem;font-size:.9rem;transition:background-color .2s}.refresh-btn:hover{background-color:#2980b9}.set-rate-btn{color:#fff;cursor:pointer;background-color:#27ae60;border:none;border-radius:4px;padding:.5rem 1.25rem;font-size:.9rem;font-weight:500;transition:background-color .2s}.set-rate-btn:hover{background-color:#219a52}.fees-selection-bar{top:var(--app-sticky-header-height);z-index:60;min-height:var(--fees-selection-bar-height);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f8fcf9f5;border:1px solid #d8e6dd;border-radius:10px;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem;padding:.85rem 1rem;display:flex;position:sticky;box-shadow:0 8px 18px #27ae6014}.fees-selection-bar__summary{flex:1;min-width:0}.fees-selection-bar__actions{flex-shrink:0}.selection-note{color:#2f4858;font-size:.95rem}.selection-note .link-btn{color:#1d6fa5;cursor:pointer;font:inherit;background:0 0;border:none;margin-left:.4rem;padding:0}.selection-note .link-btn:hover{text-decoration:underline}.fees-summary{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.fees-summary--filtered{background-color:#fffbeb;border-color:#fcd34d}.summary-filter-badge{color:#92400e;align-items:center;gap:.35rem;font-size:.75rem;font-weight:500;display:flex}.summary-cards-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;display:grid}.summary-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:1.25rem;box-shadow:0 2px 4px #00000014}.summary-label{color:#6c757d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.85rem}.summary-value{color:#2c3e50;font-size:1.5rem;font-weight:600}.summary-value.highlight{color:#27ae60}.fees-stats-row{justify-content:flex-end;align-items:center;margin-bottom:.5rem;display:flex}.fees-stats{text-align:right;color:#7f8c8d;white-space:nowrap;font-size:.9rem}.fees-stats p{margin:0}.clickable-filter{cursor:pointer}.clickable-filter:hover{color:#3498db;text-decoration:underline}.filter-cell-btn{color:#adb5bd;cursor:pointer;vertical-align:middle;opacity:0;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;width:18px;height:18px;margin-left:4px;padding:0;font-size:.75rem;transition:opacity .15s;display:inline-flex}.member-cell:hover .filter-cell-btn{opacity:1}.filter-cell-btn:hover{color:#3498db;background:#eaf4fb}.fees-table-container{background:#fff;border-radius:8px;min-height:200px;max-height:65vh;position:relative;overflow:auto;box-shadow:0 2px 4px #0000001a}.fees-table-container .fees-table{border:none;border-radius:0;overflow:visible}.table-refresh-overlay{z-index:2;background:#fff9;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.fees-table{border-collapse:collapse;table-layout:auto;width:100%;font-size:.875rem}.fees-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.fees-table th{z-index:20;text-align:left;color:#495057;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;background-color:#f8f9fa;padding:.875rem .75rem;font-size:.75rem;font-weight:600;position:sticky;top:0;box-shadow:inset 0 -2px #dee2e6}.fees-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.fees-table th.sortable:hover{background-color:#e9ecef}.fees-table th.checkbox-col,.fees-table td.checkbox-cell{text-align:center;width:40px;padding-left:.5rem;padding-right:.25rem}.fees-table th.checkbox-col{z-index:21}.fees-table input[type=checkbox]{cursor:pointer;width:16px;height:16px}.fees-table tbody tr{cursor:pointer}.fees-table tbody tr td.checkbox-cell,.fees-table tbody tr td.date-cell,.fees-table tbody tr td.member-cell,.fees-table tbody tr td.client-cell{cursor:default}.fees-table tbody tr.selected-row{background-color:#e8f4fd}.fees-table tbody tr.selected-row:hover{background-color:#d4ebfc}.fees-table th.amount-col,.fees-table th.rate-col{text-align:right}.fees-table td.amount-col,.fees-table td.rate-col{text-align:right;white-space:nowrap;width:1%;font-family:monospace}.fees-table th.description-col{min-width:200px}.fees-table tbody tr{border-bottom:1px solid #dee2e6;transition:background-color .2s}.fees-table tbody tr:hover{background-color:#f8f9fa}.fees-table td{vertical-align:middle;padding:.75rem}.period-cell{color:#495057;white-space:nowrap;font-weight:500}.date-cell{color:#6c757d;white-space:nowrap}.member-cell{display:block}.member-link{color:#3498db;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.35rem;padding:0;font-size:.875rem;font-weight:500;display:inline-flex}.member-link:hover{color:#2980b9;text-decoration:underline}.member-name{display:inline}.barrister-code{color:#95a5a6;font-family:monospace;font-size:.75rem}.member-link .barrister-code{display:none}.invoice-cell{color:#495057;font-family:monospace;font-size:.8rem}.client-cell{color:#495057;font-size:.85rem}.client-cell .case-ref{color:#6c757d;font-size:.8rem}.description-cell{color:#6c757d;text-overflow:ellipsis;white-space:nowrap;max-width:250px;overflow:hidden}.amount-cell{text-align:right;white-space:nowrap;font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.85rem}.amount-cell.highlight{color:#27ae60;font-weight:600}.rate-cell{text-align:right;white-space:nowrap}.rate-value{font-weight:600;display:inline-block}.rate-source-override{color:#d35400}.rate-source-member{color:#1f78c7}.rate-source-history{color:#8e44ad}.rate-source-default{color:#6c757d}.source-cell,.status-cell{text-align:center}.badge{text-transform:uppercase;letter-spacing:.3px;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.badge-override{color:#fff;background-color:#f39c12}.badge-member{color:#fff;background-color:#3498db}.badge-default{color:#2c3e50;background-color:#bdc3c7}.badge-success{color:#fff;background-color:#27ae60}.badge-info{color:#fff;background-color:#17a2b8}.badge-warning{color:#fff;background-color:#f39c12}.badge-secondary{color:#fff;background-color:#95a5a6}.expense-col{width:1.5rem;min-width:1.5rem;padding:0 .25rem!important}.expense-cell{text-align:center;width:1.5rem;min-width:1.5rem;padding:0 .25rem!important}.expense-badge{color:#fff;cursor:help;background-color:#7f8c8d;border-radius:3px;padding:.15rem .35rem;font-size:.65rem;font-weight:600;display:inline-block}.source-badge{border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.source-lex_payment{color:#fff;background-color:#9b59b6}.source-fee_income_historical{color:#fff;background-color:#7f8c8d}.source-manual{color:#fff;background-color:#1abc9c}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem;display:flex}.page-size-selector{align-items:center;gap:.5rem;display:flex}.page-size-label{color:#6c757d;font-size:.9rem}.page-size-select{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;padding:.4rem .6rem;font-size:.875rem;transition:border-color .2s}.page-size-select:hover{border-color:#3498db}.page-size-select:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 2px #3498db1a}.page-controls{align-items:center;gap:1rem;display:flex}.page-btn{color:#fff;cursor:pointer;background-color:#3498db;border:none;border-radius:4px;padding:.5rem 1rem;font-size:.875rem;transition:background-color .2s}.page-btn:hover:not(:disabled){background-color:#2980b9}.page-btn:disabled{cursor:not-allowed;background-color:#bdc3c7}.page-info{color:#6c757d;font-size:.9rem}.loading{justify-content:center;align-items:center;min-height:300px;display:flex}.error{text-align:center;background:#fff5f5;border:1px solid #feb2b2;border-radius:8px;padding:3rem}.error h2{color:#c53030;margin-bottom:.5rem}.error p{color:#742a2a;margin-bottom:1rem}.retry-btn{color:#fff;cursor:pointer;background-color:#e53e3e;border:none;border-radius:4px;padding:.5rem 1.5rem;font-size:.9rem}.retry-btn:hover{background-color:#c53030}.no-results{text-align:center;color:#6c757d;padding:2rem}.fees-filter-controls.in-drawer{flex-direction:column;align-items:stretch}.fees-filter-controls.in-drawer .status-select,.fees-filter-controls.in-drawer .rate-filter,.fees-filter-controls.in-drawer .filter-inputs,.fees-filter-controls.in-drawer .filter-input-group,.fees-filter-controls.in-drawer .filter-input{width:100%}.fees-filter-controls.in-drawer .filter-inputs{flex-direction:column}.fees-filter-controls.in-drawer .rate-filter{align-items:flex-start}@media (width<=1200px){.fees-page{padding:1rem}.fees-header-top,.fees-primary-controls{flex-direction:column;align-items:stretch}.fees-primary-controls,.fees-period-controls,.fees-secondary-actions{justify-content:space-between;width:100%}.fees-filter-strip{display:none}.fees-filter-trigger{display:inline-flex}.fees-selection-bar{padding:.75rem .9rem}}@media (width<=768px){.summary-value{font-size:1.25rem}.summary-cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.fees-period-controls,.fees-secondary-actions,.fees-selection-bar{flex-direction:column;align-items:stretch}.period-select,.status-select,.refresh-btn,.filter-input,.set-rate-btn{width:100%}.fees-stats-row{justify-content:flex-start}.fees-stats{text-align:left;white-space:normal}}@media (width<=640px){.summary-cards-grid{grid-template-columns:1fr}.member-link .member-name{display:none}.member-link .barrister-code{display:inline}}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:8px;width:100%;max-width:480px;animation:.2s ease-out modalSlideIn;box-shadow:0 4px 20px #0003}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid #e9ecef;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h2{color:#2c3e50;margin:0;font-size:1.25rem}.modal-close{color:#6c757d;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.modal-close:hover{color:#2c3e50}.modal-body{padding:1.5rem}.modal-info{color:#495057;margin:0 0 1.25rem}.rate-options{flex-direction:column;gap:.75rem;display:flex}.rate-option{cursor:pointer;border:1px solid #e9ecef;border-radius:6px;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem;transition:all .2s;display:flex}.rate-option-left{align-items:center;gap:.5rem;display:flex}.rate-calc-preview{color:#6c757d;font-variant-numeric:tabular-nums;white-space:nowrap;margin-left:auto;padding-left:1rem;font-size:.85rem}.rate-option:hover{background-color:#f8f9fa;border-color:#3498db}.rate-option input[type=radio]{margin:0}.rate-option input[type=radio]:checked+span{color:#3498db;font-weight:500}.custom-rate-input{border:1px solid #ddd;border-radius:4px;width:80px;margin-left:.5rem;padding:.375rem .5rem;font-size:.9rem}.custom-rate-input:focus{border-color:#3498db;outline:none}.custom-rate-input:disabled{color:#adb5bd;background-color:#f8f9fa}.custom-rate-input--readonly{color:#495057;cursor:default;background-color:#f8f9fa}.rate-direction-toggle{cursor:pointer;color:#6c757d;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:.85rem;line-height:1;transition:color .15s,background-color .15s}.rate-direction-toggle:hover:not(:disabled){color:#3498db;background-color:#e8f4fd}.rate-direction-toggle:disabled{opacity:.35;cursor:default}.custom-amount-input{text-align:right;font-variant-numeric:tabular-nums;border:1px solid #3498db;border-radius:4px;width:100px;padding:.375rem .5rem;font-size:.9rem}.custom-amount-input:focus{outline:none;box-shadow:0 0 0 2px #3498db26}.reason-field{margin-top:1.25rem}.reason-field label{color:#495057;margin-bottom:.5rem;font-size:.9rem;display:block}.reason-input{border:1px solid #ddd;border-radius:4px;width:100%;padding:.625rem .75rem;font-size:.9rem}.reason-input:focus{border-color:#3498db;outline:none}.modal-footer{background-color:#f8f9fa;border-top:1px solid #e9ecef;border-radius:0 0 8px 8px;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.cancel-btn{color:#495057;cursor:pointer;background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:.625rem 1.25rem;font-size:.9rem;transition:all .2s}.cancel-btn:hover:not(:disabled){background-color:#f8f9fa;border-color:#adb5bd}.apply-btn{color:#fff;cursor:pointer;background-color:#27ae60;border:none;border-radius:4px;padding:.625rem 1.5rem;font-size:.9rem;font-weight:500;transition:background-color .2s}.apply-btn:hover:not(:disabled){background-color:#219a52}.apply-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.pending-page{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.pending-container{background:#fff;border-radius:8px;width:100%;max-width:550px;overflow:hidden;box-shadow:0 10px 40px #0003}.pending-header{color:#fff;text-align:center;background-color:#2c3e50;padding:40px 30px}.pending-header h1{margin-bottom:10px;font-size:32px}.pending-header p{color:#bdc3c7;font-size:14px}.pending-content{text-align:center;padding:40px 30px}.pending-icon{color:#f39c12;margin-bottom:20px}.pending-content h2{color:#2c3e50;margin-bottom:20px}.pending-message{color:#555;margin-bottom:15px;font-size:16px;line-height:1.6}.pending-info{text-align:left;background-color:#f8f9fa;border-radius:8px;margin:25px 0;padding:20px}.pending-info h3{color:#2c3e50;margin-bottom:15px;font-size:16px}.pending-info ul{margin:0;padding:0;list-style:none}.pending-info li{color:#555;padding:8px 0 8px 28px;font-size:14px;position:relative}.pending-info li:before{content:"✓";color:#27ae60;font-weight:700;position:absolute;left:0}.pending-contact{border-top:1px solid #ecf0f1;margin-top:20px;padding-top:20px}.pending-contact p{color:#7f8c8d;font-size:13px}.signout-btn{color:#fff;cursor:pointer;background-color:#95a5a6;border:none;border-radius:4px;margin-top:25px;padding:12px 30px;font-size:14px;font-weight:600;transition:background-color .2s}.signout-btn:hover{background-color:#7f8c8d}.signout-btn:active{background-color:#6d7b8d}.app-container{flex-direction:column;min-height:100vh;display:flex}.loading-container{justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:4px solid #f3f3f3;border-top-color:#3498db;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.splash-container{background:#f0f2f5;flex-direction:column;gap:16px}.splash-logo{opacity:.9;width:200px;height:auto}.splash-version{color:#bbb;letter-spacing:.06em;margin:0;font-size:12px}.splash-spinner{border-width:3px;width:24px;height:24px}.error-container{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.error-message{color:#c33;background-color:#fee;border:1px solid #fcc;border-radius:4px;max-width:600px;padding:20px}
