/*!***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/resolve-url-loader/index.js??ruleSet[1].rules[6].rules[1].use[0]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[6].rules[1].use[1]!./src/global.scss?ngGlobalStyle ***!
  \***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
@import url(https://unpkg.com/open-props@1.6.17/easings.min.css);
/*!********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/resolve-url-loader/index.js??ruleSet[1].rules[6].rules[1].use[0]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[6].rules[1].use[1]!./src/theme/variables.scss?ngGlobalStyle ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/** Ionic CSS Variables **/
:root {
  /** primary **/
  --color:var(--ion-black-primary) !important;
  --ion-color-primary-rgb: 56, 128, 255;
  --ion-color-primary-contrast: var(--ion-text-primary);
  --ion-color-primary-contrast-rgb: 255, 255, 255;
  --ion-color-primary-shade: #3171e0;
  --ion-color-primary-tint: #4c8dff;
  /** secondary **/
  --ion-color-secondary-rgb: 61, 194, 255;
  --ion-color-secondary-contrast: var(--ion-text-secondary);
  --ion-color-secondary-contrast-rgb: 255, 255, 255;
  --ion-color-secondary-shade: #36abe0;
  --ion-color-secondary-tint: #50c8ff;
  /** tertiary **/
  --ion-color-tertiary-rgb: 82, 96, 255;
  --ion-color-secondary-contrast: var(--ion-text-tertiary);
  --ion-color-tertiary-contrast-rgb: 255, 255, 255;
  --ion-color-tertiary-shade: #4854e0;
  --ion-color-tertiary-tint: #6370ff;
  /** success **/
  --ion-color-success: #2dd36f;
  --ion-color-success-rgb: 45, 211, 111;
  --ion-color-success-contrast: #ffffff;
  --ion-color-success-contrast-rgb: 255, 255, 255;
  --ion-color-success-shade: #28ba62;
  --ion-color-success-tint: #42d77d;
  /** warning **/
  --ion-color-warning: #ffc409;
  --ion-color-warning-rgb: 255, 196, 9;
  --ion-color-warning-contrast: #000000;
  --ion-color-warning-contrast-rgb: 0, 0, 0;
  --ion-color-warning-shade: #e0ac08;
  --ion-color-warning-tint: #ffca22;
  /** danger **/
  --ion-color-danger: #FF1E1E;
  --ion-color-danger-rgb: 235, 68, 90;
  --ion-light: #ffffff;
  --ion-dark: #000;
  --ion-color-danger-shade: #cf3c4f;
  --ion-color-danger-tint: #ed576b;
  /** dark **/
  --ion-color-dark-rgb: 34, 36, 40;
  --ion-color-dark-contrast: #fff0;
  --ion-color-dark-contrast-rgb: 255, 255, 255;
  --ion-color-dark-shade: #ffffff40;
  --ion-color-dark-tint: #383a3e;
  /** medium **/
  --ion-color-medium: #92949c;
  --ion-color-medium-rgb: 146, 148, 156;
  --ion-color-medium-contrast: #ffffff70;
  --ion-color-medium-contrast-rgb: 255, 255, 255;
  --ion-color-medium-shade: #808289;
  --ion-color-medium-tint: #9d9fa6;
  /** light **/
  --ion-color-light-rgb: 244, 245, 248;
  --ion-color-light-contrast: #000000;
  --ion-color-light-contrast-rgb: 0, 0, 0;
  --ion-color-light-shade: #ffffffec;
  --ion-color-light-tint: #f5f6f9;
  /** fill color **/
  --pp: #00000060;
  --ss: #ffffff20;
  --tt: #000000c0;
  --star-color: var(--highlight);
  --t-sun-color: hsl(47, 100%, 88%);
  --t-moon-color: var(--ion-diffuseLight-primary);
  --t-moon-pattern-color: var(--ion-diffuseLight-primary);
  /* colorz  that will change on transition */
  --circle-bg-color: hsl(32.09deg 100% 74.71%);
  --cactus-body-color: #2dd36f;
  --cactus-flower-color: var(--ion-color-primary);
  --sand-01-color: hsl(21.25deg 38.36% 41.97%);
  --sand-02-color: hsl(21.47deg 41.85% 55.49%);
  --sand-03-color: hsl(37.3deg 56.92% 74.51%);
  --sand-04-color: hsl(53.08deg 66.67% 84.71%);
  --mountain-color: hsl(21.25deg 38.36% 41.97%);
  /* animation and transition timings */
  --t-slow: 2500ms;
  --t-med: 1500ms;
  --t-fast: 1000ms;
  --t-delay-motionpath: 400ms;
  --t-delay-colorfades: 200ms;
  --a-scale-from: scale(1);
  --a-scale-to: scale(1.05);
}

:root {
  /*
   * Dark Colors
   * -------------------------------------------
   */
  /*
   * iOS Dark Theme
   * -------------------------------------------
   */
  /*
   * Material Design Dark Theme
   * -------------------------------------------
   */
}
:root body.dark {
  --color:var(--ion-white-primary) !important;
  --ion-color-primary-rgb: 66, 140, 255;
  --ion-color-primary-contrast: var(--ion-text-primary);
  --ion-color-primary-contrast-rgb: 255, 255, 255;
  --ion-color-primary-shade: #3a7be0;
  --ion-color-primary-tint: #5598ff;
  --ion-color-secondary-rgb: 80, 200, 255;
  --ion-color-secondary-contrast: var(--ion-text-secondary);
  --ion-color-secondary-contrast-rgb: 255, 255, 255;
  --ion-color-secondary-shade: #46b0e0;
  --ion-color-secondary-tint: #62ceff;
  --ion-color-tertiary-rgb: 106, 100, 255;
  --ion-color-tertiary-contrast: var(--ion-text-secondary);
  --ion-color-tertiary-contrast-rgb: 255, 255, 255;
  --ion-color-tertiary-shade: #5d58e0;
  --ion-color-tertiary-tint: #7974ff;
  --ion-color-success: #2fdf75;
  --ion-color-success-rgb: 47, 223, 117;
  --ion-color-success-contrast: #000000;
  --ion-color-success-contrast-rgb: 0, 0, 0;
  --ion-color-success-shade: #29c467;
  --ion-color-success-tint: #44e283;
  --ion-color-warning: #ffd534;
  --ion-color-warning-rgb: 255, 213, 52;
  --ion-color-warning-contrast: #000000;
  --ion-color-warning-contrast-rgb: 0, 0, 0;
  --ion-color-warning-shade: #e0bb2e;
  --ion-color-warning-tint: #ffd948;
  --ion-color-danger: #ff4961;
  --ion-color-danger-rgb: 255, 73, 97;
  --ion-light: #000;
  --ion-dark: #fff;
  --ion-color-danger-shade: #e04055;
  --ion-color-danger-tint: #ff5b71;
  --ion-color-dark-rgb: 244, 245, 248;
  --ion-color-dark-contrast: #0000;
  --ion-color-dark-contrast-rgb: 0, 0, 0;
  --ion-color-dark-shade: #00000040;
  --ion-color-dark-tint: #f5f6f9;
  --ion-color-medium: #989aa2;
  --ion-color-medium-rgb: 152, 154, 162;
  --ion-color-medium-contrast: #00000070;
  --ion-color-medium-contrast-rgb: 0, 0, 0;
  --ion-color-medium-shade: #86888f;
  --ion-color-medium-tint: #a2a4ab;
  --ion-color-light-rgb: 34, 36, 40;
  --ion-color-light-contrast: #ffffff;
  --ion-color-light-contrast-rgb: 255, 255, 255;
  --ion-color-light-shade: #1e2023f7;
  --ion-color-light-tint: #383a3e;
  --pp: #ffffff60;
  --ss: #00000020;
  --tt: #ffffffc0;
  --dark-cosmos-color: var(--darkgrey);
  --star-color: hsl(272, 57%, 95%);
  --t-sun-color: hsl(47, 100%, 88%);
  --t-moon-color: hsl(274, 93%, 94%);
  --t-moon-pattern-color: hsl(274, 58%, 89%);
  --sunsys-color: hsl(41, 99%, 75%);
  --sunsys-patterns-color: hsl(33, 95%, 73%);
  --earth-water-color: hsl(202, 62%, 74%);
  --earth-continent-color: hsl(192, 34%, 64%);
  /* colorz  that will change on transition */
  --circle-bg-color: hsl(28, 97%, 70%);
  --cactus-body-color: hsl(337, 43%, 28%);
  --cactus-flower-color: hsl(348, 80%, 62%);
  --mountain-color: hsl(346, 43%, 50%);
  --sand-01-color: hsl(339, 55%, 30%);
  --sand-02-color: hsl(335, 62%, 37%);
  --sand-03-color: hsl(338, 53%, 38%);
  --sand-04-color: hsl(336, 46%, 50%);
  /* The poster Illustration colors */
  --poster: hsl(25, 43%, 79%);
  --poster-border: min(3vmax, 50px);
  /* animation and transition timings */
  --t-slow: 2500ms;
  --t-med: 1500ms;
  --t-fast: 1000ms;
  --t-delay-motionpath: 400ms;
  --t-delay-colorfades: 200ms;
  --a-scale-from: scale(1);
  --a-scale-to: scale(1.05);
}
:root .ios body.dark {
  --ion-background-color: #000000;
  --ion-background-color-rgb: 0, 0, 0;
  --ion-text-color: #ffffff;
  --ion-text-color-rgb: 255, 255, 255;
  --ion-color-step-50: #0d0d0d;
  --ion-color-step-100: #1a1a1a;
  --ion-color-step-150: #262626;
  --ion-color-step-200: #333333;
  --ion-color-step-250: #404040;
  --ion-color-step-300: #4d4d4d;
  --ion-color-step-350: #595959;
  --ion-color-step-400: #666666;
  --ion-color-step-450: #737373;
  --ion-color-step-500: #808080;
  --ion-color-step-550: #8c8c8c;
  --ion-color-step-600: #999999;
  --ion-color-step-650: #a6a6a6;
  --ion-color-step-700: #b3b3b3;
  --ion-color-step-750: #bfbfbf;
  --ion-color-step-800: #cccccc;
  --ion-color-step-850: #d9d9d9;
  --ion-color-step-900: #e6e6e6;
  --ion-color-step-950: #f2f2f2;
  --ion-item-background: #000000;
  --ion-card-background: #1c1c1d;
}
:root .ios ion-modal {
  --ion-background-color: var(--ion-color-step-100);
  --ion-toolbar-background: var(--ion-color-step-150);
  --ion-toolbar-border-color: var(--ion-color-step-250);
}
:root .md body.dark {
  --ion-background-color: #121212;
  --ion-background-color-rgb: 18, 18, 18;
  --ion-text-color: #ffffff;
  --ion-text-color-rgb: 255, 255, 255;
  --ion-border-color: #222222;
  --ion-color-step-50: #1e1e1e;
  --ion-color-step-100: #2a2a2a;
  --ion-color-step-150: #363636;
  --ion-color-step-200: #414141;
  --ion-color-step-250: #4d4d4d;
  --ion-color-step-300: #595959;
  --ion-color-step-350: #656565;
  --ion-color-step-400: #717171;
  --ion-color-step-450: #7d7d7d;
  --ion-color-step-500: #898989;
  --ion-color-step-550: #949494;
  --ion-color-step-600: #a0a0a0;
  --ion-color-step-650: #acacac;
  --ion-color-step-700: #b8b8b8;
  --ion-color-step-750: #c4c4c4;
  --ion-color-step-800: #d0d0d0;
  --ion-color-step-850: #dbdbdb;
  --ion-color-step-900: #e7e7e7;
  --ion-color-step-950: #f3f3f3;
  --ion-item-background: #1e1e1e;
  --ion-toolbar-background: #1f1f1f;
  --ion-tab-bar-background: #1f1f1f;
  --ion-card-background: #1e1e1e;
}

/* Optional CSS, this is added for the flashing that happens when toggling between themes */
ion-item {
  --transition: none;
}

/** Fonts **/
@font-face {
  font-family: "Urbanist";
  src: url('Urbanist-Regular.ttf');
}
@font-face {
  font-family: "main";
  src: url('TitilliumWeb-Regular.ttf');
}
@font-face {
  font-family: "Urbanist-Bold";
  src: url('Urbanist-Bold.ttf');
}
@font-face {
  font-family: "Urbanist-Light";
  src: url('Urbanist-Light.ttf');
}
@font-face {
  font-family: "number";
  src: url('SofiaSans-Variable.ttf');
}
:root {
  --ion-font-family: "number";
}

:root[mode=md] {
  --ion-font-family: "number";
}

:root[mode=ios] {
  --ion-font-family: "number";
}
/*!**********************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/core.css ***!
  \**********************************************************************************************************************************************************************************************************************************/
html.ios {
  --ion-default-font: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Roboto", sans-serif;
}

html.md {
  --ion-default-font: "Roboto", "Helvetica Neue", sans-serif;
}

html {
  --ion-font-family: var(--ion-default-font);
}

body {
  background: var(--ion-background-color);
}

body.backdrop-no-scroll {
  overflow: hidden;
}

/**
 * Card style modal needs additional padding on the
 * top of the header. We accomplish this by targeting
 * the first toolbar in the header.
 * Footer also needs this. We do not adjust the bottom
 * padding though because of the safe area.
 */
html.ios ion-modal.modal-card ion-header ion-toolbar:first-of-type,
html.ios ion-modal.modal-sheet ion-header ion-toolbar:first-of-type,
html.ios ion-modal ion-footer ion-toolbar:first-of-type {
  padding-top: 6px;
}

/**
* Card style modal needs additional padding on the
* bottom of the header. We accomplish this by targeting
* the last toolbar in the header.
*/
html.ios ion-modal.modal-card ion-header ion-toolbar:last-of-type,
html.ios ion-modal.modal-sheet ion-header ion-toolbar:last-of-type {
  padding-bottom: 6px;
}

/**
* Add padding on the left and right
* of toolbars while accounting for
* safe area values when in landscape.
*/
html.ios ion-modal ion-toolbar {
  padding-right: calc(var(--ion-safe-area-right) + 8px);
  padding-left: calc(var(--ion-safe-area-left) + 8px);
}

/**
 * Card style modal on iPadOS
 * should only have backdrop on first instance.
 */
@media screen and (min-width: 768px) {
  html.ios ion-modal.modal-card:first-of-type {
    --backdrop-opacity: 0.18;
  }
}
/**
 * Subsequent modals should not have a backdrop/box shadow
 * as it will cause the screen to appear to get progressively
 * darker. With Ionic 6, declarative modals made it
 * possible to have multiple non-presented modals in the DOM,
 * so we could no longer rely on ion-modal:first-of-type.
 * Here we disable the opacity/box-shadow for every modal
 * that comes after the first presented modal.
 *
 * Note: ion-modal:not(.overlay-hidden):first-of-type
 * does not match the first modal to not have
 * the .overlay-hidden class, it will match the
 * first modal in general only if it does not
 * have the .overlay-hidden class.
 * The :nth-child() pseudo-class has support
 * for selectors which would help us here. At the
 * time of writing it does not have great cross browser
 * support.
 *
 * Note 2: This should only apply to non-card and
 * non-sheet modals. Card and sheet modals have their
 * own criteria for displaying backdrops/box shadows.
 *
 * Do not use :not(.overlay-hidden) in place of
 * .show-modal because that triggers a memory
 * leak in Blink: https://bugs.chromium.org/p/chromium/issues/detail?id=1418768
 */
ion-modal.modal-default.show-modal ~ ion-modal.modal-default {
  --backdrop-opacity: 0;
  --box-shadow: none;
}

/**
 * This works around a bug in WebKit where the
 * content will overflow outside of the bottom border
 * radius when re-painting. As long as a single
 * border radius value is set on .ion-page, this
 * issue does not happen. We set the top left radius
 * here because the top left corner will always have a
 * radius no matter the platform.
 * This behavior only applies to card modals.
 */
html.ios ion-modal.modal-card .ion-page {
  border-top-left-radius: var(--border-radius);
}

.ion-color-primary {
  --ion-color-base: var(--ion-color-primary, #3880ff) !important;
  --ion-color-base-rgb: var(--ion-color-primary-rgb, 56, 128, 255) !important;
  --ion-color-contrast: var(--ion-color-primary-contrast, #fff) !important;
  --ion-color-contrast-rgb: var(--ion-color-primary-contrast-rgb, 255, 255, 255) !important;
  --ion-color-shade: var(--ion-color-primary-shade, #3171e0) !important;
  --ion-color-tint: var(--ion-color-primary-tint, #4c8dff) !important;
}

.ion-color-secondary {
  --ion-color-base: var(--ion-color-secondary, #3dc2ff) !important;
  --ion-color-base-rgb: var(--ion-color-secondary-rgb, 61, 194, 255) !important;
  --ion-color-contrast: var(--ion-color-secondary-contrast, #fff) !important;
  --ion-color-contrast-rgb: var(--ion-color-secondary-contrast-rgb, 255, 255, 255) !important;
  --ion-color-shade: var(--ion-color-secondary-shade, #36abe0) !important;
  --ion-color-tint: var(--ion-color-secondary-tint, #50c8ff) !important;
}

.ion-color-tertiary {
  --ion-color-base: var(--ion-color-tertiary, #5260ff) !important;
  --ion-color-base-rgb: var(--ion-color-tertiary-rgb, 82, 96, 255) !important;
  --ion-color-contrast: var(--ion-color-tertiary-contrast, #fff) !important;
  --ion-color-contrast-rgb: var(--ion-color-tertiary-contrast-rgb, 255, 255, 255) !important;
  --ion-color-shade: var(--ion-color-tertiary-shade, #4854e0) !important;
  --ion-color-tint: var(--ion-color-tertiary-tint, #6370ff) !important;
}

.ion-color-success {
  --ion-color-base: var(--ion-color-success, #2dd36f) !important;
  --ion-color-base-rgb: var(--ion-color-success-rgb, 45, 211, 111) !important;
  --ion-color-contrast: var(--ion-color-success-contrast, #fff) !important;
  --ion-color-contrast-rgb: var(--ion-color-success-contrast-rgb, 255, 255, 255) !important;
  --ion-color-shade: var(--ion-color-success-shade, #28ba62) !important;
  --ion-color-tint: var(--ion-color-success-tint, #42d77d) !important;
}

.ion-color-warning {
  --ion-color-base: var(--ion-color-warning, #ffc409) !important;
  --ion-color-base-rgb: var(--ion-color-warning-rgb, 255, 196, 9) !important;
  --ion-color-contrast: var(--ion-color-warning-contrast, #000) !important;
  --ion-color-contrast-rgb: var(--ion-color-warning-contrast-rgb, 0, 0, 0) !important;
  --ion-color-shade: var(--ion-color-warning-shade, #e0ac08) !important;
  --ion-color-tint: var(--ion-color-warning-tint, #ffca22) !important;
}

.ion-color-danger {
  --ion-color-base: var(--ion-color-danger, #eb445a) !important;
  --ion-color-base-rgb: var(--ion-color-danger-rgb, 235, 68, 90) !important;
  --ion-color-contrast: var(--ion-color-danger-contrast, #fff) !important;
  --ion-color-contrast-rgb: var(--ion-color-danger-contrast-rgb, 255, 255, 255) !important;
  --ion-color-shade: var(--ion-color-danger-shade, #cf3c4f) !important;
  --ion-color-tint: var(--ion-color-danger-tint, #ed576b) !important;
}

.ion-color-light {
  --ion-color-base: var(--ion-color-light, #f4f5f8) !important;
  --ion-color-base-rgb: var(--ion-color-light-rgb, 244, 245, 248) !important;
  --ion-color-contrast: var(--ion-color-light-contrast, #000) !important;
  --ion-color-contrast-rgb: var(--ion-color-light-contrast-rgb, 0, 0, 0) !important;
  --ion-color-shade: var(--ion-color-light-shade, #d7d8da) !important;
  --ion-color-tint: var(--ion-color-light-tint, #f5f6f9) !important;
}

.ion-color-medium {
  --ion-color-base: var(--ion-color-medium, #92949c) !important;
  --ion-color-base-rgb: var(--ion-color-medium-rgb, 146, 148, 156) !important;
  --ion-color-contrast: var(--ion-color-medium-contrast, #fff) !important;
  --ion-color-contrast-rgb: var(--ion-color-medium-contrast-rgb, 255, 255, 255) !important;
  --ion-color-shade: var(--ion-color-medium-shade, #808289) !important;
  --ion-color-tint: var(--ion-color-medium-tint, #9d9fa6) !important;
}

.ion-color-dark {
  --ion-color-base: var(--ion-color-dark, #222428) !important;
  --ion-color-base-rgb: var(--ion-color-dark-rgb, 34, 36, 40) !important;
  --ion-color-contrast: var(--ion-color-dark-contrast, #fff) !important;
  --ion-color-contrast-rgb: var(--ion-color-dark-contrast-rgb, 255, 255, 255) !important;
  --ion-color-shade: var(--ion-color-dark-shade, #1e2023) !important;
  --ion-color-tint: var(--ion-color-dark-tint, #383a3e) !important;
}

.ion-page {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  display: flex;
  position: absolute;
  flex-direction: column;
  justify-content: space-between;
  contain: layout size style;
  overflow: hidden;
  z-index: 0;
}

/**
 * When making custom dialogs, using
 * ion-content is not required. As a result,
 * some developers may wish to have dialogs
 * that are automatically sized by the browser.
 * These changes allow certain dimension values
 * such as fit-content to work correctly.
 */
ion-modal > .ion-page {
  position: relative;
  contain: layout style;
  height: 100%;
}

.split-pane-visible > .ion-page.split-pane-main {
  position: relative;
}

ion-route,
ion-route-redirect,
ion-router,
ion-select-option,
ion-nav-controller,
ion-menu-controller,
ion-action-sheet-controller,
ion-alert-controller,
ion-loading-controller,
ion-modal-controller,
ion-picker-controller,
ion-popover-controller,
ion-toast-controller,
.ion-page-hidden,
[hidden] {
  /* stylelint-disable-next-line declaration-no-important */
  display: none !important;
}

.ion-page-invisible {
  opacity: 0;
}

.can-go-back > ion-header ion-back-button {
  display: block;
}

html.plt-ios.plt-hybrid, html.plt-ios.plt-pwa {
  --ion-statusbar-padding: 20px;
}

@supports (padding-top: 20px) {
  html {
    --ion-safe-area-top: var(--ion-statusbar-padding);
  }
}
@supports (padding-top: constant(safe-area-inset-top)) {
  html {
    --ion-safe-area-top: constant(safe-area-inset-top);
    --ion-safe-area-bottom: constant(safe-area-inset-bottom);
    --ion-safe-area-left: constant(safe-area-inset-left);
    --ion-safe-area-right: constant(safe-area-inset-right);
  }
}
@supports (padding-top: env(safe-area-inset-top)) {
  html {
    --ion-safe-area-top: env(safe-area-inset-top);
    --ion-safe-area-bottom: env(safe-area-inset-bottom);
    --ion-safe-area-left: env(safe-area-inset-left);
    --ion-safe-area-right: env(safe-area-inset-right);
  }
}
ion-card.ion-color .ion-inherit-color,
ion-card-header.ion-color .ion-inherit-color {
  color: inherit;
}

.menu-content {
  transform: translate3d(0,  0,  0);
}

.menu-content-open {
  cursor: pointer;
  touch-action: manipulation;
  pointer-events: none;
}

.ios .menu-content-reveal {
  box-shadow: -8px 0 42px rgba(0, 0, 0, 0.08);
}

[dir=rtl].ios .menu-content-reveal {
  box-shadow: 8px 0 42px rgba(0, 0, 0, 0.08);
}

.md .menu-content-reveal {
  box-shadow: 4px 0px 16px rgba(0, 0, 0, 0.18);
}

.md .menu-content-push {
  box-shadow: 4px 0px 16px rgba(0, 0, 0, 0.18);
}

ion-accordion-group.accordion-group-expand-inset > ion-accordion:first-of-type {
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
}

ion-accordion-group.accordion-group-expand-inset > ion-accordion:last-of-type {
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
}

ion-accordion-group > ion-accordion:last-of-type ion-item[slot=header] {
  --border-width: 0px;
}

ion-accordion.accordion-animated > [slot=header] .ion-accordion-toggle-icon {
  transition: 300ms transform cubic-bezier(0.25, 0.8, 0.5, 1);
}

@media (prefers-reduced-motion: reduce) {
  ion-accordion .ion-accordion-toggle-icon {
    /* stylelint-disable declaration-no-important */
    transition: none !important;
  }
}
/**
 * The > [slot="header"] selector ensures that we do
 * not modify toggle icons for any nested accordions. The state
 * of one accordion should not affect any accordions inside
 * of a nested accordion group.
 */
ion-accordion.accordion-expanding > [slot=header] .ion-accordion-toggle-icon,
ion-accordion.accordion-expanded > [slot=header] .ion-accordion-toggle-icon {
  transform: rotate(180deg);
}

ion-accordion-group.accordion-group-expand-inset.md > ion-accordion.accordion-previous ion-item[slot=header] {
  --border-width: 0px;
  --inner-border-width: 0px;
}

ion-accordion-group.accordion-group-expand-inset.md > ion-accordion.accordion-expanding:first-of-type,
ion-accordion-group.accordion-group-expand-inset.md > ion-accordion.accordion-expanded:first-of-type {
  margin-top: 0;
}

ion-input input::-webkit-date-and-time-value {
  text-align: start;
}

/**
 * The .ion-datetime-button-overlay class contains
 * styles that allow any modal/popover to be
 * sized according to the dimensions of the datetime
 * when used with ion-datetime-button.
 */
.ion-datetime-button-overlay {
  --width: fit-content;
  --height: fit-content;
}

/**
 * The grid variant can scale down when inline.
 * When used in a `fit-content` overlay, this causes
 * the overlay to shrink when the month/year picker is open.
 * Explicitly setting the dimensions lets us have a consistently
 * sized grid interface.
 */
.ion-datetime-button-overlay ion-datetime.datetime-grid {
  width: 320px;
  min-height: 320px;
}

/*# sourceMappingURL=core.css.map */

/*!***************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/normalize.css ***!
  \***************************************************************************************************************************************************************************************************************************************/
audio,
canvas,
progress,
video {
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

b,
strong {
  font-weight: bold;
}

img {
  max-width: 100%;
}

hr {
  height: 1px;
  border-width: 0;
  box-sizing: content-box;
}

pre {
  overflow: auto;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

label,
input,
select,
textarea {
  font-family: inherit;
  line-height: normal;
}

textarea {
  overflow: auto;
  height: auto;
  font: inherit;
  color: inherit;
}

textarea::placeholder {
  padding-left: 2px;
}

form,
input,
optgroup,
select {
  margin: 0;
  font: inherit;
  color: inherit;
}

html input[type=button],
input[type=reset],
input[type=submit] {
  cursor: pointer;
  -webkit-appearance: button;
}

a,
a div,
a span,
a ion-icon,
a ion-label,
button,
button div,
button span,
button ion-icon,
button ion-label,
.ion-tappable,
[tappable],
[tappable] div,
[tappable] span,
[tappable] ion-icon,
[tappable] ion-label,
input,
textarea {
  touch-action: manipulation;
}

a ion-label,
button ion-label {
  pointer-events: none;
}

button {
  padding: 0;
  border: 0;
  border-radius: 0;
  font-family: inherit;
  font-style: inherit;
  font-variant: inherit;
  line-height: 1;
  text-transform: none;
  cursor: pointer;
  -webkit-appearance: button;
}

[tappable] {
  cursor: pointer;
}

a[disabled],
button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  height: auto;
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

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

td,
th {
  padding: 0;
}

/*# sourceMappingURL=normalize.css.map */

/*!***************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/structure.css ***!
  \***************************************************************************************************************************************************************************************************************************************/
* {
  box-sizing: border-box;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}

html {
  width: 100%;
  height: 100%;
  -webkit-text-size-adjust: 100%;
          text-size-adjust: 100%;
}

html:not(.hydrated) body {
  display: none;
}

html.ion-ce body {
  display: block;
}

html.plt-pwa {
  height: 100vh;
}

body {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  margin-left: 0;
  margin-right: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  padding-top: 0;
  padding-bottom: 0;
  position: fixed;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  /**
   * Because body has position: fixed,
   * it should be promoted to its own
   * layer.
   *
   * WebKit does not always promote
   * the body to its own layer on page
   * load in Ionic apps. Once scrolling on
   * ion-content starts, WebKit will promote
   * body. Unfortunately, this causes a re-paint
   * which results in scrolling being halted
   * until the next user gesture.
   *
   * This impacts the Custom Elements build.
   * The lazy loaded build causes the browser to
   * re-paint during hydration which causes WebKit
   * to promote body to its own layer.
   * In the CE Build, this hydration does not
   * happen, so the additional re-paint does not occur.
   */
  transform: translateZ(0);
  text-rendering: optimizeLegibility;
  overflow: hidden;
  touch-action: manipulation;
  -webkit-user-drag: none;
  -ms-content-zooming: none;
  word-wrap: break-word;
  overscroll-behavior-y: none;
  -webkit-text-size-adjust: none;
          text-size-adjust: none;
}

/*# sourceMappingURL=structure.css.map */

/*!****************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/typography.css ***!
  \****************************************************************************************************************************************************************************************************************************************/
html {
  font-family: var(--ion-font-family);
}

a {
  background-color: transparent;
  color: var(--ion-color-primary, #3880ff);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 16px;
  margin-bottom: 10px;
  font-weight: 500;
  line-height: 1.2;
}
h1 {
  margin-top: 20px;
  font-size: 26px;
}
h2 {
  margin-top: 18px;
  font-size: 24px;
}
h3 {
  font-size: 22px;
}

h4 {
  font-size: 20px;
}

h5 {
  font-size: 18px;
}

h6 {
  font-size: 16px;
}

small {
  font-size: 75%;
}

sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/*# sourceMappingURL=typography.css.map */

/*!*************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/display.css ***!
  \*************************************************************************************************************************************************************************************************************************************/
.ion-hide {
  display: none !important;
}

.ion-hide-up {
  display: none !important;
}

.ion-hide-down {
  display: none !important;
}

@media (min-width: 576px) {
  .ion-hide-sm-up {
    display: none !important;
  }
}
@media (max-width: 575.98px) {
  .ion-hide-sm-down {
    display: none !important;
  }
}
@media (min-width: 768px) {
  .ion-hide-md-up {
    display: none !important;
  }
}
@media (max-width: 767.98px) {
  .ion-hide-md-down {
    display: none !important;
  }
}
@media (min-width: 992px) {
  .ion-hide-lg-up {
    display: none !important;
  }
}
@media (max-width: 991.98px) {
  .ion-hide-lg-down {
    display: none !important;
  }
}
@media (min-width: 1200px) {
  .ion-hide-xl-up {
    display: none !important;
  }
}
@media (max-width: 1199.98px) {
  .ion-hide-xl-down {
    display: none !important;
  }
}

/*# sourceMappingURL=display.css.map */

/*!*************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/padding.css ***!
  \*************************************************************************************************************************************************************************************************************************************/
.ion-no-padding {
  --padding-start: 0;
  --padding-end: 0;
  --padding-top: 0;
  --padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  padding-top: 0;
  padding-bottom: 0;
}

.ion-padding {
  --padding-start: var(--ion-padding, 16px);
  --padding-end: var(--ion-padding, 16px);
  --padding-top: var(--ion-padding, 16px);
  --padding-bottom: var(--ion-padding, 16px);
  padding-left: var(--ion-padding, 16px);
  padding-right: var(--ion-padding, 16px);
  padding-top: var(--ion-padding, 16px);
  padding-bottom: var(--ion-padding, 16px);
}
@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .ion-padding {
    padding-left: unset;
    padding-right: unset;
    padding-inline-start: var(--ion-padding, 16px);
    padding-inline-end: var(--ion-padding, 16px);
  }
}

.ion-padding-top {
  --padding-top: var(--ion-padding, 16px);
  padding-top: var(--ion-padding, 16px);
}
.ion-padding-start {
  --padding-start: var(--ion-padding, 16px);
  padding-left: var(--ion-padding, 16px);
}
@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .ion-padding-start {
    padding-left: unset;
    padding-inline-start: var(--ion-padding, 16px);
  }
}

.ion-padding-end {
  --padding-end: var(--ion-padding, 16px);
  padding-right: var(--ion-padding, 16px);
}
@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .ion-padding-end {
    padding-right: unset;
    padding-inline-end: var(--ion-padding, 16px);
  }
}

.ion-padding-bottom {
  --padding-bottom: var(--ion-padding, 16px);
  padding-bottom: var(--ion-padding, 16px);
}
.ion-padding-vertical {
  --padding-top: var(--ion-padding, 16px);
  --padding-bottom: var(--ion-padding, 16px);
  padding-top: var(--ion-padding, 16px);
  padding-bottom: var(--ion-padding, 16px);
}
.ion-padding-horizontal {
  --padding-start: var(--ion-padding, 16px);
  --padding-end: var(--ion-padding, 16px);
  padding-left: var(--ion-padding, 16px);
  padding-right: var(--ion-padding, 16px);
}
@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .ion-padding-horizontal {
    padding-left: unset;
    padding-right: unset;
    padding-inline-start: var(--ion-padding, 16px);
    padding-inline-end: var(--ion-padding, 16px);
  }
}

.ion-no-margin {
  --margin-start: 0;
  --margin-end: 0;
  --margin-top: 0;
  --margin-bottom: 0;
  margin-left: 0;
  margin-right: 0;
  margin-top: 0;
  margin-bottom: 0;
}

.ion-margin {
  --margin-start: var(--ion-margin, 16px);
  --margin-end: var(--ion-margin, 16px);
  --margin-top: var(--ion-margin, 16px);
  --margin-bottom: var(--ion-margin, 16px);
  margin-left: var(--ion-margin, 16px);
  margin-right: var(--ion-margin, 16px);
  margin-top: var(--ion-margin, 16px);
  margin-bottom: var(--ion-margin, 16px);
}
@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .ion-margin {
    margin-left: unset;
    margin-right: unset;
    margin-inline-start: var(--ion-margin, 16px);
    margin-inline-end: var(--ion-margin, 16px);
  }
}

.ion-margin-top {
  --margin-top: var(--ion-margin, 16px);
  margin-top: var(--ion-margin, 16px);
}
.ion-margin-start {
  --margin-start: var(--ion-margin, 16px);
  margin-left: var(--ion-margin, 16px);
}
@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .ion-margin-start {
    margin-left: unset;
    margin-inline-start: var(--ion-margin, 16px);
  }
}

.ion-margin-end {
  --margin-end: var(--ion-margin, 16px);
  margin-right: var(--ion-margin, 16px);
}
@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .ion-margin-end {
    margin-right: unset;
    margin-inline-end: var(--ion-margin, 16px);
  }
}

.ion-margin-bottom {
  --margin-bottom: var(--ion-margin, 16px);
  margin-bottom: var(--ion-margin, 16px);
}
.ion-margin-vertical {
  --margin-top: var(--ion-margin, 16px);
  --margin-bottom: var(--ion-margin, 16px);
  margin-top: var(--ion-margin, 16px);
  margin-bottom: var(--ion-margin, 16px);
}
.ion-margin-horizontal {
  --margin-start: var(--ion-margin, 16px);
  --margin-end: var(--ion-margin, 16px);
  margin-left: var(--ion-margin, 16px);
  margin-right: var(--ion-margin, 16px);
}
@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .ion-margin-horizontal {
    margin-left: unset;
    margin-right: unset;
    margin-inline-start: var(--ion-margin, 16px);
    margin-inline-end: var(--ion-margin, 16px);
  }
}

/*# sourceMappingURL=padding.css.map */

/*!********************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/float-elements.css ***!
  \********************************************************************************************************************************************************************************************************************************************/
.ion-float-left {
  float: left !important;
}

.ion-float-right {
  float: right !important;
}

.ion-float-start {
  float: left !important;
}
[dir=rtl] .ion-float-start, :host-context([dir=rtl]) .ion-float-start {
  float: right !important;
}

.ion-float-end {
  float: right !important;
}
[dir=rtl] .ion-float-end, :host-context([dir=rtl]) .ion-float-end {
  float: left !important;
}

@media (min-width: 576px) {
  .ion-float-sm-left {
    float: left !important;
  }

  .ion-float-sm-right {
    float: right !important;
  }

  .ion-float-sm-start {
    float: left !important;
  }
  [dir=rtl] .ion-float-sm-start, :host-context([dir=rtl]) .ion-float-sm-start {
    float: right !important;
  }

  .ion-float-sm-end {
    float: right !important;
  }
  [dir=rtl] .ion-float-sm-end, :host-context([dir=rtl]) .ion-float-sm-end {
    float: left !important;
  }
}
@media (min-width: 768px) {
  .ion-float-md-left {
    float: left !important;
  }

  .ion-float-md-right {
    float: right !important;
  }

  .ion-float-md-start {
    float: left !important;
  }
  [dir=rtl] .ion-float-md-start, :host-context([dir=rtl]) .ion-float-md-start {
    float: right !important;
  }

  .ion-float-md-end {
    float: right !important;
  }
  [dir=rtl] .ion-float-md-end, :host-context([dir=rtl]) .ion-float-md-end {
    float: left !important;
  }
}
@media (min-width: 992px) {
  .ion-float-lg-left {
    float: left !important;
  }

  .ion-float-lg-right {
    float: right !important;
  }

  .ion-float-lg-start {
    float: left !important;
  }
  [dir=rtl] .ion-float-lg-start, :host-context([dir=rtl]) .ion-float-lg-start {
    float: right !important;
  }

  .ion-float-lg-end {
    float: right !important;
  }
  [dir=rtl] .ion-float-lg-end, :host-context([dir=rtl]) .ion-float-lg-end {
    float: left !important;
  }
}
@media (min-width: 1200px) {
  .ion-float-xl-left {
    float: left !important;
  }

  .ion-float-xl-right {
    float: right !important;
  }

  .ion-float-xl-start {
    float: left !important;
  }
  [dir=rtl] .ion-float-xl-start, :host-context([dir=rtl]) .ion-float-xl-start {
    float: right !important;
  }

  .ion-float-xl-end {
    float: right !important;
  }
  [dir=rtl] .ion-float-xl-end, :host-context([dir=rtl]) .ion-float-xl-end {
    float: left !important;
  }
}

/*# sourceMappingURL=float-elements.css.map */

/*!********************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/text-alignment.css ***!
  \********************************************************************************************************************************************************************************************************************************************/
.ion-text-center {
  text-align: center !important;
}

.ion-text-justify {
  text-align: justify !important;
}

.ion-text-start {
  text-align: start !important;
}

.ion-text-end {
  text-align: end !important;
}

.ion-text-left {
  text-align: left !important;
}

.ion-text-right {
  text-align: right !important;
}

.ion-text-nowrap {
  white-space: nowrap !important;
}

.ion-text-wrap {
  white-space: normal !important;
}

@media (min-width: 576px) {
  .ion-text-sm-center {
    text-align: center !important;
  }

  .ion-text-sm-justify {
    text-align: justify !important;
  }

  .ion-text-sm-start {
    text-align: start !important;
  }

  .ion-text-sm-end {
    text-align: end !important;
  }

  .ion-text-sm-left {
    text-align: left !important;
  }

  .ion-text-sm-right {
    text-align: right !important;
  }

  .ion-text-sm-nowrap {
    white-space: nowrap !important;
  }

  .ion-text-sm-wrap {
    white-space: normal !important;
  }
}
@media (min-width: 768px) {
  .ion-text-md-center {
    text-align: center !important;
  }

  .ion-text-md-justify {
    text-align: justify !important;
  }

  .ion-text-md-start {
    text-align: start !important;
  }

  .ion-text-md-end {
    text-align: end !important;
  }

  .ion-text-md-left {
    text-align: left !important;
  }

  .ion-text-md-right {
    text-align: right !important;
  }

  .ion-text-md-nowrap {
    white-space: nowrap !important;
  }

  .ion-text-md-wrap {
    white-space: normal !important;
  }
}
@media (min-width: 992px) {
  .ion-text-lg-center {
    text-align: center !important;
  }

  .ion-text-lg-justify {
    text-align: justify !important;
  }

  .ion-text-lg-start {
    text-align: start !important;
  }

  .ion-text-lg-end {
    text-align: end !important;
  }

  .ion-text-lg-left {
    text-align: left !important;
  }

  .ion-text-lg-right {
    text-align: right !important;
  }

  .ion-text-lg-nowrap {
    white-space: nowrap !important;
  }

  .ion-text-lg-wrap {
    white-space: normal !important;
  }
}
@media (min-width: 1200px) {
  .ion-text-xl-center {
    text-align: center !important;
  }

  .ion-text-xl-justify {
    text-align: justify !important;
  }

  .ion-text-xl-start {
    text-align: start !important;
  }

  .ion-text-xl-end {
    text-align: end !important;
  }

  .ion-text-xl-left {
    text-align: left !important;
  }

  .ion-text-xl-right {
    text-align: right !important;
  }

  .ion-text-xl-nowrap {
    white-space: nowrap !important;
  }

  .ion-text-xl-wrap {
    white-space: normal !important;
  }
}

/*# sourceMappingURL=text-alignment.css.map */

/*!*************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/text-transformation.css ***!
  \*************************************************************************************************************************************************************************************************************************************************/
.ion-text-uppercase {
  /* stylelint-disable-next-line declaration-no-important */
  text-transform: uppercase !important;
}

.ion-text-lowercase {
  /* stylelint-disable-next-line declaration-no-important */
  text-transform: lowercase !important;
}

.ion-text-capitalize {
  /* stylelint-disable-next-line declaration-no-important */
  text-transform: capitalize !important;
}

@media (min-width: 576px) {
  .ion-text-sm-uppercase {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: uppercase !important;
  }

  .ion-text-sm-lowercase {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: lowercase !important;
  }

  .ion-text-sm-capitalize {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: capitalize !important;
  }
}
@media (min-width: 768px) {
  .ion-text-md-uppercase {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: uppercase !important;
  }

  .ion-text-md-lowercase {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: lowercase !important;
  }

  .ion-text-md-capitalize {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: capitalize !important;
  }
}
@media (min-width: 992px) {
  .ion-text-lg-uppercase {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: uppercase !important;
  }

  .ion-text-lg-lowercase {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: lowercase !important;
  }

  .ion-text-lg-capitalize {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: capitalize !important;
  }
}
@media (min-width: 1200px) {
  .ion-text-xl-uppercase {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: uppercase !important;
  }

  .ion-text-xl-lowercase {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: lowercase !important;
  }

  .ion-text-xl-capitalize {
    /* stylelint-disable-next-line declaration-no-important */
    text-transform: capitalize !important;
  }
}

/*# sourceMappingURL=text-transformation.css.map */

/*!****************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/@ionic/angular/css/flex-utils.css ***!
  \****************************************************************************************************************************************************************************************************************************************/
.ion-align-self-start {
  align-self: flex-start !important;
}

.ion-align-self-end {
  align-self: flex-end !important;
}

.ion-align-self-center {
  align-self: center !important;
}

.ion-align-self-stretch {
  align-self: stretch !important;
}

.ion-align-self-baseline {
  align-self: baseline !important;
}

.ion-align-self-auto {
  align-self: auto !important;
}

.ion-wrap {
  flex-wrap: wrap !important;
}

.ion-nowrap {
  flex-wrap: nowrap !important;
}

.ion-wrap-reverse {
  flex-wrap: wrap-reverse !important;
}

.ion-justify-content-start {
  justify-content: flex-start !important;
}

.ion-justify-content-center {
  justify-content: center !important;
}

.ion-justify-content-end {
  justify-content: flex-end !important;
}

.ion-justify-content-around {
  justify-content: space-around !important;
}

.ion-justify-content-between {
  justify-content: space-between !important;
}

.ion-justify-content-evenly {
  justify-content: space-evenly !important;
}

.ion-align-items-start {
  align-items: flex-start !important;
}

.ion-align-items-center {
  align-items: center !important;
}

.ion-align-items-end {
  align-items: flex-end !important;
}

.ion-align-items-stretch {
  align-items: stretch !important;
}

.ion-align-items-baseline {
  align-items: baseline !important;
}

/*# sourceMappingURL=flex-utils.css.map */

/*!***************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[6].rules[0].oneOf[0].use[2]!./node_modules/resolve-url-loader/index.js??ruleSet[1].rules[6].rules[1].use[0]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[6].rules[1].use[1]!./src/global.scss?ngGlobalStyle (1) ***!
  \***************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/*
 * App Global CSS
 * ----------------------------------------------------------------------------
 * Put style rules here that you want to apply globally. These styles are for
 * the entire app and not just one component. Additionally, this file can be
 * used as an entry point to import other CSS/Sass files to be included in the
 * output CSS.
 * For more information on global stylesheets, visit the documentation:
 * https://ionicframework.com/docs/layout/global-stylesheets
 */
/* Core CSS required for Ionic components to work properly */
/* Basic CSS for apps built with Ionic */
/* Optional CSS utils that can be commented out */
:root {
  --primary-light: #8abdff;
  --primary: #6d5dfc;
  --primary-dark: #5b0eeb;
  --white: #FFFFFF;
  --greyLight-1: #E4EBF5;
  --greyLight-2: #c8d0e7;
  --greyLight-3: #bec8e4;
  --greyDark: #9baacf;
}

.menucard {
  display: flex;
  transition: all 0.75s ease-in-out, border 0.5s ease;
  margin: 5vw auto;
  width: 96vw;
  gap: 2vw;
  padding: 0vw;
  contain: none;
  overflow: visible;
  flex-direction: column;
}
.menucard .fullwrap-h {
  display: flex;
  flex-direction: row;
  transition: all 0.5s cubic-bezier(0.22, 0.61, 0.36, 1);
  contain: none;
  overflow: visible;
  gap: 1vw;
}
.menucard .fullwrap-h .imgwrap {
  margin: 0;
  padding: 0;
  display: grid;
  transition: all 0.5s cubic-bezier(0.22, 0.61, 0.36, 1), border 0.25s ease;
  grid-template-rows: 10vw 10vw 10vw 8vw 2vw;
  grid-template-columns: 1vw 18vw 18vw 1vw;
  border-radius: 15px;
  box-sizing: border-box;
  perspective: 500px;
  position: relative;
  z-index: 1;
}
.menucard .fullwrap-h .imgwrap .imgshadow {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2;
  background: none;
  pointer-events: none;
}
.menucard .fullwrap-h .imgwrap .menu-image {
  object-fit: cover;
  object-position: left top;
  overflow: hidden;
  grid-area: 1/1/5/5;
  box-sizing: border-box;
  border-radius: 15px;
  position: relative;
  z-index: -1;
  transition: all 0.5s cubic-bezier(0.22, 0.61, 0.36, 1);
  pointer-events: auto;
}
.menucard .fullwrap-h .imgwrap .counter {
  padding: 0vw 0vw 0vw 0vw;
  display: flex;
  margin: 0;
  justify-content: space-between;
  justify-items: center;
  flex-direction: row;
  align-items: center;
  background: none;
  border-radius: 0;
  transition: all 1s cubic-bezier(0.22, 0.61, 0.36, 1);
  position: absolute;
  z-index: -1;
  height: 10vw;
  gap: 3vw;
  z-index: 99;
  background: rgba(0, 0, 0, 0.2705882353);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border-radius: 20px;
  border: 1px solid white;
  pointer-events: auto;
  margin-top: 10vw;
}
.menucard .fullwrap-h .imgwrap .counter .counter-1 {
  background: none;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  border: 0px solid white;
}
.menucard .fullwrap-h .imgwrap .counter .qtysel {
  color: #ffffff;
  height: 30px;
  margin: 0;
  background: rgba(0, 0, 0, 0.5294117647);
  line-height: 28px;
  width: 30px;
  font-size: 28px;
  text-align: center;
  border-radius: 10px;
  border: 1px solid white;
}
.menucard .fullwrap-h .imgwrap .counter .counter_1 {
  background: none;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  border: 0px solid white;
}
.menucard .fullwrap-h .imgwrap .action-slot {
  padding: 0px;
  margin: 0px;
  color: var(--ion-color-primary);
  font-size: 10px;
  grid-area: 1/1/1/5;
  background: none;
  position: relative;
  z-index: -1;
}
.menucard .fullwrap-h .imgwrap .action-slot ion-chip {
  padding: 3px;
  margin: 10px;
  background: var(--ion-color-primary);
  font-size: 15px;
  width: 15vw;
  height: 4vw;
  color: white;
  display: flex;
  justify-content: center;
  align-items: center;
}
.menucard .fullwrap-h .imgwrap .action-slot ion-note {
  font-size: 10px;
  color: white;
}
.menucard .fullwrap-h .imgwrap .action-slot p {
  padding: 0px;
  margin: 0px;
  color: var(--ion-color-primary);
  font-size: 10px;
}
.menucard .fullwrap-h .fullwrap {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: all 0.5s ease-in-out;
  gap: 0vw;
  contain: none;
  overflow: visible;
  padding: 0vw 0 0px;
  margin: 0;
  will-change: contents;
}
.menucard .fullwrap-h .fullwrap .contentwrap {
  display: flex;
  padding: 0 0vw;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  text-align: center;
  transition: all 0.75s ease-in-out, border 0.25s ease;
  justify-items: center;
  perspective: 500px;
  box-sizing: border-box;
  z-index: 1;
  border-radius: 15px;
}
.menucard .fullwrap-h .fullwrap .contentwrap .titlemenu {
  padding: 2vw;
  letter-spacing: 2px;
  text-overflow: ellipsis;
  white-space: break-spaces;
  background: transparent;
  transition: all 0.5s ease-in-out;
  font-weight: 500;
}
.menucard .fullwrap-h .fullwrap .contentwrap .descriptionmenu {
  transition: all 0.5s ease-in-out, display 0 none;
  letter-spacing: 1px;
  padding: 1vw;
  transform-style: preserve-3d;
}
.menucard .fullwrap-h .fullwrap .macrolist {
  display: flex;
  flex-direction: row;
  transition: all 0.75s ease-in-out, border 0.25s ease;
  margin: 0 auto;
  border-radius: 15px;
  will-change: contents;
  height: 12vw;
  justify-content: center;
  z-index: 5;
  gap: 1vw;
  padding: 1vw;
  width: -moz-fit-content;
  width: fit-content;
  background: white;
}
.menucard .fullwrap-h .fullwrap .macrolist .calories,
.menucard .fullwrap-h .fullwrap .macrolist .proteins,
.menucard .fullwrap-h .fullwrap .macrolist .carbs,
.menucard .fullwrap-h .fullwrap .macrolist .fats {
  display: flex;
  align-items: center;
  justify-items: center;
  transition: all 1s ease-in-out;
  flex-direction: row;
  gap: 2px;
  border-radius: 20px;
  border-style: solid;
  overflow: hidden;
  padding: 1vw;
  box-sizing: border-box;
  border-width: 0px;
  justify-content: center;
  border-color: #fff;
  will-change: contents;
}
.menucard .fullwrap-h .fullwrap .macrolist .calories .macroicon,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .macroicon,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .macroicon,
.menucard .fullwrap-h .fullwrap .macrolist .fats .macroicon {
  will-change: contents;
  transition: all 1s ease-in-out;
}
.menucard .fullwrap-h .fullwrap .macrolist .calories .calicon,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .calicon,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .calicon,
.menucard .fullwrap-h .fullwrap .macrolist .fats .calicon {
  stroke: #d45920;
  fill: #f2d382;
  stroke-width: 2px;
}
.menucard .fullwrap-h .fullwrap .macrolist .calories .carbicon,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .carbicon,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .carbicon,
.menucard .fullwrap-h .fullwrap .macrolist .fats .carbicon {
  stroke: #378e6a;
  fill: none;
  stroke-width: 2px;
}
.menucard .fullwrap-h .fullwrap .macrolist .calories .proicon,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .proicon,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .proicon,
.menucard .fullwrap-h .fullwrap .macrolist .fats .proicon {
  stroke: #4692fc;
  fill: none;
  stroke-width: 2px;
}
.menucard .fullwrap-h .fullwrap .macrolist .calories .faticon,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .faticon,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .faticon,
.menucard .fullwrap-h .fullwrap .macrolist .fats .faticon {
  stroke: #810000;
  fill: #e9b277;
  stroke-width: 1px;
}
.menucard .fullwrap-h .fullwrap .macrolist .calories .calname-small,
.menucard .fullwrap-h .fullwrap .macrolist .calories .carbname-small,
.menucard .fullwrap-h .fullwrap .macrolist .calories .proname-small,
.menucard .fullwrap-h .fullwrap .macrolist .calories .fatname-small,
.menucard .fullwrap-h .fullwrap .macrolist .calories .calname,
.menucard .fullwrap-h .fullwrap .macrolist .calories .carbname,
.menucard .fullwrap-h .fullwrap .macrolist .calories .proname,
.menucard .fullwrap-h .fullwrap .macrolist .calories .fatname,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .calname-small,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .carbname-small,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .proname-small,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .fatname-small,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .calname,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .carbname,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .proname,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .fatname,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .calname-small,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .carbname-small,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .proname-small,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .fatname-small,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .calname,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .carbname,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .proname,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .fatname,
.menucard .fullwrap-h .fullwrap .macrolist .fats .calname-small,
.menucard .fullwrap-h .fullwrap .macrolist .fats .carbname-small,
.menucard .fullwrap-h .fullwrap .macrolist .fats .proname-small,
.menucard .fullwrap-h .fullwrap .macrolist .fats .fatname-small,
.menucard .fullwrap-h .fullwrap .macrolist .fats .calname,
.menucard .fullwrap-h .fullwrap .macrolist .fats .carbname,
.menucard .fullwrap-h .fullwrap .macrolist .fats .proname,
.menucard .fullwrap-h .fullwrap .macrolist .fats .fatname {
  font-size: 14px;
  font-weight: 1000;
  letter-spacing: 1px;
  padding: 0 0 0 0px;
  transition: all 0.5s, opacity 1s;
  align-items: center;
  justify-items: center;
  will-change: contents;
}
.menucard .fullwrap-h .fullwrap .macrolist .calories .calval,
.menucard .fullwrap-h .fullwrap .macrolist .calories .carbval,
.menucard .fullwrap-h .fullwrap .macrolist .calories .proval,
.menucard .fullwrap-h .fullwrap .macrolist .calories .fatval,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .calval,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .carbval,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .proval,
.menucard .fullwrap-h .fullwrap .macrolist .proteins .fatval,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .calval,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .carbval,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .proval,
.menucard .fullwrap-h .fullwrap .macrolist .carbs .fatval,
.menucard .fullwrap-h .fullwrap .macrolist .fats .calval,
.menucard .fullwrap-h .fullwrap .macrolist .fats .carbval,
.menucard .fullwrap-h .fullwrap .macrolist .fats .proval,
.menucard .fullwrap-h .fullwrap .macrolist .fats .fatval {
  font-size: 14px;
  font-weight: 1000;
  display: flex;
  height: 100%;
  padding: 0;
  transition: all 0.5s ease-in-out;
  border-radius: 20px;
  align-items: center;
  justify-items: center;
}
.menucard .caled {
  flex-direction: row;
  width: 96%;
  height: 10vw;
  color: white;
  contain: none;
  overflow: visible;
}
.menucard .caled p {
  padding: 0 1vw;
  margin: 0;
  width: 20%;
  font-size: 16px;
  border-radius: 0px 0px 0px 0px;
  align-content: space-around;
  text-align: center;
  color: var(--ion-color-primary);
}
.menucard .caled ion-card.slide-view {
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  align-content: center;
  flex-wrap: wrap;
  box-shadow: 0px 0px 20px 0px rgba(151, 151, 151, 0.231372549);
  border: 1px solid rgba(151, 151, 151, 0.231372549);
}
.menucard .caled ion-card.slide-view ion-card.slide-box {
  height: 100%;
  width: 100%;
  margin: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  border-radius: 20px;
  justify-content: space-around;
  border: 0px solid;
}
.menucard .caled ion-card.slide-view ion-card.slide-box ion-card.iconcov {
  display: flex;
  background-color: white;
  justify-content: center;
  z-index: 999;
  padding: 0px;
  margin: 0;
  align-items: center;
  rotate: -90deg;
}
.menucard .caled ion-card.slide-view ion-card.slide-box .topbot {
  stroke: var(--ion-color-primary);
  stroke-width: 1px;
}
.menucard .caled ion-card.slide-view ion-card.slide-box svg.slideiconnext {
  color: var(--ion-color-primary);
  height: 48px;
  width: 48px;
}
.menucard .caled ion-card.slide-view ion-card.slide-box svg.slideiconprev {
  color: var(--ion-color-primary);
  rotate: 180deg;
  height: 48px;
  width: 48px;
}
.menucard .caled ion-card.slide-view ion-card.slide-box path.ani {
  fill: var(--p2);
}
.menucard .caled ion-card.slide-view ion-card.slide-box ion-slides {
  height: 100%;
  width: 100%;
}
.menucard .caled ion-card.slide-view ion-card.slide-box ion-slides .swiper-wrapper {
  align-items: center;
}
.menucard .caled ion-card.slide-view ion-card.slide-box ion-slides ion-slide {
  font-size: 11px;
  color: gray;
}
.menucard .caled ion-card.slide-view ion-card.slide-box ion-slides ion-slide.activeIndex {
  font-size: 18px;
  font-weight: 700;
  border-width: 2px;
  border-style: solid;
  box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.4901960784);
  color: var(--ion-black-primary);
  padding: 0vw;
  border-radius: 10px;
  height: 70%;
  margin: auto 0px;
}
.menucard .caled ion-card.slide-view ion-card.slide-box ion-slides ion-slide.normalIndex {
  font-size: 14px;
  color: gray;
}

.calfull {
  background: #fff8e5;
}

.carbfull {
  background: #eefff8;
}

.profull {
  background: #eff5ff;
}

.fatfull {
  background: #fff1f1;
}

.caloutline {
  border-color: #f2d382;
}

.carboutline {
  border-color: #8affce;
}

.prooutline {
  border-color: #90beff;
}

.fatoutline {
  border-color: #ff9e9e;
}

@keyframes shake {
  50% {
    transform: translate3d(20px, 0, 0);
  }
}
@keyframes flip {
  100% {
    transform: rotateY(180deg);
  }
}
@keyframes pulse {
  50% {
    transform: scale(1.2);
  }
}
@keyframes glitch {
  50% {
    transform: skew(180deg);
  }
}
@keyframes fill {
  50% {
    transform: translateX(-5%);
  }
}
@keyframes sheen {
  100% {
    transform: rotateZ(60deg) translate(1em, -9em);
  }
}
@keyframes glow {
  50% {
    box-shadow: 0 0 40px var(--ion-color-tertiary);
  }
}
@keyframes blur {
  50% {
    filter: blur(20px);
    transform: skew(45deg);
  }
}
[anim=shake]:not(.toggled) {
  animation: shake var(--ease-elastic-in-1) 3s infinite alternate;
}

[anim=pulse]:not(.toggled) {
  animation: pulse var(--ease-elastic-in-1) 24s infinite alternate;
}

[anim=glitch]:not(.toggled) {
  animation: glitch var(--ease-elastic-in-1) 6ms infinite;
}

[anim=flip]:not(.toggled) {
  animation: flip var(--ease-elastic-in-1) 600ms infinite alternate;
}

[anim=fill]:not(.toggled)::after {
  animation: fill var(--ease-spring-1) 8s infinite;
}

[anim=sheen]:not(.toggled)::after {
  animation: sheen var(--ease-elastic-in-1) 1s infinite;
}

[anim=glow]:not(.toggled) {
  animation: glow var(--ease-elastic-in-1) 6s infinite alternate;
}

[anim=blur]:not(.toggled) {
  animation: blur var(--ease-elastic-in-1) 10s infinite alternate;
}

[anim=fill]::after {
  content: "";
  color: var(--black);
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 0.75rem;
  height: 100%;
  width: 200%;
  inset: 0;
  transform: translateX(-400px);
  background-color: var(--ion-color-primary);
}

[anim=sheen]::after {
  content: "";
  position: absolute;
  top: -50%;
  right: -50%;
  bottom: -50%;
  left: -50%;
  background: linear-gradient(to left, transparent, rgba(255, 255, 255, 0.108), rgba(62, 62, 62, 0.078));
  transform: rotateZ(60deg) translate(-5em, 7.5em);
}

.closed {
  --overflow: hidden;
  overflow: hidden;
}

.blurry {
  position: relative;
  transform-style: preserve-3d;
}

.blurry::before {
  content: "";
  position: absolute;
  inset: 0px;
  transform: translate3d(0px, 0px, -1px);
  background: var(red);
  filter: blur(6px);
}

@keyframes userborder {
  0%, 100% {
    border-radius: 63% 37% 54% 46%/55% 48% 52% 45%;
  }
  14% {
    border-radius: 40% 60% 54% 46%/49% 60% 40% 51%;
  }
  28% {
    border-radius: 54% 46% 38% 62%/49% 70% 30% 51%;
  }
  42% {
    border-radius: 61% 39% 55% 45%/61% 38% 62% 39%;
  }
  56% {
    border-radius: 61% 39% 67% 33%/70% 50% 50% 30%;
  }
  70% {
    border-radius: 50% 50% 34% 66%/56% 68% 32% 44%;
  }
  84% {
    border-radius: 46% 54% 50% 50%/35% 61% 39% 65%;
  }
}
.bordermove {
  animation-duration: 10s;
  animation-name: userborder;
  animation-iteration-count: infinite;
  animation-direction: alternate;
}

.snk {
  stroke: var(--ion-color-primary);
  fill: var(--p2);
  filter: drop-shadow(-1.5px 1.5px 1px rgba(0, 0, 0, 0.45));
}

.full {
  stroke: var(--ion-color-primary);
  fill: transparent;
}

.mfull {
  stroke: var(--ion-color-primary);
  fill: var(--p2);
  filter: drop-shadow(-1.5px 1.5px 1px rgba(0, 0, 0, 0.45));
}

.meals-0 {
  stroke: var(--ion-color-primary);
  fill: transparent;
}

.shadowico {
  filter: drop-shadow(-0.05rem 0.07rem 0.03rem rgba(0, 0, 0, 0.45));
}

.inputicon {
  height: 35px;
  width: 35px;
  stroke: #68B684;
  stroke-width: 1px;
  fill: none;
}

.calicon {
  height: 35px;
  width: 35px;
  stroke: var(--ion-color-primary);
  stroke-width: 1px;
  fill: none;
}

.displayicon {
  height: 35px;
  width: 35px;
  stroke: #000;
  stroke-width: 1px;
  fill: none;
  filter: drop-shadow(-3.5px 1.5px 1px rgba(0, 0, 0, 0.45));
}

.tabicon {
  height: 35px;
  width: 35px;
  stroke-width: 1.5px;
  stroke: var(--ion-text-primary);
  fill: none;
  color: transparent;
  padding: 0px;
}

.imgicon {
  height: 24px;
  width: 24px;
  stroke-width: 1.5px;
  stroke: var(--ion-white-primary);
  fill: none;
  color: transparent;
  padding: 0px;
}

.onbicon {
  height: 35px;
  width: 35px;
  stroke-width: 1px;
  stroke: var(--ion-white-primary);
  color: transparent;
  filter: drop-shadow(-3.5px 1.5px 1px rgba(0, 0, 0, 0.45));
  padding: 5px;
}

.tabicon-fill {
  height: 35px;
  width: 35px;
  stroke-width: 1px;
  stroke: none;
  color: var(--ion-color-calendar-contrast);
  filter: drop-shadow(-3.5px 1.5px 1px rgba(0, 0, 0, 0.45));
}

.container3d {
  border: 2.5px solid var(--ion-white-primary);
  background: transparent;
  box-shadow: inset 0rem 0rem 0rem rgba(0, 0, 0, 0.45), -0.1rem 0.1rem 0.3rem rgba(0, 0, 0, 0.45);
}

.container3dclear {
  border: 3px solid var(--ion-white-primary);
  border-radius: 50px;
  background: transparent;
  box-shadow: -0.5rem 0.5rem 1rem rgba(0, 0, 0, 0.45), inset -0.25rem 0.25rem 0.5rem rgba(0, 0, 0, 0.45);
}

.container3dfull {
  background: transparent;
  box-shadow: -0.5rem 0.5rem 1rem rgba(0, 0, 0, 0.45), inset -0.25rem 0.25rem 0.5rem rgba(0, 0, 0, 0.45);
}

.container3dhalf {
  background: transparent;
  box-shadow: -0.2rem 0.2rem 0.5rem rgba(0, 0, 0, 0.45), inset -0.1rem 0.1rem 0.3rem rgba(0, 0, 0, 0.45);
}

.container3dcolor {
  border: 2px solid var(--ion-white-primary);
  background: var(--ion-color-primary);
  box-shadow: -0.5rem 0.5rem 1rem rgba(0, 0, 0, 0.45), inset -0.25rem 0.25rem 0.5rem rgba(0, 0, 0, 0.45);
}

.openclear {
  overflow: visible;
  contain: none;
  background: transparent;
  --background:transparent;
}

.d3font {
  font-weight: 700;
  color: #f5f5f5;
  text-shadow: 0.1px 0.1px 0.1px #919191, 0.1px 0.2px 0.1px #919191, 0.1px 0.3px 0.1px #919191, 0.1px 0.4px 0.1px #919191, 0.1px 0.5px 0.1px #919191, 0.1px 0.6px 0.1px #919191, 0.1px 0.7px 0.1px #919191, 0.1px 0.8px 0.1px #919191, 0.1px 0.9px 0.1px #919191, 0.1px 1px 0.1px #919191, 0.1px 1.8px 0.6px rgba(16, 16, 16, 0.4), 0.1px 2.2px 1px rgba(16, 16, 16, 0.2), 0.1px 2.5px 3.5px rgba(16, 16, 16, 0.2), 0.1px 3px 6px rgba(16, 16, 16, 0.4);
}

.nomargin {
  margin: 0;
}

.nopadding {
  padding: 0;
}

.step-a {
  height: 48px;
  width: 48px;
  fill: var(--p2);
  stroke: var(--ion-color-primary);
  stroke-width: 1.5px;
  fill-opacity: 0;
}

.step-2 {
  height: 42px;
  width: 42px;
  fill: var(--ion-color-primary);
  stroke: var(--p2);
  stroke-width: 1.5px;
  fill-opacity: 0;
}

.step {
  height: 42px;
  width: 42px;
  fill: none;
  stroke: #000;
  stroke-width: 1px;
}

.steps {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
}

.button3d {
  position: relative;
  padding: 0;
  --padding-end: 0;
  --padding-start: 0;
  border: 2px solid #bfbfbf !important;
  outline: none;
  background-color: var(--ion-color-primary) !important;
  border-radius: 40px;
  box-shadow: -0.2rem 0.2rem 0.5rem rgba(0, 0, 0, 0.45), -5px 13px 35px rgba(0, 0, 0, 0.45), -6px 14px 15px rgba(0, 0, 0, 0.45), -8px 10px 30px rgba(0, 0, 0, 0.45), 2px 15px 20px 5px rgba(255, 255, 255, 0.386);
  transition: 0.13s ease-in-out;
  cursor: pointer;
}
.button3d:active {
  box-shadow: none;
}
.button3d:active .button3d__content {
  box-shadow: none;
}
.button3d__content {
  position: relative;
  display: flex;
  padding: 20px;
  width: 100%;
  height: 100%;
  box-shadow: inset 3px 2px 0px #c1c1c1, 9px 9px 5px #ffffff;
  border-radius: 40px;
  transition: 0.13s ease-in-out;
  z-index: 1;
  justify-content: center;
  align-items: center;
}

.buttonsimple {
  --border-radius: 32px;
  min-height: 24px;
  font-size: 16px;
  --background: var(--ion-color-primary);
  --box-shadow: -0.5rem 0.5rem 1rem rgba(0, 0, 0, 0.45), inset -0.25rem 0.25rem 0.5rem rgba(0, 0, 0, 0.45);
}

svg.fillmeal {
  fill: var(--ion-color-primary);
}

.raised {
  box-shadow: -0.2rem 0.2rem 0.5rem rgba(0, 0, 0, 0.45);
  border: 0px;
  border-radius: 10px;
  transition: all 0.5s ease-in-out;
}

.raised:hover {
  border-radius: 20px;
  box-shadow: -2.5px -2.5px 10px 0px rgba(255, 255, 255, 0.05) inset, 2.5px 2.5px 10px 0px rgba(0, 0, 0, 0.2) inset;
  transition: all 0.5s ease-in-out;
}

.glowbox {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 15px;
  overflow: hidden;
  letter-spacing: 1px;
  transition: 0.5s;
  -webkit-backdrop-filter: blur(15px);
          backdrop-filter: blur(15px);
}

.glowbox::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to left, rgba(220, 220, 220, 0.075), rgba(122, 122, 122, 0.075), transparent);
  transform: skewX(20deg) translateX(-100%);
  transition: 0.5s;
  animation: shine 6s infinite alternate-reverse;
}

@keyframes hoverEffect {
  0%, 100% {
    letter-spacing: 1px;
  }
  50% {
    letter-spacing: 5px;
  }
}
@keyframes shine {
  0%, 100% {
    transform: skewX(45deg) translateX(-100%);
  }
  50% {
    transform: skewX(20deg) translateX(50%);
  }
}
@keyframes borderEffect {
  0%, 100% {
    height: 100%;
    width: 100%;
  }
  50% {
    height: 0%;
    width: 50%;
  }
}
@keyframes letterEffect {
  0%, 100% {
    letter-spacing: 1px;
  }
  50% {
    letter-spacing: 3px;
  }
}
.poppedbox {
  position: relative;
  box-shadow: -5px -5px 10px 0px rgba(255, 255, 255, 0.05), 5px 5px 10px 0px rgba(0, 0, 0, 0.2), 0px 0px 0px 0px rgba(255, 255, 255, 0.05) inset, 0px 0px 0px 0px rgba(0, 0, 0, 0.2) inset;
  animation: innershadoweffect 15s infinite;
}

@keyframes innershadoweffect {
  0%, 100% {
    box-shadow: -5px -5px 10px 0px rgba(255, 255, 255, 0.49), -2px 4px 10px 0px rgba(0, 0, 0, 0.53), 0px 0px 0px 0px rgba(255, 255, 255, 0.16) inset, 0px 0px 0px 0px rgb(0, 0, 0) inset;
  }
  50% {
    box-shadow: 0px 0px 0px 0px rgba(255, 255, 255, 0.05), 0px 0px 0px 0px rgba(0, 0, 0, 0.61), -2.5px -2.5px 10px 0px rgba(255, 255, 255, 0.05) inset, 2.5px 2.5px 10px 0px rgb(0, 0, 0) inset;
  }
}
.letterbox {
  letter-spacing: 1px;
  transition: 0.5s;
  animation: letterEffect 30s infinite;
  z-index: 2;
}

.shabowbox::before {
  content: "";
  position: absolute;
  width: 0px;
  height: 0px;
  border-radius: 10px;
  transition: 0.5s;
  background: var(--t2);
  filter: blur(10px);
  box-shadow: 0 0 5px var(--t2), 0 0 15px var(--t2), 0 0 30px var(--t2), 0 0 60px var(--t2);
  animation: borderEffect 5s infinite;
}

.z0 {
  z-index: 0;
}

.z1 {
  z-index: 1;
}

.z2 {
  z-index: 2;
}

.z-1 {
  z-index: -1;
}

.pop {
  box-shadow: -2.5px 2.5px 5px 0px rgba(255, 255, 255, 0.05), -2.5px 2.5px 5px 0px rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  transition: all 0.5s ease-in-out;
}

.popleft {
  box-shadow: var(--shadow-side);
  border: 0px;
  border-radius: 10px;
  transition: all 0.5s ease-in-out;
}

.glowbox-slow {
  position: relative;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  letter-spacing: 1px;
  transition: 0.5s;
  -webkit-backdrop-filter: blur(15px);
          backdrop-filter: blur(15px);
}

.glowbox-slow::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 40%;
  height: 100%;
  background: linear-gradient(to left, rgba(255, 255, 255, 0.1), rgba(88, 88, 88, 0.112), transparent);
  transform: skewX(60deg) translateX(0);
  transition: 0.5s;
  animation: shine 10s infinite alternate-reverse;
  pointer-events: none;
}

.glowbox-slow::before {
  content: "";
  position: absolute;
  width: 0px;
  height: 0px;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  transition: 5s;
  pointer-events: none;
}

.pressed {
  box-shadow: -2.5px -2.5px 10px 0px rgba(255, 255, 255, 0.05) inset, 2.5px 2.5px 10px 0px rgba(0, 0, 0, 0.2) inset;
}

.doubleicont {
  will-change: contents;
  transition: all 1s ease-in-out;
  height: 32px;
  width: 32px;
  position: absolute;
  pointer-events: none;
  filter: drop-shadow(-0.05rem 0.07rem 0.03rem rgba(0, 0, 0, 0.45));
}

.doubleicon {
  stroke: var(--ion-color-primary);
  fill: none;
  stroke-width: 2px;
}

.banner3d {
  position: relative;
  background: linear-gradient(46deg, rgba(171, 171, 171, 0.51) 0%, var(--ion-color-primary) 40%);
  border-radius: 20px;
}

.banner3d::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 5%;
  right: 5%;
  bottom: 0;
  border-radius: 10px;
  background: color-mix(in srgb, var(--ion-color-primary) 50%, black 30%);
  transform: translate(0, -15%) rotate(-4deg);
  transform-origin: center center;
  box-shadow: 0 0 10px 7px color-mix(in srgb, var(--ion-color-primary) 50%, black 30%);
  z-index: -1;
}

.container3danim {
  position: relative;
  border: 2.5px solid var(--ion-color-primary);
  box-shadow: inset -0.2rem 0.2rem 0.5rem rgba(0, 0, 0, 0.45), -0.1rem 0.1rem 0.3rem rgba(0, 0, 0, 0.45);
  animation: container3da 5s infinite;
}

@keyframes container3da {
  0%, 100% {
    scale: 0.9;
    box-shadow: inset -0.2rem 0.2rem 0.5rem rgba(0, 0, 0, 0.45), -0.1rem 0.1rem 0.3rem rgba(0, 0, 0, 0.45);
  }
  50% {
    scale: 1;
    box-shadow: inset 0rem 0rem 0rem rgba(0, 0, 0, 0.45), -0.1rem 0.1rem 0.3rem rgba(0, 0, 0, 0.45);
  }
}
* {
  scrollbar-width: none !important;
}

html,
body {
  height: 100%;
}

ion-app {
  height: 100%;
  width: 100%;
  display: block;
}

ion-router-outlet {
  height: 100%;
  width: 100%;
  display: block;
  top: 0;
}

ion-header {
  min-height: env(safe-area-inset-top) !important;
}

.my-custom-modal {
  --max-height: 60%;
  --height: auto;
  --width: 90%;
  --ion-safe-area-bottom: 0px;
  --ion-safe-area-top: 0px;
  --ion-safe-area-left: 0px;
  --ion-safe-area-right: 0px;
  display: flex;
  align-items: center;
  justify-content: center;
  justify-content: center;
  --box-shadow: var(--shadow-m);
  background: var(--ion-ultra-primary);
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
  --border-radius: 20px;
}

ion-action-sheet.my-custom-sheet {
  --background: var(--ion-color-primary);
  --backdrop-opacity: 0.5;
  --button-background-selected: var(--ion-white-primary);
  --button-color: var(--ion-black-primary);
  --color: var(--ion-black-primary);
}
ion-action-sheet.my-custom-sheet .action-sheet-title {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 1px;
}
ion-action-sheet.my-custom-sheet .action-sheet-button {
  font-size: 18px;
  letter-spacing: 1px;
  border-bottom: 2px solid var(--ion-diffuseDark-primary);
}

ion-button {
  --background-activated: var(--ion-color-primary) !important;
  --background-focused: var(--ion-color-secondary) !important;
  --background-hover: var(--ion-color-secondary) !important;
  --background-activated-opacity: 0.5 !important;
  --background-focused-opacity: 0.7 !important;
  --background-hover-opacity: 0.7 !important;
}

ion-toolbar {
  background: var(--ion-diffuseLight-primary);
  --background: var(--ion-diffuseLight-primary);
}
ion-toolbar ion-title {
  --color: var(--ion-black-primary);
  font-weight: 600;
  letter-spacing: 1.2px;
  font-size: 1rem;
}

ion-header {
  background: var(--ion-diffuseLight-primary);
  --background: var(--ion-diffuseLight-primary);
}

ion-content ion-searchbar.custom .searchbar-input-container {
  padding: 0vh;
}
ion-content ion-searchbar.custom .searchbar-input-container ion-icon {
  color: var(--ion-color-tertiary) !important;
  width: 3vh;
}
ion-content ion-searchbar.custom .searchbar-input-container input {
  padding-inline-start: 5vh !important;
}

:root[dir=ltr] ion-chip.usage-package {
  border-radius: 14px 0px;
}
:root[dir=ltr] ion-select::part(icon) {
  position: absolute;
  right: 10px;
  opacity: 1;
  color: var(--ion-color-primary);
}
:root[dir=ltr] ion-icon.select-icon {
  position: absolute;
  right: 10px;
  opacity: 1;
}
:root[dir=ltr] ion-col.date-picker-col-1 {
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
}
:root[dir=ltr] ion-col.date-picker-col-2 {
  border-bottom-left-radius: 20px;
}
:root[dir=ltr] ion-badge.quantity-badge {
  position: absolute;
  right: 21px;
  bottom: 10px;
  width: 22px;
  height: 20px;
}

:root[dir=rtl] * {
  letter-spacing: 0;
}
:root[dir=rtl] .language-select-wrapper {
  flex-direction: row; /* Reverse order of label and select */
}
:root[dir=rtl] .language-select-wrapper .language-label {
  margin-inline-start: 16px;
  margin-inline-end: 0;
}
:root[dir=rtl] .language-select-wrapper .select-arrow {
  left: 12px;
  right: auto;
}
:root[dir=rtl] .language-select-wrapper .custom-language-select {
  padding: 0 12px; /* Adjust padding for RTL text direction */
}
:root[dir=rtl] ion-chip.usage-package {
  border-radius: 0px 14px;
}
:root[dir=rtl] ion-select::part(icon) {
  position: absolute;
  left: 10px;
  opacity: 1;
  color: var(--ion-color-primary);
}
:root[dir=rtl] ion-icon.select-icon {
  position: absolute;
  left: 10px;
  opacity: 1;
}
:root[dir=rtl] ion-col.date-picker-col-1 {
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
}
:root[dir=rtl] ion-col.date-picker-col-2 {
  border-bottom-right-radius: 20px;
}
:root[dir=rtl] ion-badge.quantity-badge {
  position: absolute;
  left: 21px;
  bottom: 10px;
  width: 22px;
  height: 20px;
}

ion-icon[name=star] {
  color: var(--ion-color-warning);
}

.ion-page {
  height: 100dvh;
  width: 100%;
  margin: 0 auto !important;
  border-radius: 0px;
  justify-content: end;
}

.calendar-slider {
  width: 100vw;
}
.calendar-slider .date2 {
  width: 40vw;
}
.calendar-slider .radio-group {
  width: 60vw;
}

@media screen and (min-height: 500px) and (min-width: 800px) {
  ion-router-outlet {
    background: transparent;
    --background: transparent;
  }
  .calendar-slider {
    width: 50vh;
  }
  .calendar-slider .date2 {
    width: 40%;
  }
  .calendar-slider .radio-group {
    width: 60%;
  }
  .baba {
    height: 100vh;
    width: 200vw;
    position: fixed;
    top: 0;
    left: -100vw;
    background: linear-gradient(21deg, var(--ion-half-primary), var(--ion-half-secondary), var(--ion-half-tertiary));
    z-index: 0;
    opacity: 1;
    visibility: visible;
    transition: all 0.5s ease-in-out;
    -webkit-backdrop-filter: blur(5px);
            backdrop-filter: blur(5px);
  }
  app-root {
    position: absolute;
    height: 100%;
    width: 50vh;
    margin: 0 calc((100vw - 50vh) / 2) !important;
    border-radius: 20px !important;
  }
  .ion-page {
    height: 100%;
    width: 100%;
    margin: 0 auto !important;
    border-radius: 20px !important;
  }
  ion-router-outlet {
    margin-top: 0px !important;
  }
  @keyframes backgrounder {
    0% {
      background-position: 0% 50%;
    }
    50% {
      background-position: 50% 0%;
    }
    100% {
      background-position: 0% 50%;
    }
  }
  @keyframes randomBackground {
    0% {
      background-position: 0% 50%;
    }
    20% {
      background-position: 30% 70%;
    }
    40% {
      background-position: 80% 40%;
    }
    60% {
      background-position: 50% 90%;
    }
    80% {
      background-position: 10% 30%;
    }
    100% {
      background-position: 0% 50%;
    }
  }
  body {
    background-color: var(--ion-color-primary) !important;
    background-size: 200%;
    /* Adjust as needed */
    background-repeat: no-repeat;
    z-index: 0;
    animation: randomBackground 250s infinite ease-in-out;
    transition: all 0.5s ease-in-out;
  }
  .swiper-slide img {
    object-fit: cover !important;
  }
  .calendar-slider ion-card.head ion-slides ion-slide.active {
    background: transparent !important;
  }
  .book-button {
    width: 45vh !important;
  }
}
ion-card.salon {
  background: var(--ion-color-primary);
}

ion-card.home {
  background: var(--ion-color-secondary);
}

ion-card.product {
  background: var(--ion-color-tertiary) !important;
}

.topLogo {
  object-fit: scale-down;
}

.txt-x-small {
  font-size: 12px !important;
}

.txt-small {
  font-size: 14px !important;
}

.txt-medium {
  font-size: 18px !important;
}

.txt-large {
  font-size: 22px !important;
}

.txt-x-large {
  font-size: 24px !important;
}

.showTabFooter {
  display: flex;
}

.hideTabFooter {
  display: none;
}

/* Adjustments for RTL (Arabic) if needed */

/*# sourceMappingURL=styles.css.map*/