html{--mat-sys-background: #faf9fd;--mat-sys-error: #ba1a1a;--mat-sys-error-container: #ffdad6;--mat-sys-inverse-on-surface: #f2f0f4;--mat-sys-inverse-primary: #abc7ff;--mat-sys-inverse-surface: #2f3033;--mat-sys-on-background: #1a1b1f;--mat-sys-on-error: #ffffff;--mat-sys-on-error-container: #93000a;--mat-sys-on-primary: #ffffff;--mat-sys-on-primary-container: #00458f;--mat-sys-on-primary-fixed: #001b3f;--mat-sys-on-primary-fixed-variant: #00458f;--mat-sys-on-secondary: #ffffff;--mat-sys-on-secondary-container: #3e4759;--mat-sys-on-secondary-fixed: #131c2b;--mat-sys-on-secondary-fixed-variant: #3e4759;--mat-sys-on-surface: #1a1b1f;--mat-sys-on-surface-variant: #44474e;--mat-sys-on-tertiary: #ffffff;--mat-sys-on-tertiary-container: #0000ef;--mat-sys-on-tertiary-fixed: #00006e;--mat-sys-on-tertiary-fixed-variant: #0000ef;--mat-sys-outline: #74777f;--mat-sys-outline-variant: #c4c6d0;--mat-sys-primary: #005cbb;--mat-sys-primary-container: #d7e3ff;--mat-sys-primary-fixed: #d7e3ff;--mat-sys-primary-fixed-dim: #abc7ff;--mat-sys-scrim: #000000;--mat-sys-secondary: #565e71;--mat-sys-secondary-container: #dae2f9;--mat-sys-secondary-fixed: #dae2f9;--mat-sys-secondary-fixed-dim: #bec6dc;--mat-sys-shadow: #000000;--mat-sys-surface: #faf9fd;--mat-sys-surface-bright: #faf9fd;--mat-sys-surface-container: #efedf0;--mat-sys-surface-container-high: #e9e7eb;--mat-sys-surface-container-highest: #e3e2e6;--mat-sys-surface-container-low: #f4f3f6;--mat-sys-surface-container-lowest: #ffffff;--mat-sys-surface-dim: #dbd9dd;--mat-sys-surface-tint: #005cbb;--mat-sys-surface-variant: #e0e2ec;--mat-sys-tertiary: #343dff;--mat-sys-tertiary-container: #e0e0ff;--mat-sys-tertiary-fixed: #e0e0ff;--mat-sys-tertiary-fixed-dim: #bec2ff;--mat-sys-neutral-variant20: #2d3038;--mat-sys-neutral10: #1a1b1f;--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}:root{--bg-body: #0a0e17;--bg-surface: #111827;--bg-surface-alt: #0e1726;--bg-hover: #1a2235;--bg-border: #1e293b;--bg-elevated: #1f2937;--bg-muted: #374151;--text-primary: #f1f5f9;--text-secondary: #e2e8f0;--text-tertiary: #cbd5e1;--text-muted: #94a3b8;--text-dimmed: #6b7280;--color-primary: #06b6d4;--color-primary-hover: rgba(6, 182, 212, .1);--color-primary-subtle: rgba(6, 182, 212, .15);--color-success: #10b981;--color-success-subtle: rgba(16, 185, 129, .15);--color-error: #ef4444;--color-error-subtle: rgba(239, 68, 68, .15);--color-warning: #f59e0b;--color-warning-subtle: rgba(245, 158, 11, .15);--color-orange: #f97316;--color-purple: #7c3aed;--color-violet: #8b5cf6;--color-blue: #3b82f6;--scrollbar-track: #0a0e17;--scrollbar-thumb: #1a2235}:root[data-theme=light]{--bg-body: #f8fafc;--bg-surface: #ffffff;--bg-surface-alt: #f1f5f9;--bg-hover: #e2e8f0;--bg-border: #cbd5e1;--bg-elevated: #f1f5f9;--bg-muted: #d1d5db;--text-primary: #0f172a;--text-secondary: #1e293b;--text-tertiary: #475569;--text-muted: #64748b;--text-dimmed: #94a3b8;--color-primary: #0891b2;--color-primary-hover: rgba(8, 145, 178, .08);--color-primary-subtle: rgba(8, 145, 178, .12);--scrollbar-track: #f1f5f9;--scrollbar-thumb: #cbd5e1}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg-body);color:var(--text-secondary);font-family:Inter,Segoe UI,Roboto,sans-serif}*{font-family:Inter,Segoe UI,Roboto,sans-serif!important}a{color:inherit;text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;background:var(--bg-hover);color:var(--text-secondary)}.btn:hover{opacity:.85}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-danger{background:var(--color-error);color:#fff}.btn-success{background:var(--color-success);color:#fff}.btn-warning{background:var(--color-warning);color:#000}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-secondary)}.btn-sm{padding:4px 12px;font-size:13px}.btn-lg{padding:12px 28px;font-size:16px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border:none;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.btn-icon:hover{background:var(--bg-hover);color:var(--text-secondary)}.btn-icon.danger:hover{background:var(--color-error-subtle);color:var(--color-error)}.btn-icon.success:hover{background:var(--color-success-subtle);color:var(--color-success)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:var(--text-muted)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:transparent;border:1px solid var(--bg-border);border-radius:8px;color:var(--text-secondary);font-size:14px;outline:none;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-dimmed)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-select option{background:var(--bg-surface);color:var(--text-secondary)}.form-textarea{resize:vertical;min-height:80px}.form-error{font-size:12px;color:var(--color-error);margin-top:2px}.form-row{display:flex;gap:16px}.form-row>*{flex:1}.checkbox{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-secondary)}.checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:10px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--bg-border)}.table td{padding:12px 16px;font-size:14px;color:var(--text-secondary);border-bottom:1px solid var(--bg-border)}.table tbody tr{transition:background .1s}.table tbody tr:hover{background:var(--bg-hover)}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-container .table{min-width:850px}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:12px 16px;font-size:13px;color:var(--text-muted)}.pagination select{padding:4px 8px;background:transparent;border:1px solid var(--bg-border);border-radius:6px;color:var(--text-secondary);font-size:13px;outline:none}.pagination select option{background:var(--bg-surface);color:var(--text-secondary)}.pagination button{display:flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer}.pagination button:hover:not(:disabled){background:var(--bg-hover);color:var(--text-secondary)}.pagination button:disabled{opacity:.3;cursor:not-allowed}.chip{display:inline-flex;align-items:center;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:500}.chip-success{background:var(--color-success-subtle);color:var(--color-success)}.chip-error{background:var(--color-error-subtle);color:var(--color-error)}.chip-warning{background:var(--color-warning-subtle);color:var(--color-warning)}.chip-primary{background:var(--color-primary-subtle);color:var(--color-primary)}.chip-orange{background:#f9731626;color:var(--color-orange)}.chip-purple{background:#7c3aed26;color:var(--color-purple)}.chip-muted{background:var(--bg-muted);color:var(--text-secondary)}.chip-solid-success{background:var(--color-success);color:#fff}.chip-solid-error{background:var(--color-error);color:#fff}.chip-solid-warning{background:var(--color-warning);color:#000}.chip-solid-orange{background:var(--color-orange);color:#fff}.chip-solid-muted{background:var(--text-dimmed);color:#fff}.tabs{display:flex;gap:0;border-bottom:1px solid var(--bg-border);margin-bottom:16px}.tab{padding:10px 20px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.card{padding:20px}.mat-mdc-dialog-container .mdc-dialog__surface{background:var(--bg-surface)!important;color:var(--text-secondary)!important;border-radius:16px!important}.snackbar-error{--mdc-snackbar-container-color: #ef4444 !important;--mdc-snackbar-supporting-text-color: #fff !important}.snackbar-success{--mdc-snackbar-container-color: #22c55e !important;--mdc-snackbar-supporting-text-color: #fff !important}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.icon-primary{color:var(--color-primary)}.icon-success{color:var(--color-success)}.icon-error{color:var(--color-error)}.icon-warning{color:var(--color-warning)}.icon-purple{color:var(--color-purple)}.text-primary-color{color:var(--color-primary)}.text-heading{color:var(--text-primary)}.text-body{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-dimmed{color:var(--text-dimmed)}ngx-charts-line-chart text,ngx-charts-bar-vertical text,ngx-charts-bar-horizontal text,ngx-charts-pie-chart text,ngx-charts-advanced-pie-chart text,.ngx-charts text{fill:var(--text-muted)!important;font-size:11px!important;font-family:Inter,Segoe UI,Roboto,sans-serif!important}.ngx-charts .tick text{fill:var(--text-muted)!important}.ngx-charts .label{fill:var(--text-secondary)!important}.ngx-charts .gridline-path,.ngx-charts .refline-path{stroke:var(--bg-border)!important}.ngx-charts .legend-labels{background:transparent!important}.ngx-charts .legend-label{color:var(--text-secondary)!important}.ngx-charts .legend-label-text{color:var(--text-secondary)!important;fill:var(--text-secondary)!important;font-size:12px!important}.chart-tooltip,.ngx-charts-tooltip-content{background:var(--bg-elevated)!important;border:1px solid var(--bg-border)!important;color:var(--text-secondary)!important;border-radius:8px!important;font-size:12px!important}.tooltip-val{font-weight:600;color:var(--text-primary)!important}
