{"version":3,"sources":["webpack:///./src/app/app/app.component.html","webpack:///./src/app/shared/big-input/big-input-action/big-input-action.component.html","webpack:///./src/app/shared/big-input/big-input/big-input.component.html","webpack:///./$_lazy_route_resource lazy namespace object","webpack:///./src/app/app-routing.module.ts","webpack:///./src/app/app.module.ts","webpack:///./src/app/app/app.component.scss","webpack:///./src/app/app/app.component.ts","webpack:///./src/app/core/animations/animations.service.ts","webpack:///./src/app/core/animations/route.animations.ts","webpack:///./src/app/core/auth/auth-guard.service.ts","webpack:///./src/app/core/auth/auth.actions.ts","webpack:///./src/app/core/auth/auth.effects.ts","webpack:///./src/app/core/auth/auth.reducer.ts","webpack:///./src/app/core/auth/auth.selectors.ts","webpack:///./src/app/core/core.module.ts","webpack:///./src/app/core/core.state.ts","webpack:///./src/app/core/error-handler/app-error-handler.service.ts","webpack:///./src/app/core/google-analytics/google-analytics.effects.ts","webpack:///./src/app/core/http-interceptors/http-error.interceptor.ts","webpack:///./src/app/core/local-storage/local-storage.service.ts","webpack:///./src/app/core/meta-reducers/debug.reducer.ts","webpack:///./src/app/core/meta-reducers/init-state-from-local-storage.reducer.ts","webpack:///./src/app/core/notifications/notification.service.ts","webpack:///./src/app/core/router/custom-serializer.ts","webpack:///./src/app/core/settings/settings.actions.ts","webpack:///./src/app/core/settings/settings.effects.ts","webpack:///./src/app/core/settings/settings.model.ts","webpack:///./src/app/core/settings/settings.reducer.ts","webpack:///./src/app/core/settings/settings.selectors.ts","webpack:///./src/app/core/title/title.service.ts","webpack:///./src/app/shared/big-input/big-input-action/big-input-action.component.scss","webpack:///./src/app/shared/big-input/big-input-action/big-input-action.component.ts","webpack:///./src/app/shared/big-input/big-input/big-input.component.scss","webpack:///./src/app/shared/big-input/big-input/big-input.component.ts","webpack:///./src/app/shared/rtl-support/rtl-support.directive.ts","webpack:///./src/app/shared/shared.module.ts","webpack:///./src/assets/Memnonlogo.png","webpack:///./src/environments/environment.ts","webpack:///./src/main.ts"],"names":[],"mappings":"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","file":"main-es5.js","sourcesContent":["module.exports = \"
\\n\\n \\n\\n \\n
\\n {{ 'anms.title.short' | translate}}
\\n \\n \\n {{item.label | translate}}\\n \\n \\n \\n
\\n\\n
\\n\\n
\\n \\n \\n\\n \\n \\n {{\\n 'anms.title.short' | translate }}\\n {{ 'anms.title.long' | translate\\n }}\\n\\n \\n \\n \\n\\n \\n \\n
\\n\\n
\\n \\n
\\n\\n
\\n
\\n \\n
\\n\\n
\\n
\\n © {{year}} - Memnons LLC All rights reserved.\\n
\\n
\\n
\\n\\n
\\n\\n
\\n\\n
\\n\"","module.exports = \"\\n\"","module.exports = \"\\n \\n \\n\\n\"","function webpackEmptyAsyncContext(req) {\n\t// Here Promise.resolve().then() is used instead of new Promise() to prevent\n\t// uncaught exception popping up in devtools\n\treturn Promise.resolve().then(function() {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t});\n}\nwebpackEmptyAsyncContext.keys = function() { return []; };\nwebpackEmptyAsyncContext.resolve = webpackEmptyAsyncContext;\nmodule.exports = webpackEmptyAsyncContext;\nwebpackEmptyAsyncContext.id = \"./$$_lazy_route_resource lazy recursive\";","import { NgModule } from '@angular/core';\nimport { Routes, RouterModule, PreloadAllModules } from '@angular/router';\n\nconst routes: Routes = [\n // { path: '', redirectTo: '/home', pathMatch: 'full' },\n // { path: '*/about', component: aboutComponent },\n // { path: '*/portfolio', component: portfolioComponent } ,\n // { path: '*/service', component: serviceComponent } ,\n // {path: '*/contact' , component: contactComponent },\n // { path: 'about', component: aboutComponent },\n // { path: 'portfolio', component: portfolioComponent } ,\n // { path: 'service', component: serviceComponent } ,\n // {path: 'contact' , component: contactComponent},\n\n {\n path: '',\n redirectTo: 'about',\n pathMatch: 'full'\n },\n {\n path: 'contact',\n loadChildren: () =>\n import('./features/contact/contact.module').then(m => m.ContactModule)\n },\n {\n path: 'service',\n loadChildren: () =>\n import('./features/service/service.module').then(m => m.ServiceModule)\n },\n {\n path: 'home',\n loadChildren: () =>\n import('./features/home/home.module').then(m => m.HomeModule)\n },\n {\n path: 'about',\n loadChildren: () =>\n import('./features/about/about.module').then(m => m.AboutModule)\n },\n {\n path: 'portfolio',\n loadChildren: () =>\n import('./features/feature-list/feature-list.module').then(\n m => m.FeatureListModule\n )\n },\n {\n path: 'settings',\n loadChildren: () =>\n import('./features/settings/settings.module').then(m => m.SettingsModule)\n },\n {\n path: 'examples',\n loadChildren: () =>\n import('./features/examples/examples.module').then(m => m.ExamplesModule)\n },\n\n {\n path: '**',\n redirectTo: 'about'\n }\n];\n\n@NgModule({\n // useHash supports github.io demo page, remove in your app\n imports: [\n RouterModule.forRoot(routes, {\n useHash: true,\n scrollPositionRestoration: 'enabled',\n preloadingStrategy: PreloadAllModules\n })\n ],\n exports: [RouterModule]\n})\nexport class AppRoutingModule {}\n","import { BrowserModule } from '@angular/platform-browser';\nimport { BrowserAnimationsModule } from '@angular/platform-browser/animations';\nimport { NgModule } from '@angular/core';\n\nimport { SharedModule } from './shared/shared.module';\nimport { CoreModule } from './core/core.module';\n\nimport { AppRoutingModule } from './app-routing.module';\nimport { AppComponent } from './app/app.component';\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome'\n\n@NgModule({\n imports: [\n // angular\n BrowserAnimationsModule,\n BrowserModule,\n\n // core & shared\n CoreModule,\n SharedModule,\n\n FontAwesomeModule,\n // app\n AppRoutingModule\n ],\n declarations: [AppComponent],\n\n bootstrap: [AppComponent]\n})\nexport class AppModule {}\n\n","module.exports = \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\n.theme-wrapper {\\n height: 100%;\\n width: 100%;\\n}\\nmat-sidenav-container {\\n height: 100%;\\n width: 100%;\\n}\\nmat-sidenav-container .toolbar {\\n position: fixed;\\n width: 100%;\\n display: flex;\\n z-index: 10;\\n}\\nmat-sidenav-container .toolbar .nav-button {\\n margin: 0 10px 0 0;\\n}\\nmat-sidenav-container .toolbar fa-icon {\\n font-size: 24px;\\n}\\nmat-sidenav-container .toolbar .branding {\\n cursor: pointer;\\n overflow: hidden;\\n padding-top: 4px;\\n text-overflow: ellipsis;\\n}\\nmat-sidenav-container .toolbar .branding.center {\\n text-align: center;\\n}\\nmat-sidenav-container .toolbar .branding img {\\n position: relative;\\n top: -2px;\\n width: 48px;\\n height: 48px;\\n}\\nmat-sidenav-container .toolbar .mat-stroked-button {\\n margin-right: 10px;\\n}\\nmat-sidenav-container .toolbar .spacer {\\n flex: 1 1 auto;\\n}\\nmat-sidenav-container .toolbar mat-select {\\n margin: 0 0 0 20px;\\n width: 40px;\\n font-size: 14px;\\n}\\n@media (max-width: 992px) {\\n mat-sidenav-container .toolbar .nav-button {\\n min-width: 0;\\n padding: 0 10px;\\n }\\n}\\nmat-sidenav-container .wrapper {\\n position: absolute;\\n top: 0;\\n left: 0;\\n right: 0;\\n bottom: 0;\\n display: flex;\\n flex-direction: column;\\n}\\nmat-sidenav-container .wrapper .content {\\n flex: 1 0 auto;\\n margin-top: 64px;\\n overflow: hidden;\\n}\\nmat-sidenav-container .wrapper .footer {\\n flex: 0 0 auto;\\n padding: 0 15px;\\n text-align: center;\\n}\\nmat-sidenav-container .wrapper .footer .row {\\n padding: 10px 0;\\n}\\nmat-sidenav-container .wrapper .footer .row .links a {\\n transition: padding 0.5s;\\n display: inline-block;\\n padding: 20px 5px;\\n}\\nmat-sidenav-container .wrapper .footer .row .links a:hover {\\n text-decoration: none;\\n}\\nmat-sidenav-container .wrapper .footer .row .links a fa-icon {\\n font-size: 30px;\\n width: 35px;\\n}\\nmat-sidenav-container .wrapper .footer .row .links a span {\\n display: inline-block;\\n width: 75px;\\n padding: 0 0 0 3px;\\n overflow: hidden;\\n text-align: left;\\n white-space: nowrap;\\n transition: width 0.5s;\\n}\\n@media (min-width: 992px) {\\n mat-sidenav-container .wrapper .footer .row .links a {\\n padding: 20px 10px;\\n }\\n}\\n@media (max-width: 768px) {\\n mat-sidenav-container .wrapper .footer .row .links a {\\n padding: 20px;\\n }\\n mat-sidenav-container .wrapper .footer .row .links a span {\\n width: 0;\\n padding: 0;\\n }\\n}\\n@media (max-width: 576px) {\\n mat-sidenav-container .wrapper .footer .row .links a {\\n padding: 20px 5px;\\n }\\n}\\n@media (min-width: 576px) {\\n mat-sidenav-container .wrapper .footer .row .signature {\\n position: relative;\\n }\\n mat-sidenav-container .wrapper .footer .row .signature a {\\n position: absolute;\\n right: 15px;\\n }\\n}\\n@media (max-width: 600px) {\\n mat-sidenav-container .content {\\n margin-top: 56px !important;\\n }\\n}\\nmat-sidenav {\\n width: 250px;\\n}\\nmat-sidenav .branding {\\n height: 64px;\\n padding: 8px 10px;\\n font-size: 20px;\\n font-weight: 500;\\n}\\nmat-sidenav .branding img {\\n height: 48px;\\n margin: 2px 10px 0 0;\\n}\\nmat-sidenav .branding span {\\n position: relative;\\n top: 3px;\\n}\\nmat-sidenav .mat-nav-list {\\n padding-top: 0;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/app/C:\\Project\\memnons_material\\projects\\memnons_material/src\\app\\app\\app.component.scss","src/app/app/C:\\Project\\memnons_material\\projects\\memnons_material/stdin","src/app/app/app.component.scss"],"names":[],"mappings":"AAy1CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC75FA;EACE,YAAA;EACA,WAAA;ACEF;ADCA;EACE,YAAA;EACA,WAAA;ACEF;ADAE;EACE,eAAA;EACA,WAAA;EACA,aAAA;EACA,WAAA;ACEJ;ADAI;EACE,kBAAA;ACEN;ADCI;EACE,eAAA;ACCN;ADEI;EACE,eAAA;EACA,gBAAA;EACA,gBAAA;EACA,uBAAA;ACAN;ADEM;EACE,kBAAA;ACAR;ADGM;EACE,kBAAA;EACA,SAAA;EACA,WAAA;EACA,YAAA;ACDR;ADKI;EACE,kBAAA;ACHN;ADMI;EACE,cAAA;ACJN;ADOI;EACE,kBAAA;EACA,WAAA;EACA,eAAA;ACLN;ADQI;EACE;IACE,YAAA;IACA,eAAA;ECNN;AACF;ADUE;EACE,kBAAA;EACA,MAAA;EACA,OAAA;EACA,QAAA;EACA,SAAA;EACA,aAAA;EACA,sBAAA;ACRJ;ADUI;EACE,cAAA;EACA,gBAAA;EACA,gBAAA;ACRN;ADWI;EACE,cAAA;EACA,eAAA;EACA,kBAAA;ACTN;ADWM;EACE,eAAA;ACTR;ADYU;EACE,wBAAA;EACA,qBAAA;EACA,iBAAA;ACVZ;ADYY;EACE,qBAAA;ACVd;ADaY;EACE,eAAA;EACA,WAAA;ACXd;ADcY;EACE,qBAAA;EACA,WAAA;EACA,kBAAA;EACA,gBAAA;EACA,gBAAA;EACA,mBAAA;EACA,sBAAA;ACZd;ADgBU;EACE;IACE,kBAAA;ECdZ;AACF;ADiBU;EACE;IACE,aAAA;ECfZ;EDiBY;IACE,QAAA;IACA,UAAA;ECfd;AACF;ADmBU;EACE;IACE,iBAAA;ECjBZ;AACF;ADqBQ;EACE;IACE,kBAAA;ECnBV;EDqBU;IACE,kBAAA;IACA,WAAA;ECnBZ;AACF;AD0BE;EACE;IACE,2BAAA;ECxBJ;AACF;AD4BA;EACE,YAAA;ACzBF;AD2BE;EACE,YAAA;EACA,iBAAA;EACA,eAAA;EACA,gBAAA;ACzBJ;AD2BI;EACE,YAAA;EACA,oBAAA;ACzBN;AD4BI;EACE,kBAAA;EACA,QAAA;AC1BN;AD8BE;EACE,cAAA;AC5BJ","file":"src/app/app/app.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', default);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary));\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn));\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary);\n  $required-label-color: mat-color($accent);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent);\n  $underline-color-warn: mat-color($warn);\n  $underline-focused-color: mat-color($primary);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import '../../styles-variables';\n\n.theme-wrapper {\n  height: 100%;\n  width: 100%;\n}\n\nmat-sidenav-container {\n  height: 100%;\n  width: 100%;\n\n  .toolbar {\n    position: fixed;\n    width: 100%;\n    display: flex;\n    z-index: 10;\n\n    .nav-button {\n      margin: 0 10px 0 0;\n    }\n\n    fa-icon {\n      font-size: 24px;\n    }\n\n    .branding {\n      cursor: pointer;\n      overflow: hidden;\n      padding-top: 4px;\n      text-overflow: ellipsis;\n\n      &.center {\n        text-align: center;\n      }\n\n      img {\n        position: relative;\n        top: -2px;\n        width: 48px;\n        height: 48px;\n      }\n    }\n\n    .mat-stroked-button {\n      margin-right: 10px;\n    }\n\n    .spacer {\n      flex: 1 1 auto;\n    }\n\n    mat-select {\n      margin: 0 0 0 20px;\n      width: 40px;\n      font-size: 14px;\n    }\n\n    @media (max-width: map-get($grid-breakpoints, lg)) {\n      .nav-button {\n        min-width: 0;\n        padding: 0 10px;\n      }\n    }\n  }\n\n  .wrapper {\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    display: flex;\n    flex-direction: column;\n\n    .content {\n      flex: 1 0 auto;\n      margin-top: 64px;\n      overflow: hidden;\n    }\n\n    .footer {\n      flex: 0 0 auto;\n      padding: 0 15px;\n      text-align: center;\n\n      .row {\n        padding: 10px 0;\n\n        .links {\n          a {\n            transition: padding 0.5s;\n            display: inline-block;\n            padding: 20px 5px;\n\n            &:hover {\n              text-decoration: none;\n            }\n\n            fa-icon {\n              font-size: 30px;\n              width: 35px;\n            }\n\n            span {\n              display: inline-block;\n              width: 75px;\n              padding: 0 0 0 3px;\n              overflow: hidden;\n              text-align: left;\n              white-space: nowrap;\n              transition: width 0.5s;\n            }\n          }\n\n          @media (min-width: map-get($grid-breakpoints, lg)) {\n            a {\n              padding: 20px 10px;\n            }\n          }\n\n          @media (max-width: map-get($grid-breakpoints, md)) {\n            a {\n              padding: 20px;\n\n              span {\n                width: 0;\n                padding: 0;\n              }\n            }\n          }\n\n          @media (max-width: map-get($grid-breakpoints, sm)) {\n            a {\n              padding: 20px 5px;\n            }\n          }\n        }\n\n        @media (min-width: map-get($grid-breakpoints, sm)) {\n          .signature {\n            position: relative;\n\n            a {\n              position: absolute;\n              right: 15px;\n            }\n          }\n        }\n      }\n    }\n  }\n\n  @media (max-width: $toolbar-breakpoint) {\n    .content {\n      margin-top: 56px !important;\n    }\n  }\n}\n\nmat-sidenav {\n  width: 250px;\n\n  .branding {\n    height: 64px;\n    padding: 8px 10px;\n    font-size: 20px;\n    font-weight: 500;\n\n    img {\n      height: 48px;\n      margin: 2px 10px 0 0;\n    }\n\n    span {\n      position: relative;\n      top: 3px;\n    }\n  }\n\n  .mat-nav-list {\n    padding-top: 0;\n  }\n}\n","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\n.theme-wrapper {\n  height: 100%;\n  width: 100%;\n}\n\nmat-sidenav-container {\n  height: 100%;\n  width: 100%;\n}\nmat-sidenav-container .toolbar {\n  position: fixed;\n  width: 100%;\n  display: flex;\n  z-index: 10;\n}\nmat-sidenav-container .toolbar .nav-button {\n  margin: 0 10px 0 0;\n}\nmat-sidenav-container .toolbar fa-icon {\n  font-size: 24px;\n}\nmat-sidenav-container .toolbar .branding {\n  cursor: pointer;\n  overflow: hidden;\n  padding-top: 4px;\n  text-overflow: ellipsis;\n}\nmat-sidenav-container .toolbar .branding.center {\n  text-align: center;\n}\nmat-sidenav-container .toolbar .branding img {\n  position: relative;\n  top: -2px;\n  width: 48px;\n  height: 48px;\n}\nmat-sidenav-container .toolbar .mat-stroked-button {\n  margin-right: 10px;\n}\nmat-sidenav-container .toolbar .spacer {\n  flex: 1 1 auto;\n}\nmat-sidenav-container .toolbar mat-select {\n  margin: 0 0 0 20px;\n  width: 40px;\n  font-size: 14px;\n}\n@media (max-width: 992px) {\n  mat-sidenav-container .toolbar .nav-button {\n    min-width: 0;\n    padding: 0 10px;\n  }\n}\nmat-sidenav-container .wrapper {\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  display: flex;\n  flex-direction: column;\n}\nmat-sidenav-container .wrapper .content {\n  flex: 1 0 auto;\n  margin-top: 64px;\n  overflow: hidden;\n}\nmat-sidenav-container .wrapper .footer {\n  flex: 0 0 auto;\n  padding: 0 15px;\n  text-align: center;\n}\nmat-sidenav-container .wrapper .footer .row {\n  padding: 10px 0;\n}\nmat-sidenav-container .wrapper .footer .row .links a {\n  transition: padding 0.5s;\n  display: inline-block;\n  padding: 20px 5px;\n}\nmat-sidenav-container .wrapper .footer .row .links a:hover {\n  text-decoration: none;\n}\nmat-sidenav-container .wrapper .footer .row .links a fa-icon {\n  font-size: 30px;\n  width: 35px;\n}\nmat-sidenav-container .wrapper .footer .row .links a span {\n  display: inline-block;\n  width: 75px;\n  padding: 0 0 0 3px;\n  overflow: hidden;\n  text-align: left;\n  white-space: nowrap;\n  transition: width 0.5s;\n}\n@media (min-width: 992px) {\n  mat-sidenav-container .wrapper .footer .row .links a {\n    padding: 20px 10px;\n  }\n}\n@media (max-width: 768px) {\n  mat-sidenav-container .wrapper .footer .row .links a {\n    padding: 20px;\n  }\n  mat-sidenav-container .wrapper .footer .row .links a span {\n    width: 0;\n    padding: 0;\n  }\n}\n@media (max-width: 576px) {\n  mat-sidenav-container .wrapper .footer .row .links a {\n    padding: 20px 5px;\n  }\n}\n@media (min-width: 576px) {\n  mat-sidenav-container .wrapper .footer .row .signature {\n    position: relative;\n  }\n  mat-sidenav-container .wrapper .footer .row .signature a {\n    position: absolute;\n    right: 15px;\n  }\n}\n@media (max-width: 600px) {\n  mat-sidenav-container .content {\n    margin-top: 56px !important;\n  }\n}\n\nmat-sidenav {\n  width: 250px;\n}\nmat-sidenav .branding {\n  height: 64px;\n  padding: 8px 10px;\n  font-size: 20px;\n  font-weight: 500;\n}\nmat-sidenav .branding img {\n  height: 48px;\n  margin: 2px 10px 0 0;\n}\nmat-sidenav .branding span {\n  position: relative;\n  top: 3px;\n}\nmat-sidenav .mat-nav-list {\n  padding-top: 0;\n}"]} */\"","import browser from 'browser-detect';\nimport { Component, OnInit } from '@angular/core';\nimport { Store, select } from '@ngrx/store';\nimport { Observable } from 'rxjs';\n\nimport { environment as env } from '../../environments/environment';\n\nimport {\n authLogin,\n authLogout,\n routeAnimations,\n AppState,\n LocalStorageService,\n selectIsAuthenticated,\n selectSettingsStickyHeader,\n selectSettingsLanguage,\n selectEffectiveTheme\n} from '../core/core.module';\nimport {\n actionSettingsChangeAnimationsPageDisabled,\n actionSettingsChangeLanguage\n} from '../core/settings/settings.actions';\n\n@Component({\n selector: 'anms-root',\n templateUrl: './app.component.html',\n styleUrls: ['./app.component.scss'],\n animations: [routeAnimations]\n})\nexport class AppComponent implements OnInit {\n isProd = env.production;\n envName = env.envName;\n version = env.versions.app;\n year = new Date().getFullYear();\n logo = require('../../assets/Memnonlogo.png');\n languages = ['en', 'de', 'sk', 'fr', 'es', 'pt-br', 'zh-cn', 'he'];\n navigation = [\n { link: 'home', label: 'anms.menu.home' },\n { link: 'about', label: 'anms.menu.about' },\n { link: 'service', label: 'anms.menu.service' },\n { link: 'contact', label: 'anms.menu.contact' },\n { link: 'portfolio', label: 'anms.menu.features' }\n // ,\n // { link: 'examples', label: 'anms.menu.examples' }\n ];\n navigationSideMenu = [\n ...this.navigation\n // { link: 'settings', label: 'anms.menu.settings' }\n ];\n\n isAuthenticated$: Observable;\n stickyHeader$: Observable;\n language$: Observable;\n theme$: Observable;\n\n constructor(\n private store: Store,\n private storageService: LocalStorageService\n ) {}\n\n private static isIEorEdgeOrSafari() {\n return ['ie', 'edge', 'safari'].includes(browser().name);\n }\n\n ngOnInit(): void {\n this.storageService.testLocalStorage();\n if (AppComponent.isIEorEdgeOrSafari()) {\n this.store.dispatch(\n actionSettingsChangeAnimationsPageDisabled({\n pageAnimationsDisabled: true\n })\n );\n }\n\n this.isAuthenticated$ = this.store.pipe(select(selectIsAuthenticated));\n this.stickyHeader$ = this.store.pipe(select(selectSettingsStickyHeader));\n this.language$ = this.store.pipe(select(selectSettingsLanguage));\n this.theme$ = this.store.pipe(select(selectEffectiveTheme));\n }\n\n onLoginClick() {\n this.store.dispatch(authLogin());\n }\n\n onLogoutClick() {\n this.store.dispatch(authLogout());\n }\n\n onLanguageSelect({ value: language }) {\n this.store.dispatch(actionSettingsChangeLanguage({ language }));\n }\n}\n","import { Injectable } from '@angular/core';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class AnimationsService {\n constructor() {\n AnimationsService.routeAnimationType = 'NONE';\n }\n\n private static routeAnimationType: RouteAnimationType = 'NONE';\n\n static isRouteAnimationsType(type: RouteAnimationType) {\n return AnimationsService.routeAnimationType === type;\n }\n\n updateRouteAnimationType(\n pageAnimations: boolean,\n elementsAnimations: boolean\n ) {\n AnimationsService.routeAnimationType =\n pageAnimations && elementsAnimations\n ? 'ALL'\n : pageAnimations\n ? 'PAGE'\n : elementsAnimations\n ? 'ELEMENTS'\n : 'NONE';\n }\n}\n\nexport type RouteAnimationType = 'ALL' | 'PAGE' | 'ELEMENTS' | 'NONE';\n","import {\r\n animate,\r\n query,\r\n style,\r\n transition,\r\n trigger,\r\n stagger,\r\n sequence\r\n} from '@angular/animations';\r\nimport { AnimationsService } from './animations.service';\r\n\r\nexport const ROUTE_ANIMATIONS_ELEMENTS = 'route-animations-elements';\r\n\r\nconst STEPS_ALL: any[] = [\r\n query(':enter > *', style({ opacity: 0, position: 'fixed' }), {\r\n optional: true\r\n }),\r\n query(':enter .' + ROUTE_ANIMATIONS_ELEMENTS, style({ opacity: 0 }), {\r\n optional: true\r\n }),\r\n sequence([\r\n query(\r\n ':leave > *',\r\n [\r\n style({ transform: 'translateY(0%)', opacity: 1 }),\r\n animate(\r\n '0.2s ease-in-out',\r\n style({ transform: 'translateY(-3%)', opacity: 0 })\r\n ),\r\n style({ position: 'fixed' })\r\n ],\r\n { optional: true }\r\n ),\r\n query(\r\n ':enter > *',\r\n [\r\n style({\r\n transform: 'translateY(-3%)',\r\n opacity: 0,\r\n position: 'static'\r\n }),\r\n animate(\r\n '0.5s ease-in-out',\r\n style({ transform: 'translateY(0%)', opacity: 1 })\r\n )\r\n ],\r\n { optional: true }\r\n )\r\n ]),\r\n query(\r\n ':enter .' + ROUTE_ANIMATIONS_ELEMENTS,\r\n stagger(75, [\r\n style({ transform: 'translateY(10%)', opacity: 0 }),\r\n animate(\r\n '0.5s ease-in-out',\r\n style({ transform: 'translateY(0%)', opacity: 1 })\r\n )\r\n ]),\r\n { optional: true }\r\n )\r\n];\r\nconst STEPS_NONE = [];\r\nconst STEPS_PAGE = [STEPS_ALL[0], STEPS_ALL[2]];\r\nconst STEPS_ELEMENTS = [STEPS_ALL[1], STEPS_ALL[3]];\r\n\r\nexport const routeAnimations = trigger('routeAnimations', [\r\n transition(isRouteAnimationsAll, STEPS_ALL),\r\n transition(isRouteAnimationsNone, STEPS_NONE),\r\n transition(isRouteAnimationsPage, STEPS_PAGE),\r\n transition(isRouteAnimationsElements, STEPS_ELEMENTS)\r\n]);\r\n\r\nexport function isRouteAnimationsAll() {\r\n return AnimationsService.isRouteAnimationsType('ALL');\r\n}\r\n\r\nexport function isRouteAnimationsNone() {\r\n return AnimationsService.isRouteAnimationsType('NONE');\r\n}\r\n\r\nexport function isRouteAnimationsPage() {\r\n return AnimationsService.isRouteAnimationsType('PAGE');\r\n}\r\n\r\nexport function isRouteAnimationsElements() {\r\n return AnimationsService.isRouteAnimationsType('ELEMENTS');\r\n}\r\n","import { Injectable } from '@angular/core';\nimport { CanActivate } from '@angular/router';\nimport { Store, select } from '@ngrx/store';\nimport { Observable } from 'rxjs';\n\nimport { selectIsAuthenticated } from './auth.selectors';\nimport { AppState } from '../core.state';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class AuthGuardService implements CanActivate {\n constructor(private store: Store) {}\n\n canActivate(): Observable {\n return this.store.pipe(select(selectIsAuthenticated));\n }\n}\n","import { createAction } from '@ngrx/store';\n\nexport const authLogin = createAction('[Auth] Login');\nexport const authLogout = createAction('[Auth] Logout');\n","import { Injectable } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { ofType, createEffect, Actions } from '@ngrx/effects';\nimport { tap } from 'rxjs/operators';\n\nimport { LocalStorageService } from '../local-storage/local-storage.service';\n\nimport { authLogin, authLogout } from './auth.actions';\n\nexport const AUTH_KEY = 'AUTH';\n\n@Injectable()\nexport class AuthEffects {\n constructor(\n private actions$: Actions,\n private localStorageService: LocalStorageService,\n private router: Router\n ) {}\n\n login = createEffect(\n () =>\n this.actions$.pipe(\n ofType(authLogin),\n tap(() =>\n this.localStorageService.setItem(AUTH_KEY, { isAuthenticated: true })\n )\n ),\n { dispatch: false }\n );\n\n logout = createEffect(\n () =>\n this.actions$.pipe(\n ofType(authLogout),\n tap(() => {\n this.router.navigate(['']);\n this.localStorageService.setItem(AUTH_KEY, {\n isAuthenticated: false\n });\n })\n ),\n { dispatch: false }\n );\n}\n","import { AuthState } from './auth.models';\nimport { authLogin, authLogout } from './auth.actions';\nimport { createReducer, on, Action } from '@ngrx/store';\n\nexport const initialState: AuthState = {\n isAuthenticated: false\n};\n\nconst reducer = createReducer(\n initialState,\n on(authLogin, state => ({ ...state, isAuthenticated: true })),\n on(authLogout, state => ({ ...state, isAuthenticated: false }))\n);\n\nexport function authReducer(\n state: AuthState | undefined,\n action: Action\n): AuthState {\n return reducer(state, action);\n}\n","import { createSelector } from '@ngrx/store';\r\n\r\nimport { selectAuthState } from '../core.state';\r\nimport { AuthState } from './auth.models';\r\n\r\nexport const selectAuth = createSelector(\r\n selectAuthState,\r\n (state: AuthState) => state\r\n);\r\n\r\nexport const selectIsAuthenticated = createSelector(\r\n selectAuthState,\r\n (state: AuthState) => state.isAuthenticated\r\n);\r\n","import { CommonModule } from '@angular/common';\nimport { NgModule, Optional, SkipSelf, ErrorHandler } from '@angular/core';\nimport {\n HttpClientModule,\n HttpClient,\n HTTP_INTERCEPTORS\n} from '@angular/common/http';\nimport {\n StoreRouterConnectingModule,\n RouterStateSerializer\n} from '@ngrx/router-store';\nimport { StoreModule } from '@ngrx/store';\nimport { EffectsModule } from '@ngrx/effects';\nimport { StoreDevtoolsModule } from '@ngrx/store-devtools';\nimport { TranslateModule, TranslateLoader } from '@ngx-translate/core';\nimport { TranslateHttpLoader } from '@ngx-translate/http-loader';\n\nimport { environment } from '../../environments/environment';\n\nimport {\n AppState,\n reducers,\n metaReducers,\n selectRouterState\n} from './core.state';\nimport { AuthEffects } from './auth/auth.effects';\nimport { selectIsAuthenticated, selectAuth } from './auth/auth.selectors';\nimport { authLogin, authLogout } from './auth/auth.actions';\nimport { AuthGuardService } from './auth/auth-guard.service';\nimport { TitleService } from './title/title.service';\nimport {\n ROUTE_ANIMATIONS_ELEMENTS,\n routeAnimations\n} from './animations/route.animations';\nimport { AnimationsService } from './animations/animations.service';\nimport { AppErrorHandler } from './error-handler/app-error-handler.service';\nimport { CustomSerializer } from './router/custom-serializer';\nimport { LocalStorageService } from './local-storage/local-storage.service';\nimport { HttpErrorInterceptor } from './http-interceptors/http-error.interceptor';\nimport { GoogleAnalyticsEffects } from './google-analytics/google-analytics.effects';\nimport { NotificationService } from './notifications/notification.service';\nimport { SettingsEffects } from './settings/settings.effects';\nimport {\n selectSettingsLanguage,\n selectEffectiveTheme,\n selectSettingsStickyHeader\n} from './settings/settings.selectors';\n\nexport {\n TitleService,\n selectAuth,\n authLogin,\n authLogout,\n routeAnimations,\n AppState,\n LocalStorageService,\n selectIsAuthenticated,\n ROUTE_ANIMATIONS_ELEMENTS,\n AnimationsService,\n AuthGuardService,\n selectRouterState,\n NotificationService,\n selectEffectiveTheme,\n selectSettingsLanguage,\n selectSettingsStickyHeader\n};\n\nexport function HttpLoaderFactory(http: HttpClient) {\n return new TranslateHttpLoader(\n http,\n `${environment.i18nPrefix}/assets/i18n/`,\n '.json'\n );\n}\n\n@NgModule({\n imports: [\n // angular\n CommonModule,\n HttpClientModule,\n\n // ngrx\n StoreModule.forRoot(reducers, { metaReducers }),\n StoreRouterConnectingModule.forRoot(),\n EffectsModule.forRoot([\n AuthEffects,\n SettingsEffects,\n GoogleAnalyticsEffects\n ]),\n environment.production\n ? []\n : StoreDevtoolsModule.instrument({\n name: 'Memnons'\n }),\n\n // 3rd party\n TranslateModule.forRoot({\n loader: {\n provide: TranslateLoader,\n useFactory: HttpLoaderFactory,\n deps: [HttpClient]\n }\n })\n ],\n declarations: [],\n providers: [\n { provide: HTTP_INTERCEPTORS, useClass: HttpErrorInterceptor, multi: true },\n { provide: ErrorHandler, useClass: AppErrorHandler },\n { provide: RouterStateSerializer, useClass: CustomSerializer }\n ],\n exports: [TranslateModule]\n})\nexport class CoreModule {\n constructor(\n @Optional()\n @SkipSelf()\n parentModule: CoreModule\n ) {\n if (parentModule) {\n throw new Error('CoreModule is already loaded. Import only in AppModule');\n }\n }\n}\n","import {\n ActionReducerMap,\n MetaReducer,\n createFeatureSelector\n} from '@ngrx/store';\nimport { routerReducer, RouterReducerState } from '@ngrx/router-store';\n\nimport { environment } from '../../environments/environment';\n\nimport { initStateFromLocalStorage } from './meta-reducers/init-state-from-local-storage.reducer';\nimport { debug } from './meta-reducers/debug.reducer';\nimport { AuthState } from './auth/auth.models';\nimport { authReducer } from './auth/auth.reducer';\nimport { RouterStateUrl } from './router/router.state';\nimport { settingsReducer } from './settings/settings.reducer';\nimport { SettingsState } from './settings/settings.model';\n\nexport const reducers: ActionReducerMap = {\n auth: authReducer,\n settings: settingsReducer,\n router: routerReducer\n};\n\nexport const metaReducers: MetaReducer[] = [\n initStateFromLocalStorage\n];\n\nif (!environment.production) {\n if (!environment.test) {\n metaReducers.unshift(debug);\n }\n}\n\nexport const selectAuthState = createFeatureSelector(\n 'auth'\n);\n\nexport const selectSettingsState = createFeatureSelector<\n AppState,\n SettingsState\n>('settings');\n\nexport const selectRouterState = createFeatureSelector<\n AppState,\n RouterReducerState\n>('router');\n\nexport interface AppState {\n auth: AuthState;\n settings: SettingsState;\n router: RouterReducerState;\n}\n","import { Injectable, ErrorHandler } from '@angular/core';\nimport { HttpErrorResponse } from '@angular/common/http';\n\nimport { environment } from '../../../environments/environment';\n\nimport { NotificationService } from '../notifications/notification.service';\n\n/** Application-wide error handler that adds a UI notification to the error handling\n * provided by the default Angular ErrorHandler.\n */\n@Injectable()\nexport class AppErrorHandler extends ErrorHandler {\n constructor(private notificationsService: NotificationService) {\n super();\n }\n\n handleError(error: Error | HttpErrorResponse) {\n let displayMessage = 'An error occurred.';\n\n if (!environment.production) {\n displayMessage += ' See console for details.';\n }\n\n this.notificationsService.error(displayMessage);\n\n super.handleError(error);\n }\n}\n","import { Injectable } from '@angular/core';\r\nimport { Router, NavigationEnd } from '@angular/router';\r\nimport { createEffect } from '@ngrx/effects';\r\nimport { tap, filter } from 'rxjs/operators';\r\n\r\n@Injectable()\r\nexport class GoogleAnalyticsEffects {\r\n constructor(private router: Router) {}\r\n\r\n pageView = createEffect(\r\n () => () =>\r\n this.router.events.pipe(\r\n filter(event => event instanceof NavigationEnd),\r\n tap((event: NavigationEnd) => {\r\n (window).ga('set', 'page', event.urlAfterRedirects);\r\n (window).ga('send', 'pageview');\r\n })\r\n ),\r\n { dispatch: false }\r\n );\r\n}\r\n","import { Injectable, Injector, ErrorHandler } from '@angular/core';\nimport {\n HttpEvent,\n HttpInterceptor,\n HttpHandler,\n HttpRequest,\n HttpErrorResponse\n} from '@angular/common/http';\nimport { Observable } from 'rxjs';\nimport { tap } from 'rxjs/operators';\n\n/** Passes HttpErrorResponse to application-wide error handler */\n@Injectable()\nexport class HttpErrorInterceptor implements HttpInterceptor {\n constructor(private injector: Injector) {}\n\n intercept(\n request: HttpRequest,\n next: HttpHandler\n ): Observable> {\n return next.handle(request).pipe(\n tap({\n error: (err: any) => {\n if (err instanceof HttpErrorResponse) {\n const appErrorHandler = this.injector.get(ErrorHandler);\n appErrorHandler.handleError(err);\n }\n }\n })\n );\n }\n}\n","import { Injectable } from '@angular/core';\n\nconst APP_PREFIX = 'ANMS-';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class LocalStorageService {\n constructor() {}\n\n static loadInitialState() {\n return Object.keys(localStorage).reduce((state: any, storageKey) => {\n if (storageKey.includes(APP_PREFIX)) {\n const stateKeys = storageKey\n .replace(APP_PREFIX, '')\n .toLowerCase()\n .split('.')\n .map(key =>\n key\n .split('-')\n .map((token, index) =>\n index === 0\n ? token\n : token.charAt(0).toUpperCase() + token.slice(1)\n )\n .join('')\n );\n let currentStateRef = state;\n stateKeys.forEach((key, index) => {\n if (index === stateKeys.length - 1) {\n currentStateRef[key] = JSON.parse(localStorage.getItem(storageKey));\n return;\n }\n currentStateRef[key] = currentStateRef[key] || {};\n currentStateRef = currentStateRef[key];\n });\n }\n return state;\n }, {});\n }\n\n setItem(key: string, value: any) {\n localStorage.setItem(`${APP_PREFIX}${key}`, JSON.stringify(value));\n }\n\n getItem(key: string) {\n return JSON.parse(localStorage.getItem(`${APP_PREFIX}${key}`));\n }\n\n removeItem(key: string) {\n localStorage.removeItem(`${APP_PREFIX}${key}`);\n }\n\n /** Tests that localStorage exists, can be written to, and read from. */\n testLocalStorage() {\n const testValue = 'testValue';\n const testKey = 'testKey';\n let retrievedValue: string;\n const errorMessage = 'localStorage did not return expected value';\n\n this.setItem(testKey, testValue);\n retrievedValue = this.getItem(testKey);\n this.removeItem(testKey);\n\n if (retrievedValue !== testValue) {\n throw new Error(errorMessage);\n }\n }\n}\n","import { ActionReducer } from '@ngrx/store';\n\nimport { AppState } from '../core.state';\n\nexport function debug(\n reducer: ActionReducer\n): ActionReducer {\n return function(state, action) {\n const newState = reducer(state, action);\n console.log(`[DEBUG] action: ${action.type}`, {\n payload: (action).payload,\n oldState: state,\n newState\n });\n return newState;\n };\n}\n","import { ActionReducer, INIT, UPDATE } from '@ngrx/store';\n\nimport { LocalStorageService } from '../local-storage/local-storage.service';\nimport { AppState } from '../core.state';\n\nexport function initStateFromLocalStorage(\n reducer: ActionReducer\n): ActionReducer {\n return function(state, action) {\n const newState = reducer(state, action);\n if ([INIT.toString(), UPDATE.toString()].includes(action.type)) {\n return { ...newState, ...LocalStorageService.loadInitialState() };\n }\n return newState;\n };\n}\n","import { Injectable, NgZone } from '@angular/core';\nimport { MatSnackBar, MatSnackBarConfig } from '@angular/material';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class NotificationService {\n constructor(\n private readonly snackBar: MatSnackBar,\n private readonly zone: NgZone\n ) {}\n\n default(message: string) {\n this.show(message, {\n duration: 2000,\n panelClass: 'default-notification-overlay'\n });\n }\n\n info(message: string) {\n this.show(message, {\n duration: 2000,\n panelClass: 'info-notification-overlay'\n });\n }\n\n success(message: string) {\n this.show(message, {\n duration: 2000,\n panelClass: 'success-notification-overlay'\n });\n }\n\n warn(message: string) {\n this.show(message, {\n duration: 2500,\n panelClass: 'warning-notification-overlay'\n });\n }\n\n error(message: string) {\n this.show(message, {\n duration: 3000,\n panelClass: 'error-notification-overlay'\n });\n }\n\n private show(message: string, configuration: MatSnackBarConfig) {\n // Need to open snackBar from Angular zone to prevent issues with its position per\n // https://stackoverflow.com/questions/50101912/snackbar-position-wrong-when-use-errorhandler-in-angular-5-and-material\n this.zone.run(() => this.snackBar.open(message, null, configuration));\n }\n}\n","import { Injectable } from '@angular/core';\r\nimport { RouterStateSnapshot } from '@angular/router';\r\nimport { RouterStateSerializer } from '@ngrx/router-store';\r\nimport { RouterStateUrl } from './router.state';\r\n\r\n@Injectable()\r\nexport class CustomSerializer implements RouterStateSerializer {\r\n serialize(routerState: RouterStateSnapshot): RouterStateUrl {\r\n let route = routerState.root;\r\n\r\n while (route.firstChild) {\r\n route = route.firstChild;\r\n }\r\n\r\n const {\r\n url,\r\n root: { queryParams }\r\n } = routerState;\r\n const { params } = route;\r\n\r\n return { url, params, queryParams };\r\n }\r\n}\r\n","import { createAction, props } from '@ngrx/store';\n\nimport { Language } from './settings.model';\n\nexport const actionSettingsChangeLanguage = createAction(\n '[Settings] Change Language',\n props<{ language: Language }>()\n);\n\nexport const actionSettingsChangeTheme = createAction(\n '[Settings] Change Theme',\n props<{ theme: string }>()\n);\nexport const actionSettingsChangeAutoNightMode = createAction(\n '[Settings] Change Auto Night Mode',\n props<{ autoNightMode: boolean }>()\n);\n\nexport const actionSettingsChangeStickyHeader = createAction(\n '[Settings] Change Sticky Header',\n props<{ stickyHeader: boolean }>()\n);\n\nexport const actionSettingsChangeAnimationsPage = createAction(\n '[Settings] Change Animations Page',\n props<{ pageAnimations: boolean }>()\n);\n\nexport const actionSettingsChangeAnimationsPageDisabled = createAction(\n '[Settings] Change Animations Page Disabled',\n props<{ pageAnimationsDisabled: boolean }>()\n);\n\nexport const actionSettingsChangeAnimationsElements = createAction(\n '[Settings] Change Animations Elements',\n props<{ elementsAnimations: boolean }>()\n);\nexport const actionSettingsChangeHour = createAction(\n '[Settings] Change Hours',\n props<{ hour: number }>()\n);\n","import { ActivationEnd, Router } from '@angular/router';\nimport { Injectable } from '@angular/core';\nimport { OverlayContainer } from '@angular/cdk/overlay';\nimport { select, Store } from '@ngrx/store';\nimport { Actions, createEffect, ofType } from '@ngrx/effects';\nimport { TranslateService } from '@ngx-translate/core';\nimport { combineLatest, interval, merge, of } from 'rxjs';\nimport {\n tap,\n withLatestFrom,\n map,\n distinctUntilChanged,\n mapTo,\n filter\n} from 'rxjs/operators';\n\nimport { selectSettingsState } from '../core.state';\nimport { LocalStorageService } from '../local-storage/local-storage.service';\nimport { AnimationsService } from '../animations/animations.service';\nimport { TitleService } from '../title/title.service';\n\nimport {\n actionSettingsChangeAnimationsElements,\n actionSettingsChangeAnimationsPage,\n actionSettingsChangeAnimationsPageDisabled,\n actionSettingsChangeAutoNightMode,\n actionSettingsChangeLanguage,\n actionSettingsChangeTheme,\n actionSettingsChangeStickyHeader,\n actionSettingsChangeHour\n} from './settings.actions';\nimport {\n selectEffectiveTheme,\n selectSettingsLanguage,\n selectPageAnimations,\n selectElementsAnimations\n} from './settings.selectors';\nimport { State } from './settings.model';\n\nexport const SETTINGS_KEY = 'SETTINGS';\n\nconst INIT = of('anms-init-effect-trigger');\n\n@Injectable()\nexport class SettingsEffects {\n constructor(\n private actions$: Actions,\n private store: Store,\n private router: Router,\n private overlayContainer: OverlayContainer,\n private localStorageService: LocalStorageService,\n private titleService: TitleService,\n private animationsService: AnimationsService,\n private translateService: TranslateService\n ) {}\n\n changeHour = createEffect(() =>\n interval(60_000).pipe(\n mapTo(new Date().getHours()),\n distinctUntilChanged(),\n map(hour => actionSettingsChangeHour({ hour }))\n )\n );\n\n persistSettings = createEffect(\n () =>\n this.actions$.pipe(\n ofType(\n actionSettingsChangeAnimationsElements,\n actionSettingsChangeAnimationsPage,\n actionSettingsChangeAnimationsPageDisabled,\n actionSettingsChangeAutoNightMode,\n actionSettingsChangeLanguage,\n actionSettingsChangeStickyHeader,\n actionSettingsChangeTheme\n ),\n withLatestFrom(this.store.pipe(select(selectSettingsState))),\n tap(([action, settings]) =>\n this.localStorageService.setItem(SETTINGS_KEY, settings)\n )\n ),\n { dispatch: false }\n );\n\n updateRouteAnimationType = createEffect(\n () =>\n merge(\n INIT,\n this.actions$.pipe(\n ofType(\n actionSettingsChangeAnimationsElements,\n actionSettingsChangeAnimationsPage\n )\n )\n ).pipe(\n withLatestFrom(\n combineLatest([\n this.store.pipe(select(selectPageAnimations)),\n this.store.pipe(select(selectElementsAnimations))\n ])\n ),\n tap(([action, [pageAnimations, elementsAnimations]]) =>\n this.animationsService.updateRouteAnimationType(\n pageAnimations,\n elementsAnimations\n )\n )\n ),\n { dispatch: false }\n );\n\n updateTheme = createEffect(\n () =>\n merge(INIT, this.actions$.pipe(ofType(actionSettingsChangeTheme))).pipe(\n withLatestFrom(this.store.pipe(select(selectEffectiveTheme))),\n tap(([action, effectiveTheme]) => {\n const classList = this.overlayContainer.getContainerElement()\n .classList;\n const toRemove = Array.from(classList).filter((item: string) =>\n item.includes('-theme')\n );\n if (toRemove.length) {\n classList.remove(...toRemove);\n }\n classList.add(effectiveTheme);\n })\n ),\n { dispatch: false }\n );\n\n setTranslateServiceLanguage = createEffect(\n () =>\n this.store.pipe(\n select(selectSettingsLanguage),\n distinctUntilChanged(),\n tap(language => this.translateService.use(language))\n ),\n { dispatch: false }\n );\n\n setTitle = createEffect(\n () =>\n merge(\n this.actions$.pipe(ofType(actionSettingsChangeLanguage)),\n this.router.events.pipe(filter(event => event instanceof ActivationEnd))\n ).pipe(\n tap(() => {\n this.titleService.setTitle(\n this.router.routerState.snapshot.root,\n this.translateService\n );\n })\n ),\n { dispatch: false }\n );\n}\n","import { AppState } from '../core.module';\n\nexport const NIGHT_MODE_THEME = 'BLACK-THEME';\n\nexport type Language = 'en' | 'sk' | 'de' | 'fr' | 'es' | 'pt-br' | 'he';\n\nexport interface SettingsState {\n language: string;\n theme: string;\n autoNightMode: boolean;\n nightTheme: string;\n stickyHeader: boolean;\n pageAnimations: boolean;\n pageAnimationsDisabled: boolean;\n elementsAnimations: boolean;\n hour: number;\n}\n\nexport interface State extends AppState {\n settings: SettingsState;\n}\n","import { SettingsState, NIGHT_MODE_THEME } from './settings.model';\nimport {\n actionSettingsChangeAnimationsElements,\n actionSettingsChangeAnimationsPage,\n actionSettingsChangeAnimationsPageDisabled,\n actionSettingsChangeAutoNightMode,\n actionSettingsChangeHour,\n actionSettingsChangeLanguage,\n actionSettingsChangeStickyHeader,\n actionSettingsChangeTheme\n} from './settings.actions';\nimport { Action, createReducer, on } from '@ngrx/store';\n\nexport const initialState: SettingsState = {\n language: 'en',\n theme: 'DEFAULT-THEME',\n autoNightMode: false,\n nightTheme: NIGHT_MODE_THEME,\n stickyHeader: true,\n pageAnimations: true,\n pageAnimationsDisabled: false,\n elementsAnimations: true,\n hour: 0\n};\n\nconst reducer = createReducer(\n initialState,\n on(\n actionSettingsChangeLanguage,\n actionSettingsChangeTheme,\n actionSettingsChangeAutoNightMode,\n actionSettingsChangeStickyHeader,\n actionSettingsChangeAnimationsPage,\n actionSettingsChangeAnimationsElements,\n actionSettingsChangeHour,\n (state, action) => ({ ...state, ...action })\n ),\n on(\n actionSettingsChangeAnimationsPageDisabled,\n (state, { pageAnimationsDisabled }) => ({\n ...state,\n pageAnimationsDisabled,\n pageAnimations: false\n })\n )\n);\n\nexport function settingsReducer(\n state: SettingsState | undefined,\n action: Action\n) {\n return reducer(state, action);\n}\n","import { createSelector } from '@ngrx/store';\n\nimport { SettingsState } from './settings.model';\nimport { selectSettingsState } from '../core.state';\n\nexport const selectSettings = createSelector(\n selectSettingsState,\n (state: SettingsState) => state\n);\n\nexport const selectSettingsStickyHeader = createSelector(\n selectSettings,\n (state: SettingsState) => state.stickyHeader\n);\n\nexport const selectSettingsLanguage = createSelector(\n selectSettings,\n (state: SettingsState) => state.language\n);\n\nexport const selectTheme = createSelector(\n selectSettings,\n settings => settings.theme\n);\n\nexport const selectPageAnimations = createSelector(\n selectSettings,\n settings => settings.pageAnimations\n);\n\nexport const selectElementsAnimations = createSelector(\n selectSettings,\n settings => settings.elementsAnimations\n);\n\nexport const selectAutoNightMode = createSelector(\n selectSettings,\n settings => settings.autoNightMode\n);\n\nexport const selectNightTheme = createSelector(\n selectSettings,\n settings => settings.nightTheme\n);\n\nexport const selectHour = createSelector(\n selectSettings,\n settings => settings.hour\n);\n\nexport const selectIsNightHour = createSelector(\n selectAutoNightMode,\n selectHour,\n (autoNightMode, hour) => autoNightMode && (hour >= 21 || hour <= 7)\n);\n\nexport const selectEffectiveTheme = createSelector(\n selectTheme,\n selectNightTheme,\n selectIsNightHour,\n (theme, nightTheme, isNightHour) =>\n (isNightHour ? nightTheme : theme).toLowerCase()\n);\n","import { Title } from '@angular/platform-browser';\nimport { Injectable } from '@angular/core';\nimport { ActivatedRouteSnapshot } from '@angular/router';\nimport { TranslateService } from '@ngx-translate/core';\nimport { filter } from 'rxjs/operators';\n\nimport { environment as env } from '../../../environments/environment';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class TitleService {\n constructor(\n private translateService: TranslateService,\n private title: Title\n ) {}\n\n setTitle(\n snapshot: ActivatedRouteSnapshot,\n lazyTranslateService?: TranslateService\n ) {\n let lastChild = snapshot;\n while (lastChild.children.length) {\n lastChild = lastChild.children[0];\n }\n const { title } = lastChild.data;\n const translate = lazyTranslateService || this.translateService;\n if (title) {\n translate\n .get(title)\n .pipe(filter(translatedTitle => translatedTitle !== title))\n .subscribe(translatedTitle =>\n this.title.setTitle(`${translatedTitle} - ${env.appName}`)\n );\n } else {\n this.title.setTitle(env.appName);\n }\n }\n}\n","module.exports = \"button {\\n padding: 0;\\n min-width: 36px;\\n margin-left: 10px;\\n}\\nbutton mat-icon {\\n position: relative;\\n top: 2px;\\n font-size: 18px;\\n}\\nbutton fa-icon {\\n position: relative;\\n font-size: 18px;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9hcHAvc2hhcmVkL2JpZy1pbnB1dC9iaWctaW5wdXQtYWN0aW9uL0M6XFxQcm9qZWN0XFxtZW1ub25zX21hdGVyaWFsXFxwcm9qZWN0c1xcbWVtbm9uc19tYXRlcmlhbC9zcmNcXGFwcFxcc2hhcmVkXFxiaWctaW5wdXRcXGJpZy1pbnB1dC1hY3Rpb25cXGJpZy1pbnB1dC1hY3Rpb24uY29tcG9uZW50LnNjc3MiLCJzcmMvYXBwL3NoYXJlZC9iaWctaW5wdXQvYmlnLWlucHV0LWFjdGlvbi9iaWctaW5wdXQtYWN0aW9uLmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0UsVUFBQTtFQUNBLGVBQUE7RUFDQSxpQkFBQTtBQ0NGO0FEQ0U7RUFDRSxrQkFBQTtFQUNBLFFBQUE7RUFDQSxlQUFBO0FDQ0o7QURDRTtFQUNFLGtCQUFBO0VBQ0EsZUFBQTtBQ0NKIiwiZmlsZSI6InNyYy9hcHAvc2hhcmVkL2JpZy1pbnB1dC9iaWctaW5wdXQtYWN0aW9uL2JpZy1pbnB1dC1hY3Rpb24uY29tcG9uZW50LnNjc3MiLCJzb3VyY2VzQ29udGVudCI6WyJidXR0b24ge1xuICBwYWRkaW5nOiAwO1xuICBtaW4td2lkdGg6IDM2cHg7XG4gIG1hcmdpbi1sZWZ0OiAxMHB4O1xuXG4gIG1hdC1pY29uIHtcbiAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgdG9wOiAycHg7XG4gICAgZm9udC1zaXplOiAxOHB4O1xuICB9XG4gIGZhLWljb24ge1xuICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICBmb250LXNpemU6IDE4cHg7XG4gIH1cbn1cbiIsImJ1dHRvbiB7XG4gIHBhZGRpbmc6IDA7XG4gIG1pbi13aWR0aDogMzZweDtcbiAgbWFyZ2luLWxlZnQ6IDEwcHg7XG59XG5idXR0b24gbWF0LWljb24ge1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHRvcDogMnB4O1xuICBmb250LXNpemU6IDE4cHg7XG59XG5idXR0b24gZmEtaWNvbiB7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZm9udC1zaXplOiAxOHB4O1xufSJdfQ== */\"","import {\n Component,\n Input,\n Output,\n EventEmitter,\n ChangeDetectionStrategy\n} from '@angular/core';\n\n@Component({\n selector: 'anms-big-input-action',\n templateUrl: './big-input-action.component.html',\n styleUrls: ['./big-input-action.component.scss'],\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BigInputActionComponent {\n @Input()\n disabled = false;\n @Input()\n fontSet = '';\n @Input()\n fontIcon = '';\n @Input()\n faIcon = '';\n @Input()\n label = '';\n @Input()\n color = '';\n\n @Output()\n action = new EventEmitter();\n\n hasFocus = false;\n\n onClick() {\n this.action.emit();\n }\n}\n","module.exports = \".big-input {\\n width: 100%;\\n transition: all 0.5s;\\n display: flex;\\n padding: 10px 10px 10px 20px;\\n}\\n.big-input input {\\n flex-grow: 1;\\n border: 0;\\n font-size: 20px;\\n min-width: 100px;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9hcHAvc2hhcmVkL2JpZy1pbnB1dC9iaWctaW5wdXQvQzpcXFByb2plY3RcXG1lbW5vbnNfbWF0ZXJpYWxcXHByb2plY3RzXFxtZW1ub25zX21hdGVyaWFsL3NyY1xcYXBwXFxzaGFyZWRcXGJpZy1pbnB1dFxcYmlnLWlucHV0XFxiaWctaW5wdXQuY29tcG9uZW50LnNjc3MiLCJzcmMvYXBwL3NoYXJlZC9iaWctaW5wdXQvYmlnLWlucHV0L2JpZy1pbnB1dC5jb21wb25lbnQuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTtFQUNFLFdBQUE7RUFDQSxvQkFBQTtFQUNBLGFBQUE7RUFDQSw0QkFBQTtBQ0NGO0FEQ0U7RUFDRSxZQUFBO0VBQ0EsU0FBQTtFQUNBLGVBQUE7RUFDQSxnQkFBQTtBQ0NKIiwiZmlsZSI6InNyYy9hcHAvc2hhcmVkL2JpZy1pbnB1dC9iaWctaW5wdXQvYmlnLWlucHV0LmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLmJpZy1pbnB1dCB7XG4gIHdpZHRoOiAxMDAlO1xuICB0cmFuc2l0aW9uOiBhbGwgMC41cztcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogMTBweCAxMHB4IDEwcHggMjBweDtcblxuICBpbnB1dCB7XG4gICAgZmxleC1ncm93OiAxO1xuICAgIGJvcmRlcjogMDtcbiAgICBmb250LXNpemU6IDIwcHg7XG4gICAgbWluLXdpZHRoOiAxMDBweDtcbiAgfVxufVxuIiwiLmJpZy1pbnB1dCB7XG4gIHdpZHRoOiAxMDAlO1xuICB0cmFuc2l0aW9uOiBhbGwgMC41cztcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogMTBweCAxMHB4IDEwcHggMjBweDtcbn1cbi5iaWctaW5wdXQgaW5wdXQge1xuICBmbGV4LWdyb3c6IDE7XG4gIGJvcmRlcjogMDtcbiAgZm9udC1zaXplOiAyMHB4O1xuICBtaW4td2lkdGg6IDEwMHB4O1xufSJdfQ== */\"","import { Component, Input, ChangeDetectionStrategy } from '@angular/core';\n\n@Component({\n selector: 'anms-big-input',\n templateUrl: './big-input.component.html',\n styleUrls: ['./big-input.component.scss'],\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BigInputComponent {\n @Input()\n placeholder: string;\n\n @Input()\n value = '';\n @Input()\n disabled = false;\n\n hasFocus = false;\n}\n","import { Directive, ElementRef, OnInit, OnDestroy } from '@angular/core';\r\nimport { TranslateService, LangChangeEvent } from '@ngx-translate/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\n@Directive({\r\n selector: '[rtl]' // tslint:disable-line\r\n})\r\nexport class RtlSupportDirective implements OnInit, OnDestroy {\r\n private subscription: Subscription;\r\n constructor(private el: ElementRef, public translate: TranslateService) {\r\n el.nativeElement.style.textAlign =\r\n translate.currentLang === 'he' ? 'right' : 'left';\r\n el.nativeElement.style.direction =\r\n translate.currentLang === 'he' ? 'rtl' : 'ltr';\r\n }\r\n ngOnInit() {\r\n this.subscription = this.translate.onLangChange.subscribe(\r\n (event: LangChangeEvent) => {\r\n this.el.nativeElement.style.textAlign =\r\n event.lang === 'he' ? 'right' : 'left';\r\n this.el.nativeElement.style.direction =\r\n event.lang === 'he' ? 'rtl' : 'ltr';\r\n }\r\n );\r\n }\r\n\r\n ngOnDestroy() {\r\n if (this.subscription) {\r\n this.subscription.unsubscribe();\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\n\nimport { TranslateModule } from '@ngx-translate/core';\n\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatToolbarModule } from '@angular/material/toolbar';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatChipsModule } from '@angular/material/chips';\nimport { MatSidenavModule } from '@angular/material/sidenav';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatCardModule } from '@angular/material/card';\nimport { MatListModule } from '@angular/material/list';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatSnackBarModule } from '@angular/material/snack-bar';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { MatDividerModule } from '@angular/material/divider';\nimport { MatSliderModule } from '@angular/material/';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatNativeDateModule } from '@angular/material';\n\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\nimport { library } from '@fortawesome/fontawesome-svg-core';\nimport {\n faBars,\n faUserCircle,\n faPowerOff,\n faCog,\n faPlayCircle,\n faRocket,\n faPlus,\n faEdit,\n faTrash,\n faTimes,\n faCaretUp,\n faCaretDown,\n faExclamationTriangle,\n faFilter,\n faTasks,\n faCheck,\n faSquare,\n faLanguage,\n faPaintBrush,\n faLightbulb,\n faWindowMaximize,\n faStream,\n faBook,\n faSitemap,\n faMobile,\n faLaptopCode,\n faLaptop,\n faLink\n} from '@fortawesome/free-solid-svg-icons';\nimport {\n faGithub,\n faMediumM,\n faTwitter,\n faInstagram,\n faYoutube,\n faLinkedin\n} from '@fortawesome/free-brands-svg-icons';\n\nlibrary.add(\n faSitemap,\n faMobile,\n faLaptopCode,\n faLaptop,\n faLink,\n faBars,\n faUserCircle,\n faPowerOff,\n faCog,\n faRocket,\n faPlayCircle,\n faGithub,\n faMediumM,\n faTwitter,\n faInstagram,\n faYoutube,\n faLinkedin,\n faPlus,\n faEdit,\n faTrash,\n faTimes,\n faCaretUp,\n faCaretDown,\n faExclamationTriangle,\n faFilter,\n faTasks,\n faCheck,\n faSquare,\n faLanguage,\n faPaintBrush,\n faLightbulb,\n faWindowMaximize,\n faStream,\n faBook\n);\n\nimport { BigInputComponent } from './big-input/big-input/big-input.component';\nimport { BigInputActionComponent } from './big-input/big-input-action/big-input-action.component';\nimport { RtlSupportDirective } from './rtl-support/rtl-support.directive';\n\n@NgModule({\n imports: [\n CommonModule,\n FormsModule,\n\n TranslateModule,\n\n MatButtonModule,\n MatToolbarModule,\n MatSelectModule,\n MatTabsModule,\n MatInputModule,\n MatProgressSpinnerModule,\n MatChipsModule,\n MatCardModule,\n MatSidenavModule,\n MatCheckboxModule,\n MatListModule,\n MatMenuModule,\n MatIconModule,\n MatTooltipModule,\n MatSnackBarModule,\n MatSlideToggleModule,\n MatDividerModule,\n\n FontAwesomeModule\n ],\n declarations: [\n BigInputComponent,\n BigInputActionComponent,\n RtlSupportDirective\n ],\n exports: [\n CommonModule,\n FormsModule,\n ReactiveFormsModule,\n\n TranslateModule,\n\n MatButtonModule,\n MatMenuModule,\n MatTabsModule,\n MatChipsModule,\n MatInputModule,\n MatProgressSpinnerModule,\n MatCheckboxModule,\n MatCardModule,\n MatSidenavModule,\n MatListModule,\n MatSelectModule,\n MatToolbarModule,\n MatIconModule,\n MatTooltipModule,\n MatSnackBarModule,\n MatSlideToggleModule,\n MatDividerModule,\n MatSliderModule,\n MatDatepickerModule,\n MatNativeDateModule,\n\n FontAwesomeModule,\n\n BigInputComponent,\n BigInputActionComponent,\n RtlSupportDirective\n ]\n})\nexport class SharedModule {}\n","module.exports = __webpack_public_path__ + \"Memnonlogo.png\";","// The file contents for the current environment will overwrite these during build.\n// The build system defaults to the dev environment which uses `environment.ts`, but if you do\n// `ng build --env=prod` then `environment.prod.ts` will be used instead.\n// The list of which env maps to which file can be found in `.angular-cli.json`.\n\nconst packageJson = require('../../../../package.json');\n\nexport const environment = {\n appName: 'Memnons',\n envName: 'DEV',\n production: false,\n test: false,\n i18nPrefix: '',\n versions: {\n app: packageJson.version,\n angular: packageJson.dependencies['@angular/core'],\n ngrx: packageJson.dependencies['@ngrx/store'],\n material: packageJson.dependencies['@angular/material'],\n bootstrap: packageJson.dependencies.bootstrap,\n rxjs: packageJson.dependencies.rxjs,\n ngxtranslate: packageJson.dependencies['@ngx-translate/core'],\n fontAwesome: packageJson.dependencies['@fortawesome/fontawesome-free'],\n angularCli: packageJson.devDependencies['@angular/cli'],\n typescript: packageJson.devDependencies['typescript'],\n cypress: packageJson.devDependencies['cypress']\n }\n};\n","import { enableProdMode } from '@angular/core';\nimport { platformBrowserDynamic } from '@angular/platform-browser-dynamic';\n\nimport { AppModule } from './app/app.module';\nimport { environment } from './environments/environment';\n\nif (environment.production) {\n enableProdMode();\n}\n\nplatformBrowserDynamic()\n .bootstrapModule(AppModule)\n .catch(err => console.error(err));\n"],"sourceRoot":""}