.d-flex{display:flex}.d-flex-wrap{display:flex;flex-wrap:wrap}.d-inline-flex{display:inline-flex}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-end{justify-content:flex-end}.align-center{align-items:center}.align-bottom{align-items:flex-end}.d-flex-between{display:flex;justify-content:space-between}.d-flex-center{display:flex;align-items:center}.d-flex-start{display:flex;align-items:flex-start}.d-flex-end{display:flex;align-items:flex-end}.d-flex-center-between{display:flex;align-items:center;justify-content:space-between}.d-flex-center2{display:flex;align-items:center;justify-content:center}.d-flex-column{display:flex;flex-direction:column}.grow-1{flex-grow:1;align-items:flex-end}.m-top-0px{margin-top:0}.m-bottom-0px{margin-bottom:0}.m-right-0px{margin-right:0}.m-left-0px{margin-left:0}.m-top-5px{margin-top:5px}.m-bottom-5px{margin-bottom:5px}.m-right-5px{margin-right:5px}.m-left-5px{margin-left:5px}.m-top-10px{margin-top:10px}.m-bottom-10px{margin-bottom:10px}.m-right-10px{margin-right:10px}.m-left-10px{margin-left:10px}.m-top-12px{margin-top:12px}.m-bottom-12px{margin-bottom:12px}.m-right-12px{margin-right:12px}.m-left-12px{margin-left:12px}.m-top-15px{margin-top:15px}.m-bottom-15px{margin-bottom:15px}.m-right-15px{margin-right:15px}.m-left-15px{margin-left:15px}.m-top-20px{margin-top:20px}.m-bottom-20px{margin-bottom:20px}.m-right-20px{margin-right:20px}.m-left-20px{margin-left:20px}.m-top-25px{margin-top:25px}.m-bottom-25px{margin-bottom:25px}.m-right-25px{margin-right:25px}.m-left-25px{margin-left:25px}.m-top-30px{margin-top:30px}.m-bottom-30px{margin-bottom:30px}.m-right-30px{margin-right:30px}.m-left-30px{margin-left:30px}.m-top-40px{margin-top:40px}.m-bottom-40px{margin-bottom:40px}.m-right-40px{margin-right:40px}.m-left-40px{margin-left:40px}.m-top-50px{margin-top:50px}.m-bottom-50px{margin-bottom:50px}.m-right-50px{margin-right:50px}.m-left-50px{margin-left:50px}.m-top-60px{margin-top:60px}.m-bottom-60px{margin-bottom:60px}.m-right-60px{margin-right:60px}.m-left-60px{margin-left:60px}.m-top-100px{margin-top:100px}.m-bottom-100px{margin-bottom:100px}.m-right-100px{margin-right:100px}.m-left-100px{margin-left:100px}.m-left-auto{margin-left:auto}.m-right-auto{margin-right:auto}.p-0{padding:0}.p-right-0{padding-right:0}.p-left-0{padding-left:0}.p-top-0{padding-top:0}.p-bottom-0{padding-bottom:0}.p-5px{padding:5px}.p-right-5px{padding-right:5px}.p-left-5px{padding-left:5px}.p-top-5px{padding-top:5px}.p-bottom-5px{padding-bottom:5px}.p-10px{padding:10px}.p-right-10px{padding-right:10px}.p-left-10px{padding-left:10px}.p-top-10px{padding-top:10px}.p-bottom-10px{padding-bottom:10px}.p-15px{padding:15px}.p-right-15px{padding-right:15px}.p-left-15px{padding-left:15px}.p-top-15px{padding-top:15px}.p-bottom-15px{padding-bottom:15px}.p-20px{padding:20px}.p-right-20px{padding-right:20px}.p-left-20px{padding-left:20px}.p-top-20px{padding-top:20px}.p-bottom-20px{padding-bottom:20px}.p-25px{padding:25px}.p-right-25px{padding-right:25px}.p-left-25px{padding-left:25px}.p-top-25px{padding-top:25px}.p-bottom-25px{padding-bottom:25px}.p-30px{padding:30px}.p-right-30px{padding-right:30px}.p-left-30px{padding-left:30px}.p-top-30px{padding-top:30px}.p-bottom-30px{padding-bottom:30px}html{height:100%;--mat-sys-background: light-dark(#f9faf3, #121410);--mat-sys-error: light-dark(#ba1a1a, #ffb4ab);--mat-sys-error-container: light-dark(#ffdad6, #93000a);--mat-sys-inverse-on-surface: light-dark(#f1f1eb, #2f312d);--mat-sys-inverse-primary: light-dark(#02e600, #026e00);--mat-sys-inverse-surface: light-dark(#2f312d, #e2e3dc);--mat-sys-on-background: light-dark(#1a1c18, #e2e3dc);--mat-sys-on-error: light-dark(#ffffff, #690005);--mat-sys-on-error-container: light-dark(#93000a, #ffdad6);--mat-sys-on-primary: light-dark(#ffffff, #013a00);--mat-sys-on-primary-container: light-dark(#015300, #77ff61);--mat-sys-on-primary-fixed: light-dark(#002200, #002200);--mat-sys-on-primary-fixed-variant: light-dark(#015300, #015300);--mat-sys-on-secondary: light-dark(#ffffff, #263422);--mat-sys-on-secondary-container: light-dark(#3c4b37, #d7e8cd);--mat-sys-on-secondary-fixed: light-dark(#121f0e, #121f0e);--mat-sys-on-secondary-fixed-variant: light-dark(#3c4b37, #3c4b37);--mat-sys-on-surface: light-dark(#1a1c18, #e2e3dc);--mat-sys-on-surface-variant: light-dark(#43483f, #dfe4d7);--mat-sys-on-tertiary: light-dark(#ffffff, #003737);--mat-sys-on-tertiary-container: light-dark(#004f4f, #00fbfb);--mat-sys-on-tertiary-fixed: light-dark(#002020, #002020);--mat-sys-on-tertiary-fixed-variant: light-dark(#004f4f, #004f4f);--mat-sys-outline: light-dark(#73796e, #8d9387);--mat-sys-outline-variant: light-dark(#c3c8bc, #43483f);--mat-sys-primary: light-dark(#026e00, #02e600);--mat-sys-primary-container: light-dark(#77ff61, #015300);--mat-sys-primary-fixed: light-dark(#77ff61, #77ff61);--mat-sys-primary-fixed-dim: light-dark(#02e600, #02e600);--mat-sys-scrim: light-dark(#000000, #000000);--mat-sys-secondary: light-dark(#54634d, #bbcbb2);--mat-sys-secondary-container: light-dark(#d7e8cd, #3c4b37);--mat-sys-secondary-fixed: light-dark(#d7e8cd, #d7e8cd);--mat-sys-secondary-fixed-dim: light-dark(#bbcbb2, #bbcbb2);--mat-sys-shadow: light-dark(#000000, #000000);--mat-sys-surface: light-dark(#f9faf3, #121410);--mat-sys-surface-bright: light-dark(#f9faf3, #383a35);--mat-sys-surface-container: light-dark(#eeeee7, #1e201c);--mat-sys-surface-container-high: light-dark(#e8e9e1, #282b26);--mat-sys-surface-container-highest: light-dark(#e2e3dc, #333531);--mat-sys-surface-container-low: light-dark(#f3f4ed, #1a1c18);--mat-sys-surface-container-lowest: light-dark(#ffffff, #0c0f0b);--mat-sys-surface-dim: light-dark(#dadbd3, #121410);--mat-sys-surface-tint: light-dark(#026e00, #02e600);--mat-sys-surface-variant: light-dark(#dfe4d7, #43483f);--mat-sys-tertiary: light-dark(#006a6a, #00dddd);--mat-sys-tertiary-container: light-dark(#00fbfb, #004f4f);--mat-sys-tertiary-fixed: light-dark(#00fbfb, #00fbfb);--mat-sys-tertiary-fixed-dim: light-dark(#00dddd, #00dddd);--mat-sys-neutral-variant20: #2c3229;--mat-sys-neutral10: #1a1c18;--mat-sys-level0: 0px 0px 0px 0px rgba(0, 0, 0, .2), 0px 0px 0px 0px rgba(0, 0, 0, .14), 0px 0px 0px 0px rgba(0, 0, 0, .12);--mat-sys-level1: 0px 2px 1px -1px rgba(0, 0, 0, .2), 0px 1px 1px 0px rgba(0, 0, 0, .14), 0px 1px 3px 0px rgba(0, 0, 0, .12);--mat-sys-level2: 0px 3px 3px -2px rgba(0, 0, 0, .2), 0px 3px 4px 0px rgba(0, 0, 0, .14), 0px 1px 8px 0px rgba(0, 0, 0, .12);--mat-sys-level3: 0px 3px 5px -1px rgba(0, 0, 0, .2), 0px 6px 10px 0px rgba(0, 0, 0, .14), 0px 1px 18px 0px rgba(0, 0, 0, .12);--mat-sys-level4: 0px 5px 5px -3px rgba(0, 0, 0, .2), 0px 8px 10px 1px rgba(0, 0, 0, .14), 0px 3px 14px 2px rgba(0, 0, 0, .12);--mat-sys-level5: 0px 7px 8px -4px rgba(0, 0, 0, .2), 0px 12px 17px 2px rgba(0, 0, 0, .14), 0px 5px 22px 4px rgba(0, 0, 0, .12);--mat-sys-body-large: 400 1rem / 1.5rem Roboto;--mat-sys-body-large-font: Roboto;--mat-sys-body-large-line-height: 1.5rem;--mat-sys-body-large-size: 1rem;--mat-sys-body-large-tracking: .031rem;--mat-sys-body-large-weight: 400;--mat-sys-body-medium: 400 .875rem / 1.25rem Roboto;--mat-sys-body-medium-font: Roboto;--mat-sys-body-medium-line-height: 1.25rem;--mat-sys-body-medium-size: .875rem;--mat-sys-body-medium-tracking: .016rem;--mat-sys-body-medium-weight: 400;--mat-sys-body-small: 400 .75rem / 1rem Roboto;--mat-sys-body-small-font: Roboto;--mat-sys-body-small-line-height: 1rem;--mat-sys-body-small-size: .75rem;--mat-sys-body-small-tracking: .025rem;--mat-sys-body-small-weight: 400;--mat-sys-display-large: 400 3.562rem / 4rem Roboto;--mat-sys-display-large-font: Roboto;--mat-sys-display-large-line-height: 4rem;--mat-sys-display-large-size: 3.562rem;--mat-sys-display-large-tracking: -.016rem;--mat-sys-display-large-weight: 400;--mat-sys-display-medium: 400 2.812rem / 3.25rem Roboto;--mat-sys-display-medium-font: Roboto;--mat-sys-display-medium-line-height: 3.25rem;--mat-sys-display-medium-size: 2.812rem;--mat-sys-display-medium-tracking: 0;--mat-sys-display-medium-weight: 400;--mat-sys-display-small: 400 2.25rem / 2.75rem Roboto;--mat-sys-display-small-font: Roboto;--mat-sys-display-small-line-height: 2.75rem;--mat-sys-display-small-size: 2.25rem;--mat-sys-display-small-tracking: 0;--mat-sys-display-small-weight: 400;--mat-sys-headline-large: 400 2rem / 2.5rem Roboto;--mat-sys-headline-large-font: Roboto;--mat-sys-headline-large-line-height: 2.5rem;--mat-sys-headline-large-size: 2rem;--mat-sys-headline-large-tracking: 0;--mat-sys-headline-large-weight: 400;--mat-sys-headline-medium: 400 1.75rem / 2.25rem Roboto;--mat-sys-headline-medium-font: Roboto;--mat-sys-headline-medium-line-height: 2.25rem;--mat-sys-headline-medium-size: 1.75rem;--mat-sys-headline-medium-tracking: 0;--mat-sys-headline-medium-weight: 400;--mat-sys-headline-small: 400 1.5rem / 2rem Roboto;--mat-sys-headline-small-font: Roboto;--mat-sys-headline-small-line-height: 2rem;--mat-sys-headline-small-size: 1.5rem;--mat-sys-headline-small-tracking: 0;--mat-sys-headline-small-weight: 400;--mat-sys-label-large: 500 .875rem / 1.25rem Roboto;--mat-sys-label-large-font: Roboto;--mat-sys-label-large-line-height: 1.25rem;--mat-sys-label-large-size: .875rem;--mat-sys-label-large-tracking: .006rem;--mat-sys-label-large-weight: 500;--mat-sys-label-large-weight-prominent: 700;--mat-sys-label-medium: 500 .75rem / 1rem Roboto;--mat-sys-label-medium-font: Roboto;--mat-sys-label-medium-line-height: 1rem;--mat-sys-label-medium-size: .75rem;--mat-sys-label-medium-tracking: .031rem;--mat-sys-label-medium-weight: 500;--mat-sys-label-medium-weight-prominent: 700;--mat-sys-label-small: 500 .688rem / 1rem Roboto;--mat-sys-label-small-font: Roboto;--mat-sys-label-small-line-height: 1rem;--mat-sys-label-small-size: .688rem;--mat-sys-label-small-tracking: .031rem;--mat-sys-label-small-weight: 500;--mat-sys-title-large: 400 1.375rem / 1.75rem Roboto;--mat-sys-title-large-font: Roboto;--mat-sys-title-large-line-height: 1.75rem;--mat-sys-title-large-size: 1.375rem;--mat-sys-title-large-tracking: 0;--mat-sys-title-large-weight: 400;--mat-sys-title-medium: 500 1rem / 1.5rem Roboto;--mat-sys-title-medium-font: Roboto;--mat-sys-title-medium-line-height: 1.5rem;--mat-sys-title-medium-size: 1rem;--mat-sys-title-medium-tracking: .009rem;--mat-sys-title-medium-weight: 500;--mat-sys-title-small: 500 .875rem / 1.25rem Roboto;--mat-sys-title-small-font: Roboto;--mat-sys-title-small-line-height: 1.25rem;--mat-sys-title-small-size: .875rem;--mat-sys-title-small-tracking: .006rem;--mat-sys-title-small-weight: 500;--mat-sys-corner-extra-large: 28px;--mat-sys-corner-extra-large-top: 28px 28px 0 0;--mat-sys-corner-extra-small: 4px;--mat-sys-corner-extra-small-top: 4px 4px 0 0;--mat-sys-corner-full: 9999px;--mat-sys-corner-large: 16px;--mat-sys-corner-large-end: 0 16px 16px 0;--mat-sys-corner-large-start: 16px 0 0 16px;--mat-sys-corner-large-top: 16px 16px 0 0;--mat-sys-corner-medium: 12px;--mat-sys-corner-none: 0;--mat-sys-corner-small: 8px;--mat-sys-dragged-state-layer-opacity: .16;--mat-sys-focus-state-layer-opacity: .12;--mat-sys-hover-state-layer-opacity: .08;--mat-sys-pressed-state-layer-opacity: .12}body{color-scheme:light;color:var(--mat-sys-on-surface);font:var(--mat-sys-body-medium);margin:0;height:100%}.page-container{padding:24px;max-width:1400px;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.page-header h1{margin:0;font:var(--mat-sys-headline-medium)}.filters-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:16px}.full-width{width:100%}.status-chip{display:inline-flex;align-items:center;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-chip.status-active,.status-chip.status-ok,.status-chip.status-completed,.status-chip.status-paid{background-color:#e8f5e9;color:#2e7d32}.status-chip.status-archived,.status-chip.status-cancelled,.status-chip.status-failed{background-color:#ffebee;color:#c62828}.status-chip.status-draft,.status-chip.status-pending,.status-chip.status-scheduled{background-color:#e3f2fd;color:#1565c0}.status-chip.status-in_progress,.status-chip.status-sent{background-color:#fff3e0;color:#e65100}.status-chip.status-overdue,.status-chip.status-expired{background-color:#fce4ec;color:#ad1457}.status-chip.status-partially_paid,.status-chip.status-refunded{background-color:#f3e5f5;color:#6a1b9a}.mat-mdc-table{width:100%}.clickable-row{cursor:pointer}.clickable-row:hover{background-color:var(--mat-sys-surface-variant)}.form-row{display:flex;gap:16px}.form-row>*{flex:1}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.chart-bar-container{display:flex;flex-direction:column;gap:8px}.chart-bar{display:flex;align-items:center;gap:12px}.chart-bar .chart-bar-label{width:120px;font-size:13px;text-align:right;flex-shrink:0}.chart-bar .chart-bar-track{flex:1;height:24px;background:var(--mat-sys-surface-variant);border-radius:4px;overflow:hidden}.chart-bar .chart-bar-fill{height:100%;border-radius:4px;background:var(--mat-sys-primary);transition:width .4s ease}.chart-bar .chart-bar-value{width:60px;font-size:13px;font-weight:500}.chart-pie{width:180px;height:180px;border-radius:50%;position:relative}.stat-card{text-align:center}.stat-card .stat-value{font:var(--mat-sys-display-small);color:var(--mat-sys-primary)}.stat-card .stat-label{font:var(--mat-sys-body-medium);color:var(--mat-sys-on-surface-variant);margin-top:4px}.stat-card .stat-change{font-size:13px;margin-top:4px}.stat-card .stat-change.positive{color:#2e7d32}.stat-card .stat-change.negative{color:#c62828}mat-form-field.mat-form-field.mat-form-field-appearance-outline>div.mat-form-field-wrapper>div.mat-form-field-flex>div.mat-form-field-infix{padding:.4em 0}mat-form-field.mat-form-field.mat-form-field-appearance-outline>div.mat-form-field-wrapper>div.mat-form-field-flex>div.mat-form-field-infix>span.mat-form-field-label-wrapper{top:-1.5em}.mat-form-field-appearance-outline.mat-form-field-can-float.mat-form-field-should-float .mat-form-field-label{transform:translateY(-1.1em) scale(.75);width:133.33333%}
