:root{--mat-sys-primary: #3c6e89;--mat-sys-on-primary: white;--mat-sys-on-surface: #000000}html{--mat-sys-background: #f9f9fb;--mat-sys-error: #ba1a1a;--mat-sys-error-container: #ffdad6;--mat-sys-inverse-on-surface: #f0f1f3;--mat-sys-inverse-primary: #9ccdeb;--mat-sys-inverse-surface: #2e3133;--mat-sys-on-background: #191c1e;--mat-sys-on-error: #ffffff;--mat-sys-on-error-container: #93000a;--mat-sys-on-primary: #ffffff;--mat-sys-on-primary-container: #134c65;--mat-sys-on-primary-fixed: #001e2c;--mat-sys-on-primary-fixed-variant: #134c65;--mat-sys-on-secondary: #ffffff;--mat-sys-on-secondary-container: #384954;--mat-sys-on-secondary-fixed: #0b1e27;--mat-sys-on-secondary-fixed-variant: #384954;--mat-sys-on-surface: #191c1e;--mat-sys-on-surface-variant: #41484d;--mat-sys-on-tertiary: #ffffff;--mat-sys-on-tertiary-container: #593c64;--mat-sys-on-tertiary-fixed: #2a1036;--mat-sys-on-tertiary-fixed-variant: #593c64;--mat-sys-outline: #71787d;--mat-sys-outline-variant: #c1c7cd;--mat-sys-primary: #31647e;--mat-sys-primary-container: #c4e7ff;--mat-sys-primary-fixed: #c4e7ff;--mat-sys-primary-fixed-dim: #9ccdeb;--mat-sys-scrim: #000000;--mat-sys-secondary: #4f616c;--mat-sys-secondary-container: #d2e5f3;--mat-sys-secondary-fixed: #d2e5f3;--mat-sys-secondary-fixed-dim: #b6c9d6;--mat-sys-shadow: #000000;--mat-sys-surface: #f9f9fb;--mat-sys-surface-bright: #f9f9fb;--mat-sys-surface-container: #edeef0;--mat-sys-surface-container-high: #e7e8ea;--mat-sys-surface-container-highest: #e2e2e5;--mat-sys-surface-container-low: #f3f3f6;--mat-sys-surface-container-lowest: #ffffff;--mat-sys-surface-dim: #d9dadc;--mat-sys-surface-tint: #31647e;--mat-sys-surface-variant: #dde3e9;--mat-sys-tertiary: #72537d;--mat-sys-tertiary-container: #f8d8ff;--mat-sys-tertiary-fixed: #f8d8ff;--mat-sys-tertiary-fixed-dim: #e0baea;--mat-sys-neutral-variant20: #2b3136;--mat-sys-neutral10: #191c1e;--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;background-color:var(--mat-sys-surface);color:var(--mat-sys-on-surface);color:#000!important;font:var(--mat-sys-body-medium);margin:0}html,body{height:100%}.loading-spinner{display:flex;flex-direction:column;align-items:center;padding:40px 0;gap:12px;opacity:.7}.loading-spinner p{font-size:14px}.custom-form-field-width{width:280px}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.grid.grid-1{grid-template-columns:1fr}.grid.grid-3{grid-template-columns:repeat(3,1fr)}@media(max-width:1200px){.grid{grid-template-columns:1fr}}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:900px){.two-col{grid-template-columns:1fr}}.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:900px){.three-col{grid-template-columns:1fr}}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;background:#eee}.chip.red{background:#ffebee;color:#c62828}.chip.amber{background:#fff3e0;color:#e65100}.chip.grey{background:#eceff1;color:#455a64}.list-row{display:grid;grid-template-columns:1.5fr 1.3fr .6fr .8fr;align-items:center;gap:8px;padding:6px 0}.list-row.header{font-weight:600;color:#666;border-bottom:1px solid #eee;margin-bottom:8px}.progress{display:flex;align-items:center;gap:8px}.progress small{width:36px;text-align:right;font-size:11px;color:#666}.score-none{color:#999}.score-low{background:#f4433626;color:#c62828;font-weight:600}.score-medium{background:#ff980026;color:#ef6c00;font-weight:600}.score-normal{background:#0000000a}.score-high{background:#4caf5026;color:#2e7d32;font-weight:600}.chart-container{display:flex;flex-direction:column;align-items:center}.chart-container h4{margin:0 0 16px;font-size:16px;font-weight:500;color:#424242;text-align:center;width:100%}.line-chart,.bubble-chart{width:100%;height:300px}.heatmap-chart{width:100%;height:400px}.bar-chart{width:100%;height:250px}.score-circle{border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-circle.excellent{border-color:#4caf50;background:#4caf501a}.score-circle.good{border-color:#8bc34a;background:#8bc34a1a}.score-circle.fair{border-color:#ff9800;background:#ff98001a}.score-circle.poor{border-color:#f44336;background:#f443361a}.status-excellent{border-color:#4caf50;background:#4caf501a;color:#2e7d32}.status-good{border-color:#8bc34a;background:#8bc34a1a;color:#558b2f}.status-warning{border-color:#ff9800;background:#ff98001a;color:#ef6c00}.status-alert{border-color:#f44336;background:#f443361a;color:#c62828}.card-section{margin-bottom:24px}.card-section h4{margin:0 0 8px;font-size:14px;font-weight:600}.card-section .section-description{font-size:12px;color:#666;margin:0 0 12px}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-col{display:flex;flex-direction:column}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.p-8{padding:8px}.p-12{padding:12px}.p-16{padding:16px}.list-item{padding:12px;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.list-item:hover{background:#f5f5f5}.list-item:last-child{border-bottom:none}
