/* node_modules/@angular/material/prebuilt-themes/azure-blue.css */
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;
}
html {
  --mat-sys-level0:
    0px 0px 0px 0px rgba(0, 0, 0, 0.2),
    0px 0px 0px 0px rgba(0, 0, 0, 0.14),
    0px 0px 0px 0px rgba(0, 0, 0, 0.12);
}
html {
  --mat-sys-level1:
    0px 2px 1px -1px rgba(0, 0, 0, 0.2),
    0px 1px 1px 0px rgba(0, 0, 0, 0.14),
    0px 1px 3px 0px rgba(0, 0, 0, 0.12);
}
html {
  --mat-sys-level2:
    0px 3px 3px -2px rgba(0, 0, 0, 0.2),
    0px 3px 4px 0px rgba(0, 0, 0, 0.14),
    0px 1px 8px 0px rgba(0, 0, 0, 0.12);
}
html {
  --mat-sys-level3:
    0px 3px 5px -1px rgba(0, 0, 0, 0.2),
    0px 6px 10px 0px rgba(0, 0, 0, 0.14),
    0px 1px 18px 0px rgba(0, 0, 0, 0.12);
}
html {
  --mat-sys-level4:
    0px 5px 5px -3px rgba(0, 0, 0, 0.2),
    0px 8px 10px 1px rgba(0, 0, 0, 0.14),
    0px 3px 14px 2px rgba(0, 0, 0, 0.12);
}
html {
  --mat-sys-level5:
    0px 7px 8px -4px rgba(0, 0, 0, 0.2),
    0px 12px 17px 2px rgba(0, 0, 0, 0.14),
    0px 5px 22px 4px rgba(0, 0, 0, 0.12);
}
html {
  --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: 0.031rem;
  --mat-sys-body-large-weight: 400;
  --mat-sys-body-medium: 400 0.875rem / 1.25rem Roboto;
  --mat-sys-body-medium-font: Roboto;
  --mat-sys-body-medium-line-height: 1.25rem;
  --mat-sys-body-medium-size: 0.875rem;
  --mat-sys-body-medium-tracking: 0.016rem;
  --mat-sys-body-medium-weight: 400;
  --mat-sys-body-small: 400 0.75rem / 1rem Roboto;
  --mat-sys-body-small-font: Roboto;
  --mat-sys-body-small-line-height: 1rem;
  --mat-sys-body-small-size: 0.75rem;
  --mat-sys-body-small-tracking: 0.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: -0.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 0.875rem / 1.25rem Roboto;
  --mat-sys-label-large-font: Roboto;
  --mat-sys-label-large-line-height: 1.25rem;
  --mat-sys-label-large-size: 0.875rem;
  --mat-sys-label-large-tracking: 0.006rem;
  --mat-sys-label-large-weight: 500;
  --mat-sys-label-large-weight-prominent: 700;
  --mat-sys-label-medium: 500 0.75rem / 1rem Roboto;
  --mat-sys-label-medium-font: Roboto;
  --mat-sys-label-medium-line-height: 1rem;
  --mat-sys-label-medium-size: 0.75rem;
  --mat-sys-label-medium-tracking: 0.031rem;
  --mat-sys-label-medium-weight: 500;
  --mat-sys-label-medium-weight-prominent: 700;
  --mat-sys-label-small: 500 0.688rem / 1rem Roboto;
  --mat-sys-label-small-font: Roboto;
  --mat-sys-label-small-line-height: 1rem;
  --mat-sys-label-small-size: 0.688rem;
  --mat-sys-label-small-tracking: 0.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: 0.009rem;
  --mat-sys-title-medium-weight: 500;
  --mat-sys-title-small: 500 0.875rem / 1.25rem Roboto;
  --mat-sys-title-small-font: Roboto;
  --mat-sys-title-small-line-height: 1.25rem;
  --mat-sys-title-small-size: 0.875rem;
  --mat-sys-title-small-tracking: 0.006rem;
  --mat-sys-title-small-weight: 500;
}
html {
  --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;
}
html {
  --mat-sys-dragged-state-layer-opacity: 0.16;
  --mat-sys-focus-state-layer-opacity: 0.12;
  --mat-sys-hover-state-layer-opacity: 0.08;
  --mat-sys-pressed-state-layer-opacity: 0.12;
}

/* src/styles.scss */
html,
body {
  height: 100%;
}
body {
  margin: 0;
  font-family:
    Roboto,
    "Helvetica Neue",
    sans-serif;
  background: #f5f6fb;
  color: #0f1a2a;
}
a {
  color: inherit;
}
:root {
  --app-card-radius: 1.25rem;
  --app-card-shadow: 0 24px 60px -28px rgba(15, 23, 42, 0.55);
  --app-toolbar-background: #f8fafc;
  --app-text-color: #0f172a;
  --app-muted-text: rgba(30, 41, 59, 0.6);
}
app-home-page {
  display: block;
  padding: 1.5rem 0;
}
.app-shell {
  display: grid;
  gap: 1.75rem;
}
.material-card {
  border-radius: var(--app-card-radius);
  box-shadow: var(--app-card-shadow);
  border: none;
  background-color: rgba(255, 255, 255, 0.92);
  color: var(--app-text-color);
}
.control-card {
  padding: 1.75rem clamp(1.5rem, 2.5vw, 2.25rem);
  background-color: var(--app-toolbar-background);
}
.control-card .control-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1.5rem;
}
.control-card .toolbar-left {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.control-card .toolbar-title {
  margin: 0;
  font-size: clamp(1.5rem, 1.5vw + 1rem, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #1e293b;
}
.control-card .tab-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
}
.control-card .tab-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.control-card .tab-button {
  padding: 0.45rem 1.6rem;
  border-radius: 999px;
  border: 1px solid rgba(30, 64, 175, 0.18);
  background-color: #e0ecff;
  color: #1d4ed8;
  font-weight: 600;
  font-size: 0.95rem;
  transition: all 0.25s ease;
  cursor: pointer;
}
.control-card .tab-button:hover,
.control-card .tab-button:focus-visible {
  outline: none;
  border-color: rgba(59, 130, 246, 0.5);
  box-shadow: 0 8px 18px -12px rgba(37, 99, 235, 0.45);
}
.control-card .tab-button--active {
  background-color: #2563eb;
  color: #ffffff;
  border-color: transparent;
  box-shadow: 0 12px 24px -18px rgba(37, 99, 235, 0.55);
}
.control-card .mapping-button {
  padding: 0.45rem 1.4rem;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.4);
  background: rgba(255, 255, 255, 0.85);
  color: var(--app-text-color);
  font-weight: 600;
  letter-spacing: -0.01em;
  box-shadow: 0 12px 24px -18px rgba(15, 23, 42, 0.4);
  transition: all 0.25s ease;
  cursor: pointer;
}
.control-card .mapping-button:hover,
.control-card .mapping-button:focus-visible {
  outline: none;
  border-color: rgba(59, 130, 246, 0.45);
  color: #1d4ed8;
}
.control-card .toolbar-filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 1rem;
}
.control-card .selector {
  min-width: 150px;
}
.selector.mat-mdc-form-field,
.filter-field.mat-mdc-form-field {
  --mdc-filled-text-field-container-color: rgba(255, 255, 255, 0.82);
  --mdc-filled-text-field-hover-container-color: rgba(255, 255, 255, 0.94);
  --mdc-filled-text-field-focus-active-indicator-color: transparent;
  --mdc-filled-text-field-active-indicator-color: transparent;
  --mat-mdc-form-field-state-layer-color: transparent;
  border-radius: 999px;
}
.selector .mdc-text-field--filled,
.filter-field .mdc-text-field--filled {
  border-radius: 999px;
  box-shadow: 0 14px 34px -22px rgba(15, 23, 42, 0.65);
}
.selector .mat-mdc-form-field-infix,
.filter-field .mat-mdc-form-field-infix {
  padding: 1.6rem 1.25rem 0.55rem 1.25rem;
}
.selector .mdc-line-ripple,
.filter-field .mdc-line-ripple {
  display: none;
}
.selector .mdc-floating-label,
.filter-field .mdc-floating-label {
  color: var(--app-muted-text);
  font-weight: 500;
}
.selector .mat-mdc-select-value-text,
.selector .mat-mdc-select-arrow,
.filter-field .mat-mdc-select-value-text,
.filter-field .mat-mdc-select-arrow {
  color: var(--app-text-color);
  font-weight: 600;
}
.selector .mat-mdc-select-trigger,
.filter-field .mat-mdc-select-trigger {
  gap: 0.75rem;
}
.view-container {
  min-height: 320px;
}
.app-table-card {
  background-color: #ffffff;
  border-radius: 1.5rem;
  box-shadow: 0 10px 40px rgba(15, 23, 42, 0.08), 0 6px 14px rgba(15, 23, 42, 0.05);
  padding: 0;
  overflow: hidden;
}
.app-table-container {
  overflow-x: auto;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 1.5rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
}
.error-snackbar {
  --mdc-snackbar-container-color: #b91c1c;
  --mdc-snackbar-supporting-text-color: #fff;
  --mdc-snackbar-container-shape: 12px;
}
.error-snackbar .mdc-snackbar__label {
  font-weight: 600;
}
.error-snackbar .mat-mdc-snack-bar-action {
  color: #fff;
  font-weight: 600;
}
.cdk-overlay-pane.full-screen-dialog {
  width: 100vw !important;
  max-width: 100vw !important;
  height: 100vh !important;
  max-height: 100vh !important;
  top: 0 !important;
  left: 0 !important;
}
.full-screen-dialog .mat-mdc-dialog-surface {
  border-radius: 0;
  display: flex;
  flex-direction: column;
  height: 100%;
  max-height: 100%;
}
.full-screen-dialog .mat-mdc-dialog-content {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  overflow: auto;
  padding: 1.5rem;
}
.full-screen-dialog .mat-mdc-dialog-title {
  padding: 1.5rem 1.5rem 0;
}
.full-screen-dialog .mat-mdc-dialog-actions {
  padding: 1.5rem;
}
.app-data-table {
  width: 100%;
  min-width: 960px;
  border-collapse: collapse;
  border-radius: 1.5rem;
  overflow: hidden;
}
.app-data-table--compact {
  min-width: 100%;
}
.app-data-table thead,
.app-data-table .mat-mdc-header-row {
  background:
    linear-gradient(
      135deg,
      #e2e8ff 0%,
      #dff4ff 100%);
  color: #0f172a;
}
.app-data-table thead th,
.app-data-table .mat-mdc-header-cell {
  padding: 18px;
  font-weight: 700;
  text-align: left;
  border-bottom: 1px solid #e8ecf3;
  color: inherit;
}
.app-data-table tbody td,
.app-data-table .mat-mdc-cell {
  padding: 16px 18px;
  border-bottom: 1px solid #eaf0ff;
  vertical-align: middle;
  font-size: 15px;
}
.app-data-table tbody tr:hover,
.app-data-table .mat-mdc-row:hover {
  background-color: #fafbff;
}
.app-data-table.mat-mdc-table {
  background: transparent;
}
@media (max-width: 960px) {
  .control-card .control-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .control-card .toolbar-filters {
    justify-content: flex-start;
  }
}
@media (max-width: 600px) {
  .control-card {
    padding: 1.5rem;
  }
  .control-card .tab-row {
    flex-direction: column;
    align-items: stretch;
  }
  .control-card .tab-group {
    width: 100%;
  }
  .control-card .tab-button,
  .control-card .mapping-button {
    width: 100%;
    text-align: center;
  }
  .control-card .selector {
    flex: 1 1 100%;
  }
}

/* angular:styles/global:styles */
/*# sourceMappingURL=styles.css.map */
