/*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/resolve-url-loader/index.js??ruleSet[1].rules[6].rules[1].use[0]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[6].rules[1].use[1]!./src/custom-theme.scss?ngGlobalStyle ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
.cdk-visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
  outline: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  left: 0;
}
[dir=rtl] .cdk-visually-hidden {
  left: auto;
  right: 0;
}

html {
  color-scheme: light;
}
html {
  --mat-sys-background: light-dark(var(--color-6), var(--color-1));
  --mat-sys-error: light-dark(var(--error-color-3), var(--error-color-2));
  --mat-sys-error-container: light-dark(var(--error-color-2), var(--error-color-4));
  --mat-sys-inverse-on-surface: light-dark(var(--color-6), var(--color-2));
  --mat-sys-inverse-primary: light-dark(var(--color-5), var(--color-3));
  --mat-sys-inverse-surface: light-dark(var(--color-2), var(--color-6));
  --mat-sys-on-background: light-dark(var(--color-1), var(--color-6));
  --mat-sys-on-error: light-dark(#ffffff, var(--error-color-5));
  --mat-sys-on-error-container: light-dark(var(--error-color-4), var(--error-color-2));
  --mat-sys-on-primary: light-dark(#ffffff, var(--color-1));
  --mat-sys-on-primary-container: light-dark(var(--color-2), var(--color-6));
  --mat-sys-on-primary-fixed: light-dark(var(--color-1), var(--color-1));
  --mat-sys-on-primary-fixed-variant: light-dark(var(--color-2), var(--color-2));
  --mat-sys-on-secondary: light-dark(#ffffff, var(--color-2));
  --mat-sys-on-secondary-container: light-dark(var(--color-2), var(--color-6));
  --mat-sys-on-secondary-fixed: light-dark(var(--color-1), var(--color-1));
  --mat-sys-on-secondary-fixed-variant: light-dark(var(--color-2), var(--color-2));
  --mat-sys-on-surface: light-dark(var(--color-1), var(--color-6));
  --mat-sys-on-surface-variant: light-dark(var(--color-2), var(--color-6));
  --mat-sys-on-tertiary: light-dark(#ffffff, var(--color-1));
  --mat-sys-on-tertiary-container: light-dark(var(--color-2), var(--color-6));
  --mat-sys-on-tertiary-fixed: light-dark(var(--color-1), var(--color-1));
  --mat-sys-on-tertiary-fixed-variant: light-dark(var(--color-2), var(--color-2));
  --mat-sys-outline: light-dark(var(--color-4), var(--color-4));
  --mat-sys-outline-variant: light-dark(var(--color-5), var(--color-2));
  --mat-sys-primary: light-dark(var(--color-3), var(--color-5));
  --mat-sys-primary-container: light-dark(var(--color-6), var(--color-2));
  --mat-sys-primary-fixed: light-dark(var(--color-6), var(--color-6));
  --mat-sys-primary-fixed-dim: light-dark(var(--color-5), var(--color-5));
  --mat-sys-scrim: light-dark(#222, #222);
  --mat-sys-secondary: light-dark(var(--color-3), var(--color-5));
  --mat-sys-secondary-container: light-dark(var(--color-6), var(--color-2));
  --mat-sys-secondary-fixed: light-dark(var(--color-6), var(--color-6));
  --mat-sys-secondary-fixed-dim: light-dark(var(--color-5), var(--color-5));
  --mat-sys-shadow: light-dark(#222, #222);
  --mat-sys-surface: light-dark(var(--color-6), var(--color-1));
  --mat-sys-surface-bright: light-dark(var(--color-6), var(--color-2));
  --mat-sys-surface-container: light-dark(var(--color-6), var(--color-1));
  --mat-sys-surface-container-high: light-dark(var(--color-6), var(--color-2));
  --mat-sys-surface-container-highest: light-dark(var(--color-6), var(--color-2));
  --mat-sys-surface-container-low: light-dark(var(--color-6), var(--color-1));
  --mat-sys-surface-container-lowest: light-dark(#ffffff, var(--color-1));
  --mat-sys-surface-dim: light-dark(var(--color-6), var(--color-1));
  --mat-sys-surface-tint: light-dark(var(--color-3), var(--color-5));
  --mat-sys-surface-variant: light-dark(var(--color-6), var(--color-2));
  --mat-sys-tertiary: light-dark(var(--color-3), var(--color-5));
  --mat-sys-tertiary-container: light-dark(var(--color-6), var(--color-2));
  --mat-sys-tertiary-fixed: light-dark(var(--color-6), var(--color-6));
  --mat-sys-tertiary-fixed-dim: light-dark(var(--color-5), var(--color-5));
  --mat-sys-neutral-variant20: var(--color-2);
  --mat-sys-neutral10: var(--color-1);
}
html {
  --mat-sys-level0: 0px 0px 0px 0px rgba(34, 34, 34, 0.2), 0px 0px 0px 0px rgba(34, 34, 34, 0.14), 0px 0px 0px 0px rgba(34, 34, 34, 0.12);
}
html {
  --mat-sys-level1: 0px 2px 1px -1px rgba(34, 34, 34, 0.2), 0px 1px 1px 0px rgba(34, 34, 34, 0.14), 0px 1px 3px 0px rgba(34, 34, 34, 0.12);
}
html {
  --mat-sys-level2: 0px 3px 3px -2px rgba(34, 34, 34, 0.2), 0px 3px 4px 0px rgba(34, 34, 34, 0.14), 0px 1px 8px 0px rgba(34, 34, 34, 0.12);
}
html {
  --mat-sys-level3: 0px 3px 5px -1px rgba(34, 34, 34, 0.2), 0px 6px 10px 0px rgba(34, 34, 34, 0.14), 0px 1px 18px 0px rgba(34, 34, 34, 0.12);
}
html {
  --mat-sys-level4: 0px 5px 5px -3px rgba(34, 34, 34, 0.2), 0px 8px 10px 1px rgba(34, 34, 34, 0.14), 0px 3px 14px 2px rgba(34, 34, 34, 0.12);
}
html {
  --mat-sys-level5: 0px 7px 8px -4px rgba(34, 34, 34, 0.2), 0px 12px 17px 2px rgba(34, 34, 34, 0.14), 0px 5px 22px 4px rgba(34, 34, 34, 0.12);
}
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;
}
html {
  --mdc-dialog-container-shape: 0.4rem;
}
html {
  --mdc-outlined-text-field-disabled-outline-color: rgba(0, 0, 0, 0.06);
}
html {
  --mat-datepicker-calendar-date-selected-state-background-color: var(--color-4);
}
html {
  --mdc-circular-progress-active-indicator-color: #fff;
}
html {
  --mdc-elevated-card-container-shape: 0.04rem;
}

.mat-mdc-progress-bar {
  --mdc-linear-progress-track-color: var(--color-4);
}

.mat-mdc-menu-panel {
  --mat-menu-container-color: #fff;
}

.mat-mdc-table {
  --mat-sys-surface: #fff;
}

.mat-datepicker-content {
  box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12) !important;
}
.mat-datepicker-content {
  --mat-sys-surface-container-high: #fff;
  --mat-sys-on-surface-variant: rgba(0, 0, 0, 0.54);
}
.mat-datepicker-content {
  --mat-datepicker-calendar-container-shape: 0.4rem;
}

.mat-calendar-period-button {
  --mat-datepicker-calendar-period-button-text-color: #000;
}

.mat-calendar-table-header-divider::after {
  --mat-datepicker-calendar-header-divider-color: rgba(0, 0, 0, 0.12);
}

.mat-calendar-body-cell {
  --mat-datepicker-calendar-text-size: 1.4rem;
}
.mat-calendar-body-cell {
  --mat-datepicker-calendar-date-text-color: rgba(0, 0, 0, 0.87);
}

.mat-calendar-body-today:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical) {
  --mat-datepicker-calendar-date-today-outline-color: rgba(0, 0, 0, 0.38);
}

.mdc-text-field--outlined {
  --mdc-filled-text-field-container-shape: 0.4rem;
}

.mat-datepicker-toggle {
  --mat-datepicker-toggle-icon-color: rgba(0, 0, 0, 0.54);
}

.mat-mdc-tab.mdc-tab--active:focus .mdc-tab__text-label,
.mat-mdc-tab.mdc-tab--active .mdc-tab__text-label {
  --mat-tab-header-active-label-text-color: var(--color-4);
}
.mat-mdc-tab.mdc-tab--active:focus .mdc-tab__text-label,
.mat-mdc-tab.mdc-tab--active .mdc-tab__text-label {
  --mat-tab-header-active-hover-label-text-color: var(--color-4);
}
.mat-mdc-tab.mdc-tab--active:focus .mdc-tab__text-label,
.mat-mdc-tab.mdc-tab--active .mdc-tab__text-label {
  --mat-tab-header-active-focus-label-text-color: var(--color-4);
}

.mat-mdc-tab .mdc-tab-indicator__content--underline {
  --mdc-tab-indicator-active-indicator-color: var(--color-4);
}

.mat-mdc-tab.mdc-tab--active:hover .mdc-tab__ripple::before {
  opacity: 0.04;
}
.mat-mdc-tab.mdc-tab--active:hover .mdc-tab__ripple::before {
  --mat-tab-header-active-ripple-color: var(--color-4);
}
.mat-mdc-tab.mdc-tab--active:hover .mdc-tab__ripple::before {
  --mat-tab-header-inactive-ripple-color: var(--color-4);
}

.mat-mdc-tab-link-container {
  border-bottom: none !important;
}

.mat-mdc-tab-link {
  --mdc-tab-indicator-active-indicator-color: var(--color-4);
}

.mat-mdc-card {
  --mdc-elevated-card-container-color: #fff;
}

.mat-mdc-checkbox.mat-primary {
  --mdc-checkbox-unselected-hover-icon-color: rgba(0, 0, 0, 0.54);
}
.mat-mdc-checkbox.mat-primary {
  --mdc-checkbox-unselected-focus-icon-color: rgba(0, 0, 0, 0.54);
}
.mat-mdc-checkbox.mat-primary {
  --mdc-checkbox-unselected-icon-color: rgba(0, 0, 0, 0.54);
}
.mat-mdc-checkbox.mat-primary {
  --mdc-checkbox-selected-focus-icon-color: var(--color-4);
}
.mat-mdc-checkbox.mat-primary {
  --mdc-checkbox-selected-icon-color: var(--color-4);
}

.mat-mdc-dialog-container {
  --mat-dialog-container-elevation-shadow: 0px 8px 10px -5px rgba(0, 0, 0, 0.2), 0px 16px 24px 2px rgba(0, 0, 0, 0.14), 0px 6px 30px 5px rgba(0, 0, 0, 0.12);
}

html {
  --mat-expansion-container-shape: square;
}
html {
  --mat-expansion-header-text-size: 1.4rem;
}
html {
  --mat-expansion-header-text-weight: 500;
}
html {
  --mat-expansion-container-text-size: 1.25rem;
}

.mat-body-2.default,
.mat-caption.default,
.mat-icon.default {
  color: var(--primary-text-color);
}

.mat-title.success,
.mat-body-1.success,
.mat-body-2.success,
.mat-caption.success,
.mat-subheading-1.success,
.mat-subheading-2.success {
  color: var(--success-color-4);
}

.mat-title.warning,
.mat-body-1.warning,
.mat-body-2.warning,
.mat-caption.warning,
.mat-subheading-1.warning,
.mat-subheading-2.warning {
  color: var(--warning-color-5);
}

.mat-title.gray,
.mat-body-1.gray,
.mat-body-2:not(.badge).gray,
.mat-body-2 .gray,
.mat-caption.gray,
.mat-subheading-1.gray,
.mat-subheading-2.gray,
.mat-display-1.gray,
.mat-headline.gray,
.mat-hint.gray {
  color: var(--secondary-text-color);
}

.mat-title.red,
.mat-body-1.red,
.mat-body-2.red,
.mat-caption.red,
.mat-subheading-1.red {
  color: var(--error-color-4);
}

.mat-caption.white,
.mat-body-2.white {
  color: var(--background-gray);
}

.mat-icon,
.material-icons {
  display: flex;
  align-items: center;
}

.mat-icon.md-18 {
  width: 18px;
  height: 18px;
  font-size: 1.8rem;
  flex: 0 0 18px;
}

.mat-icon.md-16 {
  width: 16px;
  height: 16px;
  font-size: 1.6rem;
}

.mat-icon.md-12 {
  width: 12px;
  height: 12px;
  font-size: 1.2rem;
}

.material-icons.dk-gray,
.mat-icon.dk-gray,
.mat-mdc-menu-item .mat-icon.dk-gray {
  color: var(--dark-gray);
}

.material-icons.gray,
.mat-icon.gray,
.mat-mdc-menu-item .mat-icon.gray {
  color: var(--gray);
}

.material-icons.light-gray,
.mat-icon.light-gray,
.mat-mdc-menu-item .mat-icon.light-gray {
  color: var(--light-gray);
}

.material-icons.turquoise,
.mat-icon.turquoise,
.mat-mdc-menu-item .mat-icon.turquoise {
  color: #00A7A7;
}

.material-icons.white,
.mat-icon.white,
.mat-mdc-menu-item .mat-icon.white {
  color: var(--background-gray);
}

.mat-icon.success,
.mat-mdc-menu-item .mat-icon.success {
  color: var(--success-color-4);
}

.mat-icon.error .mat-mdc-menu-item .mat-icon.error {
  color: var(--error-color-4);
}

.mat-button.btn-sm {
  padding: 0.8rem 1.2rem;
  min-width: unset;
  line-height: unset;
}

/* this is to override a stubborn setting on material icons */
button .mat-icon {
  height: unset;
  width: unset;
}

.mat-icon.mat-primary {
  color: var(--color-4);
}

.mat-standard-chip {
  padding: unset;
  min-height: unset;
}

.material-icons:not(.outlined) {
  font-family: "Material Icons";
  transform: rotate(0.03deg);
}
.material-icons:not(.outlined) .mat-badge-content {
  font-family: "Poppins";
}

.material-icons.outlined {
  font-family: "Material Icons Outlined";
  transform: rotate(0.03deg);
}

.material-icons.md-32 {
  font-size: 3.2rem;
}

/*Added browser focus outline back for keyboard focus - until we can decide what we globally want*/
.mat-icon-button:focus-visible {
  outline: -webkit-focus-ring-color auto 1px;
}

.mat-mdc-icon-button.mat-mdc-button-base {
  width: 40px;
  height: 40px;
  padding: 0;
}

.mdc-icon-button.mat-mdc-icon-button .mat-mdc-button-touch-target {
  display: none;
}

.mat-mdc-icon-button:hover .mat-mdc-button-persistent-ripple::before {
  content: none;
}

.cdk-overlay-pane .mat-mdc-menu-panel {
  border-radius: 0;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.16);
  min-height: 37px;
}

.mat-mdc-menu-panel .mat-mdc-menu-content .mat-mdc-menu-item span {
  font-size: 1.4rem;
  font-weight: 400;
}

.mat-mdc-menu-panel .mat-mdc-menu-content .mat-mdc-menu-item {
  border-radius: 0;
}

.menu-dropdown .mat-mdc-menu-content {
  padding: 0;
}

.menu-dropdown .mat-mdc-menu-content .mat-mdc-menu-item {
  line-height: 1.5;
  min-height: 37px;
  padding: 0.8rem 1.6rem;
  display: flex;
  align-items: center;
}

.menu-dropdown .mat-mdc-menu-content .mat-mdc-menu-item .mdc-icon {
  font-size: 18px;
  margin-right: 8px;
  margin-top: -1px;
}

.menu-dropdown .mat-mdc-menu-item:hover:not([disabled]),
.menu-dropdown .mat-mdc-menu-item.cdk-program-focused:not([disabled]),
.menu-dropdown .mat-mdc-menu-item.cdk-keyboard-focused:not([disabled]),
.menu-dropdown .mat-mdc-menu-item-highlighted:not([disabled]) {
  background: var(--color-0);
}

.mat-mdc-menu-submenu-icon {
  width: var(--mat-menu-item-icon-size);
  height: 10px;
  fill: currentColor;
  padding-left: var(--mat-menu-item-spacing);
  display: none !important;
}

.mat-mdc-menu-item .mat-icon.md-18 {
  flex-shrink: 0;
  margin-right: var(--mat-menu-item-spacing, 8px);
  height: var(--mat-menu-item-icon-size, 18px);
  width: var(--mat-menu-item-icon-size, 18px);
}

.mat-mdc-menu-panel .mat-mdc-menu-content .mat-mdc-menu-item span {
  align-items: center;
}

/* Date Picker */
.mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical) {
  background-color: var(--color-0);
}

/* Material Card Overrides */
.mat-mdc-card.card,
.mat-mdc-card.card-sm,
.mat-mdc-card.horizontal {
  box-shadow: unset;
  transition: unset;
}

.mat-mdc-card .mat-mdc-card-header,
.mat-mdc-card .mat-mdc-card-content {
  padding: unset;
}

.mat-mdc-card .mat-mdc-card-header-text {
  flex: 1 1 auto;
  width: calc(100% - 32px);
  margin: 0;
}

.mdc-mdc-card-title {
  font-size: unset;
  font-weight: unset;
}

.mat-mdc-card .mat-mdc-card-title:not(:first-child),
.mat-mdc-card .mat-mdc-card-subtitle:not(:first-child) {
  margin-top: 0;
}

.mat-mdc-card .mat-mdc-card-content:first-child,
.mat-mdc-card .mat-mdc-card-content:last-child {
  padding: 0;
}

/* this is added automatically by material when you use mat-card-header so removing
it from the dom because it adds margin and messes up the layout */
.mat-mdc-card-header-text:empty {
  display: none;
}

.mat-mdc-card.card {
  position: relative;
  padding: 2.4rem;
  border-radius: 4px;
  border: 1px solid var(--border-gray);
  margin-bottom: 1.6rem;
  box-shadow: unset;
}

.mat-mdc-card.card.m-b-32 {
  margin-bottom: 3.2rem;
}

.mat-mdc-card.card.m-b-0 {
  margin-bottom: 0;
}

.mat-mdc-card.card-sm {
  position: relative;
  padding: 1.6rem;
  border-radius: 4px;
  border: 1px solid var(--border-gray);
  margin-bottom: 0.8rem;
  box-shadow: unset;
}

.mat-mdc-card.card:not(.horizontal) > .mat-mdc-card-content:not(.m-t-0),
.mat-mdc-card.card > .mat-mdc-card-content:not(.m-t-0) {
  margin-top: 2.4rem;
  margin-bottom: 0;
}

.mat-mdc-card-content.flex {
  display: flex;
}

.mat-mdc-card-content.m-t-0 {
  margin-top: 0;
}

.mat-mdc-card-content.m-b-0 {
  margin-bottom: 0;
}

.mat-mdc-card.card .mat-card-header-text,
.mat-mdc-card.card-sm .mat-card-header-text {
  margin: 0;
}

.mat-mdc-card.card .mat-card-actions,
.mat-mdc-card.card-sm .mat-card-actions,
.mat-mdc-card.card .mdc-card__actions,
.mat-mdc-card.card-sm .mdc-card__actions {
  margin-left: unset;
  margin-right: unset;
  padding: unset;
  margin-top: 3.2rem;
  min-height: unset;
}

.mat-mdc-card.card > .mat-card-actions:last-child,
.mat-mdc-card.card-sm > .mat-card-actions:last-child {
  margin-bottom: unset !important;
  padding-bottom: unset !important;
}

.mat-mdc-card.horizontal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row;
  box-shadow: unset;
}

.mat-mdc-card.horizontal .mat-mdc-card-header {
  flex-direction: column;
  flex: 1 1 auto;
}

.mat-mdc-card.horizontal .mat-mdc-card-header.flex-row {
  flex-direction: row;
}

.mat-mdc-card.horizontal .mat-mdc-card-header.flex-row-reverse {
  flex-direction: row-reverse;
}

.mat-mdc-card.horizontal .mat-mdc-card-content,
.mat-mdc-card.horizontal .mat-mdc-card-actions {
  margin: 0;
}

.mat-mdc-card.horizontal .mat-mdc-card-actions,
.mat-mdc-card.horizontal .mat-mdc-card-actions .mat-button {
  display: flex;
  align-items: center;
}

.mat-mdc-card.horizontal .mat-mdc-card-actions .mat-button:hover {
  background: none;
}

.mat-mdc-card.horizontal .mat-icon:not(.m-l-0) {
  margin: 0 0 0 0.8rem;
}

.mat-mdc-card.card.disabled,
.mat-mdc-card.card-sm.disabled {
  background: var(--background-light-gray);
}

.mat-mdc-card.card.disabled .btn-tertiary,
.mat-mdc-card.card-sm.disabled .btn-tertiary {
  background: none;
}

/*** Material Form Field Overrides (normal size - 54) ***/
.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline__leading,
.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline__notch,
.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline__trailing {
  border-width: 1px;
}

.mat-mdc-form-field-type-mat-select.mat-mdc-form-field.small .mdc-text-field--outlined .mdc-notched-outline__notch {
  max-width: calc(100% - 40px);
}

.mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--invalid):not(.mdc-text-field--focused) .mdc-notched-outline__leading,
.mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--invalid):not(.mdc-text-field--focused) .mdc-notched-outline__notch,
.mat-mdc-form-field .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--invalid):not(.mdc-text-field--focused) .mdc-notched-outline__trailing {
  border-color: var(--border-gray);
}

.mat-mdc-form-field:hover .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--invalid):not(.mdc-text-field--focused) .mdc-notched-outline__leading,
.mat-mdc-form-field:hover .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--invalid):not(.mdc-text-field--focused) .mdc-notched-outline__notch,
.mat-mdc-form-field:hover .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--invalid):not(.mdc-text-field--focused) .mdc-notched-outline__trailing {
  border-color: var(--color-3) !important;
}

.mat-mdc-form-field:hover .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--invalid):not(.mdc-text-field--focused) .mdc-floating-label {
  color: var(--color-3) !important;
  will-change: unset;
}

.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__leading {
  border-radius: 4px 0 0 4px;
  min-width: 8px;
}

.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__trailing {
  border-radius: 0 4px 4px 0;
}

.table-filter .mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__leading {
  border-radius: 4px 0 0 4px;
}

.table-filter .mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__trailing {
  border-radius: 0 4px 4px 0;
}

.mat-mdc-form-field .mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above,
.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above {
  font-size: 1.2rem;
}

.mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--invalid):not(.mdc-text-field--focused) .mdc-floating-label {
  color: var(--secondary-text-color);
  will-change: unset;
}

.mat-mdc-form-field .mat-mdc-floating-label.mdc-floating-label,
.mat-mdc-form-field:not(.mat-form-field-no-animations) .mdc-text-field__input {
  line-height: 1.5;
  pointer-events: all;
  font-size: 1.6rem;
  font-weight: 400;
  will-change: unset;
}

.small .mat-mdc-form-field .mat-mdc-floating-label.mdc-floating-label,
.small .mat-mdc-form-field:not(.mat-form-field-no-animations) .mdc-text-field__input {
  font-size: 1.4rem;
}

.mat-mdc-form-field.mat-body-2 .mat-mdc-floating-label.mdc-floating-label:not(.mdc-floating-label--float-above),
.mat-mdc-form-field.mat-body-2:not(.mat-form-field-no-animations) .mdc-text-field__input,
.table-filter .mat-mdc-form-field .mat-mdc-floating-label.mdc-floating-label:not(.mdc-floating-label--float-above),
.table-filter .mat-mdc-form-field .mat-mdc-floating-label.mdc-floating-label,
.table-filter .mat-mdc-form-field:not(.mat-form-field-no-animations) .mdc-text-field__input {
  font-size: 1.4rem;
}

.mat-mdc-form-field-subscript-dynamic-size .mat-mdc-form-field-error-wrapper {
  padding: 0 8px;
}

.mat-mdc-form-field-error-wrapper .mat-mdc-form-field-error {
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  color: var(--error-color-4);
}
.mat-mdc-form-field-error-wrapper .mat-mdc-form-field-error .mat-icon {
  font-size: 14px;
  color: var(--error-color-4);
  margin-right: 0.4rem;
  width: unset;
  height: unset;
}

.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline__leading,
.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline__notch,
.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline__trailing {
  border-color: --error-color-4;
}

.mdc-text-field.mdc-text-field--invalid,
.mdc-text-field.mdc-text-field--invalid .mdc-floating-label {
  color: var(--error-color-4);
  will-change: unset;
}

/*** Small Form Field Overrides (smaller size 40) ***/
.mat-form-field-appearance-outline {
  width: 100%;
  margin-bottom: 1.6rem;
}

.form-field-group .mat-form-field-appearance-outline {
  margin-bottom: unset;
}

.m-b-0 .mat-form-field-appearance-outline {
  margin-bottom: 0;
}

.mat-form-field-appearance-outline.m-b-0 {
  margin-bottom: 0;
}

.mat-mdc-form-field.small .mat-mdc-form-field-infix {
  min-height: 41px;
}

.mat-mdc-form-field.small .mat-mdc-text-field-wrapper {
  flex: 0;
}

.mat-mdc-form-field.small .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mat-mdc-form-field-infix {
  padding-top: 1rem;
  padding-bottom: 0.9rem;
}

.form-field-group .form-field .mat-mdc-form-field.small .mat-mdc-form-field-infix {
  width: unset;
}

.mat-mdc-form-field.small .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-floating-label {
  top: 19px;
}

.mat-mdc-text-field-wrapper.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above {
  --mat-mdc-form-field-label-transform: translateY( -36px) scale(var(--mat-mdc-form-field-floating-label-scale, 1));
}

.mat-mdc-form-field {
  --mat-mdc-form-field-floating-label-scale: 1!important;
}

.mat-mdc-form-field.small .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above {
  --mat-mdc-form-field-label-transform: translateY( -28px) scale(var(--mat-mdc-form-field-floating-label-scale, 0.65));
  transform: var(--mat-mdc-form-field-label-transform);
}

.mat-mdc-select,
.mat-mdc-option.mdc-list-item,
.mat-mdc-option.mat-mdc-focus-indicator.mdc-list-item.mdc-list-item--selected {
  font-size: 1.6rem;
}

.mat-mdc-form-field .mdc-text-field--outlined .mdc-notched-outline__notch {
  width: unset !important;
}

.mat-form-field-disabled .mdc-text-field--outlined .mdc-notched-outline__leading,
.mat-form-field-disabled .mdc-text-field--outlined .mdc-notched-outline__notch,
.mat-form-field-disabled .mdc-text-field--outlined .mdc-notched-outline__trailing {
  background-color: var(--background-light-gray);
  border-color: var(--light-gray);
}
.mat-form-field-disabled .mdc-text-field--outlined .mdc-notched-outline__leading label,
.mat-form-field-disabled .mdc-text-field--outlined .mdc-notched-outline__notch label,
.mat-form-field-disabled .mdc-text-field--outlined .mdc-notched-outline__trailing label {
  color: var(--secondary-text-color);
}

.mat-mdc-form-field.small .mat-mdc-form-field-icon-suffix {
  margin-right: 4px;
}

.mat-datepicker-content .mat-mdc-button .mdc-button__label span {
  font-size: 1.4rem;
}

.mat-datepicker-content .mat-calendar-controls {
  margin-top: 0;
}

.mat-datepicker-content .mat-calendar {
  height: 100% !important;
}

.mat-mdc-form-field.small .mat-mdc-form-field-icon-suffix .mat-mdc-icon-button.mat-mdc-button-base,
.mat-mdc-form-field.small .mat-mdc-form-field-icon-suffix > .mat-icon {
  padding: 8px;
}

.mat-mdc-form-field.small .mat-mdc-form-field-icon-suffix .mat-mdc-icon-button.mat-mdc-button-base {
  height: 40px;
  width: 40px;
}

.mat-mdc-form-field.small .mat-mdc-form-field-icon-suffix .mat-mdc-icon-button .mat-mdc-button-touch-target,
.mat-mdc-icon-button .mat-mdc-button-persistent-ripple,
.mat-mdc-checkbox .mdc-checkbox__ripple .mat-mdc-checkbox-ripple,
.mdc-checkbox__ripple {
  display: none;
}

mat-row.mat-mdc-row:not(:last-of-type),
mat-header-row.mat-mdc-header-row,
mat-footer-row.mat-mdc-footer-row:not(:last-of-type) {
  border-bottom: 1px solid var(--border-gray) !important;
}

mat-header-row.mat-mdc-header-row {
  background: var(--background-gray);
}

.table.mat-mdc-table .mat-mdc-row:hover,
.table .mat-mdc-row:hover {
  background-color: var(--color-hover);
  background: var(--color-hover);
  cursor: pointer;
  filter: drop-shadow(0px 4px 8px rgba(0, 0, 0, 0.16));
}

.mat-mdc-table .mdc-data-table__cell,
.mat-mdc-table .mdc-data-table__header-cell {
  border: 0 !important;
}

.mat-mdc-tab-group {
  height: 100%;
}

.mat-mdc-tab-group.mat-primary .mat-ink-bar {
  background: var(--color-4);
}

.mat-mdc-tab-header {
  position: sticky;
  top: 0;
  border-bottom: none;
  z-index: 2;
}

.mat-mdc-tab-list {
  border-bottom: 1px solid var(--border-gray);
}

.mdc-tab__text-label {
  height: 46px;
  min-width: 26px;
  padding: 0;
  margin-right: 32px;
  font-size: 1.4rem;
  color: var(--primary-text-color);
  font-weight: 400;
  opacity: 1;
}

.mat-mdc-tab:not(.mat-mdc-tab-disabled) .mdc-tab__text-label,
.mat-mdc-tab-link:not(.mat-mdc-tab-disabled) .mdc-tab__text-label,
.mat-mdc-tab-link:not(.mat-mdc-tab-disabled):focus .mdc-tab__text-label {
  color: var(--primary-text-color);
}

.mdc-tab__text-label.cdk-focused {
  background-color: transparent;
}

.mdc-tab__text-label:last-child {
  margin-right: 0;
}

.mdc-tab--active .mdc-tab__text-label {
  font-weight: 500;
  color: var(--color-4);
}

.mat-mdc-tab-body-wrapper {
  flex-grow: 1;
}

.mat-mdc-tab-body-content {
  padding: 0;
}

.mat-mdc-tab-link.mdc-tab {
  height: unset;
}

.overlay-bg,
.cdk-overlay-dark-backdrop {
  background-color: rgba(17, 17, 17, 0.7) !important;
}

.cdk-overlay-pane {
  height: unset !important;
}

.mdc-checkbox-frame {
  border-color: var(--border-gray);
}

.mdc-checkbox-layout .mdc-checkbox-label {
  font-size: 1.4rem;
}

.mat-mdc-checkbox label {
  font-size: 1.4rem;
}

.mat-mdc-checkbox .mdc-checkbox .mdc-checkbox__native-control:enabled ~ .mdc-checkbox__background .mdc-checkbox__checkmark,
.mat-mdc-checkbox.mat-primary {
  color: #fff !important;
  --mdc-checkbox-selected-checkmark-color: #fff;
}

.mat-mdc-checkbox .mdc-checkbox .mdc-checkbox__native-control:enabled ~ .mdc-checkbox__background .mdc-checkbox__mixedmark {
  color: #fff;
  border-color: #fff;
}

.mat-mdc-checkbox-touch-target {
  display: none;
}

.mat-mdc-tab-label-container {
  border-bottom-style: none !important;
}

.mat-mdc-dialog-container,
.mat-mdc-dialog-container .mdc-dialog__content,
.app-modal .mat-mdc-dialog-container .mdc-dialog__content,
.modal-content {
  letter-spacing: normal !important;
  font-family: "Poppins" !important;
  line-height: 1.5 !important;
}

@media (max-width: 1024px) {
  /* modal overrides */
  .cdk-overlay-container .cdk-overlay-pane.product-modal {
    max-width: 95vw !important;
  }
}
@media (max-width: 768px) {
  .mat-mdc-card.card {
    padding: 1.6rem;
  }
}
@media (min-width: 0) and (max-width: 600px) {
  .mat-mdc-tab-group {
    padding-top: 2.5rem;
  }
  .mat-mdc-tab-header {
    padding-left: 0;
    padding-right: 0;
    border-bottom: 0;
  }
  .mat-mdc-tab-label:first-child {
    margin-left: 1.6rem;
  }
  .mat-mdc-tab-label:last-child {
    margin-right: 1.6rem;
  }
  .mat-mdc-tab-body-content {
    padding: 1.6rem;
    overflow-x: hidden;
  }
  .mat-mdc-card.card {
    position: relative;
    padding: 0.8rem;
    border-radius: 4px;
    border: 1px solid var(--border-gray);
    margin-bottom: 1.6rem;
    box-shadow: unset;
  }
}
@media (max-width: 599px) {
  .cdk-overlay-pane.mat-mdc-dialog-panel {
    max-width: unset;
  }
}
@media print {
  .mat-mdc-dialog-container .mdc-dialog__surface {
    box-shadow: none !important;
  }
  .overlay-bg,
  .cdk-overlay-dark-backdrop {
    background-color: rgb(255, 255, 255) !important;
  }
}
.mat-mdc-table .mat-mdc-header-cell {
  font-family: "Poppins", sans-serif !important;
}
/*!******************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[5].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[5].rules[0].oneOf[0].use[2]!./node_modules/ngx-toastr/toastr.css?ngGlobalStyle ***!
  \******************************************************************************************************************************************************************************************************************************************/
/* based on angular-toastr css https://github.com/Foxandxss/angular-toastr/blob/cb508fe6801d6b288d3afc525bb40fee1b101650/dist/angular-toastr.css */

/* position */
.toast-center-center {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.toast-top-center {
  top: 0;
  right: 0;
  width: 100%;
}
.toast-bottom-center {
  bottom: 0;
  right: 0;
  width: 100%;
}
.toast-top-full-width {
  top: 0;
  right: 0;
  width: 100%;
}
.toast-bottom-full-width {
  bottom: 0;
  right: 0;
  width: 100%;
}
.toast-top-left {
  top: 12px;
  left: 12px;
}
.toast-top-right {
  top: 12px;
  right: 12px;
}
.toast-bottom-right {
  right: 12px;
  bottom: 12px;
}
.toast-bottom-left {
  bottom: 12px;
  left: 12px;
}

/* toast styles */
.toast-title {
  font-weight: bold;
}
.toast-message {
  word-wrap: break-word;
}
.toast-message a,
.toast-message label {
  color: #FFFFFF;
}
.toast-message a:hover {
  color: #CCCCCC;
  text-decoration: none;
}
.toast-close-button {
  position: relative;
  right: -0.3em;
  top: -0.3em;
  float: right;
  font-size: 20px;
  font-weight: bold;
  color: #FFFFFF;
  text-shadow: 0 1px 0 #ffffff;
  /* opacity: 0.8; */
}
.toast-close-button:hover,
.toast-close-button:focus {
  color: #000000;
  text-decoration: none;
  cursor: pointer;
  opacity: 0.4;
}
/*Additional properties for button version
 iOS requires the button element instead of an anchor tag.
 If you want the anchor version, it requires `href="#"`.*/
button.toast-close-button {
  padding: 0;
  cursor: pointer;
  background: transparent;
  border: 0;
}
.toast-container {
  pointer-events: none;
  position: fixed;
  z-index: 999999;
}
.toast-container * {
  box-sizing: border-box;
}
.toast-container .ngx-toastr {
  position: relative;
  overflow: hidden;
  margin: 0 0 6px;
  padding: 15px 15px 15px 50px;
  width: 300px;
  border-radius: 3px 3px 3px 3px;
  background-position: 15px center;
  background-repeat: no-repeat;
  background-size: 24px;
  box-shadow: 0 0 12px #999999;
  color: #FFFFFF;
}
.toast-container .ngx-toastr:hover {
  box-shadow: 0 0 12px #000000;
  opacity: 1;
  cursor: pointer;
}
/* https://github.com/FortAwesome/Font-Awesome-Pro/blob/master/advanced-options/raw-svg/regular/info-circle.svg */
.toast-info {
  background-image: url("");
}
/* https://github.com/FortAwesome/Font-Awesome-Pro/blob/master/advanced-options/raw-svg/regular/times-circle.svg */
.toast-error {
  background-image: url("");
}
/* https://github.com/FortAwesome/Font-Awesome-Pro/blob/master/advanced-options/raw-svg/regular/check.svg */
.toast-success {
  background-image: url("");
}
/* https://github.com/FortAwesome/Font-Awesome-Pro/blob/master/advanced-options/raw-svg/regular/exclamation-triangle.svg */
.toast-warning {
  background-image: url("");
}
.toast-container.toast-top-center .ngx-toastr,
.toast-container.toast-bottom-center .ngx-toastr {
  width: 300px;
  margin-left: auto;
  margin-right: auto;
}
.toast-container.toast-top-full-width .ngx-toastr,
.toast-container.toast-bottom-full-width .ngx-toastr {
  width: 96%;
  margin-left: auto;
  margin-right: auto;
}
.ngx-toastr {
  background-color: #030303;
  pointer-events: auto;
}
.toast-success {
  background-color: #51A351;
}
.toast-error {
  background-color: #BD362F;
}
.toast-info {
  background-color: #2F96B4;
}
.toast-warning {
  background-color: #F89406;
}
.toast-progress {
  position: absolute;
  left: 0;
  bottom: 0;
  height: 4px;
  background-color: #000000;
  opacity: 0.4;
}
/* Responsive Design */
@media all and (max-width: 240px) {
  .toast-container .ngx-toastr.div {
    padding: 8px 8px 8px 50px;
    width: 11em;
  }
  .toast-container .toast-close-button {
    right: -0.2em;
    top: -0.2em;
  }
}
@media all and (min-width: 241px) and (max-width: 480px) {
  .toast-container .ngx-toastr.div {
    padding: 8px 8px 8px 50px;
    width: 18em;
  }
  .toast-container .toast-close-button {
    right: -0.2em;
    top: -0.2em;
  }
}
@media all and (min-width: 481px) and (max-width: 768px) {
  .toast-container .ngx-toastr.div {
    padding: 15px 15px 15px 50px;
    width: 25em;
  }
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/resolve-url-loader/index.js??ruleSet[1].rules[6].rules[1].use[0]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[6].rules[1].use[1]!./src/form-field-styles.scss?ngGlobalStyle ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* form fields */
.form-field-group {
  flex: 1 1 auto;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  flex-wrap: wrap;
  grid-gap: 1.6rem;
  gap: 1.6rem;
}

.form-field-group.halves {
  flex: 1 1 auto;
  width: 100%;
  flex-wrap: nowrap;
}

.form-field-group.halves > .form-field {
  max-width: calc(50% - 8px);
}

.form-field-group.thirds {
  flex: 1 1 auto;
  width: 100%;
  flex-wrap: nowrap;
}

.form-field-group.thirds > .form-field {
  max-width: 33.333%;
}

.form-field-wrapper > input {
  max-width: 100%;
}

.form-field-group .form-field {
  flex: 1;
  max-width: 100%;
  margin-bottom: 0;
}

.form-field {
  display: flex;
  width: 100%;
}

.form-field.small {
  margin-bottom: 1.6rem;
}

.form-field.large {
  margin-bottom: 2.4rem;
}

.form-field.small.m-b-0 {
  margin-bottom: 0;
}

/* outlined inputs with floating labels (like material) */
.form-field.outline:not(.row) {
  flex-direction: column;
}

.form-field.outline.row {
  flex-direction: row;
}

.form-field-wrapper {
  position: relative;
  flex: 1 1 auto;
  display: flex;
  align-items: center;
}

.form-field-wrapper > label {
  position: absolute;
  font-weight: 400;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background-color: white;
  color: var(--secondary-text-color);
  margin: 0 1.2rem;
  transition: 0.1s all ease-out;
  transform-origin: left top;
  pointer-events: none;
  white-space: nowrap;
}

.form-field-wrapper textarea > label {
  top: 20px;
}

.large .form-field-wrapper > input,
.large .form-field-wrapper textarea,
.large .form-field-wrapper .ng-select,
.large .form-field-wrapper .ng-select.ng-select-single,
.large .form-field-wrapper .ng-select.ng-select-multiple {
  min-height: 52px;
  padding: 1.4rem 1.2rem;
  font-size: 1.6rem;
}

.large .form-field-wrapper > label,
.large .form-field-wrapper textarea > label,
.large .form-field-wrapper .ng-select > label,
.large .form-field-wrapper .ng-select.ng-select-single > label,
.large .form-field-wrapper .ng-select.ng-select-multiple > label {
  font-size: 1.6rem;
}

.small .form-field-wrapper > input,
.small .form-field-wrapper textarea,
.small .form-field-wrapper .ng-select,
.small .form-field-wrapper .ng-select.ng-select-single,
.small .form-field-wrapper .ng-select.ng-select-multiple {
  min-height: 38px;
  padding: 0.8rem 1.2rem;
  font-size: 1.4rem;
}

.small .form-field-wrapper > label,
.small .form-field-wrapper textarea > label,
.small .form-field-wrapper .ng-select > label,
.small .form-field-wrapper .ng-select.ng-select-single > label,
.small .form-field-wrapper .ng-select.ng-select-multiple > label {
  font-size: 1.4rem;
}

.form-field-wrapper > input {
  flex: 1 1 auto;
  outline: none;
  border: 1px solid var(--border-gray);
  border-radius: 4px;
  transition: 0.1s ease-out;
  color: var(--primary-text-color);
  max-width: 100%;
}
.form-field-wrapper > input.hasIcon {
  padding-right: 4rem;
}
.form-field-wrapper > input:focus {
  border-color: var(--color-4);
}
.form-field-wrapper > input:focus + label, .form-field-wrapper > input:focus + div + label {
  color: var(--color-4);
  top: 3px;
  padding: 0 0.4rem;
  margin: 0 0.8rem;
  transform: translateY(-50%) scale(0.75);
}
.form-field-wrapper > input:hover {
  border-color: var(--color-3);
}
.form-field-wrapper > input:hover + label, .form-field-wrapper > input:hover + div + label {
  color: var(--color-3);
}
.form-field-wrapper > input:not(:placeholder-shown) + label, .form-field-wrapper > input:disabled + .disabled.float-label, .form-field-wrapper > input:not(:placeholder-shown) + div + label {
  top: 3px;
  padding: 0 0.4rem;
  margin: 0 0.8rem;
  transform: translateY(-50%) scale(0.75);
}
.form-field-wrapper > input:disabled {
  pointer-events: none;
  color: var(--light-gray);
}
.form-field-wrapper > input:disabled:placeholder-shown:not(:focus) + label:not(.disabled.float-label) {
  background: unset;
}

.outline.form-field.has-errors .form-field-wrapper > input,
.outline.form-field.has-errors .form-field-wrapper > textarea {
  border-color: var(--error-color-4);
}
.outline.form-field.has-errors .form-field-wrapper > input + label, .outline.form-field.has-errors .form-field-wrapper > input + div + label,
.outline.form-field.has-errors .form-field-wrapper > textarea + label,
.outline.form-field.has-errors .form-field-wrapper > textarea + div + label {
  color: var(--error-color-4);
}
.outline.form-field.has-errors .form-field-wrapper > input:hover,
.outline.form-field.has-errors .form-field-wrapper > textarea:hover {
  border-color: var(--error-color-3);
}
.outline.form-field.has-errors .form-field-wrapper > input:hover + label, .outline.form-field.has-errors .form-field-wrapper > input:hover + div + label,
.outline.form-field.has-errors .form-field-wrapper > textarea:hover + label,
.outline.form-field.has-errors .form-field-wrapper > textarea:hover + div + label {
  color: var(--error-color-3);
}
.outline.form-field.has-errors .form-field-wrapper > input:focus,
.outline.form-field.has-errors .form-field-wrapper > textarea:focus {
  border-color: var(--error-color-4);
}
.outline.form-field.has-errors .form-field-wrapper > input:focus + label, .outline.form-field.has-errors .form-field-wrapper > input:focus + div + label,
.outline.form-field.has-errors .form-field-wrapper > textarea:focus + label,
.outline.form-field.has-errors .form-field-wrapper > textarea:focus + div + label {
  color: var(--error-color-4);
}
.outline.form-field.has-errors .form-field-wrapper > input:not(:placeholder-shown) + label,
.outline.form-field.has-errors .form-field-wrapper > textarea:not(:placeholder-shown) + label {
  color: var(--error-color-4);
}

.outline.form-field.has-errors > label {
  color: var(--error-color-4);
}

.form-field-wrapper .ng-select.ng-select-single,
.form-field-wrapper .ng-select.ng-select-multiple {
  flex: 1 1 auto;
  outline: none;
  transition: 0.1s ease-out;
  color: var(--primary-text-color);
  max-width: 100%;
  border-radius: 4px;
  border: 1px solid var(--border-gray);
}
.form-field-wrapper .ng-select.ng-select-single .ng-select-container,
.form-field-wrapper .ng-select.ng-select-multiple .ng-select-container {
  padding: 0;
  border: 0;
  min-height: unset;
  height: unset;
}
.form-field-wrapper .ng-select.ng-select-single .ng-select-container .ng-value-container,
.form-field-wrapper .ng-select.ng-select-multiple .ng-select-container .ng-value-container {
  padding: 0;
}
.form-field-wrapper .ng-select.ng-select-single .ng-value-container .ng-value .caption,
.form-field-wrapper .ng-select.ng-select-multiple .ng-value-container .ng-value .caption {
  font-size: 1.2rem;
}
.form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel,
.form-field-wrapper .ng-select.ng-select-multiple .ng-dropdown-panel {
  text-align: left;
}
.form-field-wrapper .ng-select.ng-select-single.ng-select-focused,
.form-field-wrapper .ng-select.ng-select-multiple.ng-select-focused {
  border-color: var(--color-4);
}
.form-field-wrapper .ng-select.ng-select-single.ng-select-focused + label,
.form-field-wrapper .ng-select.ng-select-multiple.ng-select-focused + label {
  color: var(--color-4);
}
.form-field-wrapper .ng-select.ng-select-single.ng-select-focused:not(.ng-select-opened) > .ng-select-container, .form-field-wrapper .ng-select.ng-select-single.ng-select:not(.ng-select-opened).select-small > .ng-select-container:hover,
.form-field-wrapper .ng-select.ng-select-multiple.ng-select-focused:not(.ng-select-opened) > .ng-select-container,
.form-field-wrapper .ng-select.ng-select-multiple.ng-select:not(.ng-select-opened).select-small > .ng-select-container:hover {
  outline: none;
  box-shadow: none;
  border: none;
}
.form-field-wrapper .ng-select.ng-select-single:hover,
.form-field-wrapper .ng-select.ng-select-multiple:hover {
  border-color: var(--color-3);
}
.form-field-wrapper .ng-select.ng-select-single:hover + label,
.form-field-wrapper .ng-select.ng-select-multiple:hover + label {
  color: var(--color-3);
}
.form-field-wrapper .ng-select.ng-select-single:required:not(.ng-invalid) + label, .form-field-wrapper .ng-select.ng-select-single.ng-select-focused.ng-select-opened + label, .form-field-wrapper .ng-select.ng-select-single.float-label + label, .form-field-wrapper .ng-select.ng-select-single div + label,
.form-field-wrapper .ng-select.ng-select-multiple:required:not(.ng-invalid) + label,
.form-field-wrapper .ng-select.ng-select-multiple.ng-select-focused.ng-select-opened + label,
.form-field-wrapper .ng-select.ng-select-multiple.float-label + label,
.form-field-wrapper .ng-select.ng-select-multiple div + label {
  top: 3px;
  padding: 0 0.4rem;
  margin: 0 0.8rem;
  transform: translateY(-50%) scale(0.75);
}
.form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel .ng-dropdown-header .ng-select.ng-select-single.search,
.form-field-wrapper .ng-select.ng-select-multiple .ng-dropdown-panel .ng-dropdown-header .ng-select.ng-select-single.search {
  border: 0;
}
.form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-marked,
.form-field-wrapper .ng-select.ng-select-multiple .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-marked {
  background: var(--color-hover);
  color: var(--text-primary-color);
}
.form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected,
.form-field-wrapper .ng-select.ng-select-multiple .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected {
  background: var(--color-0);
  color: var(--text-primary-color);
}
.form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel .ng-dropdown-panel-items .ng-option,
.form-field-wrapper .ng-select.ng-select-multiple .ng-dropdown-panel .ng-dropdown-panel-items .ng-option {
  padding: 0.8rem 1.6rem;
  font-size: 1.4rem;
}
.form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel .ng-dropdown-panel-items:hover,
.form-field-wrapper .ng-select.ng-select-multiple .ng-dropdown-panel .ng-dropdown-panel-items:hover {
  background: var(--color-hover);
}
.form-field-wrapper .ng-select.ng-select-single:disabled,
.form-field-wrapper .ng-select.ng-select-multiple:disabled {
  pointer-events: none;
  color: var(--light-gray);
}

.outline.form-field.has-errors .ng-select {
  border-color: var(--error-color-4);
}
.outline.form-field.has-errors .ng-select + label {
  color: var(--error-color-4);
}
.outline.form-field.has-errors .ng-select:hover {
  border-color: var(--error-color-3);
}
.outline.form-field.has-errors .ng-select:hover + label {
  color: var(--error-color-3);
}
.outline.form-field.has-errors .ng-select:focus {
  border-color: var(--error-color-4);
}
.outline.form-field.has-errors .ng-select:focus + label {
  color: var(--error-color-4);
}
.outline.form-field.has-errors .ng-select:not(:placeholder-shown) + label {
  color: var(--error-color-4);
}

.form-field-wrapper textarea {
  flex: 1 1 auto;
  outline: none;
  border: 1px solid var(--border-gray);
  border-radius: 4px;
  transition: 0.1s ease-out;
  color: var(--text-primary-color);
  padding: 0.8rem 1.2rem;
  resize: none;
}
.form-field-wrapper textarea:focus {
  border-color: var(--color-4);
}
.form-field-wrapper textarea:focus + label {
  color: var(--color-4);
  top: 4px;
  padding: 0 0.4rem;
  margin: 0 0.8rem;
  transform: translateY(-50%) scale(0.75);
}
.form-field-wrapper textarea:hover {
  border-color: var(--color-3);
}
.form-field-wrapper textarea:hover + label {
  color: var(--color-3);
}
.form-field-wrapper textarea.float-label + label {
  top: 3px;
  padding: 0 0.4rem;
  margin: 0 0.8rem;
  transform: translateY(-50%) scale(0.75);
}
.form-field-wrapper textarea:not(:placeholder-shown) + label {
  top: 4px;
  padding: 0 0.4rem;
  margin: 0 0.8rem;
  transform: translateY(-50%) scale(0.75);
}
.form-field-wrapper textarea:disabled {
  pointer-events: none;
}

.form-field-message {
  display: flex;
  min-height: 22px;
  height: auto;
  padding: 0.4rem;
}

.form-field-message:empty {
  height: 0;
  padding: 0;
  min-height: 0;
}

.info-msg {
  color: var(--secondary-text-color);
  flex: 1 1 auto;
  align-items: flex-start;
}

.error-msg {
  color: var(--error-color-4);
  display: flex;
  align-items: flex-start;
}
.error-msg .mat-icon.error {
  min-width: fit-content;
  font-size: 14px;
  color: var(--error-color-4);
  margin-right: 0.4rem;
  width: unset;
  height: unset;
}

button.input-icon,
button.input-icon:hover {
  background: none;
  border: none;
  padding: 0;
}

.mat-icon.suffix {
  flex: 0 0 24px;
  position: absolute;
  right: 8px;
}

input:-webkit-autofill + label {
  top: 3px;
  padding: 0 0.4rem;
  margin: 0 0.8rem;
  transform: translateY(-50%) scale(0.75);
}

.form-field-wrapper label.always-active {
  top: 0.3rem;
  padding: 0 0.4rem;
  margin: 0 0.8rem;
  transform: translateY(-50%) scale(0.75);
}

@media (min-width: 960px) and (max-width: 1120px) {
  .form-field-group.halves,
  .form-field-group.thirds {
    flex-wrap: wrap;
    flex-direction: column;
    grid-gap: 0;
    gap: 0;
  }
  .form-field-group.halves .form-field,
  .form-field-group.thirds .form-field {
    max-width: 100%;
  }
}
@media (max-width: 600px) {
  .form-field-group.halves,
  .form-field-group.thirds {
    flex-wrap: wrap;
    flex-direction: column;
    grid-gap: 0;
    gap: 0;
  }
  .form-field-group.halves .form-field,
  .form-field-group.thirds .form-field {
    max-width: 100%;
  }
}
/*!****************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ng-select/ng-select/themes/default.theme.css ***!
  \****************************************************************************************************************************************************************************************************************************************************/
.ng-select.ng-select-opened>.ng-select-container{background:#fff;border-color:hsl(0,0%,70%) #ccc hsl(0,0%,85%)}.ng-select.ng-select-opened>.ng-select-container:hover{box-shadow:none}.ng-select.ng-select-opened>.ng-select-container .ng-arrow{top:-2px;border-color:rgba(0,0,0,0) rgba(0,0,0,0) #999;border-width:0 5px 5px}.ng-select.ng-select-opened>.ng-select-container .ng-arrow:hover{border-color:rgba(0,0,0,0) rgba(0,0,0,0) #333}.ng-select.ng-select-opened.ng-select-top>.ng-select-container{border-top-right-radius:0;border-top-left-radius:0}.ng-select.ng-select-opened.ng-select-right>.ng-select-container{border-top-right-radius:0;border-bottom-right-radius:0}.ng-select.ng-select-opened.ng-select-bottom>.ng-select-container{border-bottom-right-radius:0;border-bottom-left-radius:0}.ng-select.ng-select-opened.ng-select-left>.ng-select-container{border-top-left-radius:0;border-bottom-left-radius:0}.ng-select.ng-select-focused:not(.ng-select-opened)>.ng-select-container{border-color:#007eff;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 0 3px rgba(0,126,255,.1)}.ng-select.ng-select-disabled>.ng-select-container{background-color:#f9f9f9}.ng-select .ng-has-value .ng-placeholder{display:none}.ng-select .ng-select-container{color:#333;background-color:#fff;border-radius:4px;border:1px solid #ccc;min-height:36px;align-items:center}.ng-select .ng-select-container:hover{box-shadow:0 1px 0 rgba(0,0,0,.06)}.ng-select .ng-select-container .ng-value-container{align-items:center;padding-left:10px}[dir=rtl] .ng-select .ng-select-container .ng-value-container{padding-right:10px;padding-left:0}.ng-select .ng-select-container .ng-value-container .ng-placeholder{color:#999}.ng-select.ng-select-single .ng-select-container{height:36px}.ng-select.ng-select-single .ng-select-container .ng-value-container .ng-input{top:5px;left:0;padding-left:10px;padding-right:50px}[dir=rtl] .ng-select.ng-select-single .ng-select-container .ng-value-container .ng-input{padding-right:10px;padding-left:50px}.ng-select.ng-select-multiple.ng-select-disabled>.ng-select-container .ng-value-container .ng-value{background-color:#f9f9f9;border:1px solid hsl(0,0%,90%)}.ng-select.ng-select-multiple.ng-select-disabled>.ng-select-container .ng-value-container .ng-value .ng-value-label{padding:0 5px}.ng-select.ng-select-multiple .ng-select-container .ng-value-container{padding-top:5px;padding-left:7px}[dir=rtl] .ng-select.ng-select-multiple .ng-select-container .ng-value-container{padding-right:7px;padding-left:0}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{font-size:.9em;margin-bottom:5px;color:#333;background-color:rgb(234.6,244.68,255);border-radius:2px;margin-right:5px}[dir=rtl] .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{margin-right:0;margin-left:5px}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value.ng-value-disabled{background-color:#f9f9f9}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value.ng-value-disabled .ng-value-label{padding-left:5px}[dir=rtl] .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value.ng-value-disabled .ng-value-label{padding-left:0;padding-right:5px}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-label{display:inline-block;padding:1px 5px}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon{display:inline-block;padding:1px 5px}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon:hover{background-color:rgb(209.1,231.78,255)}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon.left{border-right:1px solid rgb(183.6,218.88,255)}[dir=rtl] .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon.left{border-left:1px solid rgb(183.6,218.88,255);border-right:none}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon.right{border-left:1px solid rgb(183.6,218.88,255)}[dir=rtl] .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon.right{border-left:0;border-right:1px solid rgb(183.6,218.88,255)}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-input{padding:0 0 3px 3px}[dir=rtl] .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-input{padding:0 3px 3px 0}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-input>input{color:#000}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-placeholder{top:5px;padding-bottom:5px;padding-left:3px}[dir=rtl] .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-placeholder{padding-right:3px;padding-left:0}.ng-select .ng-clear-wrapper{color:#999}.ng-select .ng-clear-wrapper:hover .ng-clear{color:#d0021b}.ng-select .ng-clear-wrapper:focus .ng-clear{color:#d0021b}.ng-select .ng-clear-wrapper:focus{outline:none}.ng-select .ng-spinner-zone{padding:5px 5px 0 0}[dir=rtl] .ng-select .ng-spinner-zone{padding:5px 0 0 5px}.ng-select .ng-arrow-wrapper{width:25px;padding-right:5px}[dir=rtl] .ng-select .ng-arrow-wrapper{padding-left:5px;padding-right:0}.ng-select .ng-arrow-wrapper:hover .ng-arrow{border-top-color:#666}.ng-select .ng-arrow-wrapper .ng-arrow{border-color:#999 rgba(0,0,0,0) rgba(0,0,0,0);border-style:solid;border-width:5px 5px 2.5px}.ng-dropdown-panel{background-color:#fff;border:1px solid #ccc;box-shadow:0 1px 0 rgba(0,0,0,.06);left:0}.ng-dropdown-panel.ng-select-top{bottom:100%;border-top-right-radius:4px;border-top-left-radius:4px;border-bottom-color:hsl(0,0%,90%);margin-bottom:-1px}.ng-dropdown-panel.ng-select-top .ng-dropdown-panel-items .ng-option:first-child{border-top-right-radius:4px;border-top-left-radius:4px}.ng-dropdown-panel.ng-select-right{left:100%;top:0;border-top-right-radius:4px;border-bottom-right-radius:4px;border-bottom-left-radius:4px;border-bottom-color:hsl(0,0%,90%);margin-bottom:-1px}.ng-dropdown-panel.ng-select-right .ng-dropdown-panel-items .ng-option:first-child{border-top-right-radius:4px}.ng-dropdown-panel.ng-select-bottom{top:100%;border-bottom-right-radius:4px;border-bottom-left-radius:4px;border-top-color:hsl(0,0%,90%);margin-top:-1px}.ng-dropdown-panel.ng-select-bottom .ng-dropdown-panel-items .ng-option:last-child{border-bottom-right-radius:4px;border-bottom-left-radius:4px}.ng-dropdown-panel.ng-select-left{left:-100%;top:0;border-top-left-radius:4px;border-bottom-right-radius:4px;border-bottom-left-radius:4px;border-bottom-color:hsl(0,0%,90%);margin-bottom:-1px}.ng-dropdown-panel.ng-select-left .ng-dropdown-panel-items .ng-option:first-child{border-top-left-radius:4px}.ng-dropdown-panel .ng-dropdown-header{border-bottom:1px solid #ccc;padding:5px 7px}.ng-dropdown-panel .ng-dropdown-footer{border-top:1px solid #ccc;padding:5px 7px}.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup{-webkit-user-select:none;user-select:none;padding:8px 10px;font-weight:500;color:rgba(0,0,0,.54);cursor:pointer}.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup.ng-option-disabled{cursor:default}.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup.ng-option-marked{background-color:rgb(244.8,249.84,255)}.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup.ng-option-selected,.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup.ng-option-selected.ng-option-marked{color:rgba(0,0,0,.54);background-color:rgb(234.6,244.68,255);font-weight:600}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option{background-color:#fff;color:rgba(0,0,0,.87);padding:8px 10px}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected,.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked{color:#333;background-color:rgb(234.6,244.68,255)}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected .ng-option-label,.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked .ng-option-label{font-weight:600}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-marked{background-color:rgb(244.8,249.84,255);color:#333}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-disabled{color:#ccc}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-child{padding-left:22px}[dir=rtl] .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-child{padding-right:22px;padding-left:0}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .ng-tag-label{font-size:80%;font-weight:400;padding-right:5px}[dir=rtl] .ng-dropdown-panel .ng-dropdown-panel-items .ng-option .ng-tag-label{padding-left:5px;padding-right:0}[dir=rtl] .ng-dropdown-panel{direction:rtl;text-align:right}/*# sourceMappingURL=default.theme.css.map */

/*!******************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/tippy.js/dist/tippy.css ***!
  \******************************************************************************************************************************************************************************************************************************/
.tippy-box[data-animation=fade][data-state=hidden]{opacity:0}[data-tippy-root]{max-width:calc(100vw - 10px)}.tippy-box{position:relative;background-color:#333;color:#fff;border-radius:4px;font-size:14px;line-height:1.4;white-space:normal;outline:0;transition-property:transform,visibility,opacity}.tippy-box[data-placement^=top]>.tippy-arrow{bottom:0}.tippy-box[data-placement^=top]>.tippy-arrow:before{bottom:-7px;left:0;border-width:8px 8px 0;border-top-color:initial;transform-origin:center top}.tippy-box[data-placement^=bottom]>.tippy-arrow{top:0}.tippy-box[data-placement^=bottom]>.tippy-arrow:before{top:-7px;left:0;border-width:0 8px 8px;border-bottom-color:initial;transform-origin:center bottom}.tippy-box[data-placement^=left]>.tippy-arrow{right:0}.tippy-box[data-placement^=left]>.tippy-arrow:before{border-width:8px 0 8px 8px;border-left-color:initial;right:-7px;transform-origin:center left}.tippy-box[data-placement^=right]>.tippy-arrow{left:0}.tippy-box[data-placement^=right]>.tippy-arrow:before{left:-7px;border-width:8px 8px 8px 0;border-right-color:initial;transform-origin:center right}.tippy-box[data-inertia][data-state=visible]{transition-timing-function:cubic-bezier(.54,1.5,.38,1.11)}.tippy-arrow{width:16px;height:16px;color:#333}.tippy-arrow:before{content:"";position:absolute;border-color:transparent;border-style:solid}.tippy-content{position:relative;padding:5px 9px;z-index:1}
/*!***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/resolve-url-loader/index.js??ruleSet[1].rules[6].rules[1].use[0]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[6].rules[1].use[1]!./src/styles.scss?ngGlobalStyle ***!
  \***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/*ng-select default styles*/
/* CSS Reset */
/* box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Set core root defaults */
html {
  font-size: 10px;
  height: 100%;
  overflow-y: hidden;
}

html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  height: 100%;
  margin: 0;
  font-family: "Poppins", sans-serif;
  line-height: 1.5;
  letter-spacing: normal;
}

/* Typography */
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
li,
label,
input,
textarea,
form,
fieldset,
legend {
  font-family: "Poppins", sans-serif;
  margin: unset;
  color: var(--primary-text-color);
}

.mat-display-4 {
  font-size: 5.6rem;
  font-weight: 400;
  line-height: 1.5;
}

.mat-display-3 {
  font-size: 4rem;
  font-weight: 400;
  line-height: 1.5;
}

.mat-display-2 {
  font-size: 3rem;
  font-weight: 500;
  line-height: 1.5;
}

.mat-display-1 {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.5;
}

.mat-headline {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.5;
}

.mat-title {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.5;
}

.mat-subheading-2,
.mat-dialog-title {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
}

.mat-subheading-1 {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.5;
}

.mat-body-1 {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
}

.mat-body-2 {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
}

.mat-button {
  font-size: 1.4rem;
  font-weight: 500;
}

.mat-caption {
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.5;
}

.mat-error,
.mat-hint,
.error-msg {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.5rem;
}

.mat-input {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5;
}

/* a elements that don't have a class get default styles */
a:not([class]) {
  text-decoration: none;
  color: var(--color-4);
}

/* Make images easier to work with */
img,
picture {
  max-width: 100%;
  display: block;
}

/* Utility classes */
.d-none {
  display: none;
}

.extra-bold {
  font-weight: 700;
}

strong,
.bold {
  font-weight: 600;
}

.semi-bold,
.mat-body-2.semi-bold {
  font-weight: 500;
}

.fw-normal {
  font-weight: 400;
}

.italic {
  font-style: italic;
}

.cursor-hand {
  cursor: pointer;
}

.text-right {
  text-align: right;
}

.text-left {
  text-align: left;
}

.text-center {
  text-align: center;
}

.text-ellipsis,
.truncate {
  max-width: 100%;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.noBreak {
  white-space: nowrap;
}

.warning-color {
  color: var(--warning-color-5);
}

.warning-bg {
  background: var(--warning-color-0);
}

.error-color {
  color: var(--error-color-5);
}

.error-bg {
  background: var(--error-color-0);
}

.mat-icon.error {
  color: var(--error-color-5);
}

.white-bg {
  background: #fff;
}

.gray-bg {
  background: var(--background-gray);
}

.md-18 {
  font-size: 1.6rem;
  width: 16px;
  height: 16px;
}

.md-16 {
  font-size: 1.6rem;
  width: 16px;
  height: 16px;
}

.md-12 {
  font-size: 1.2rem;
  width: 12px;
  height: 12px;
}

.d-flex {
  display: flex;
}

.flex-column {
  flex-direction: column;
}

.flex-row {
  flex-direction: row;
}

.flex-row-reverse {
  flex-direction: row-reverse;
}

.justify-content-center {
  justify-content: center;
}

.align-items-center {
  align-items: center;
}

.pad-0 {
  padding: 0;
}

.pad-8 {
  padding: 0.8rem;
}

.pad-t-8 {
  padding-top: 0.8rem;
}

.pad-b-8 {
  padding-bottom: 0.8rem;
}

.pad-l-8 {
  padding-left: 0.8rem;
}

.pad-r-8 {
  padding-right: 0.8rem;
}

.pad-16 {
  padding: 1.6rem;
}

.pad-t-16 {
  padding-top: 1.6rem;
}

.pad-b-16 {
  padding-bottom: 1.6rem;
}

.pad-l-16 {
  padding-left: 1.6rem;
}

.pad-r-16 {
  padding-right: 1.6rem;
}

.pad-24 {
  padding: 2.4rem;
}

.pad-t-24 {
  padding-top: 2.4rem;
}

.pad-b-24 {
  padding-bottom: 2.4rem;
}

.pad-l-24 {
  padding-left: 2.4rem;
}

.pad-r-24 {
  padding-right: 2.4rem;
}

.m-0 {
  margin: 0;
}

.m-t-0 {
  margin-top: 0;
}

.m-b-0 {
  margin-bottom: 0;
}

.m-r-0 {
  margin-right: 0;
}

.m-l-0 {
  margin-left: 0;
}

.m-t-4 {
  margin-top: 0.4rem;
}

.m-b-4 {
  margin-bottom: 0.4rem;
}

.m-r-4 {
  margin-right: 0.4rem;
}

.m-l-4 {
  margin-left: 0.4rem;
}

.m-t-8 {
  margin-top: 0.8rem;
}

.m-b-8 {
  margin-bottom: 0.8rem;
}

.m-r-8 {
  margin-right: 0.8rem;
}

.m-l-8 {
  margin-left: 0.8rem;
}

.m-t-16 {
  margin-top: 1.6rem;
}

.m-b-16 {
  margin-bottom: 1.6rem;
}

.m-r-16 {
  margin-right: 1.6rem;
}

.m-l-16 {
  margin-left: 1.6rem;
}

.m-t-24 {
  margin-top: 2.4rem;
}

.m-b-24 {
  margin-bottom: 2.4rem;
}

.m-r-24 {
  margin-right: 2.4rem;
}

.m-l-24 {
  margin-left: 2.4rem;
}

.m-t-32 {
  margin-top: 3.2rem;
}

.m-b-32 {
  margin-bottom: 3.2rem;
}

.m-r-32 {
  margin-right: 3.2rem;
}

.m-l-32 {
  margin-left: 3.2rem;
}

.m-l-auto {
  margin-left: auto;
}

.m-r-auto {
  margin-right: auto;
}

[hidden].hidden-d-none {
  display: none !important;
}

[hidden] {
  visibility: hidden;
  opacity: 0;
}

.no-break {
  white-space: nowrap;
}

.no-border {
  border: none;
}

.w-100 {
  width: 100%;
}

/* Theme styles */
:root {
  --primary-text-color: #222222;
  --secondary-text-color: #757575;
  --gray: #757575;
  --light-gray: #ababab;
  --dark-gray: #656565;
  --border-gray: #d7d7d7;
  --background-gray: #f8f8f8;
  --background-light-gray: #eeeeee;
  --background-white: #fff;
  --info-color-0: #e0eeff;
  --info-color-1: #c5dcfa;
  --info-color-2: #8ab9f6;
  --info-color-3: #5096f1;
  --info-color-4: #1672ec;
  --info-color-5: #0f56b3;
  --info-color-6: #0a3977;
  --error-color-0: #fdeeeb;
  --error-color-1: #fcd0cf;
  --error-color-2: #faa09e;
  --error-color-3: #f7716e;
  --error-color-4: #F5413D;
  --error-color-5: #da100b;
  --error-color-6: #910b08;
  --warning-color-0: #fffbe8;
  --warning-color-1: #fff5cc;
  --warning-color-2: #ffeb99;
  --warning-color-3: #ffe267;
  --warning-color-4: #ffce01;
  --warning-color-5: #d4b011;
  --warning-color-6: #8e750b;
  --success-color-0: #ebf8eb;
  --success-color-1: #c5f2c7;
  --success-color-2: #8ce590;
  --success-color-3: #52d858;
  --success-color-4: #2ab930;
  --success-color-5: #26ab2c;
  --success-color-6: #155d18;
}

:root.blue {
  --color-hover: #f3f8ff;
  --color-0: #e0eeff;
  --color-1: #c5dcfa;
  --color-2: #8ab9f6;
  --color-3: #5096f1;
  --color-4: #1672ec;
  --color-5: #0f56b3;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: var(--color-5);
  --nav-item-bg-active: var(--color-4);
  --nav-item-bg-hover: var(--color-4);
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.blue-inverted {
  --color-hover: #f3f8ff;
  --color-0: #e0eeff;
  --color-1: #c5dcfa;
  --color-2: #8ab9f6;
  --color-3: #5096f1;
  --color-4: #1672ec;
  --color-5: #0f56b3;
  --nav-font-color: var(--dark-gray);
  --nav-font-color-2: var(--secondary-text-color);
  --nav-font-color-active: var(--color-4);
  --nav-border-top: var(--background-light-gray);
  --nav-border-left: var(--color-4);
  --header-nav-bg-color: #fbfbfb;
  --nav-item-bg-active: var(--color-4);
  --nav-item-bg-hover: #f3f8ff;
  --nav-item-border-active: var(--dark-gray);
  --nav-shadow-color: rgba(0, 0, 0, 0.24);
}

:root.purple {
  --color-hover: #f3effe;
  --color-0: #e1d8fc;
  --color-1: #c3b0f8;
  --color-2: #a489f5;
  --color-3: #8661f1;
  --color-4: #683aee;
  --color-5: #4e2cb3;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: var(--color-4);
  --nav-item-bg-active: var(--color-5);
  --nav-item-bg-hover: var(--color-5);
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.purple-inverted {
  --color-hover: #f3effe;
  --color-0: #e1d8fc;
  --color-1: #c3b0f8;
  --color-2: #a489f5;
  --color-3: #8661f1;
  --color-4: #683aee;
  --color-5: #4e2cb3;
  --nav-font-color: #656565;
  --nav-font-color-2: var(--secondary-text-color);
  --nav-font-color-active: var(--color-4);
  --nav-border-top: var(--background-light-gray);
  --nav-border-left: var(--color-4);
  --header-nav-bg-color: #fbfbfb;
  --nav-item-bg-active: var(--color-4);
  --nav-item-bg-hover: #f3effe;
  --nav-item-border-active: var(--dark-gray);
  --nav-shadow-color: rgba(0, 0, 0, 0.24);
}

:root.light-purple {
  --color-hover: #fbebfc;
  --color-0: #f9d6fc;
  --color-1: #efaef9;
  --color-2: #d983ef;
  --color-3: #be62e0;
  --color-4: #9933cc;
  --color-5: #7825af;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: var(--color-4);
  --nav-item-bg-active: var(--color-5);
  --nav-item-bg-hover: var(--color-5);
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.light-purple-inverted {
  --color-hover: #fbebfc;
  --color-0: #f9d6fc;
  --color-1: #efaef9;
  --color-2: #d983ef;
  --color-3: #be62e0;
  --color-4: #9933cc;
  --color-5: #7825af;
  --nav-font-color: var(--dark-gray);
  --nav-font-color-2: var(--secondary-text-color);
  --nav-font-color-active: var(--color-4);
  --nav-border-top: var(--background-light-gray);
  --nav-border-left: var(--color-4);
  --header-nav-bg-color: #fbfbfb;
  --nav-item-bg-active: var(--color-4);
  --nav-item-bg-hover: #fbebfc;
  --nav-item-border-active: var(--dark-gray);
  --nav-shadow-color: rgba(0, 0, 0, 0.24);
}

:root.orange {
  --color-hover: #fcf5ea;
  --color-0: #fbead0;
  --color-1: #f7d1a2;
  --color-2: #e8ab71;
  --color-3: #d2844b;
  --color-4: #b5521a;
  --color-5: #9b3b13;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: var(--color-4);
  --nav-item-bg-active: var(--color-5);
  --nav-item-bg-hover: var(--color-5);
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.orange-inverted {
  --color-hover: #fcf5ea;
  --color-0: #fbead0;
  --color-1: #f7d1a2;
  --color-2: #e8ab71;
  --color-3: #d2844b;
  --color-4: #b5521a;
  --color-5: #9b3b13;
  --nav-font-color: var(--dark-gray);
  --nav-font-color-2: var(--secondary-text-color);
  --nav-font-color-active: var(--color-4);
  --nav-border-top: var(--background-light-gray);
  --nav-border-left: var(--color-4);
  --header-nav-bg-color: #fbfbfb;
  --nav-item-bg-active: var(--color-4);
  --nav-item-bg-hover: #fcf5ea;
  --nav-item-border-active: var(--dark-gray);
  --nav-shadow-color: rgba(0, 0, 0, 0.24);
}

:root.green {
  --color-hover: #eff9e1;
  --color-0: #e5f8ca;
  --color-1: #c7f298;
  --color-2: #97da61;
  --color-3: #67b537;
  --color-4: #31850a;
  --color-5: #227207;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: var(--color-4);
  --nav-item-bg-active: var(--color-5);
  --nav-item-bg-hover: var(--color-5);
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.green-inverted {
  --color-hover: #eff9e1;
  --color-0: #e5f8ca;
  --color-1: #c7f298;
  --color-2: #97da61;
  --color-3: #67b537;
  --color-4: #31850a;
  --color-5: #227207;
  --nav-font-color: var(--dark-gray);
  --nav-font-color-2: var(--secondary-text-color);
  --nav-font-color-active: var(--color-4);
  --nav-border-top: var(--background-light-gray);
  --nav-border-left: var(--color-4);
  --header-nav-bg-color: #fbfbfb;
  --nav-item-bg-active: var(--color-4);
  --nav-item-bg-hover: #eff9e1;
  --nav-item-border-active: var(--dark-gray);
  --nav-shadow-color: rgba(0, 0, 0, 0.24);
}

:root.turquoise {
  --color-hover: #e9faf3;
  --color-0: #d3f8e9;
  --color-1: #aaf2db;
  --color-2: #78d9c3;
  --color-3: #4fb4a6;
  --color-4: #21837e;
  --color-5: #186d70;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: var(--color-4);
  --nav-item-bg-active: var(--color-5);
  --nav-item-bg-hover: var(--color-5);
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.turquoise-inverted {
  --color-hover: #e9faf3;
  --color-0: #d3f8e9;
  --color-1: #aaf2db;
  --color-2: #78d9c3;
  --color-3: #4fb4a6;
  --color-4: #21837e;
  --color-5: #186d70;
  --nav-font-color: var(--dark-gray);
  --nav-font-color-2: var(--secondary-text-color);
  --nav-font-color-active: var(--color-4);
  --nav-border-top: var(--background-light-gray);
  --nav-border-left: var(--color-4);
  --header-nav-bg-color: #fbfbfb;
  --nav-item-bg-active: var(--color-4);
  --nav-item-bg-hover: #e9faf3;
  --nav-item-border-active: var(--dark-gray);
  --nav-shadow-color: rgba(0, 0, 0, 0.24);
}

:root.brown {
  --color-hover: #fbf8f0;
  --color-0: #f9f1d6;
  --color-1: #f4e1b0;
  --color-2: #e0c282;
  --color-3: #c19d5c;
  --color-4: #996e2e;
  --color-5: #835821;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: var(--color-4);
  --nav-item-bg-active: var(--color-5);
  --nav-item-bg-hover: var(--color-5);
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.brown-inverted {
  --color-hover: #fbf8f0;
  --color-0: #f9f1d6;
  --color-1: #f4e1b0;
  --color-2: #e0c282;
  --color-3: #c19d5c;
  --color-4: #996e2e;
  --color-5: #835821;
  --nav-font-color: var(--dark-gray);
  --nav-font-color-2: var(--secondary-text-color);
  --nav-font-color-active: var(--color-4);
  --nav-border-top: var(--background-light-gray);
  --nav-border-left: var(--color-4);
  --header-nav-bg-color: #fbfbfb;
  --nav-item-bg-active: var(--color-4);
  --nav-item-bg-hover: #fbf8f0;
  --nav-item-border-active: var(--dark-gray);
  --nav-shadow-color: rgba(0, 0, 0, 0.24);
}

:root.red {
  --color-hover: #f3f8ff;
  --color-0: #e0eeff;
  --color-1: #c5dcfa;
  --color-2: #8ab9f6;
  --color-3: #5096f1;
  --color-4: #1672ec;
  --color-5: #0f56b3;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: #b82e2e;
  --nav-item-bg-active: #9b2727;
  --nav-item-bg-hover: #9b2727;
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.black {
  --color-hover: #f3f8ff;
  --color-0: #e0eeff;
  --color-1: #c5dcfa;
  --color-2: #8ab9f6;
  --color-3: #5096f1;
  --color-4: #1672ec;
  --color-5: #0f56b3;
  --nav-font-color: #fff;
  --nav-font-color-2: #fff;
  --nav-font-color-active: #fff;
  --nav-border-top: #fff;
  --nav-border-left: #fff;
  --header-nav-bg-color: #3f3e3e;
  --nav-item-bg-active: var(--primary-text-color);
  --nav-item-bg-hover: var(--primary-text-color);
  --nav-item-border-active: #fff;
  --nav-shadow-color: transparent;
}

:root.white {
  --color-hover: #f3f8ff;
  --color-0: #e0eeff;
  --color-1: #c5dcfa;
  --color-2: #8ab9f6;
  --color-3: #5096f1;
  --color-4: #1672ec;
  --color-5: #0f56b3;
  --nav-font-color: var(--dark-gray);
  --nav-font-color-2: var(--dark-gray);
  --nav-font-color-active: var(--dark-gray);
  --nav-border-top: var(--dark-gray);
  --nav-border-left: var(--dark-gray);
  --header-nav-bg-color: #fbfbfb;
  --nav-item-bg-active: var(--background-light-gray);
  --nav-item-bg-hover: var(--background-light-gray);
  --nav-item-border-active: var(--dark-gray);
  --nav-shadow-color: rgba(0, 0, 0, 0.24);
}

.primary {
  color: var(--primary-text-color);
}

.secondary {
  color: var(--secondary-text-color);
}

/* buttons */
button,
.btn {
  font-family: "Poppins", sans-serif;
  display: flex;
  justify-content: center;
  text-align: center;
  align-items: center;
  white-space: nowrap;
  -webkit-user-select: none;
  user-select: none;
  border: 1px solid transparent;
  padding: unset;
  line-height: unset;
  border-radius: 4px;
  background: none;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

button:not(:disabled):hover,
.btn:not(:disabled):hover {
  cursor: pointer;
}

.btn-primary {
  font-size: 1.6rem;
  font-weight: 500;
  color: #fff;
  background: var(--color-4);
  border-color: var(--color-4);
}

.btn-primary:hover {
  background: var(--color-3);
  border-color: var(--color-3);
}

.btn-primary.selected,
.btn-primary.active,
.btn-primary:active,
.btn-primary:focus {
  background: var(--color-5);
  border-color: var(--color-5);
}

.btn-primary.disabled,
.btn-primary.disabled:hover,
.btn-primary.disabled:active,
.btn-primary.disabled.active,
.btn-primary.disabled:focus,
.btn-primary:disabled,
.btn-primary:disabled:hover,
.btn-primary:disabled:active,
.btn-primary:disabled.active,
.btn-primary:disabled:focus {
  background: var(--color-2);
  border-color: var(--color-2);
  cursor: not-allowed;
}

.btn-secondary {
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--color-4);
  background: #fff;
  border-color: var(--color-4);
}

.btn-secondary:hover {
  color: var(--color-3);
  background: var(--color-hover);
  border-color: var(--color-3);
}

.btn-secondary.selected,
.btn-secondary.active,
.btn-secondary:active,
.btn-secondary:focus {
  color: var(--color-5);
  background: var(--color-0);
  border-color: var(--color-5);
}

.btn-secondary:disabled,
.btn-secondary.disabled,
.btn-secondary.disabled:active,
.btn-secondary.disabled.active,
.btn-secondary.disabled:focus {
  color: var(--light-gray);
  border-color: var(--border-gray);
}

.btn-tertiary {
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--dark-gray);
  background: #fff;
  border-color: var(--dark-gray);
}

.btn-tertiary:hover {
  color: var(--secondary-text-color);
  background: var(--background-gray);
  border-color: var(--secondary-text-color);
}

.btn-tertiary.selected,
.btn-tertiary.active,
.btn-tertiary:active,
.btn-tertiary:focus {
  color: var(--primary-text-color);
  background: #ebebeb;
  border-color: var(--primary-text-color);
}

.btn-tertiary:disabled,
.btn-tertiary.disabled {
  color: var(--light-gray);
  border-color: var(--border-gray);
}

.btn-ltgray {
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--primary-text-color);
  background: #fff;
  border-color: var(--border-gray);
}

.btn-ltgray:hover {
  color: var(--primary-text-color);
  border-color: var(--border-gray);
  background: var(--background-gray);
}

.btn-ltgray.selected,
.btn-ltgray.active,
.btn-ltgray:active,
.btn-ltgray:focus {
  color: var(--primary-text-color);
  border-color: var(--border-gray);
  background: var(--background-light-gray);
}

.btn-ltgray.disabled,
.btn-ltgray.disabled:hover,
.btn-ltgray.disabled:active,
.btn-ltgray.disabled.active,
.btn-ltgray.disabled:focus,
.btn-ltgray:disabled,
.btn-ltgray:disabled:hover,
.btn-ltgray:disabled:active,
.btn-ltgray:disabled.active,
.btn-ltgray:disabled:focus {
  color: var(--light-gray);
  cursor: not-allowed;
}

.btn-success {
  background: var(--success-color-5);
  border-color: var(--success-color-5);
  color: #fff;
}

.btn-success:hover {
  background: var(--success-color-5);
  border-color: var(--success-color-5);
}

.btn-success:disabled {
  background: var(--light-gray);
  border-color: var(--border-gray);
}

.btn-warning {
  background: var(--error-color-4);
  border-color: var(--error-color-4);
  color: #fff;
}

.btn-warning:hover {
  background: var(--error-color-5);
  border-color: var(--error-color-5);
  color: #fff;
}

.btn.dark-gray,
a.dark-gray,
a.dark-gray:not([href]):not([tabindex]) {
  color: var(--dark-gray);
}

.btn.dark-gray:hover,
a.dark-gray:hover,
a.dark-gray:not([href]):not([tabindex]):hover {
  color: var(--primary-text-color);
}

/* buttons that look like links and text links have the same styles */
.btn-link {
  border: 0;
  background: 0;
  box-shadow: 0;
}

.btn-link,
.text-link {
  color: var(--color-4);
  font-weight: 500;
}

.btn-link.bold,
.text-link.bold {
  font-weight: 600;
}

.btn-link:hover,
.text-link:hover {
  color: var(--color-3);
  background: var(--color-hover);
}

.btn-link.selected,
.btn-link.active,
.btn-link:active,
.btn-link:focus,
.text-link.selected,
.text-link.active,
.text-link:active,
.text-link:focus {
  color: var(--color-5);
  background: none;
}

.btn-link:disabled,
.btn-link.disabled,
.text-link:disabled,
.text-link.disabled {
  color: var(--light-gray);
}

.btn-link.lg,
.text-link.lg {
  font-size: 1.6rem;
}

.btn-link.md,
.btn-link.sm,
.text-link.md,
.text-link.sm {
  font-size: 1.4rem;
}

.link-btn {
  text-decoration: none;
  display: flex;
  align-items: center;
}

.link-btn .mat-icon {
  display: flex;
  align-items: center;
}

.text-link,
a:not([href]):not([tabindex]) {
  color: var(--color-4);
  text-decoration: none;
  cursor: pointer;
}

.text-link:hover,
a:not([href]):not([tabindex]):hover {
  background: none;
  color: var(--color-3);
}

a.btn-tertiary:not([href]):not([tabindex]) {
  color: var(--dark-gray);
}

a.btn-tertiary:not([href]):not([tabindex]):hover {
  color: var(--secondary-text-color);
}

/* button Sizes */
.btn-lg {
  padding: 1.2rem 1.8rem;
  font-size: 1.6rem;
}

.btn-md {
  padding: 1rem 1.6rem;
  font-size: 1.4rem;
}

.btn-sm {
  padding: 0.8rem 1.2rem;
  font-size: 1.4rem;
}

.btn-xs {
  padding: 0.4rem 0.8rem;
  font-size: 1.4rem;
}

/* used for the table header dropdown menu buttons and anywhere else you would need this size button */
.btn-icon-40,
.menu-icon {
  width: 40px;
  height: 40px;
  flex: 0 0 40px;
}

.btn-icon-36 {
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
}

.btn-icon-only {
  border: 0;
  background: none;
  box-shadow: none;
}

/* buttons sizes for buttons with icons  */
.btn-lg .mat-icon {
  flex: 0 0 1.8rem;
  align-self: center;
  font-size: 1.8rem;
}

.btn-md .mat-icon,
.btn-sm .mat-icon {
  flex: 0 0 1.6rem;
  align-self: center;
  font-size: 1.6rem;
  margin-right: 0.8rem;
}

.btn-loader {
  font-size: 1.8rem;
}

/* Badges */
label.badge {
  font-size: 1.4rem;
}

label.badge-sm {
  font-size: 1.2rem;
}

.badge {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  padding: 0.6rem 0.8rem;
  border-radius: 4px;
}

.badge-sm {
  font-size: 1.2rem;
  padding-top: 0.2rem;
  padding-bottom: 0.2rem;
}

.badge.m-r-24 {
  margin-right: 2.4rem;
}

.badge.blue {
  background: #e0eeff;
  color: var(--primary-text-color);
}

.badge.purple {
  background: #f7e6ff;
  color: var(--primary-text-color);
}

.badge.orange {
  background: #fff1ec;
  color: var(--primary-text-color);
}

.badge.red {
  background: var(--error-color-1);
  color: var(--primary-text-color);
}

.badge.yellow {
  background: var(--warning-color-1);
  color: var(--primary-text-color);
}

.badge.green {
  background: var(--success-color-1);
  color: var(--primary-text-color);
}

.badge.gray {
  background: var(--background-gray);
  color: var(--primary-text-color);
}

.badge.color-theme {
  background: var(--color-1);
  color: var(--primary-text-color);
}

.badge.color-theme .mat-icon {
  color: var(--color-4);
}

/* Toast Messages
    These toast message styles are for
      normal toasts (no title and has icon)
      toasts with no title and no icon (.no-icon)
      toasts with with title (.alert-bar)
*/
.toast-container.toast-top-center {
  color: var(--primary-text-color);
}

.toast-container.toast-top-center .ngx-toastr,
.toast-container.toast-top-center .no-icon,
.toast-container .ngx-toastr {
  width: max-content;
  padding: 0.8rem 1.6rem;
  margin: 2.4rem auto;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.15);
  border-radius: 4px;
  display: flex;
  align-items: center;
}

#toast-container > div {
  pointer-events: auto;
}

.toast-container .alert-bar {
  width: 620px;
  padding: 0.8rem 1.6rem;
  margin: 2.4rem auto;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.15);
  border-radius: 4px;
  position: relative;
}

.toast-container .ngx-toastr:hover,
.toast-container .no-icon:hover,
.toast-container .alert-bar:hover {
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.15);
}

.toast-success {
  background-image: none;
  background: var(--success-color-0);
  border: 1px solid var(--success-color-5);
}

.toast-success:not(.no-icon):before {
  font-family: "Material Icons";
  content: "check_circle";
  -webkit-font-feature-settings: "liga";
  transform: rotate(0.03deg);
  color: var(--success-color-5);
  margin-right: 0.8rem;
  font-size: 18px;
}

.toast-info {
  background-image: none;
  background: #e0eeff;
  border: 1px solid #1672ec;
}

.toast-info:not(.no-icon):before {
  font-family: "Material Icons";
  content: "info";
  -webkit-font-feature-settings: "liga";
  transform: rotate(0.03deg);
  color: #1672ec;
  margin-right: 0.8rem;
  font-size: 18px;
}

.toast-warning {
  background-image: none;
  background: var(--warning-color-0);
  border: 1px solid var(--warning-color-5);
}

.toast-warning:not(.no-icon):before {
  font-family: "Material Icons";
  content: "warning";
  -webkit-font-feature-settings: "liga";
  transform: rotate(0.03deg);
  color: var(--warning-color-5);
  margin-right: 0.8rem;
  font-size: 18px;
}

.toast-error {
  background-image: none;
  background: var(--error-color-0);
  border: 1px solid var(--error-color-4);
}

.toast-error:not(.no-icon):before {
  font-family: "Material Icons";
  content: "warning";
  -webkit-font-feature-settings: "liga";
  transform: rotate(0.03deg);
  color: var(--error-color-4);
  margin-right: 0.8rem;
  font-size: 18px;
}

.alert-bar:before {
  position: absolute;
  margin-top: -1px;
}

.toast-title {
  color: var(--primary-text-color);
  font-size: 1.6rem;
  font-weight: 500;
  padding-bottom: 4;
}

.toast-message {
  padding-right: 4rem;
  min-width: fit-content;
  font-size: 1.4rem;
  color: var(--primary-text-color);
  font-weight: 400;
  line-height: 1.5;
  flex: 1 1 auto;
  order: 1;
  white-space: break-spaces;
}

.alert-bar .toast-title,
.alert-bar .toast-message {
  margin-left: 2.4rem;
}

button.toast-close-button {
  flex: 0 0 20px;
  padding: 0;
  cursor: pointer;
  background: transparent;
  border: 0;
  color: var(--primary-text-color);
  font-weight: 400;
  order: 2;
  top: 50%;
  position: absolute;
  transform: translateY(-50%);
  right: 0.8rem;
}

button.toast-close-button:hover {
  color: var(--primary-text-color);
  opacity: 1;
  font-weight: 400;
}

/* Elevations */
.elevation-1 {
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.24);
}

.elevation-2 {
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.16);
}

.elevation-3 {
  box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.12);
}

.elevation-4 {
  box-shadow: 0px 16px 24px rgba(0, 0, 0, 0.12);
}

/* Overlays*/
.overlay-bg {
  background: rgba(34, 34, 34, 0.62);
}

.overlay-dkGray-bg {
  background: var(--dark-gray);
}

/* Modals */
.modal-header {
  display: flex;
  align-items: flex-start;
  padding-bottom: 0;
  justify-content: space-between;
  gap: 1.6px;
  padding: 2.4rem 4rem;
}

.modal-header h2 {
  display: flex;
  position: relative;
  flex: 1 1 auto;
  align-items: center;
  margin: 0;
  padding: 0;
}

.modal-header button {
  flex: 0 0 24px;
}

.modal-header button:focus-visible {
  outline: none;
}

.modal-content {
  max-height: 75vh;
  padding: 0 4rem 2.4rem;
  flex: 1 1 auto;
  justify-content: flex-start;
}

.modal-footer {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
  padding: 1.6rem 4rem;
  margin-bottom: 0;
  min-height: 40px;
  gap: 1.6rem;
  border-top: 1px solid var(--border-gray);
}

.modal-footer .footer-left,
.modal-footer .footer-right {
  flex: 0 0 auto;
  display: flex;
  gap: 1.6rem;
}

.btn-modal {
  padding: 1rem 1.6rem;
  font-size: 1.4rem;
}

.btn-modal-print {
  padding: 0.8rem;
}

/* Input overrides */
input {
  color: var(--primary-text-color);
}

input::placeholder {
  opacity: 1;
}

/* Change the autofill color */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px white inset;
}

/*change text in autofill textbox*/
input:-webkit-autofill {
  -webkit-text-fill-color: var(--primary-text-color);
}

form.readonly input:-webkit-autofill {
  -webkit-text-fill-color: var(--secondary-text-color);
  -webkit-box-shadow: 0 0 0 30px #fff inset;
}

/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox */
input[type=number] {
  -moz-appearance: textfield;
}

/* cards */
.card {
  background: #fff;
  border: 1px solid var(--border-gray);
  border-radius: 4px;
}

.card.disabled {
  background: var(--background-light-gray);
}

.card.pad-16 {
  padding: 1.6rem;
}

.card.pad-24 {
  padding: 2.4rem;
}

.card.no-border {
  border: none;
}

.card.account {
  padding: 4rem;
  max-width: 520px;
  width: 100%;
  justify-content: center;
  align-items: center;
  flex: 0 0 auto;
  align-self: center;
  box-shadow: 0px 4px 46px 0px rgba(0, 0, 0, 0.1490196078);
}

.card.account h1 {
  flex: 1 1 auto;
  align-self: center;
  margin: 0 0 2.4rem 0;
  text-align: center;
}

.card.account p:not(.error-msg) {
  flex: 1 1 auto;
  align-self: center;
}

.card.account p.text-center {
  text-align: center;
}

.card.account form {
  display: flex;
  flex-direction: column;
  max-width: 440px;
  width: 100%;
}

/* employee profile cards */
.card.profile-card {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border-gray);
}

.card.profile-card header {
  flex: 1 1 auto;
  padding: 1.6rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--border-gray);
}

.card.profile-card h3 {
  flex: 1 1 auto;
  margin: 0;
  max-width: calc(100% - 32px);
  overflow: hidden;
  text-overflow: ellipsis;
}

.card.profile-card .edit-btn {
  flex: 0 0 40px;
  align-self: center;
}

.card.profile-card .mat-icon {
  color: var(--dark-gray);
}

.card.profile-card .empty-card {
  padding: 16px;
  margin: 0;
}

.card.profile-card form {
  flex: 1 1 auto;
  padding: 16px 16px 0 16px;
  display: flex;
  flex-direction: column;
}

.card.profile-card .ng-container {
  border-radius: 0 !important;
}

.profile-card-footer {
  display: flex;
  width: calc(100% + 32px);
  margin: 0 0 0 -16px;
  padding: 16px;
  align-items: center;
  justify-content: flex-end;
  border-top: 1px solid var(--border-gray);
}

.profile-card-footer .btn {
  padding: 8px 24px;
  margin-left: 8px;
}

/* profile pages with further details (employee profile, applicant profile, position profile ...) */
.profile-details-view {
  padding: 2.4rem;
}
.profile-details-view > header {
  margin-bottom: 1.6rem;
}
.profile-details-view .profile-controls {
  display: flex;
  margin-left: auto;
  align-items: center;
}
.profile-details-view .profile-controls .prev, .profile-details-view .profile-controls .next {
  color: var(--primary-text-color);
}
.profile-details-view .profile-controls .mat-icon {
  color: var(--color-4);
}

.profile-details-view.gray-bg {
  background: var(--background-gray);
}

/* configuration views */
.configuration-page-view {
  padding: 2.4rem;
}
.configuration-page-view > header {
  margin-top: 1.6rem;
  margin-bottom: 1.6rem;
  display: flex;
}
.configuration-page-view > header.column {
  flex-direction: column;
}

.configuration-page-view.showSaveBar {
  height: calc(100% - 55px);
  overflow-y: auto;
}

.back-to-previous-page {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  color: var(--dark-gray);
  margin: 0 0 1.6rem -0.5rem;
  text-decoration: none;
  font-size: 1.4rem;
}

.back-to-previous-page .mat-icon {
  flex: 0 0 24px;
  margin-top: -0.2rem;
  margin-right: 0.8rem;
}

.back-to-previous-page.mobile {
  margin: 0;
  display: none;
}

.back-to-previous-page.mobile .mat-icon {
  margin: 0 0.8rem 0 -0.8rem;
}

/* basic form fields - 32px height  */
.basic.form-field {
  flex: 1 1 auto;
  display: flex;
  margin-bottom: 16px;
  align-items: center;
}

.basic.form-field label,
.basic.form-field input {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-size: 14px;
}

.basic.form-field label {
  flex: 0 1 150px;
  align-self: center;
  margin-right: 32px;
}

.basic.form-field .form-field-wrap {
  display: flex;
  flex-direction: column;
  align-self: center;
  flex: 0 1 216px;
  min-width: 0;
  width: 100%;
  min-height: 40px;
}

.basic .form-field-wrap input {
  flex: 1 1 auto;
  width: 100%;
  height: 40px;
  padding: 0 12px;
  border: 1px solid var(--border-gray);
  border-radius: 4px;
}

.basic .form-field-wrap .datepicker {
  flex: 1 1 auto;
  display: flex;
  width: 100%;
  align-items: center;
}

.basic .form-field-wrap .datepicker input {
  max-width: 180px;
  position: relative;
  z-index: 1;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

form:not(.readonly) .basic.form-field .mat-datepicker-toggle .mat-mdc-icon-button.mat-mdc-button-base {
  width: 36px;
  height: 40px;
  line-height: 32px;
  border: 1px solid var(--border-gray);
  border-left-width: 0;
  border-radius: 0;
  background: var(--background-gray);
}

.basic.form-field .mat-datepicker-toggle .mat-icon {
  font-size: 18px;
  width: 18px;
  height: 18px;
  margin-top: -4px;
}

/* basic form field - hover */
.basic.form-field input:not([type=checkbox]):hover {
  border: 1px solid var(--color-3);
}

/* basic form field - focus */
.basic.form-field input:not([type=checkbox]):focus {
  outline: none;
  border: 1px solid var(--color-4);
}

/* basic form field - error */
.basic.form-field.has-errors label {
  color: var(--error-color-4);
}

.basic.form-field.has-errors input,
.basic.form-field.has-errors input:not([type=checkbox]):hover,
.basic.form-field.has-errors input:not([type=checkbox]):focus,
.basic.form-field.has-errors textarea,
.basic.form-field.has-errors textarea:not([type=checkbox]):hover,
.basic.form-field.has-errors textarea:not([type=checkbox]):focus {
  border: 1px solid var(--error-color-4);
}

.basic.form-field.has-warning input,
.basic.form-field.has-warning input:not([type=checkbox]):hover,
.basic.form-field.has-warning input:not([type=checkbox]):focus {
  border: 1px solid var(--warning-color-5);
}

.basic.form-field.has-errors .error-msg {
  font-size: 12px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--error-color-4);
}

.basic.form-field .warning-msg {
  font-size: 13px;
  color: var(--warning-color-5);
}

.basic.form-field.has-warning .warn-msg {
  font-size: 12px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--warning-color-5);
}

/* basic form fields readonly styles */
form.readonly .basic.form-field label {
  margin-top: 0;
  margin-right: 32px;
}

form.readonly .basic.form-field .form-field-wrap {
  min-height: 24px;
}

form.readonly .basic .form-field-wrap input,
form.readonly .basic .form-field-wrap.datepicker input,
form .basic .form-field-wrap input[disabled] {
  height: 24px;
  padding: 0;
  border: 0;
  pointer-events: none;
  max-width: unset;
  color: var(--secondary-text-color);
  background: none;
}

form.readonly .basic.form-field .mat-datepicker-toggle .mat-icon-button,
form.readonly .basic.form-field .mat-datepicker-toggle .mat-icon {
  display: none;
}

.basic.form-field input::placeholder {
  color: var(--light-gray);
}

/* Remove step icons from number inputs */
/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox */
input[type=number] {
  -moz-appearance: textfield;
}

/* Custom Scrollbar Styles - Chrome and Only */
/* width */
::-webkit-scrollbar {
  width: 14px;
}

/* Track */
::-webkit-scrollbar-track {
  background: var(--background-light-gray);
  box-shadow: inset 0 0 4px #e0e0e0;
  border-radius: 0;
}

/* Handle */
::-webkit-scrollbar-thumb {
  background: #c9c9c9;
  border-radius: 77px;
  border: 3px solid var(--background-light-gray);
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
  background: #c9c9c9;
}

/* search input styles */
.search-wrapper {
  flex: 1 1 auto;
  display: flex;
  background: #fff;
  align-self: center;
}

.search-wrapper form {
  flex: 1 1 auto;
  display: flex;
}

.search-box {
  background: #fff;
  align-self: center;
  flex: 1 1 auto;
  position: relative;
  height: inherit;
  display: inline-block;
  vertical-align: middle;
}

.search-icon {
  position: absolute;
  top: 0.8rem;
  left: 0;
  padding: 0 1.4rem;
  color: var(--light-gray);
}

input.mat-input-element.search-input,
.search-input {
  height: 40px;
  width: 100%;
  border-color: transparent;
  padding-left: 4.8rem;
  position: relative;
  background: transparent;
  border: 1px solid var(--border-gray);
  border-radius: 4px;
  margin-top: 0;
}

input.mat-input-element.search-input:focus,
.search-input:focus {
  outline: none;
  border: 1px solid var(--color-4);
  box-shadow: 0px 0px 0px 2px rgba(24, 144, 255, 0.2);
  border-radius: 4px;
}

/*ng-select custom styles*/
.ng-select {
  display: flex !important;
  flex-direction: column;
  width: 100%;
}

/*ng-select container*/
.ng-select.ng-select-single .ng-select-container,
.ng-select.ng-select-multiple .ng-select-container {
  height: auto;
  border-radius: 4px;
}

.ng-select.ng-select-disabled > .ng-select-container {
  background-color: transparent;
  border-radius: 4px;
  border: none;
}

.ng-select .ng-select-container:hover,
.ng-select.ng-select-disabled > .ng-select-container:hover {
  box-shadow: none;
}

/*placeholder*/
.ng-select .ng-select-container .ng-value-container .ng-placeholder {
  font-size: 16px;
  color: var(--light-gray) !important;
}

/* smaller placeholder text - used in table filters and other areas we use the smaller ng-select font */
.ng-select.search.sm .ng-select-container .ng-value-container .ng-placeholder {
  font-size: 14px;
  color: var(--light-gray);
}

.form-field.basic .ng-select .ng-select-container .ng-value-container .ng-placeholder {
  font-size: 14px;
}

.ng-select.search .ng-select-container .ng-value-container .ng-placeholder {
  font-size: 14px;
}

filters .ng-select.multi-select-filter.select-small.ng-select-multiple .ng-select-container .ng-value-container {
  flex-wrap: nowrap;
  max-width: calc(100% - 36px);
  padding-top: 0;
  padding-bottom: 0;
}

.ng-select .ng-select-container,
.ng-select:not(.multi-select-filter) .ng-select-container .ng-value-label,
.ng-select .ng-dropdown-panel {
  font-size: 16px;
  font-weight: 400;
  color: var(--primary-text-color);
  text-align: left;
}

.small .form-field-wrapper .ng-select .ng-select-container,
.small .form-field-wrapper .ng-select:not(.multi-select-filter) .ng-select-container .ng-value-label,
.small .form-field-wrapper .ng-select .ng-dropdown-panel,
.small .form-field-wrapper .ng-option-label,
.small .form-field-wrapper .ng-value-container {
  font-size: 14px;
}

.ng-select.ng-select-multiple.ng-select-filtered .ng-select-container .ng-value-container .ng-placeholder,
.ng-select.ng-select-multiple .ng-select-container.ng-has-value .ng-value-container .ng-placeholder {
  display: none;
}

.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-placeholder {
  top: 0;
  align-items: center;
  height: 100%;
  padding-bottom: 0;
  padding-left: 0;
}

/*ng-input*/
.ng-select.ng-select-single .ng-select-container .ng-value-container .ng-input {
  top: 0;
  height: 100%;
}

.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-input > input {
  color: unset;
}

.ng-select .ng-select-container .ng-value-container .ng-input > input {
  height: 100%;
  color: var(--primary-text-color);
}

/*arrow styles*/
.ng-select .ng-arrow-wrapper {
  width: 24px;
  height: 24px;
  padding-right: 0;
}

.ng-select.ng-select-disabled .ng-arrow-wrapper {
  display: none;
}

.ng-select .ng-arrow-wrapper .ng-arrow {
  height: 24px !important;
  width: 24px !important;
  border-color: none;
  border-style: none;
  border-width: 0;
  line-height: 1;
  right: 0;
}

.ng-select .ng-arrow-wrapper:hover .ng-arrow {
  border-top-color: transparent;
}

.ng-select .ng-arrow-wrapper .ng-arrow:after {
  font-family: "Material Icons";
  content: "expand_more";
  position: absolute;
  left: 0;
  height: 24px;
  width: 24px;
  font-size: 24px;
  font-weight: normal;
  font-style: normal;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  color: var(--gray);
  transform: rotate(0.03deg);
  text-rendering: optimizeLegibility;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ng-select.ng-select-opened > .ng-select-container .ng-arrow {
  top: 0;
  border: none;
}

/*dropdown panel*/
::ng-deep .ng-dropdown-panel,
::ng-deep .ng-dropdown-panel.ng-select-bottom {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border: none;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.16);
  margin-top: 1px;
}

/*no items found text*/
.ng-select .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-disabled {
  font-size: 14px;
  color: var(--light-gray);
}

.ng-select.select-medium .ng-dropdown-panel .ng-dropdown-panel-items .ng-option p {
  font-size: 1.4rem;
}

/*move search indicator when focused for searchable single select*/
.ng-select.ng-select-single.ng-select-searchable.ng-select-focused:not(.ng-select-filtered) .ng-select-container.ng-has-value .ng-value-container .ng-input {
  position: relative;
  width: auto;
  padding-right: 0;
  padding-left: 0;
  margin-left: 7px;
  flex: 1 1 auto;
  align-self: flex-end;
}

.ng-select.ng-select-single.ng-select-searchable.ng-select-focused:not(.ng-select-filtered) .ng-select-container.ng-has-value .ng-value-container .ng-value {
  flex: 1 0 auto;
}

/*chip styles for mult-select*/
.chip-container,
.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value {
  display: flex;
  align-items: center;
  margin-bottom: 0.7rem;
  background-color: #e0e0e0;
  border: none;
  border-radius: 31px;
  color: var(--primary-text-color);
  font-size: 1.4rem;
  line-height: 22px;
}

.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value:empty {
  display: none;
}

.ng-select.ng-select-multiple.ng-select-disabled > .ng-select-container .ng-value-container .ng-value {
  background-color: transparent;
  border: none;
  margin-bottom: 1.6rem;
  margin-right: 0;
}

.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-label {
  display: inline-flex;
  padding: 3px 7px;
}

.ng-select.ng-select-multiple.ng-select-disabled .ng-select-container .ng-value-container .ng-value .ng-value-label {
  align-items: center;
  padding: 0;
}

.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon {
  padding: 3px 8px 3px 2px;
}

.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon.right {
  border-left: none;
  color: var(--gray);
}

.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon:hover {
  background-color: transparent;
}

/*clear button*/
.ng-select .ng-clear-wrapper {
  width: 20px !important;
  height: 20px;
  margin-right: 10px;
}

.ng-select .ng-clear-wrapper .ng-clear {
  font-size: 0 !important;
}

.ng-select .ng-clear-wrapper .ng-clear::before {
  font-family: "Material Icons Outlined";
  content: "cancel";
  position: absolute;
  top: 0;
  width: 20px;
  height: 20px;
  font-size: 20px;
  color: var(--gray);
  line-height: 1;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/*ng-select small styles*/
.ng-select.select-small {
  max-width: 216px;
  min-height: 40px;
}

.ng-select.ng-select-disabled.select-small,
.ng-select.ng-select-disabled.select-small .ng-select-container {
  min-height: 24px;
}

.ng-select.select-small .ng-select-container {
  min-height: 40px;
  border-color: var(--border-gray);
  border-radius: 4px;
  padding: 0;
}

.ng-select.ng-select-disabled.select-small .ng-select-container {
  align-items: flex-start;
}

.ng-select.ng-select-focused:not(.ng-select-opened).select-small > .ng-select-container {
  outline: none;
  border: 1px solid var(--color-4);
  box-shadow: 0px 0px 0px 2px rgba(24, 144, 255, 0.2);
}

.ng-select:not(.ng-select-opened).select-small > .ng-select-container:hover {
  box-shadow: none;
  border: 1px solid var(--color-3);
  cursor: pointer;
}

.ng-select.ng-select-disabled:not(.ng-select-opened).select-small > .ng-select-container:hover {
  border: 0;
  cursor: default;
}

.ng-select.select-small:not(.ng-select-multiple) .ng-select-container .ng-value-container .ng-input {
  padding-left: 12px;
  padding-bottom: 0;
}

.ng-select.select-small .ng-arrow-wrapper {
  margin-right: 4px;
  margin-left: 8px;
}

.ng-select.select-small .ng-arrow-wrapper .ng-arrow:after {
  color: var(--light-gray);
}

.ng-select.select-small .ng-select-container .ng-value-container,
.ng-select.select-small .ng-select-container .ng-value-container .ng-value,
.ng-select.select-small .ng-select-container .ng-value-container .ng-value .ng-value-label {
  font-size: 1.4rem;
  color: var(--primary-text-color);
}

.ng-select.select-small .ng-select-container .ng-value-container .ng-value:empty {
  display: none;
}

.ng-select.ng-select-disabled.select-small .ng-select-container .ng-value-container .ng-value .ng-value-label {
  color: var(--secondary-text-color);
}

.ng-select.select-small .ng-dropdown-panel.ng-select-bottom {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-color: transparent;
  border: none;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.16);
  margin-top: 0;
}

.ng-dropdown-panel .ng-dropdown-header {
  border-bottom: none;
  padding: 0;
}

.ng-dropdown-panel .ng-dropdown-header:hover {
  background: var(--color-hover);
}

.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items {
  max-height: 185px;
}

/*for multiple small selects dropdown options*/
.ng-select.ng-select-multiple.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option {
  display: flex;
  align-items: center;
  padding-left: 1rem;
}

.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-disabled {
  color: var(--light-gray);
}

.ng-select.ng-select-disabled.select-small .ng-select-container .ng-value-container,
.ng-select.ng-select-disabled.select-small .ng-select-container .ng-value-container .ng-input {
  padding: 0;
}

.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option:not(.ng-option-selected).ng-option-marked,
.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-marked:hover,
.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option:hover,
.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected:hover,
.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked:hover,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-selected.ng-option-marked:hover,
.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-marked:hover {
  background: var(--color-hover);
  border-radius: 0;
}

.ng-select.ng-select-multiple.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option:not(.ng-option-selected).ng-option-marked,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option:not(.ng-option-selected).ng-option-marked {
  background: transparent;
}

.ng-select.ng-select-multiple.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option:not(.ng-option-selected).ng-option-marked:hover,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option:not(.ng-option-selected).ng-option-marked:hover {
  background: var(--color-hover);
}

.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option,
.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option:not(.ng-option-selected).ng-option-marked,
.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected .ng-option-label,
.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked .ng-option-label,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-selected.ng-option-marked .ng-option-label,
.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected:not(.ng-option-marked) .ng-option-label {
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--primary-text-color);
}

/*ng-select small and ng-select medium with outline select-single - check on selection in dropdown*/
.form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected,
.ng-select.ng-select-single.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected,
.ng-select.select-medium.outline .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-selected {
  position: relative;
  padding-right: 2.4rem;
}

.form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected:after,
.ng-select.ng-select-single.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected:after,
.ng-select.ng-select-single.select-medium.outline .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected:after,
.ng-select:not(.ng-select-multiple) .ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-selected:after {
  content: "check";
  position: absolute;
  top: 10px;
  right: 8px;
  width: 16px;
  height: 16px;
  font-family: "Material Icons";
  font-size: 16px;
  font-weight: 700;
  font-style: normal;
  direction: ltr;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  color: var(--success-color-5);
  text-rendering: optimizeLegibility;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transform: rotate(0.03deg);
}

.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected,
.ng-select.select-small .ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-selected {
  background: #fff;
}

/*ng-select medium styles*/
.ng-select.select-medium {
  max-width: 320px;
  min-width: 0;
  min-height: 40px;
}

.ng-select.select-medium .ng-select-container {
  min-height: 40px;
  border-color: var(--border-gray);
}

.ng-select.select-medium .ng-select-container .ng-value-container {
  padding-left: 0.8rem;
}

.ng-select.select-medium .ng-select-container .ng-value-container .ng-placeholder {
  color: var(--secondary-text-color);
}

.ng-select.select-medium .ng-arrow-wrapper {
  margin-right: 8px;
}

.ng-select.select-medium .ng-arrow-wrapper .ng-arrow:after {
  color: var(--gray);
}

.ng-select.select-medium.ng-select-opened > .ng-select-container .ng-arrow:after {
  content: "expand_less";
}

.ng-select.select-medium .ng-dropdown-panel .ng-dropdown-panel-items .ng-option {
  display: flex !important;
  align-items: center;
  padding: 0.8rem 1.6rem;
  color: var(--primary-text-color);
  font-size: 1.4rem;
}

.ng-select.select-medium .ng-dropdown-panel .ng-dropdown-panel-items .ng-option:first-child {
  padding-top: 16px;
}

.ng-select.select-medium .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-marked,
.ng-select.select-medium .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected,
.ng-select.select-medium .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-marked,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-selected,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-selected.ng-option-marked {
  background-color: var(--color-hover);
}

.ng-select.select-medium .name,
.ng-select.select-medium .title,
.ng-select.select-medium .title-small {
  /*to truncate really long names/titles in dropdown*/
  width: 183px;
}

/*medium single*/
.ng-select.ng-select-single.select-medium .ng-select-container {
  padding: 0.8rem 0;
}

.ng-select.ng-select-single.select-medium .ng-select-container .ng-value-container .ng-value {
  display: flex;
  align-items: center;
}

.ng-select.ng-select-single.select-medium .ng-select-container .ng-value-container .ng-value:empty {
  display: none;
}

.ng-select.ng-select-single.select-medium .ng-select-container .ng-value-container .ng-input {
  padding-left: 8px;
}

.ng-select.ng-select-single.select-medium .ng-dropdown-panel .ng-dropdown-header {
  border-bottom: none;
  padding: 16px 16px 8px;
}

.ng-select.ng-select-single.select-medium .ng-dropdown-panel .ng-dropdown-header:hover {
  background-color: var(--color-hover);
}

.ng-select.select-medium .ng-dropdown-panel .ng-dropdown-panel-items .ng-option:first-child {
  padding-top: 8px;
}

/*medium outline*/
.ng-select.select-medium.outline {
  max-width: 100%;
  min-height: 56px;
}

.ng-select.select-medium.outline .ng-select-container {
  min-height: 56px;
  border: 1px solid var(--border-gray);
}

.ng-select.select-medium.outline .ng-select-container {
  border-radius: 4px;
}

.ng-select.select-medium.outline.ng-select-focused:not(.ng-select-opened) > .ng-select-container {
  box-shadow: none;
}

.ng-select.select-medium.outline.ng-select-focused > .ng-select-container {
  border: 1px solid var(--color-4);
}

.ng-select.ng-select-single.select-medium.outline .ng-select-container .ng-value-container .ng-input {
  padding-left: 1.6rem;
}

.ng-select.ng-select-single.select-medium.outline .ng-dropdown-panel.ng-select-bottom {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-color: transparent;
  margin-top: 0;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.16);
}

/*ng-select outline with floating label*/
.select-form-field {
  position: relative;
  padding: 0.8rem 0 0;
}

.ng-select.select-small.outline,
.ng-select.select-medium.outline {
  z-index: 1;
}

.ng-select.select-small.outline + label,
.ng-select.select-medium.outline + label {
  position: absolute;
  top: 0;
  left: 1.2rem;
  padding: 0 4px;
  background: #fff;
  color: var(--secondary-text-color);
  font-size: 1.2rem;
  z-index: 2;
}

/*medium multiple*/
.ng-select.ng-select-multiple.select-medium .ng-select-container {
  padding: 0;
}

.ng-select.ng-select-multiple.select-medium .ng-select-container .ng-value-container {
  position: relative;
  padding-top: 7px;
}

.ng-select.ng-select-multiple.select-medium .ng-select-container .ng-value-container .ng-input {
  position: relative;
  top: -2px;
  height: 100%;
  padding: 0;
  font-size: 14px;
  line-height: 21px;
}

.ng-select.ng-select-multiple.select-medium.ng-select-disabled .ng-select-container .ng-value-container .ng-input {
  display: none;
}

.ng-select.ng-select-multiple.select-medium .ng-dropdown-panel .ng-dropdown-panel-items .ng-option {
  position: relative;
}

/*ng-select medium w/floating label (size 16px like material inputs) */
.ng-select.select-medium.floating-label .ng-select-container .ng-value-container {
  padding-left: 1.6rem;
}

.ng-select.floating-label .ng-select-container .ng-value-container .ng-placeholder {
  font-size: 16px;
}

.ng-select.floating-label .ng-select-container,
.ng-select.floating-label .ng-select-container .ng-value-label,
.ng-select.floating-label .ng-dropdown-panel {
  font-size: 16px;
  font-weight: 400;
  color: var(--primary-text-color);
}

.small .ng-select.floating-label .ng-select-container,
.small .ng-select.floating-label .ng-select-container .ng-value-label,
.small .ng-select.floating-label .ng-dropdown-panel {
  font-size: 14px;
}

.ng-dropdown-panel.floating-label .ng-dropdown-panel-items .ng-option.ng-option-selected,
.ng-dropdown-panel.floating-label .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked,
.ng-dropdown-panel .ng-dropdown-panel-items.scroll-host .ng-option.ng-option-selected.ng-option-marked {
  color: var(--primary-text-color);
  background-color: var(--color-hover);
}

.ng-dropdown-panel.floating-label .ng-dropdown-panel-items .ng-option {
  background-color: #fff;
  color: var(--primary-text-color);
  padding: 8px 16px;
}

.ng-dropdown-panel.floating-label .ng-dropdown-panel-items .ng-option .ng-option-label {
  font-size: 1.6rem;
}

.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected .ng-option-label,
.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected.ng-option-marked .ng-option-label {
  font-weight: 500;
}

.ng-select.select-small.outline.ng-select-focused + label,
.ng-select.select-medium.outline.ng-select-focused + label,
.ng-select.select-medium.outline.floating-label.ng-select-focused + label {
  color: var(--color-4);
}

/*ng-select search styles*/
.ng-select.ng-select-single.search .ng-select-container {
  height: 40px;
  border: 1px solid var(--border-gray);
}

.ng-select.ng-select-opened.ng-select-bottom.search > .ng-select-container {
  border-bottom-right-radius: 4px;
  border-bottom-left-radius: 4px;
}

.ng-select.ng-select-focused.search .ng-select-container {
  border: 1px solid var(--color-4);
  box-shadow: 0px 0px 0px 2px rgba(24, 144, 255, 0.2);
  border-radius: 4px;
}

.ng-select.search .ng-arrow-wrapper {
  display: none;
}

.ng-select.search .ng-clear-wrapper {
  width: 16px !important;
  height: 16px;
}

.ng-select.search .ng-clear-wrapper .ng-clear::before {
  width: 16px;
  height: 16px;
  font-size: 16px;
  color: var(--light-gray);
}

.ng-select.search .ng-dropdown-panel.ng-select-bottom {
  display: none;
}

.ng-select.search .ng-select-container .ng-value-container,
.ng-select.search .ng-select-container .ng-value-container .ng-input {
  padding-left: 32px;
}

.ng-select.search .ng-select-container .ng-value-container .ng-input:before {
  font-family: "Material Icons Outlined";
  content: "search";
  position: absolute;
  top: 5px;
  left: 8px;
  width: 20px;
  height: 20px;
  font-size: 20px;
  color: var(--light-gray);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ng-select.search .ng-select-container .ng-value-container .ng-input > input {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1;
}

#paymentForm .ccFields .form-field-wrapper .ng-select.ng-select-single .ng-dropdown-panel .ng-dropdown-panel-items {
  max-height: 105px;
}

/* name container with avatar and employee name /job title */
.employee {
  display: flex;
  align-items: center;
  max-width: 100%;
}

/*avatar styles*/
.avatar {
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Poppins";
  color: #fff;
  text-transform: uppercase;
}

.avatar img {
  border-radius: 50%;
}

.avatar.chip {
  flex: 0 0 2rem;
  width: 2rem;
  height: 2rem;
  font-size: 0.9rem;
  color: #fff;
  margin-right: 0.8rem;
}

.chip-fullname {
  width: 100px;
  display: inline-block;
}

/* alert styles */
.alert {
  display: flex;
  border-radius: 4px;
  padding: 0.8rem;
}

.alert p {
  align-self: flex-start;
  flex: 1 1 auto;
}

.alert .mat-icon {
  margin-right: 0.8rem;
  flex: 0 0 18px;
  align-self: flex-start;
}

.alert.success {
  border: 1px solid var(--success-color-5);
  background: var(--success-color-0);
}

.alert.success .mat-icon {
  color: var(--success-color-5);
}

.alert.info {
  border: 1px solid var(--info-color-5);
  background: var(--info-color-0);
}

.alert.info .mat-icon {
  color: var(--info-color-5);
}

.alert.warning {
  border: 1px solid var(--warning-color-5);
  background: var(--warning-color-0);
}

.alert.warning .mat-icon {
  color: var(--warning-color-5);
}

.alert.error {
  border: 1px solid var(--error-color-5);
  background: var(--error-color-0);
}

.alert.error .mat-icon {
  color: var(--error-color-5);
}

/* avatar sizes */
.avatar-xl {
  flex: 0 0 12rem;
  width: 12rem;
  height: 12rem;
  font-size: 5.6rem;
}

.avatar-lg {
  flex: 0 0 10rem;
  width: 10rem;
  height: 10rem;
  font-size: 3rem;
}

.avatar-md {
  flex: 0 0 9rem;
  width: 9rem;
  height: 9rem;
  font-size: 3rem;
}

.avatar-64 {
  flex: 0 0 6.4rem;
  width: 6.4rem;
  height: 6.4rem;
  font-size: 2.5rem;
}

.avatar-sm {
  flex: 0 0 3.5rem;
  width: 3.5rem;
  height: 3.5rem;
  font-size: 1.4rem;
  margin-right: 0.8rem;
}

.avatar-24 {
  flex: 0 0 2.4rem;
  width: 2.4rem;
  height: 2.4rem;
  font-size: 1rem;
  margin-right: 0.8rem;
  line-height: 1;
}

.avatar-xs {
  flex: 0 0 1.8rem;
  width: 1.8rem;
  height: 1.8rem;
  font-size: 0.75rem;
  margin-right: 0.8rem;
  line-height: 1;
}

.name-container {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-width: 0;
  align-items: flex-start;
  text-align: left;
}

.name-container.inline {
  flex-direction: row;
  align-items: center;
}

.name {
  flex: 1 1 auto;
  color: var(--primary-text-color);
}

.title {
  flex: 1 1 auto;
}

.title-small {
  font-size: 1.2rem;
}

.title-small span {
  color: var(--secondary-text-color);
}

.noSelect {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
}

/*Checkbox Styles*/
.checkbox-container {
  display: inline-flex;
  align-items: center;
  width: 100%;
  min-width: 0;
  min-height: 20px;
  line-height: 1.5;
}

input[type=checkbox].checkbox {
  position: relative;
  top: 0;
  left: 0;
  display: inline-block;
  margin: 0;
  background-color: transparent; /* For iOS < 15 */
  border-radius: 2px;
  border: 2px solid var(--border-gray);
  font: inherit;
  color: currentColor;
  appearance: none; /* Remove most all native input styles */
  transition: background-color 0.3s ease;
  cursor: pointer;
}

input[type=checkbox].checkbox:disabled {
  border-color: var(--color-1);
}

input[type=checkbox].checkbox:checked {
  border: 0;
  background-color: CanvasText; /* Windows High Contrast Mode */
  background-color: var(--color-4);
}

input[type=checkbox].checkbox:disabled:checked {
  background-color: var(--color-1);
}

input[type=checkbox].checkbox:before {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  color: #fff;
  font-family: "Material Icons";
  font-weight: normal;
  font-style: normal;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  text-rendering: optimizeLegibility;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transform: rotate(0.03deg);
  opacity: 0;
}

input[type=checkbox].checkbox.checkmark:before {
  content: "check";
}

input[type=checkbox].checkbox.indeterminate:before {
  content: "remove";
}

input[type=checkbox].checkbox:checked:before {
  opacity: 1;
}

.checkbox.checkbox-sm,
.checkbox.checkbox-sm:before {
  height: 14px;
  width: 14px;
}

.checkbox.checkbox-sm {
  flex: 0 0 14px;
}

.checkbox.checkbox-sm:before {
  font-size: 14px;
}

.checkbox.checkbox-sm label {
  font-size: 1.4rem;
}

.checkbox.checkbox-lg,
.checkbox.checkbox-lg:before {
  height: 18px;
  width: 18px;
}

.checkbox.checkbox-lg {
  flex: 0 0 18px;
}

.checkbox.checkbox-lg:before {
  font-size: 18px;
}

.checkbox.checkbox-lg label {
  font-size: 1.6rem;
}

input[type=checkbox].checkbox ~ label {
  cursor: pointer;
}

input[type=checkbox].checkbox:disabled {
  border-color: var(--border-gray);
}

input[type=checkbox].checkbox:disabled:checked {
  background-color: var(--color-1);
}

input[type=checkbox].checkbox:disabled:hover,
input[type=checkbox].checkbox:disabled:hover + label {
  cursor: default;
}

.radio-group {
  display: grid;
  place-content: start;
}

.radio-group.filter-dropdown {
  margin: 0;
}

.radio-group.inline {
  display: inline-grid;
  grid-template-columns: 1fr 1fr;
  margin: 1.6rem 0 2rem 0;
}

.radio-group label {
  display: grid;
  grid-template-columns: 2rem auto;
  grid-gap: 1rem;
  margin-bottom: 2rem;
  cursor: pointer;
  align-items: center;
}

.radio-group.inline label {
  grid-template-columns: 2rem auto;
  margin-bottom: 0;
}

.radio-group.filter-dropdown label {
  align-items: center;
}

.radio-group label:last-child {
  margin-bottom: 0;
}

input[type=radio].radio-btn {
  appearance: none; /* Remove most all native input styles */
  background-color: transparent; /* For iOS < 15 */
  margin: 0;
  font: inherit;
  color: currentColor;
  border-radius: 50%;
  border-style: solid;
  border-color: var(--border-gray);
  display: grid;
  place-content: center;
}

input[type=radio].radio-btn::before {
  content: "";
  border-radius: 50%;
  transform: scale(0);
  transition: transform 0.3s ease-in-out;
  background-color: CanvasText; /* Windows High Contrast Mode */
  background-color: var(--color-4);
}

input[type=radio]:checked {
  border-color: var(--color-4);
}

input[type=radio]:checked::before {
  transform: scale(1);
}

.radio-btn.radio-sm {
  height: 15px;
  width: 15px;
  border-width: 1.5px;
}

.radio-btn.radio-sm:before {
  height: 7px;
  width: 7px;
}

.radio-btn.radio-sm + span {
  font-size: 1.4rem;
}

.radio-btn.radio-lg {
  height: 18px;
  width: 18px;
  border-width: 2px;
}

.radio-btn.radio-lg:before {
  height: 10px;
  width: 10px;
}

.radio-btn.radio-lg + span {
  font-size: 1.6rem;
}

.radio-btn.radio-lg + span.mat-body-2 {
  font-size: 1.4rem;
}

input[type=radio].radio-btn:disabled {
  border-color: var(--border-gray);
}

input[type=radio].radio-btn:checked:disabled {
  border-color: var(--color-1);
}

input[type=radio].radio-btn:checked:disabled::before {
  background-color: var(--color-1);
}

/* checkbox pill toggle - (see schedule header for html example) */
.checkbox-pill-switch .switch {
  position: relative;
  width: 26px;
  height: 14px;
}

.checkbox-pill-switch .switch input {
  width: 26px;
  height: 16px;
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  vertical-align: top;
}

@supports (-webkit-touch-callout: none) {
  .checkbox-pill-switch .switch input {
    opacity: 0;
  }
}
.checkbox-pill-switch .slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 26px;
  background-color: var(--light-gray);
  transition: 0.4s;
}

.checkbox-pill-switch .slider:before {
  position: absolute;
  content: "";
  height: 10px;
  width: 10px;
  left: 2px;
  bottom: 2px;
  background-color: white;
  transition: 0.4s;
}

.checkbox-pill-switch input:checked + .slider {
  background-color: var(--color-4);
}

.checkbox-pill-switch input:focus + .slider {
  box-shadow: 0 0 1px var(--color-4);
}

.checkbox-pill-switch input:checked + .slider:before {
  transform: translateX(12px);
}

.checkbox-pill-switch .slider.round {
  border-radius: 10px;
}

.checkbox-pill-switch .slider.round:before {
  border-radius: 50%;
}

.checkbox-pill-switch .switch-label {
  padding-right: 8px;
  vertical-align: top;
  cursor: pointer;
}

/* radio pill toggle (see my-team.component for html example ) */
.radio-pill-switch {
  position: relative;
  display: flex;
  align-items: center;
  white-space: nowrap;
  grid-gap: 0.4rem;
  gap: 0.4rem;
  padding: 0.4rem;
  background: var(--background-light-gray);
  border: none;
  border-radius: 1.4rem;
  box-shadow: inset 0px 1px 2px rgba(97, 97, 97, 0.2), inset 0px 2px 4px rgba(97, 97, 97, 0.2);
}

.radio-pill-switch legend {
  position: absolute;
  font-size: 2px;
  opacity: 0;
}

.radio-pill-switch input {
  opacity: 0;
  position: absolute;
}

.radio-pill-switch label {
  width: 100%;
  padding: 0.4rem 1.2rem;
}

.radio-pill-switch label.icon {
  line-height: 0;
}

.radio-pill-switch label.checked {
  background: #fff;
  border-radius: 1.2rem;
  transition: 0.2s ease-in-out;
  box-shadow: 0px 1px 2px rgba(97, 97, 97, 0.2), 0px 2px 4px rgba(97, 97, 97, 0.2);
}

/*slide toggle button*/
button.slide-toggle-btn {
  border: 0;
  padding: 0;
  background-color: transparent;
  font: inherit;
}

.slide-toggle-btn {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  position: relative;
  margin: 0 1.6rem;
  color: #222;
  cursor: pointer;
  gap: 1ch;
}

.slide-toggle-display--large {
  --offset: 2px;
  --diameter: 17.5px;
}

.slide-toggle-display--small {
  --offset: 1px;
  --diameter: 10px;
}

.slide-toggle-display {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: space-around;
  box-sizing: content-box;
  width: calc(var(--diameter) * 2 + var(--offset) * 2);
  height: calc(var(--diameter) + var(--offset) * 2);
  border-radius: 100vw;
  border: 0.16rem solid var(--border-color); /*added a semi-transparent border so it can be visible in Windows High-Contrast Mode*/
  background-color: var(--light-gray);
}

.slide-toggle-display::before {
  content: "";
  z-index: 2;
  position: absolute;
  top: 50%;
  left: var(--offset);
  box-sizing: border-box;
  width: var(--diameter);
  height: var(--diameter);
  border: 0.16rem solid rgba(0, 0, 0, 0.1); /*added a semi-transparent border so it can be visible in Windows High-Contrast Mode*/
  border-radius: 50%;
  background-color: #fff;
  transform: translate(0, -50%);
}

.slide-toggle-btn.locked .slide-toggle-display::after {
  content: "lock";
  font-family: "Material Icons";
  font-size: 14px;
  position: absolute;
  top: 0;
  right: 3px;
  z-index: 2;
  color: var(--primary-text-color);
  opacity: 1;
}

/*slide toggle focus states*/
.slide-toggle-btn:focus, .slide-toggle-btn:focus:not(:focus-visible) .slide-toggle-display {
  outline: 0;
}

.slide-toggle-btn:focus .slide-toggle-display {
  /*until we decide how are these going to be styled - adding default styles from browsers*/
  outline: 1px dotted #212121;
  outline: 1px auto -webkit-focus-ring-color;
}

.slide-toggle-btn[aria-pressed=true] .slide-toggle-display {
  background-color: var(--success-color-5);
}

.slide-toggle-btn[aria-pressed=true] .slide-toggle-display::before {
  transform: translate(100%, -50%);
}

.slide-toggle-btn[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

/*right to left support*/
[dir=rtl] .slide-toggle-display::before {
  left: auto;
  right: var(--offset);
}

[dir=rtl] .slide-toggle-btn[aria-pressed=true] + .slide-toggle-display::before {
  transform: translate(-100%, -50%);
}

.date-range-picker {
  display: flex;
  align-items: center;
  height: 40px;
  border-radius: 4px;
  border: 1px solid var(--border-gray);
}

.date-range-picker button {
  height: 100%;
  background-color: var(--background-light-gray);
  border-radius: 0;
}

.date-range-picker button:first-of-type {
  border-right: 1px solid var(--border-gray);
}

.date-range-picker button:last-of-type {
  border-left: 1px solid var(--border-gray);
}

.date-range-picker p {
  max-width: 100%;
  width: 210px;
  text-align: center;
}

section.main-section {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  flex: 1;
  display: flex;
  flex-direction: column;
}

section.has-header-tabs > header {
  position: sticky;
  z-index: 1;
  top: 0;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.24);
  width: 100%;
  display: flex;
  justify-content: space-between;
  background: transparent;
  padding: 0 2.4rem;
  min-height: 63px;
  align-items: center;
  background: #fff;
}

section.has-header-tabs h1 {
  flex: 0 0 auto;
}

section.has-header-tabs .nav-tabs {
  flex: 0 0 auto;
  margin-left: auto;
}

section.has-header-tabs .nav-tab {
  height: 63px;
  text-decoration: none;
  font-weight: 400;
  color: var(--primary-color-text);
}

section.has-header-tabs .mdc-tab--active .mdc-tab__text-label,
section.has-header-tabs .mat-mdc-tab-label-active {
  font-weight: 500;
  color: var(--color-4);
}

section.has-header-tabs .mat-mdc-tab-nav-panel {
  position: relative;
  top: 4px;
  display: block;
  height: calc(100vh - 67px);
}

section.header-tabs > header {
  position: sticky;
  z-index: 1;
  top: 0;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.24);
  width: 100%;
  display: flex;
  background: transparent;
  padding: 1.6rem 2.4rem;
  min-height: 63px;
  align-items: center;
  background: #fff;
}

section.header-tabs h1 {
  margin-bottom: 0;
  z-index: 2;
}

.header-tabs .mat-mdc-tab-group {
  height: calc(100% - 63px);
  display: flex;
  flex-direction: column;
  max-width: 100%;
  z-index: 2;
  margin-top: 4px;
  background: var(--background-gray);
}

.header-tabs .mat-mdc-tab-group.mat-primary .mat-ink-bar {
  background: var(--color-4);
}

.header-tabs .mat-mdc-tab-header {
  display: flex;
  overflow: hidden;
  position: relative;
  flex-shrink: 0;
  align-self: flex-end;
  min-height: 63px;
  align-items: center;
  border: 0;
  margin-top: -63px;
}

.header-tabs .mat-mdc-tab-label-container {
  display: flex;
  flex-grow: 1;
  overflow: hidden;
  z-index: 1;
  flex: 1 1 auto;
  align-self: center;
  min-height: 63px;
  margin-top: -8px;
}

.header-tabs .mat-mdc-tab-label {
  height: 63px;
  min-width: 26px;
  padding: 0;
  margin-right: 3.8rem;
  color: var(--primary-text-color);
  font-weight: 400;
  font-size: 2rem;
  opacity: 1;
}

.header-tabs .mat-mdc-tab-label.cdk-focused {
  background-color: transparent;
}

.tab-label-text {
  font-size: 2rem;
}

.header-tabs .mat-mdc-tab.mdc-tab {
  height: 63px;
}

.header-tabs .mat-mdc-tab:not(.mat-mdc-tab-disabled).mdc-tab--active .mdc-tab__text-label,
.header-tabs .mat-mdc-tab-label-active {
  font-weight: 500;
  color: var(--color-4);
}

.header-tabs ::ng-deep .mat-mdc-tab-header-pagination-controls-enabled .mat-mdc-tab-header-pagination {
  display: none;
}

.tabs > .mat-mdc-tab-body-wrapper {
  height: calc(100vh - 63px);
}

.tabs > .mat-mdc-tab-body-wrapper .mat-mdc-tab-body-content {
  height: calc(100% - 0.5rem);
  background: var(--background-gray);
  padding: 0;
}

.header-tabs .tab-label-icon {
  display: none;
}

.table-header-bar-padWrap {
  padding: 2.4rem 2.4rem 0 2.4rem;
  top: 0;
  z-index: 3;
  background: var(--background-gray);
  position: relative;
}

.mat-table-padWrap {
  position: relative;
  top: 0;
  padding: 0 2.4rem 2.4rem 2.4rem;
  background: var(--background-gray);
  z-index: 2;
}

.table .mat-mdc-table {
  border: 1px solid var(--border-gray);
}

.table.has-header-bar .mat-mdc-table {
  border-top-width: 0;
}

.table-header-bar {
  position: relative;
  top: 0;
  height: 76px;
  display: flex;
  align-items: center;
  background: #fff;
  border-bottom: 1px solid var(--border-gray);
  padding: 1.6rem;
  z-index: 2;
  border: 1px solid var(--border-gray);
}

.table-header-bar .table-search {
  flex: 1 1 auto;
  min-width: 150px;
  display: flex;
  max-width: 40%;
  width: 100%;
  margin-right: 1.6rem;
}

.table-header-bar .table-search.w100 {
  min-width: 100%;
}

.table-header-bar .action-buttons {
  display: flex;
  justify-content: flex-end;
  margin-left: auto;
}

.action-buttons button {
  margin-left: 1.6rem;
}

.table-header-bar .filters {
  flex: 1 1 auto;
  display: flex;
  z-index: 2;
}

.table.has-header-bar .mat-mdc-header-row {
  z-index: 2;
  background: var(--background-gray);
}

.table .search-btn,
.table .table-search .text-link {
  display: none;
}

.table .mat-mdc-table {
  position: relative;
  z-index: 1;
}

.table .mat-mdc-row {
  min-height: unset;
  padding: 1.6rem 0;
}

/* no results from filters / search */
.table .mat-mdc-row.inactive-non-found {
  padding: 1.6rem;
  background: #fff;
}

.table .mat-mdc-table .mat-mdc-row:hover {
  background: var(--color-hover);
  cursor: pointer;
  filter: drop-shadow(0px 4px 8px rgba(0, 0, 0, 0.16));
}

.table .mat-mdc-table .mat-mdc-row.no-hover:hover {
  background: unset;
  cursor: default;
  filter: unset;
}

.table .mat-mdc-row.inactive-non-found:hover {
  filter: none;
  background: #fff;
  cursor: default;
}

.table .mat-mdc-row:last-child {
  border-bottom: 0;
}

.table .mat-mdc-table mat-cell:first-of-type,
.table .mat-mdc-table mat-header-cell:first-of-type,
.table .mat-mdc-table mat-footer-cell:first-of-type {
  padding-left: 1.6rem;
}

.mat-mdc-header-cell {
  color: var(--primary-text-color);
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 1.5;
  min-height: 68px;
  background: var(--background-gray);
}

.table [class*=mat-column] {
  padding-right: 1.6rem;
}

.icon-text-wrapper {
  display: flex;
  align-items: center;
  max-width: 100%;
}

.icon-text-wrapper img,
.icon-text-wrapper .mat-icon {
  margin-right: 0.8rem;
  width: 24px;
  height: 24px;
}

.table .mat-column-actions {
  flex: 1;
  max-width: 85px;
  justify-content: flex-end;
}

.table-no-result-msg {
  text-align: left;
}

/*calendar styles*/
.calendar-container {
  position: relative;
  display: block;
  width: 100%;
  height: auto;
  box-sizing: border-box;
}

.calendar-container:not(.card) {
  background: #fff;
}

.yearly .calendar-nav,
.monthly .calendar-nav {
  position: relative;
  display: flex;
  align-items: center;
}

.calendar-container.card .calendar-nav {
  position: absolute;
}

.calendar-controls {
  display: flex;
  flex: 1 1 auto;
  width: 100%;
  height: 100%;
}

.calendar-nav button {
  position: relative;
  transition: opacity 500ms ease, visibility 500ms ease;
}

.calendar-container.card .calendar-nav button {
  position: absolute;
}

.calendar-nav button:first-of-type {
  left: 0;
  margin: 0;
}

.calendar-nav button:last-of-type {
  right: 0;
  margin: 0;
}

.calendar-container.card .calendar-multi-container,
.yearly:not(.my-team) .calendar-multi-container {
  /*calculated values*/
  --gap-count: calc(var(--grid-column-count) - 1);
  --total-gap-width: calc(var(--gap-count) * var(--grid-layout-gap));
  --grid-item--max-width: calc((100% - var(--total-gap-width)) / var(--grid-column-count));
  grid-template-columns: repeat(auto-fill, minmax(max(var(--grid-item--min-width), var(--grid-item--max-width)), 1fr));
}

.yearly .calendar-multi-container {
  margin: 2.4rem auto;
}

.calendar-multi-container {
  display: grid;
  grid-gap: var(--grid-layout-gap);
}

.calendar-month h3 {
  text-align: center;
}

.read-only .calendar-month h3,
.monthly .calendar-month .weekday {
  width: 100%;
  padding: 0.8rem 0;
  border: 1px solid var(--border-gray);
  background: var(--background-gray);
}

.calendar-month-grid {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.calendar-weekdays,
.calendar-days {
  width: 100%;
}

.calendar-row {
  display: grid;
  border-collapse: collapse;
  grid-template-columns: repeat(7, 1fr);
  grid-auto-rows: minmax(30px, 1fr);
}

.calendar-days .calendar-row {
  border-top: 1px solid #e0e0e0;
}

.calendar-item.weekday,
.calendar-item.day.inactive,
.calendar-item.day button,
.read-only .calendar-item.day {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  height: 100%;
}

.calendar-item,
.calendar-item button,
.read-only .calendar-item {
  color: var(--primary-text-color);
  font-size: 1.2rem;
}

.yearly .calendar-item,
.yearly .calendar-item button {
  font-size: 0.9rem;
}

.calendar-item.weekday {
  font-weight: bold;
}

.calendar-item.day.inactive {
  background: var(--background-gray);
  color: var(--secondary-text-color);
  transition: none;
}

.calendar-item.day {
  border-left: 1px solid #e0e0e0;
  border-bottom: 1px solid #e0e0e0;
  border-right: none;
  transition: all 0.4s ease-in;
}

.calendar-item.day:nth-child(7n) {
  border-right: 1px solid #e0e0e0;
}

.calendar-item.day button {
  width: 100%;
  height: 100%;
  border-radius: 0;
}

.calendar-item.day button[aria-pressed=true],
.read-only .calendar-item.day.selected {
  background: var(--color-4);
}

.calendar-item.day button[aria-pressed=true],
.read-only .calendar-item.day.selected {
  font-weight: bold;
  color: #fff;
}

.calendar-item.day button:not(.event-bar).status-success,
.calendar-item.day button:not(.event-bar).status-warning,
.calendar-item.day button:not(.event-bar).status-error,
.calendar-item.day button:not(.event-bar).status-grayscale,
.calendar-item.day button:not(.event-bar).status-holiday,
.calendar-item.day button.current-day,
.calendar-item.day span.current-day {
  font-weight: 500;
}

/*status colors*/
.current-day {
  background-color: var(--color-0);
  border: 1px solid var(--color-4);
}

.current-day,
.date-range {
  background-color: var(--color-0);
}

.status-success {
  background-color: var(--success-color-4);
}

.status-warning {
  background-color: var(--warning-color-4);
}

.status-error {
  background-color: var(--error-color-3);
}

.status-grayscale {
  background-color: var(--border-gray);
}

.status-multievent {
  background-color: #F975BC;
}

.status-holiday {
  background-color: #EBFDFD;
}

.status-success.status-warning {
  background: linear-gradient(to right bottom, var(--success-color-4) 48%, var(--warning-color-4) 50%);
}

.status-success.status-error {
  background: linear-gradient(to right bottom, var(--success-color-4) 48%, var(--error-color-3) 50%);
}

.status-grayscale.status-warning {
  background: linear-gradient(to right bottom, var(--border-gray) 48%, var(--warning-color-4) 50%);
}

.status-grayscale.status-error {
  background: linear-gradient(to right bottom, var(--border-gray) 48%, var(--error-color-3) 50%);
}

.status-warning.status-error {
  background: linear-gradient(to right bottom, var(--warning-color-4) 48%, var(--error-color-3) 50%);
}

.status-multievent.status-error {
  background: linear-gradient(to right bottom, #F975BC 48%, var(--error-color-3) 50%);
}

.status-holiday.status-error {
  background: linear-gradient(to right bottom, #EBFDFD 48%, var(--error-color-3) 50%);
}

.status-success.status-warning,
.status-success.status-error,
.status-warning.status-error,
.status-grayscale.status-warning,
.status-grayscale.status-error {
  background-origin: border-box;
}

.current-day.status-success,
.current-day.status-warning,
.current-day.status-error,
.current-day.status-success.status-warning,
.current-day.status-success.status-error,
.current-day.status-warning.status-error,
.current-day.status-multievent,
.current-day.status-holiday {
  box-shadow: inset 0 0 0 1px var(--color-4);
  border: 1px solid var(--color-4);
}

/*calendar/schedule event bar colors*/
.event-bar.status-success {
  background-color: var(--success-color-1);
  border-left: 2px solid var(--success-color-4);
}

.event-bar.status-grayscale {
  background-color: var(--background-gray);
  border-left: 2px solid var(--dark-gray);
}

.event-bar.status-warning {
  background-color: var(--warning-color-1);
  border-left: 2px solid var(--warning-color-4);
}

.event-bar.status-error {
  background-color: var(--error-color-1);
  border-left: 2px solid var(--error-color-4);
}

.event-bar.status-holiday {
  background-color: #ebfdfd;
}

.absence-dialog-container .mat-dialog-container,
.shift-label-dialog-container .mat-dialog-container {
  overflow: visible;
}

/*top icons*/
.mat-icon.icon-bkg {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 32px !important;
  width: 32px !important;
}

.mat-icon.icon-bkg:after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  height: 32px;
  width: 32px;
  border-radius: 0.4rem;
  z-index: -1;
}

.mat-icon.pto {
  color: var(--success-color-5);
}

.mat-icon.pto:after {
  background: var(--success-color-0);
}

.mat-icon.vacation {
  color: #aa00ff;
}

.mat-icon.vacation:after {
  background: #f7e6ff;
}

.mat-icon.sick {
  color: #03a9f4;
}

.mat-icon.sick:after {
  background: #e6f6fe;
}

/*save bar footer*/
.save-footer {
  height: 100%;
  overflow: auto;
}

.save-footer.showSaveBar {
  height: calc(100% - 55px);
}

.save-bar {
  padding: 0.8rem;
  position: fixed;
  right: 0;
  bottom: 0;
  background: var(--background-gray);
  box-shadow: 0px 0px 16px rgba(0, 0, 0, 0.12);
  width: calc(100% - 220px);
  transition: width 0.2s ease-in;
  z-index: 1000;
  display: flex;
  justify-content: center;
  grid-gap: 1.6rem;
  gap: 1.6rem;
}

.configuration-page-view .save-bar.collapsed {
  width: calc(100% - 295px);
  left: 295px;
}

.configuration-page-view .save-bar:not(.collapsed) {
  width: calc(100% - 465px);
  left: 465px;
}

.btn.save {
  min-width: 110px;
}

.collapsed {
  width: calc(100% - 50px);
}

.tippy-box {
  align-items: flex-start;
  padding: 0.8rem;
  overflow: visible !important;
  min-height: fit-content;
  height: unset;
  color: #FFFFFF;
  background: var(--primary-text-color);
  border-radius: 4px;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 500;
  font-size: 14px;
  line-height: 21px;
  max-width: unset !important;
  margin: 0.5rem 0;
}

.tippy-content {
  padding: 0;
}

.tippy-box.tooltip-large .tippy-content {
  max-width: 75vw;
  white-space: normal;
  word-break: break-all;
}

.tippy-box.tooltip-medium .tippy-content {
  max-width: 450px;
  white-space: normal;
  word-break: break-all;
}

.tippy-box.tooltip-small .tippy-content {
  max-width: 200px;
  width: 100%;
}

.tippy-box[data-placement^=top] > .tippy-arrow:before {
  bottom: -10px;
  left: -8px;
  border-width: 16px 17px 0px;
  border-top-color: var(--primary-text-color);
}

.tippy-box[data-placement^=bottom] > .tippy-arrow:before {
  top: -11px;
  left: -10px;
  border-width: 0px 18px 17px;
  border-bottom-color: var(--primary-text-color);
}

.tippy-box.theme-color {
  background: var(--color-4);
}

.tippy-box.theme-color[data-placement^=top] > .tippy-arrow:before {
  border-top-color: var(--color-4);
}

.tippy-box.theme-color[data-placement^=bottom] > .tippy-arrow:before {
  border-bottom-color: var(--color-4);
}

.tippy-box.theme-color[data-placement^=left] > .tippy-arrow:before {
  border-left-color: var(--color-4);
}

.tippy-box.theme-color[data-placement^=right] > .tippy-arrow:before {
  border-right-color: var(--color-4);
}

.employee-search-overlay {
  background-color: #fff;
  max-height: 30.4rem;
  padding: 0.8rem 0 0.8rem 0.8rem;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.16);
}

/* Quill Editor Global Styles */
.editor {
  /* quill editor specific classes */
}
.editor > * {
  word-break: break-word;
}
.editor p {
  font-size: 1.4rem;
  margin-bottom: 1.6rem;
}
.editor p:last-of-type {
  margin-bottom: 0;
}
.editor a {
  color: var(--color-4);
  text-decoration: underline;
  font-size: 1.4rem;
  font-weight: 500;
}
.editor em {
  font-style: italic;
}
.editor ol {
  list-style-type: decimal;
  padding: 0 0 0 3.2rem;
}
.editor ul {
  list-style-type: disc;
  padding: 0 0 0 3.2rem;
}
.editor li {
  font-size: 1.4rem;
  padding: 0;
  margin: 0;
}
.editor .ql-align-center {
  text-align: center;
}
.editor .ql-align-right {
  text-align: right;
}
.editor .ql-align-justify {
  text-align: justify;
}

/* Media Queries */
/* Part of the cSS Reset Styles
  Remove all animations, transitions and smooth scroll for people that prefer not to see them
*/
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
@media (max-width: 1439px) {
  .table-header-bar:not(.calendar-view):not(.calendar-list-view):not(.position-view):not(.applicant-view):not(#scheduling-view):not(#employee-timesheet-history-table-header):not(.configuration-view):not(:empty) {
    height: 132px;
  }
  .table.has-header-bar:not(.calendar-view):not(.calendar-list-view):not(.position-view):not(.applicant-view):not(#scheduling-view).mat-mdc-header-row:not(.configuration-view):not(:empty) {
    top: 132px;
  }
}
@media (max-width: 1200px) {
  .expanded-nav .card-row {
    flex-direction: column;
    margin-bottom: 0;
  }
}
@media (max-width: 1080px) {
  .collapsed-nav .card-row {
    flex-direction: column;
    margin-bottom: 0;
  }
}
@media (min-width: 960px) {
  .toast-container.toast-top-center .ngx-toastr {
    max-width: 75rem;
  }
}
@media (max-width: 960px) {
  .calendar-container.yearly {
    padding: 1.6rem;
  }
  .ng-select.search .ng-select-container .ng-value-container .ng-input > input {
    font-size: 16px;
  }
  .save-bar,
  .collapsed {
    width: 100%;
  }
  section.has-header-tabs .mat-mdc-tab-nav-panel {
    height: calc(100vh - 118px);
  }
  .tabs > .mat-mdc-tab-body-wrapper {
    height: calc(100vh - 118px);
  }
  .header-tabs {
    height: calc(100% - 56px);
  }
  .has-header-tabs {
    height: calc(100% - 56px);
  }
  /* configuration and profile pages */
  .back-to-previous-page.mobile {
    display: flex;
  }
  .configuration-page-view header {
    margin-top: 0;
  }
}
@media (max-width: 960px) and (min-width: 600px) {
  .toast-container.toast-top-center .ngx-toastr {
    max-width: 50rem;
  }
}
@media (max-width: 900px) {
  .card-row {
    flex-direction: column;
  }
  .card.profile-card {
    margin-right: 0;
  }
}
@media (max-width: 768px) {
  section.header-tabs > header {
    padding: 1.6rem;
  }
  section.has-header-tabs > header {
    padding: 0 1.6rem;
    min-height: 56px;
  }
  section.has-header-tabs .nav-tab {
    padding: 0 1.6rem;
    height: 56px;
    min-width: 75px;
  }
  section.has-header-tabs .mat-mdc-tab-nav-panel {
    height: calc(100vh - 116px);
  }
  .tab-label-text {
    font-size: 1.8rem;
  }
  .tabs > .mat-mdc-tab-body-wrapper .mat-mdc-tab-body-content {
    height: 100%;
  }
  .ng-select.ng-select-single.search.sm .ng-select-container {
    height: 40px;
    min-height: 40px;
  }
  .ng-select.search.sm .ng-select-container .ng-value-container .ng-input:before {
    top: 4px;
  }
  /* Tables */
  .table-header-bar,
  .table-header-bar-padWrap,
  .mat-table-padWrap,
  .mat-table-padWrap.no-results,
  .mobile-no-results.inactive-non-found {
    padding-left: 1.6rem;
    padding-right: 1.6rem;
  }
  /* Modals */
  .modal-header,
  .modal-content,
  .modal-footer {
    padding-left: 2.4rem;
    padding-right: 2.4rem;
  }
  /* Cards */
  /* 24 needs to adjust to 16 at this breakpoint */
  .card.pad-24 {
    padding: 1.6rem;
  }
  .account-settings,
  .configuration-page-view {
    padding: 1.6rem;
  }
}
@media (max-width: 600px) {
  /* profile pages with further details (employee profile, applicant profile, position profile ...) */
  .profile-details-view {
    padding: 1.6rem;
  }
  .profile-details-view .profile-controls {
    justify-content: space-between;
    margin-left: 0;
  }
  .profile-details-view .profile-controls .prev, .profile-details-view .profile-controls .next {
    color: var(--color-4);
  }
  /* settings, configuration and profile pages */
  .configuration-page-view header {
    margin-top: 0.8rem;
  }
  .back-to-previous-page {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    color: var(--dark-gray);
    margin: 0 0 0.8rem -0.5rem;
  }
  .back-to-previous-page.mobile {
    margin-bottom: 0;
  }
  .back-to-previous-page .mat-icon {
    flex: 0 0 24px;
    margin-top: -0.2rem;
    margin-right: 0.8rem;
  }
  .table-header-bar {
    border-left-width: 0;
    border-right-width: 0;
  }
  .table-header-bar-padWrap {
    padding: 1.2rem 0 1.6rem 0;
  }
  .table-header-bar,
  .mat-table-padWrap,
  .mat-table-padWrap.no-results,
  .mobile-no-results.inactive-non-found {
    padding-left: 0.8rem;
    padding-right: 0.8rem;
  }
  .table .search-btn {
    display: flex;
    width: 39px;
    height: 39px;
    line-height: 39px;
  }
  .table .table-search {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    flex: 1 1 auto;
    min-height: 68px;
    width: 100%;
    padding: 1.6rem 0.8rem;
    background: #fff;
    z-index: 3;
    min-width: 100%;
  }
  .table .ng-select.search {
    margin-right: 8px;
  }
  .table .table-search .text-link {
    display: block;
  }
  .basic.form-field label {
    margin-right: 24px;
  }
  .toast-container.toast-top-center .ngx-toastr {
    max-width: 30rem;
  }
  .card.account {
    padding: 2.4rem;
  }
  section.header-tabs > header {
    padding: 1.6rem 0.8rem;
  }
  .header-tabs .mat-mdc-tab.mdc-tab {
    padding: 0;
    min-width: 63px;
  }
  .header-tabs .tab-label-icon {
    display: block;
  }
  .header-tabs .mat-mdc-tab-label {
    margin-right: 1.9rem;
  }
  section.has-header-tabs > header {
    padding: 0 0.8rem;
  }
  section.header-nav-tabs .nav-tab {
    padding: 0 0.8rem;
  }
  section.has-header-tabs .mat-mdc-tab-label {
    margin-right: 1.9rem;
  }
  section.has-header-tabs .nav-tab {
    height: 56px;
  }
  section.has-header-tabs .tab-label-icon {
    display: block;
  }
  .tab-label-text {
    display: none;
    font-size: 1.6rem;
  }
  /* Modals */
  .modal-header,
  .modal-content,
  .modal-footer {
    padding-left: 1.6rem;
    padding-right: 1.6rem;
  }
  .btn-modal {
    padding: 0.8rem 1.2rem;
    font-size: 1.4rem;
  }
  /* 24 and 16 needs to adjust to 8 at this breakpoint */
  /*  TODO: CeCe change class dynamically based on breakpoint instead of this */
  .card.pad-24,
  .card.pad-16 {
    padding: 0.8rem;
  }
  .account-settings,
  .configuration-page-view {
    padding: 0.8rem;
  }
}
.holiday-tooltip-wrapper {
  display: flex;
}

.holiday-tooltip-wrapper .mat-icon {
  font-size: 1.8rem;
}

@media (min-width: 0) and (max-width: 600px) {
  .mat-mdc-tab-group {
    padding-top: 0;
  }
}
@media (max-width: 480px) {
  .card.account {
    padding: 1.6rem;
  }
}
@media (max-width: 414px) {
  .tabs > .mat-mdc-tab-body-wrapper .mat-mdc-tab-body-content {
    height: 100%;
  }
}
@media (min-width: 241px) and (max-width: 480px) {
  .toast-container .toast-close-button {
    right: 0.8rem;
    top: 50%;
  }
}
@media (max-width: 414px) {
  .modal-header,
  .modal-content,
  .modal-footer {
    padding-left: 0.8rem;
    padding-right: 0.8rem;
  }
}
@media print {
  .avatar {
    border: 1px solid var(--border-gray);
  }
}
@media (max-width: 350px) {
  .table .search-btn.mobile-only {
    display: flex;
    width: 24px;
    height: 39px;
    line-height: unset;
    align-items: center;
  }
  .table-header-bar .action-buttons .btn-sm {
    padding: 0.8rem 0.8rem;
  }
}

/*# sourceMappingURL=styles.css.map*/